/* ==========================================================================
   AUS Driving School Perth - mockup stylesheet
   Implements 03-design/design-system.md exactly.
   Motif: the L-plate rule (amber lane line, amber L-corner, square plate chips).
   Hard rules: border-radius:0 everywhere, 44px touch targets, no glass,
   no ambient motion, en-dashes only.
   ========================================================================== */

/* ---------- 6. Token block (:root) ---------- */
:root{
  /* type */
  --font-display: "Archivo", "Arial Narrow", system-ui, sans-serif;
  --font-body:    "Libre Franklin", system-ui, "Segoe UI", Roboto, Arial, sans-serif;

  --fs-display: clamp(2.25rem, 1.30rem + 4.2vw, 4.0rem);
  --fs-h1:      clamp(1.9375rem, 1.30rem + 2.8vw, 3.0rem);
  --fs-h2:      clamp(1.5rem, 1.16rem + 1.5vw, 2.25rem);
  --fs-h3:      clamp(1.375rem, 1.20rem + 0.8vw, 1.625rem);
  --fs-h4:      clamp(1.1875rem, 1.13rem + 0.3vw, 1.25rem);
  --fs-h5:      1.0625rem;
  --fs-h6:      0.9375rem;
  --fs-lead:    clamp(1.125rem, 1.06rem + 0.3vw, 1.25rem);
  --fs-body:    1.0625rem;   /* 17px floor */
  --fs-body-sm: 0.9375rem;
  --fs-small:   0.875rem;
  --fs-xs:      0.8125rem;
  --fs-overline:0.8125rem;

  /* colour: base */
  --bg:        #FBFAF7;
  --bg-dark:   #0F1013;
  --surface:   #FFFFFF;
  --surface-2: #F2F0EA;

  /* colour: ink */
  --ink:           #15161A;
  --ink-soft:      #3A3D45;
  --muted:         #6B6F79;
  --ink-on-dark:   #FBFAF7;
  --muted-on-dark: #A7AAB2;

  /* colour: accent (L-plate amber) */
  --accent:        #F5C518;
  --accent-hover:  #F7D24B;
  --accent-press:  #DCB00E;
  --accent-ink:    #9A7A05;
  --on-accent:     #15161A;

  /* colour: success (P-plate green) */
  --success:     #127A4A;
  --success-ink: #0E5E39;
  --success-bg:  #DCEEE3;

  /* colour: danger (hazard red) */
  --danger:     #C0392B;
  --danger-ink: #9A2D22;
  --danger-bg:  #F7DEDA;

  /* structure */
  --line:         #E2DFD6;
  --line-strong:  #C7C3B7;
  --line-on-dark: #2A2C32;

  /* focus */
  --focus:         #15161A;
  --focus-on-dark: #F5C518;

  /* spacing scale (4px base) */
  --space-1: 4px;  --space-2: 8px;  --space-3: 12px; --space-4: 16px;
  --space-5: 24px; --space-6: 32px; --space-7: 48px; --space-8: 64px;
  --space-9: 96px;

  /* layout */
  --maxw: 1280px;
  --gutter: clamp(1rem, 3vw, 2rem);

  /* motion (short, purposeful only) */
  --ease: cubic-bezier(0,0,.2,1);
  --dur:  .15s;
}

/* ---------- Global reset (5.) ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ border-radius:0 !important; }   /* the hard rule, enforced globally */

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }

body{
  margin:0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.65;
  font-weight: 400;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img{ max-width:100%; height:auto; display:block; }

a{ color:var(--accent-ink); }

:where(a):focus-visible,
:where(button,input,select,textarea,[tabindex]):focus-visible{
  outline:3px solid var(--focus);
  outline-offset:2px;
}
.on-dark :focus-visible{ outline-color:var(--focus-on-dark); }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}

/* ---------- 2. Typography ---------- */
h1,h2,h3,h4,h5,h6{
  font-family: var(--font-display);
  color: var(--ink);
  margin: 0 0 0.5em;
  text-wrap: balance;
}
h1{ font-size:var(--fs-h1); line-height:1.06; letter-spacing:-0.02em; font-weight:800; }
h2{ font-size:var(--fs-h2); line-height:1.12; letter-spacing:-0.015em; font-weight:700; }
h3{ font-size:var(--fs-h3); line-height:1.18; letter-spacing:-0.01em; font-weight:700; }
h4{ font-size:var(--fs-h4); line-height:1.25; letter-spacing:-0.005em; font-weight:700; }
h5{ font-size:var(--fs-h5); line-height:1.30; font-weight:600; }
h6{ font-size:var(--fs-h6); line-height:1.35; letter-spacing:0.02em; font-weight:600; }

.display{ font-family:var(--font-display); font-size:var(--fs-display);
  line-height:1.02; letter-spacing:-0.02em; font-weight:800; }

