/* Easy Way Driving School — Fresh Site (2026) */
:root{
  --bg:#ffffff;
  --surface:#ffffff;
  --surface2:#f8fafc;
  --text:#0f172a;
  --muted:#475569;
  --line: rgba(2,6,23,.12);
  --accent:#ff7a00;
  --accent2:#ffc400;
  --shadow: 0 12px 36px rgba(2,6,23,.10);
  --radius: 18px;
  --radius2: 28px;
  --container: 1180px;
  --ease: cubic-bezier(.2,.9,.2,1);
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: linear-gradient(180deg, #ffffff, #f7fafc);
  color:var(--text);
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
p{color:var(--muted); margin:0 0 14px 0; line-height:1.75}
h1,h2,h3{margin:0 0 12px 0; letter-spacing:-.02em}
h1{font-size: clamp(34px, 4vw, 56px); line-height:1.06}
h2{font-size: clamp(26px, 3vw, 40px); line-height:1.14}
h3{font-size: 20px}
.small{font-size:14px;color:var(--muted)}
.kicker{font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:#64748b}
.container{max-width:var(--container); margin:0 auto; padding:0 20px}
.section{padding:84px 0}
.section.tight{padding:60px 0}
.grid{display:grid; gap:18px}
.grid.two{grid-template-columns: repeat(2, minmax(0,1fr))}
.grid.three{grid-template-columns: repeat(3, minmax(0,1fr))}
@media (max-width: 900px){
  .grid.two, .grid.three{grid-template-columns:1fr}
  .section{padding:70px 0}
}

.hr{height:1px;background: var(--line); margin: 18px 0}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 14px; border-radius:14px;
  border: 1px solid rgba(2,6,23,.14);
  background: rgba(255,255,255,.92);
  color:#0f172a;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
  cursor:pointer;
  font-weight:800;
}
.btn:hover{transform: translateY(-1px); background:#fff; border-color: rgba(2,6,23,.22)}
.btn.primary{
  background: linear-gradient(135deg, var(--accent2), var(--accent));
  border-color: transparent;
  color:#111827;
  font-weight:900;
}
.btn.primary:hover{transform: translateY(-1px) scale(1.01)}
.btn.black{background:#0f172a; color:#fff; border:none; font-weight:900}
.btn.black:hover{transform: translateY(-2px); box-shadow: 0 18px 40px rgba(0,0,0,.22)}

/* Cards */
.card{
  border-radius: var(--radius);
  background: #fff;
  border:1px solid rgba(2,6,23,.10);
  box-shadow: 0 12px 30px rgba(2,6,23,.08);
  overflow:hidden;
}
.cardPad{padding:22px}
.cardHover{
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.cardHover:hover{
  transform: translateY(-4px);
  border-color: rgba(255,122,0,.28);
  box-shadow: 0 18px 40px rgba(2,6,23,.12);
}

/* Navbar */
.topbar{
  position:sticky; top:0; z-index:10000;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
  transition: background .25s var(--ease), box-shadow .25s var(--ease);
}
.topbar.is-scrolled{
  box-shadow: 0 14px 40px rgba(2,6,23,.10);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding: 14px 0;}
.brand{display:flex; align-items:center; gap:12px;}
.brand img{height:56px; width:auto;}
.brandText{display:flex; flex-direction:column; line-height:1.05}
.brandLine1{font-size:22px; font-weight:950; letter-spacing:-.3px}
.brandLine2{font-size:14px; font-weight:900}
.navlinks{display:flex; align-items:center; gap:14px}
.navlinks a{font-size:15px; font-weight:700; padding:10px 10px; border-radius:12px}
.navlinks a:hover{background: rgba(2,6,23,.05)}
.navcta{display:flex; align-items:center; gap:10px}
.burger{display:none}
.mobilemenu{display:none; padding: 10px 0 18px}
.mobilemenu a{display:block; padding:12px 12px; border-radius:14px; font-weight:700}
.mobilemenu a:hover{background: rgba(2,6,23,.05)}
@media (max-width: 900px){
  .navlinks{display:none}
  .burger{display:inline-flex}
  .mobilemenu.open{display:block}
}

/* Hero (generic) */
.hero{padding: 72px 0 34px}
.heroWrap{
  position:relative;
  border-radius: var(--radius2);
  border:1px solid rgba(2,6,23,.10);
  box-shadow: var(--shadow);
  overflow:hidden;
  background:
    linear-gradient(rgba(0,0,0,.45), rgba(0,0,0,.40)),
    url("/assets/img/hero.webp");
  background-size:cover;
  background-position:center;
}
.heroInner{
  position:relative;
  padding: 56px 46px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 22px;
  color:#fff;
}
.heroInner p{color: rgba(255,255,255,.85)}
@media (max-width:900px){
  .heroInner{grid-template-columns:1fr; padding: 34px 18px;}
}

.pills{display:flex; flex-wrap:wrap; gap:10px}
.pill{
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.20);
  color:#fff;
  font-size:14px;
}

/* Home steps (from your screenshot) */
.stepsSection{
  padding: 90px 0 110px;
  background: #f6f3ea;
  position: relative;
  overflow: hidden;
}
.stepsHeader{ text-align:center; max-width: 820px; margin: 0 auto 46px; }
.stepsHeader h2{
  font-size: clamp(26px, 3.2vw, 44px);
  font-weight: 950;
  letter-spacing:-.03em;
  margin:0;
}
.stepsHeader .miniIcons{display:flex; justify-content:center; gap:8px; margin-bottom:14px}
.stepsHeader .miniIcons span{
  width: 28px; height: 28px; border-radius: 6px;
  background: #ffc400;
  display:flex; align-items:center; justify-content:center;
  font-weight: 900; color:#0f172a; font-size: 14px;
}
.stepsGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 28px;
  align-items:start;
  position: relative;
}
.stepCard{
  position: relative;
  background: #e7e5de;
  padding: 26px 28px;
  min-height: 210px;
  box-shadow: 0 18px 45px rgba(2,6,23,.10);
  border: 1px solid rgba(2,6,23,.06);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.stepCard:hover{transform: translateY(-6px); box-shadow: 0 26px 60px rgba(2,6,23,.14);}
.stepCard.highlight{background:#ffc400}
.stepNo{font-size:64px; font-weight:950; line-height:1; margin:0 0 14px}
.stepTitle{margin:0 0 8px; font-weight:900; font-size:16px}
.stepText{margin:0; font-size:13px; color: rgba(15,23,42,.72); line-height:1.6}
.step1{margin-top:0}
.step2{margin-top:78px}
.step3{margin-top:0}
.stepsSection::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height: 86px; background: #0f172a; opacity:.92;
}
.stepsSection .container{position:relative; z-index:1}
@media (max-width:980px){
  .stepsGrid{grid-template-columns:1fr}
  .step2{margin-top:0}
  .stepsSection::after{height:70px}
}

/* Pricing cards (shared) */
.pricingCards{padding: 0 0 80px; background:#fff;}
.planGridHome{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px}
@media (max-width:900px){ .planGridHome{grid-template-columns:1fr} }

.planCard2{
  position:relative;
  border-radius: var(--radius);
  background:#fff;
  border:1px solid rgba(2,6,23,.10);
  box-shadow: 0 14px 34px rgba(2,6,23,.08);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.planCard2:hover{
  transform: translateY(-5px);
  box-shadow: 0 22px 48px rgba(2,6,23,.12);
  border-color: rgba(255,122,0,.28);
}
.planPad2{padding:22px}
.planName{font-weight:950; font-size:18px; margin:0 0 6px}
.planDesc{margin:0 0 14px; color:#64748b; font-size:13px}
.priceRow2{display:flex; align-items:baseline; gap:10px; margin: 10px 0 16px}
.priceAmt2{font-size:46px; font-weight:950; letter-spacing:-.04em}
.pricePer2{font-size:14px; color:#64748b}
.planList2{margin:0; padding-left:18px; color:#475569}
.planList2 li{margin:9px 0}
.planBtnRow{margin-top:18px}
.planBtnRow .btn{width:100%}
.planPopular2{
  border-color: rgba(255,122,0,.55)!important;
  box-shadow: 0 24px 58px rgba(2,6,23,.14)!important
}
.planPopular2::after{
  content:"Most popular";
  position:absolute; top:14px; right:14px;
  padding:7px 10px; border-radius:999px;
  background: linear-gradient(135deg, var(--accent2), var(--accent));
  color:#111827; font-weight:900; font-size:12px;
}

/* Footer */
.footer{
  border-top:1px solid var(--line);
  padding: 40px 0;
  color:#e2e8f0;
  background: #0b1220;
}
.footer a{color:#e2e8f0}
.footer a:hover{text-decoration:underline}
.footerGrid{display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:18px}
@media (max-width:900px){ .footerGrid{grid-template-columns:1fr} }
.footer .small{color: rgba(226,232,240,.78)}

/* ===== Service Areas thin bar (ONE version) ===== */
.service-areas-bar{
  background:#0b1220;
  padding:18px 0;
  border-top: 2px solid var(--accent2);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.serviceAreasInner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.serviceAreasTitle{
  font-weight:950;
  color:#fff;
  font-size:18px;
}
.serviceAreasLinks{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}
.serviceAreasLinks a{
  color: rgba(255,255,255,.80);
  font-weight: 900;
  font-size: 14px;
  position:relative;
  padding-bottom:4px;
}
.serviceAreasLinks a:after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:0; height:2px;
  background: var(--accent2);
  transition:.25s;
}
.serviceAreasLinks a:hover{ color:#fff; }
.serviceAreasLinks a:hover:after{ width:100%; }

/* ===== Location Pages (Addon) ===== */
.locationHero{ padding: 70px 0 26px; }
.locationHero .heroWrap{
  background:
    linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.42)),
    url("/assets/img/hero.jpg");
  background-size: cover;
  background-position: center;
  background-repeat:no-repeat;
}
.locationSection{ padding: 70px 0; }
.locationCards .card{ height:100%; }

.locationFaq details{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(2,6,23,.10);
  border-radius: var(--radius);
  box-shadow: 0 10px 25px rgba(2,6,23,.08);
  overflow:hidden;
}
.locationFaq summary{
  cursor:pointer;
  list-style:none;
  padding: 18px 18px;
  font-weight: 950;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.locationFaq summary::-webkit-details-marker{ display:none; }
.locationFaq .faqPlus{
  width: 34px;
  height: 34px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 950;
  background: linear-gradient(135deg, var(--accent2), var(--accent));
  color:#111827;
}
.locationFaq .faqBody{ padding: 0 18px 18px; }
