@font-face{
  font-family:'Barlow';
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("fonts/barlow-400.woff2") format("woff2");
}
@font-face{
  font-family:'Barlow';
  font-style:normal;
  font-weight:500;
  font-display:swap;
  src:url("fonts/barlow-500.woff2") format("woff2");
}
@font-face{
  font-family:'Barlow';
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("fonts/barlow-600.woff2") format("woff2");
}
@font-face{
  font-family:'Barlow Condensed';
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("fonts/barlow-condensed-600.woff2") format("woff2");
}
@font-face{
  font-family:'Barlow Condensed';
  font-style:normal;
  font-weight:800;
  font-display:swap;
  src:url("fonts/barlow-condensed-800.woff2") format("woff2");
}

:root{
  --black:#0d0e10;
  --asphalt:#1b1d20;
  --red:#d61f2c;
  --red-dark:#b3121e;
  --blue:#2456c8;
  --paper:#f2f1ed;
  --paper-dark:#e4e2dc;
  --ink:#1c1d1f;
  --line:#cfcdc6;
  --white:#fbfaf7;
  --max:1100px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:'Barlow',sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
}
h1,h2,h3{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.01em;
  line-height:1.05;
}

.lane{
  padding:14px 0;
  height:34px;
  background-color:var(--black);
  background-image:repeating-linear-gradient(90deg,var(--white) 0 56px,transparent 56px 96px);
  background-size:96px 6px;
  background-repeat:repeat-x;
  background-position:0 center;
  background-clip:padding-box;
}

header{
  background:var(--black);
  color:var(--white);
  position:sticky;
  top:0;
  z-index:50;
  border-bottom:3px solid var(--red);
}
.legal header{position:static}
.nav{
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 24px;
  gap:20px;
}
.nav-logo{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  color:var(--white);
}
.nav-logo img{height:54px;width:auto;display:block}
.nav-logo span{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  font-size:1.25rem;
  letter-spacing:.04em;
}
@media(max-width:560px){.nav-logo span{display:none}}
nav ul{display:flex;gap:26px;list-style:none}
nav a,.nav>a:not(.nav-logo){
  color:var(--white);
  text-decoration:none;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:600;
  text-transform:uppercase;
  font-size:1.02rem;
  letter-spacing:.05em;
  padding-bottom:2px;
  border-bottom:2px solid transparent;
}
nav a:hover,nav a:focus-visible,.nav>a:not(.nav-logo):hover,.nav>a:not(.nav-logo):focus-visible{
  border-bottom-color:var(--red);
  outline:none;
}
@media(max-width:760px){nav ul{display:none}}

.hero{
  background:
    linear-gradient(90deg, rgba(13,14,16,.96) 0%, rgba(13,14,16,.82) 48%, rgba(13,14,16,.45) 100%),
    url("images/car-orange-traffic-cones-lesson-driving-school-concept.jpg") center right/cover no-repeat;
  color:var(--white);
  position:relative;
  overflow:hidden;
}
.hero-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:90px 24px 100px;
  position:relative;
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:40px;
  align-items:center;
}
@media(max-width:820px){.hero-inner{grid-template-columns:1fr;padding:64px 24px 72px}}
.hero .eyebrow{
  display:inline-block;
  background:var(--red);
  color:var(--white);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.95rem;
  padding:4px 12px;
  margin-bottom:22px;
}
.hero h1{
  font-size:clamp(2.6rem,6.5vw,4.8rem);
  max-width:15ch;
}
.hero h1 em{font-style:normal;color:var(--red)}
.hero p{
  margin-top:24px;
  max-width:52ch;
  font-size:1.15rem;
  color:#c7c9cc;
}
.hero .cta{
  display:inline-block;
  margin-top:36px;
  background:var(--red);
  color:var(--white);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  font-size:1.15rem;
  letter-spacing:.05em;
  padding:14px 30px;
  text-decoration:none;
}
.hero .cta:hover,.hero .cta:focus-visible{background:var(--red-dark);outline:none}
.hero-logo{display:flex;justify-content:center}
.hero-logo img{
  max-width:300px;
  width:100%;
  height:auto;
  filter:drop-shadow(0 16px 26px rgba(0,0,0,.45));
}
@media(max-width:820px){.hero-logo{order:-1}.hero-logo img{max-width:200px}}

.home section{padding:80px 24px}
.wrap{max-width:var(--max);margin:0 auto}
.sec-label,.legal .label{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.95rem;
  color:#85837c;
  margin-bottom:8px;
}
.home section h2{
  font-size:clamp(1.9rem,4vw,2.8rem);
  margin-bottom:28px;
  position:relative;
  display:inline-block;
}
.home section h2::after{
  content:"";
  display:block;
  height:6px;
  margin-top:10px;
  background:repeating-linear-gradient(90deg,var(--red) 0 32px,transparent 32px 54px);
}

.about{background:var(--paper)}
.about-grid{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:48px;
  align-items:start;
}
@media(max-width:820px){.about-grid{grid-template-columns:1fr}}
.portrait{
  aspect-ratio:3/4;
  background:var(--paper-dark);
  border:2px dashed #aaa89f;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#8a887f;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  text-align:center;
  padding:16px;
}
.about p{margin-bottom:19px; font-size: 1.1em;}
.about p:last-child{margin-bottom:0}