.lead{ font-size:var(--fs-lead); line-height:1.55; font-weight:400; color:var(--ink-soft); }
.body-sm{ font-size:var(--fs-body-sm); line-height:1.55; }
small,.small{ font-size:var(--fs-small); line-height:1.5; letter-spacing:0.005em; font-weight:500; }
.xs{ font-size:var(--fs-xs); line-height:1.5; letter-spacing:0.01em; font-weight:500; }

.overline{
  font-family:var(--font-body);
  font-size:var(--fs-overline);
  line-height:1.2;
  letter-spacing:0.14em;
  font-weight:700;
  text-transform:uppercase;
  color:var(--accent-ink);
  display:block;
}

p{ margin:0 0 1rem; max-width:68ch; }
.price-table td, .price-table th{ font-variant-numeric: tabular-nums; }

/* small reusable text helpers */
.text-center{ text-align:center; }
.mx-auto{ margin-left:auto; margin-right:auto; }
.measure{ max-width:62ch; }
ul.clean{ list-style:none; margin:0; padding:0; }

/* ---------- 4. Motif: the L-plate rule ---------- */
.rule-amber{ position:relative; padding-top:1.25rem; }
.rule-amber::before{
  content:""; position:absolute; top:0; left:0;
  width:48px; height:4px; background:var(--accent);
}
.section-head .overline + h2{ margin-top:0.25rem; }
.section-head::before{
  content:""; display:block; width:48px; height:4px;
  background:var(--accent); margin-bottom:1rem;
}

.l-corner{ position:relative; }
.l-corner::before{
  content:""; position:absolute; top:0; left:0;
  width:22px; height:22px; pointer-events:none;
  border-top:4px solid var(--accent);
  border-left:4px solid var(--accent);
}

.plate-chip{
  display:inline-flex; align-items:center; gap:.4em;
  min-height:24px; padding:.25rem .55rem;
  font-family:var(--font-body); font-size:var(--fs-xs);
  font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--on-accent); background:var(--accent);
  border:2px solid var(--ink);
}
.plate-chip--pass{
  background:var(--success); color:#FFFFFF; border-color:#0B4730;
}
.plate-chip--ghost{
  background:transparent; color:var(--accent); border-color:var(--accent);
}

/* ---------- 5.1 Skip link ---------- */
.skip-link{
  position:absolute; left:-9999px; top:0; z-index:1000;
  background:var(--ink); color:var(--ink-on-dark);
  padding:.75rem 1rem; font-weight:600; text-decoration:none;
}
.skip-link:focus{ left:0; }

/* ---------- layout helpers ---------- */
.section{ padding:clamp(3rem,7vw,5.5rem) 0; }
.section--alt{ background:var(--surface-2); }
.section--dark{ background:var(--bg-dark); color:var(--ink-on-dark);
  border-top:4px solid var(--accent); }
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{ color:var(--ink-on-dark); }
.section__inner{ max-width:1280px; margin:0 auto; padding:0 clamp(1rem,3vw,2rem); }
.section-head{ max-width:62ch; margin-bottom:2rem; }
.section--dark .section-head .overline{ color:var(--accent); }

.divider{ height:1px; background:var(--line); border:0; margin:0; }
.divider--lane{ position:relative; height:4px; background:transparent; border:0; }
.divider--lane::before{ content:""; position:absolute; left:0; top:0;
  width:48px; height:4px; background:var(--accent); }

/* ---------- 5.2 Navigation (sticky header) ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--surface);
  border-bottom:1px solid var(--line);
  transition:box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.site-header[data-condensed="true"]{
  box-shadow:0 1px 0 var(--line-strong), 0 6px 18px rgba(15,16,19,.08);
  border-bottom-color:var(--line-strong);
}
.site-header__inner{
  max-width:1280px; margin:0 auto; padding:0 clamp(1rem,3vw,2rem);
  min-height:72px;
  display:flex; align-items:center; gap:1.5rem;
  transition:min-height var(--dur) var(--ease);
}
.site-header[data-condensed="true"] .site-header__inner{ min-height:60px; }
.site-logo{ display:flex; align-items:center; min-height:44px; text-decoration:none; gap:.6rem; }
.site-logo img{ height:40px; width:auto; }
.site-logo .wordmark{ display:none; }

.primary-nav{ display:flex; align-items:center; gap:.25rem; margin-left:auto; }
.primary-nav a{
  display:inline-flex; align-items:center; min-height:44px;
  padding:0 .9rem;
  font-family:var(--font-body); font-weight:600; font-size:var(--fs-body-sm);
  color:var(--ink); text-decoration:none;
  border-bottom:3px solid transparent;
  transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.primary-nav a:hover{ color:var(--accent-ink); border-bottom-color:var(--accent); }
.primary-nav a[aria-current="page"]{ border-bottom-color:var(--accent); }

.header-phone{
  display:inline-flex; align-items:center; gap:.5rem; min-height:44px;
  padding:0 .75rem; font-weight:700; color:var(--ink); text-decoration:none;
  transition:color var(--dur) var(--ease);
}
.header-phone:hover{ color:var(--accent-ink); }
.header-phone svg{ width:18px; height:18px; }

.header-cta{ margin-left:.25rem; }

.nav-toggle, .header-call-mobile{ display:none; }

@media (max-width:1080px){
  .primary-nav{ display:none; }
  .header-phone{ display:none; }
  .header-cta{ display:none; }
  .header-call-mobile, .nav-toggle{
    display:inline-flex; align-items:center; justify-content:center;
    min-width:44px; min-height:44px;
  }
  .header-call-mobile{ margin-left:auto; color:var(--ink); text-decoration:none; }
  .header-call-mobile svg{ width:22px; height:22px; }
  .nav-toggle{ margin-left:.25rem; background:none; border:2px solid var(--ink);
    color:var(--ink); cursor:pointer; padding:0; }
  .nav-toggle svg{ width:22px; height:22px; }
}

/* mobile panel */
.mobile-nav{ display:none; border-top:1px solid var(--line);
  background:var(--surface); padding:.5rem 0 1.25rem; }
.mobile-nav[data-open="true"]{ display:block; }
.mobile-nav a{
  display:flex; align-items:center; min-height:48px;
  padding:0 clamp(1rem,4vw,1.5rem);
  font-weight:600; color:var(--ink); text-decoration:none;
  border-bottom:1px solid var(--line);
}
.mobile-nav a:hover{ background:var(--surface-2); color:var(--accent-ink); }
.mobile-nav .sub a{ padding-left:2.5rem; font-weight:500; color:var(--ink-soft); font-size:var(--fs-body-sm); }
.mobile-nav .group-label{
  padding:.9rem clamp(1rem,4vw,1.5rem) .35rem; font-family:var(--font-display);
  font-weight:700; font-size:var(--fs-body-sm); color:var(--muted);
  text-transform:uppercase; letter-spacing:.08em;
}
.mobile-nav__actions{ padding:1rem clamp(1rem,4vw,1.5rem) 0; display:grid; gap:.75rem; }
.mobile-nav__actions .tel-row{ display:flex; gap:1rem; flex-wrap:wrap; }
.mobile-nav__actions .tel-row a{ border:0; min-height:44px; padding:0; font-weight:700;
  color:var(--ink); }
.mobile-nav__actions .tel-row a:hover{ background:none; color:var(--accent-ink); }

/* "Lessons" desktop dropdown */
.has-sub{ position:relative; }
.has-sub > .submenu{
  position:absolute; top:100%; left:0; min-width:220px;
  background:var(--surface); border:1px solid var(--line);
  box-shadow:0 8px 24px rgba(15,16,19,.12);
  display:none; padding:.25rem 0; z-index:120;
}
.has-sub:hover > .submenu,
.has-sub:focus-within > .submenu{ display:block; }
.submenu a{
  display:flex; align-items:center; min-height:44px; padding:0 1rem;
  border-bottom:0; font-size:var(--fs-body-sm); border-left:3px solid transparent;
}
.submenu a:hover{ background:var(--surface-2); color:var(--accent-ink);
  border-left-color:var(--accent); }

/* ---------- 5.3 Hero ---------- */
.hero{ background:var(--bg-dark); color:var(--ink-on-dark);
  border-bottom:4px solid var(--accent); }
.hero__inner{
  max-width:1280px; margin:0 auto; padding:clamp(2.5rem,6vw,5rem) clamp(1rem,3vw,2rem);
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;
}
.hero__eyebrow{ color:var(--accent); }
.hero h1{ color:var(--ink-on-dark); font-size:var(--fs-display);
  line-height:1.02; letter-spacing:-0.02em; }
.hero__sub{ color:var(--muted-on-dark); font-size:var(--fs-lead);
  max-width:46ch; margin:1rem 0 1.75rem; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:.875rem; align-items:center; }
.hero__call{ color:var(--ink-on-dark); font-weight:600; margin:1.25rem 0 0; }
.hero__call a{ color:var(--accent); font-weight:700; text-decoration:none; }
.hero__call a:hover{ text-decoration:underline; }
.hero__media{ position:relative; }
.hero__media img{ width:100%; aspect-ratio:1024/675; object-fit:cover; }
.hero__media::before{
  content:""; position:absolute; top:0; left:0; width:32px; height:32px;
  border-top:5px solid var(--accent); border-left:5px solid var(--accent);
}

/* compact page hero (interior pages) */
.page-hero{ background:var(--bg-dark); color:var(--ink-on-dark);
  border-bottom:4px solid var(--accent); }