.training{background:var(--asphalt);color:var(--white)}
.training .sec-label{color:#9a9c98}
.training-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
}
@media(max-width:820px){.training-grid{grid-template-columns:1fr}}
.training h3{
  font-size:1.5rem;
  color:var(--red);
  margin-bottom:14px;
}
.training p{margin-bottom:14px;color:#d4d6d8;max-width:60ch}
.block-banner{
  margin-top:14px;
  border:2px solid var(--red);
  padding:18px 22px;
}
.block-banner strong{
  display:block;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  font-size:1.25rem;
  color:var(--red);
  margin-bottom:4px;
}

.prices{background:var(--paper)}
.prices .note{max-width:60ch;margin-bottom:28px}
.table-scroll{overflow-x:auto}
table{
  border-collapse:collapse;
  width:100%;
  min-width:640px;
  background:var(--white);
}
caption{
  text-align:left;
  font-size:.9rem;
  color:#85837c;
  padding:10px 2px;
  caption-side:bottom;
}
th,td{
  padding:14px 18px;
  text-align:right;
  border-bottom:1px solid var(--line);
  font-variant-numeric:tabular-nums;
}
th{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-size:1.05rem;
}
thead th{
  background:var(--black);
  color:var(--white);
  border-bottom:3px solid var(--red);
}
tbody th{text-align:left;white-space:nowrap}
tbody tr:nth-child(even){background:#f7f6f2}
td.na{color:#a5a39a;text-align:center}

.fleet{background:var(--paper-dark)}
.tiles{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:24px;
}
.tile{
  background:var(--white);
  border:1px solid var(--line);
  display:flex;
  flex-direction:column;
}
.tile-img{
  aspect-ratio:16/10;
  background:var(--paper);
  border-bottom:3px solid var(--red);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#8a887f;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  text-align:center;
  padding:12px;
  overflow:hidden;
}
.tile-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.tile-img--photo{padding:0}
.tile-img img.contain{
  object-fit:contain;
  background:#fff;
  padding:8px;
}
.tile-img--placeholder{
  background:
    linear-gradient(135deg, rgba(13,14,16,.06), rgba(214,31,44,.12)),
    var(--paper);
}
.tile-body{padding:20px 22px 24px;flex:1}
.tile-class{
  display:inline-block;
  background:var(--black);
  color:var(--white);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  font-size:.95rem;
  letter-spacing:.08em;
  padding:3px 10px;
  margin-bottom:10px;
}
.tile-class b{color:var(--red);font-weight:800}
.tile h3{font-size:1.35rem;margin-bottom:8px}
.tile p{font-size:.98rem;color:#55564f}

.contact{background:var(--black);color:var(--white)}
.contact .sec-label{color:#9a9c98}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact .ph{
  border:2px dashed #45474b;
  padding:24px;
  color:#9a9c98;
}
.contact .ph strong{
  display:block;
  color:var(--red);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  margin-bottom:8px;
}
.contact .ph a{
  color:var(--white);
  text-decoration:none;
  border-bottom:1px solid rgba(251,250,247,.35);
}
.contact .ph a:hover,.contact .ph a:focus-visible{border-bottom-color:var(--red);outline:none}
.hours{
  display:grid;
  grid-template-columns:max-content 1fr;
  column-gap:18px;
  row-gap:4px;
}
.hours dt{color:var(--white);font-weight:600}
.hours dd{margin:0}

.legal main{
  max-width:900px;
  margin:0 auto;
  padding:70px 24px 86px;
}
.legal h1{
  font-size:clamp(2.2rem,5vw,3.6rem);
  margin-bottom:30px;
}
.legal main h2{
  font-size:1.55rem;
  margin:34px 0 12px;
  color:var(--red);
}
.legal p,.legal li{margin-bottom:14px;max-width:72ch}
.legal ul{padding-left:22px}
.legal .notice{
  background:var(--white);
  border-left:6px solid var(--red);
  padding:18px 22px;
  margin-bottom:28px;
}
.legal-box{
  background:var(--white);
  border:1px solid var(--line);
  padding:22px;
  margin:18px 0;
}
.legal main a{
  color:var(--red);
  text-decoration:none;
  border-bottom:1px solid rgba(214,31,44,.35);
}
.legal main a:hover,.legal main a:focus-visible{border-bottom-color:var(--red);outline:none}

footer{
  background:var(--black);
  color:#9a9c98;
  border-top:3px solid var(--red);
  font-size:.9rem;
}
.foot{
  max-width:var(--max);
  margin:0 auto;
  padding:22px 24px;
  display:flex;
  flex-wrap:wrap;
  gap:20px;
  justify-content:space-between;
}
footer a{color:#c7c9cc;text-decoration:none}
footer a:hover,footer a:focus-visible{color:var(--red);outline:none}

@media(max-width:620px){
  .legal .nav,.legal .foot{
    align-items:flex-start;
    flex-direction:column;
  }
}