.page-hero__inner{ max-width:1280px; margin:0 auto;
  padding:clamp(2.25rem,5vw,3.75rem) clamp(1rem,3vw,2rem); }
.page-hero h1{ color:var(--ink-on-dark); }
.page-hero .overline{ color:var(--accent); }
.page-hero p{ color:var(--muted-on-dark); font-size:var(--fs-lead); max-width:54ch; }
.page-hero .hero__actions{ margin-top:1.5rem; }

/* breadcrumb */
.breadcrumb{ font-size:var(--fs-small); color:var(--muted-on-dark); margin:0 0 1rem; }
.breadcrumb a{ color:var(--ink-on-dark); text-decoration:none; }
.breadcrumb a:hover{ color:var(--accent); }
.breadcrumb span{ color:var(--muted-on-dark); padding:0 .4rem; }

@media (max-width:900px){
  .hero__inner{ grid-template-columns:1fr; }
  .hero__media{ order:-1; }
}

/* ---------- 5.4 Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  min-height:48px; padding:.75rem 1.5rem;
  font-family:var(--font-body); font-size:var(--fs-body-sm); font-weight:700;
  letter-spacing:.01em; text-decoration:none; cursor:pointer;
  border:2px solid transparent; background:none;
  transition:background-color var(--dur) var(--ease), color var(--dur) var(--ease),
    border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.btn:active{ transform:translateY(1px); }
.btn svg{ width:18px; height:18px; }

.btn--primary{ background:var(--accent); color:var(--on-accent); border-color:var(--accent); }
.btn--primary:hover{ background:var(--accent-hover); border-color:var(--accent-hover); }
.btn--primary:active{ background:var(--accent-press); border-color:var(--accent-press); }

.btn--secondary{ background:var(--ink); color:var(--ink-on-dark); border-color:var(--ink); }
.btn--secondary:hover{ background:#000; border-color:#000; }

.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line-strong); }
.btn--ghost:hover{ border-color:var(--ink); }

.btn--ghost-light{ background:transparent; color:var(--ink-on-dark); border-color:var(--ink-200,#C9CBD1); }
.btn--ghost-light:hover{ border-color:var(--accent); color:var(--accent); }

.btn--success{ background:var(--success); color:#fff; border-color:var(--success); }
.btn--success:hover{ background:var(--success-ink); border-color:var(--success-ink); }

.btn--block{ width:100%; }
.btn[disabled]{ opacity:.5; cursor:not-allowed; }
.btn:focus-visible{ outline:3px solid var(--focus); outline-offset:2px; }
.on-dark .btn:focus-visible{ outline-color:var(--focus-on-dark); }

.btn-row{ display:flex; flex-wrap:wrap; gap:.875rem; align-items:center; }

/* ---------- 5.13 Trust strip ---------- */
.trust-strip{ background:var(--surface-2); border-bottom:1px solid var(--line); }
.trust-strip__inner{ max-width:1280px; margin:0 auto; padding:1rem clamp(1rem,3vw,2rem);
  display:flex; flex-wrap:wrap; gap:1rem 2rem; align-items:center; justify-content:center; }
.trust-item{ display:inline-flex; align-items:center; gap:.5rem;
  font-weight:600; font-size:var(--fs-body-sm); color:var(--ink-soft); }
.trust-item .tick{ color:var(--success); width:18px; height:18px; flex:0 0 auto; }
.trust-item img{ height:40px; width:auto; }

/* ---------- 5.5 Feature / "why us" cards ---------- */
.feature-grid{ display:grid; gap:1.25rem;
  grid-template-columns:repeat(4,1fr); }
.feature-card{
  background:var(--surface); border:1px solid var(--line);
  border-top:4px solid var(--accent);
  padding:1.75rem 1.5rem; position:relative;
}
.feature-card .icon{ width:32px; height:32px; color:var(--ink); margin-bottom:1rem;
  stroke:var(--ink); stroke-width:1.75; fill:none; }
.feature-card h4{ margin-bottom:.5rem; }
.feature-card p{ color:var(--ink-soft); font-size:var(--fs-body-sm); margin:0; max-width:none; }

@media (max-width:980px){ .feature-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .feature-grid{ grid-template-columns:1fr; } }

/* ---------- steps (how lessons work) ---------- */
.steps{ display:grid; gap:1.25rem; grid-template-columns:repeat(4,1fr); counter-reset:step; }
.step{ background:var(--surface); border:1px solid var(--line); border-top:4px solid var(--accent);
  padding:1.5rem 1.5rem 1.75rem; position:relative; }
.step__num{ font-family:var(--font-display); font-weight:800; font-size:2.25rem;
  line-height:1; color:var(--accent-ink); display:block; margin-bottom:.5rem;
  font-variant-numeric:tabular-nums; }
.step h4{ margin:0 0 .4rem; }
.step p{ margin:0; color:var(--ink-soft); font-size:var(--fs-body-sm); max-width:none; }
@media (max-width:980px){ .steps{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } }

/* ---------- 5.6 lesson cards + course cards ---------- */
.lesson-grid{ display:grid; gap:1.25rem; grid-template-columns:repeat(2,1fr); }
@media (max-width:680px){ .lesson-grid{ grid-template-columns:1fr; } }

.lesson-card{
  background:var(--surface); border:1px solid var(--line); border-top:4px solid var(--accent);
  padding:1.75rem; display:flex; flex-direction:column; gap:.75rem;
}
.lesson-card__head{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.lesson-card .price{ font-family:var(--font-display); font-weight:800;
  font-size:1.5rem; color:var(--ink); font-variant-numeric:tabular-nums; }
.lesson-card .price span{ font-size:var(--fs-small); font-weight:600; color:var(--muted); }
.lesson-card ul{ list-style:none; margin:0; padding:0; display:grid; gap:.5rem; }
.lesson-card li{ display:flex; gap:.5rem; font-size:var(--fs-body-sm); color:var(--ink-soft); }
.lesson-card li::before{ content:""; flex:0 0 auto; width:8px; height:8px;
  margin-top:.45em; background:var(--accent); }
.lesson-card p{ font-size:var(--fs-body-sm); color:var(--ink-soft); max-width:none; }
.lesson-card .btn{ margin-top:auto; }

.course-card{ background:var(--surface); border:1px solid var(--line);
  display:flex; flex-direction:column; }
.course-card__media{ aspect-ratio:300/165; overflow:hidden; border-bottom:4px solid var(--accent);
  background:var(--surface-2); }
.course-card__media img{ width:100%; height:100%; object-fit:cover; }
.course-card__body{ padding:1.25rem 1.25rem 1.5rem; display:flex; flex-direction:column; gap:.5rem; }
.course-card h4{ margin:0; }
.course-card p{ font-size:var(--fs-body-sm); color:var(--ink-soft); margin:0; max-width:none; }
.course-card .course-link{ margin-top:auto; font-weight:700; color:var(--accent-ink); text-decoration:none;
  display:inline-flex; align-items:center; gap:.4rem; min-height:44px; }
.course-card .course-link:hover{ color:var(--ink); text-decoration:underline; }

.card-grid{ display:grid; gap:1.25rem; grid-template-columns:repeat(3,1fr); }
@media (max-width:980px){ .card-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .card-grid{ grid-template-columns:1fr; } }

/* ---------- 5.7 Category cards (areas / test centres) ---------- */
.category-grid{ display:grid; gap:1px; background:var(--line);
  grid-template-columns:repeat(3,1fr); border:1px solid var(--line); }
.category-card{
  background:var(--surface); padding:1.5rem 1.25rem; min-height:120px;
  display:flex; flex-direction:column; justify-content:space-between;
  text-decoration:none; color:var(--ink); position:relative;
  transition:background-color var(--dur) var(--ease);
}
.category-card::before{ content:""; position:absolute; top:0; left:0;
  width:0; height:4px; background:var(--accent); transition:width .18s var(--ease); }
.category-card:hover::before,
.category-card:focus-visible::before{ width:100%; }
.category-card:hover{ background:var(--surface-2); }
.category-card .overline{ color:var(--muted); }
.category-card h4{ margin:.35rem 0 0; }
.category-card .meta{ font-size:var(--fs-small); color:var(--muted); }

@media (max-width:780px){ .category-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:440px){ .category-grid{ grid-template-columns:1fr; } }

/* ---------- 5.8 Pricing ---------- */
.price-grid{ display:grid; gap:1.25rem; grid-template-columns:repeat(3,1fr); }
.price-card{ background:var(--surface); border:1px solid var(--line);
  border-top:4px solid var(--accent); padding:1.75rem 1.5rem; position:relative;
  display:flex; flex-direction:column; gap:1rem; }
.price-card--featured{ border-top-color:var(--success); box-shadow:0 0 0 2px var(--success) inset; }
.price-card .tier{ font-family:var(--font-display); font-weight:700; font-size:var(--fs-h4); margin:0; }
.price-card .amount{ font-family:var(--font-display); font-weight:800; font-size:2.25rem;
  line-height:1; font-variant-numeric:tabular-nums; color:var(--ink); }
.price-card .amount .per{ font-family:var(--font-body); font-size:var(--fs-small);
  font-weight:600; color:var(--muted); }
.price-card .save{ color:var(--success-ink); font-weight:700; font-size:var(--fs-small); margin:0; }
.price-card .chip-row{ position:absolute; top:1rem; right:1rem; }
.price-card ul{ list-style:none; margin:0; padding:0; display:grid; gap:.5rem; }
.price-card li{ display:flex; gap:.5rem; font-size:var(--fs-body-sm); color:var(--ink-soft); }
.price-card li::before{ content:""; flex:0 0 auto; width:8px; height:8px; margin-top:.45em;
  background:var(--accent); }
.price-card .btn{ margin-top:auto; }

.price-table{ width:100%; border-collapse:collapse; }
.price-table caption{ text-align:left; font-weight:700; margin-bottom:.5rem;
  font-family:var(--font-display); font-size:var(--fs-h4); }
.price-table th, .price-table td{ text-align:left; padding:.75rem 1rem;
  border-bottom:1px solid var(--line); font-size:var(--fs-body-sm); }
.price-table th{ font-family:var(--font-display); font-weight:700; background:var(--surface-2); }
.price-table tbody tr:nth-child(even){ background:var(--surface-2); }
.price-table td.num, .price-table th.num{ text-align:right; font-variant-numeric:tabular-nums; font-weight:700; }
.table-wrap{ overflow-x:auto; border:1px solid var(--line); }

@media (max-width:900px){ .price-grid{ grid-template-columns:1fr; } }

/* ---------- 5.10 Testimonials / recent passes ---------- */
.passes-strip{ display:grid; gap:1px; background:var(--line);
  grid-template-columns:repeat(6,1fr); border:1px solid var(--line); }
.passes-strip img{ width:100%; aspect-ratio:1/1; object-fit:cover; background:var(--surface-2); }
.passes-note{ color:var(--muted); font-size:var(--fs-small); margin-top:.75rem; }

.quote-card{ background:var(--surface); border:1px solid var(--line);
  border-left:4px solid var(--accent); padding:1.75rem; }
.quote-card blockquote{ margin:0 0 1rem; font-size:var(--fs-lead); color:var(--ink);
  line-height:1.55; }
.quote-card .who{ display:flex; align-items:center; gap:.75rem; }
.quote-card .who .name{ font-weight:700; }
.quote-card .who .where{ color:var(--muted); font-size:var(--fs-small); }
.quote-card .stars{ color:var(--accent-ink); letter-spacing:.1em; font-weight:700; }

@media (max-width:780px){ .passes-strip{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:380px){ .passes-strip{ grid-template-columns:repeat(2,1fr); } }

/* ---------- 5.11 Forms ---------- */
.form{ display:grid; gap:1.25rem; max-width:640px; }
.field{ display:grid; gap:.4rem; }
.field label{ font-weight:600; font-size:var(--fs-body-sm); color:var(--ink); }
.field .hint{ font-size:var(--fs-xs); color:var(--muted); }
.field .req{ color:var(--danger-ink); }
.field--row{ display:grid; gap:1.25rem; grid-template-columns:1fr 1fr; max-width:none; }
@media (max-width:520px){ .field--row{ grid-template-columns:1fr; } }

.input, .select, .textarea{
  width:100%; min-height:48px; padding:.7rem .9rem;
  font-family:var(--font-body); font-size:var(--fs-body); color:var(--ink);
  background:var(--surface); border:1px solid var(--line-strong);
  border-bottom-width:2px;
  transition:border-color var(--dur) var(--ease);
}
.textarea{ min-height:140px; resize:vertical; }
.input:hover,.select:hover,.textarea:hover{ border-color:var(--ink-soft); }
.input:focus,.select:focus,.textarea:focus{
  outline:none; border-color:var(--ink); border-bottom-color:var(--accent);
}
.input:focus-visible,.select:focus-visible,.textarea:focus-visible{
  outline:3px solid var(--focus); outline-offset:2px;
}

.field[data-state="error"] .input{ border-color:var(--danger); }
.field[data-state="error"] .msg{ color:var(--danger-ink); font-size:var(--fs-small); }
.field[data-state="ok"] .input{ border-color:var(--success); }

.choice-set{ display:flex; flex-wrap:wrap; gap:.75rem; }
.choice{ display:inline-flex; align-items:center; gap:.6rem; min-height:44px; cursor:pointer;
  border:1px solid var(--line-strong); padding:.5rem .9rem; background:var(--surface);
  font-size:var(--fs-body-sm); font-weight:600; }
.choice:hover{ border-color:var(--ink-soft); }
.choice input{ width:22px; height:22px; accent-color:var(--accent); }
.choice:focus-within{ border-color:var(--ink); }

.form__actions{ display:flex; gap:.875rem; align-items:center; flex-wrap:wrap; }
.form-note{ font-size:var(--fs-xs); color:var(--muted); margin:0; }

/* ---------- info panels / detail blocks ---------- */
.info-grid{ display:grid; gap:1.25rem; grid-template-columns:repeat(2,1fr); }
@media (max-width:760px){ .info-grid{ grid-template-columns:1fr; } }
.info-card{ background:var(--surface); border:1px solid var(--line); border-top:4px solid var(--accent);
  padding:1.5rem 1.5rem 1.75rem; }
.info-card h3,.info-card h4{ margin-top:0; }
.info-card p:last-child{ margin-bottom:0; }
.info-card dl{ margin:0; display:grid; gap:.5rem; }
.info-card dt{ font-weight:700; font-size:var(--fs-body-sm); }
.info-card dd{ margin:0 0 .5rem; color:var(--ink-soft); font-size:var(--fs-body-sm); }
.hours-list{ list-style:none; margin:0; padding:0; }
.hours-list li{ display:flex; justify-content:space-between; gap:1rem; padding:.4rem 0;
  border-bottom:1px solid var(--line); font-size:var(--fs-body-sm); }
.hours-list li:last-child{ border-bottom:0; }
.hours-list .day{ font-weight:600; }
.hours-list .time{ color:var(--ink-soft); font-variant-numeric:tabular-nums; }

/* credential checklist */
.cred-list{ list-style:none; margin:0; padding:0; display:grid; gap:.75rem; }
.cred-list li{ display:flex; gap:.6rem; align-items:flex-start; font-size:var(--fs-body); }
.cred-list .tick{ color:var(--success); width:20px; height:20px; flex:0 0 auto; margin-top:.15em; }

/* notice / honest flags (use sparingly) */
.notice{ border:1px solid var(--line-strong); border-left:4px solid var(--accent);
  background:var(--surface); padding:1rem 1.25rem; font-size:var(--fs-body-sm);
  color:var(--ink-soft); }
.notice strong{ color:var(--ink); }
.notice--info{ border-left-color:var(--success); }

/* FAQ */
.faq{ display:grid; gap:0; border:1px solid var(--line); }
.faq details{ border-bottom:1px solid var(--line); background:var(--surface); }
.faq details:last-child{ border-bottom:0; }
.faq summary{ cursor:pointer; padding:1.1rem 1.25rem; font-family:var(--font-display);
  font-weight:700; font-size:var(--fs-h5); list-style:none; min-height:44px;
  display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--font-display); font-weight:800;
  color:var(--accent-ink); font-size:1.4rem; line-height:1; flex:0 0 auto; }
.faq details[open] summary::after{ content:"\2212"; }
.faq summary:hover{ color:var(--accent-ink); }
.faq details > p{ margin:0; padding:0 1.25rem 1.25rem; color:var(--ink-soft); }

/* journey list (resources) */
.journey{ list-style:none; margin:0; padding:0; display:grid; gap:1.25rem; counter-reset:j; }
.journey li{ background:var(--surface); border:1px solid var(--line); border-left:4px solid var(--accent);
  padding:1.25rem 1.5rem 1.4rem 1.5rem; position:relative; }
.journey li h4{ margin:0 0 .4rem; }
.journey li p{ margin:0; color:var(--ink-soft); }

/* two-col prose layout */
.prose-2{ display:grid; gap:2rem 3rem; grid-template-columns:repeat(2,1fr); }
@media (max-width:820px){ .prose-2{ grid-template-columns:1fr; } }
.prose h2,.prose h3{ margin-top:1.5rem; }
.prose h2:first-child,.prose h3:first-child{ margin-top:0; }

/* stats row */
.stats{ display:grid; gap:1px; background:var(--line-on-dark); grid-template-columns:repeat(5,1fr);
  border:1px solid var(--line-on-dark); }
.stat{ background:var(--bg-dark); padding:1.5rem 1.25rem; text-align:center; }
.stat .num{ font-family:var(--font-display); font-weight:800; font-size:2rem; color:var(--accent);
  display:block; line-height:1; font-variant-numeric:tabular-nums; }
.stat .label{ color:var(--muted-on-dark); font-size:var(--fs-small); margin-top:.4rem; display:block; }
@media (max-width:880px){ .stats{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:440px){ .stats{ grid-template-columns:1fr; } }

/* chips row (course chips on home) */
.chip-list{ display:flex; flex-wrap:wrap; gap:.6rem; margin:0; padding:0; list-style:none; }
.chip-list a{ display:inline-flex; align-items:center; min-height:44px; padding:.5rem 1rem;
  border:1px solid var(--line-strong); background:var(--surface); color:var(--ink);
  text-decoration:none; font-size:var(--fs-body-sm); font-weight:600;
  transition:border-color var(--dur) var(--ease), color var(--dur) var(--ease), background-color var(--dur) var(--ease); }
.chip-list a:hover{ border-color:var(--ink); color:var(--accent-ink); background:var(--surface-2); }

/* media band */
.media-band{ position:relative; }
.media-band img{ width:100%; aspect-ratio:768/282; object-fit:cover; }

/* CTA band */
.cta-band{ background:var(--bg-dark); color:var(--ink-on-dark); border-top:4px solid var(--accent); }
.cta-band__inner{ max-width:1280px; margin:0 auto; padding:clamp(2.5rem,6vw,4.5rem) clamp(1rem,3vw,2rem);
  display:flex; flex-wrap:wrap; gap:1.5rem 3rem; align-items:center; justify-content:space-between; }
.cta-band h2{ color:var(--ink-on-dark); margin:0 0 .35rem; }
.cta-band p{ color:var(--muted-on-dark); margin:0; max-width:48ch; }
.cta-band .btn-row{ flex:0 0 auto; }

/* guarantee block */
.guarantee{ display:grid; grid-template-columns:auto 1fr; gap:2rem; align-items:center; }
.guarantee img{ width:140px; height:auto; }
@media (max-width:560px){ .guarantee{ grid-template-columns:1fr; } .guarantee img{ width:120px; } }

/* utility spacing */
.mt-1{ margin-top:.5rem; } .mt-2{ margin-top:1rem; } .mt-3{ margin-top:1.5rem; } .mt-4{ margin-top:2rem; }
.mb-0{ margin-bottom:0; } .mb-2{ margin-bottom:1rem; } .mb-3{ margin-bottom:1.5rem; }
.stack > * + *{ margin-top:1rem; }

/* ---------- 5.12 Footer ---------- */
.site-footer{ background:var(--bg-dark); color:var(--ink-on-dark);
  border-top:4px solid var(--accent); }
.site-footer__inner{ max-width:1280px; margin:0 auto;
  padding:clamp(2.5rem,5vw,4rem) clamp(1rem,3vw,2rem);
  display:grid; gap:2rem; grid-template-columns:1.3fr 1fr 1.3fr 1fr; }
.site-footer h5{ color:var(--ink-on-dark); margin-bottom:1rem;
  font-size:var(--fs-h6); text-transform:uppercase; letter-spacing:.06em; }
.site-footer a{ color:var(--ink-on-dark); text-decoration:none; }
.site-footer a:hover{ color:var(--accent); }
.site-footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.site-footer li a{ display:inline-flex; min-height:32px; align-items:center; }
.site-footer .muted{ color:var(--muted-on-dark); font-size:var(--fs-small); }
.site-footer__brand p{ color:var(--muted-on-dark); font-size:var(--fs-small); max-width:34ch; }
.site-footer__brand img.badge{ height:64px; width:auto; margin-top:1rem; }
.footer-contact{ display:grid; gap:.6rem; }
.footer-contact .row{ display:flex; gap:.5rem; align-items:flex-start; font-size:var(--fs-small);
  color:var(--ink-on-dark); }
.footer-contact .row svg{ width:18px; height:18px; flex:0 0 auto; margin-top:.15em; color:var(--accent); }
.footer-contact a{ color:var(--ink-on-dark); }
.footer-hours{ margin-top:1rem; }
.footer-hours .muted{ display:block; }
.footer-social{ display:flex; gap:.75rem; margin-top:.75rem; }
.footer-social a{ display:inline-flex; align-items:center; justify-content:center;
  min-width:44px; min-height:44px; border:1px solid var(--line-on-dark); color:var(--ink-on-dark); }
.footer-social a:hover{ border-color:var(--accent); color:var(--accent); }
.footer-social svg{ width:20px; height:20px; }
.site-footer__bottom{ border-top:1px solid var(--line-on-dark);
  padding:1.25rem clamp(1rem,3vw,2rem); display:flex; flex-wrap:wrap;
  gap:1rem; justify-content:space-between; max-width:1280px; margin:0 auto; }
.site-footer__bottom, .site-footer__bottom a{ font-size:var(--fs-small); color:var(--muted-on-dark); }
.site-footer__bottom nav{ display:flex; gap:1.25rem; flex-wrap:wrap; }
.site-footer__bottom a{ text-decoration:none; }
.site-footer__bottom a:hover{ color:var(--accent); }

@media (max-width:980px){ .site-footer__inner{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .site-footer__inner{ grid-template-columns:1fr; } }

/* ---------- 9. Print ---------- */
@media print{
  .site-header, .site-footer, .nav-toggle, .hero__actions, .header-cta,
  .cta-band .btn-row, .mobile-nav, .trust-strip{ display:none; }
  *{ background:#fff !important; color:#000 !important; }
  a[href^="http"]::after{ content:" (" attr(href) ")"; font-size:11px; }
  .hero, .page-hero, .section--dark, .cta-band{ border:0 !important; }
}

/* ---------- scroll-reveal (user-triggered via IntersectionObserver) ---------- */
.reveal{ opacity:0; transform:translateY(8px); transition:opacity .45s var(--ease), transform .45s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}
