/* ============================================================
   TNG SIMULATION DRIVING SCHOOL — shared stylesheet (all pages)
   No external CDN / fonts. Offline-capable.
   Palette sourced from repo DESIGN.md (traffic-colour system).
   Aesthetic: editorial driver's-handbook meets warm West-African craft.
   ============================================================ */
:root{
  --paper:#f4efe5;
  --paper-2:#efe6d6;
  --card:#fffaf0;
  --ink:#152532;
  --ink-soft:#26333d;
  --muted:#56636c;
  --line:#d9cdb8;
  --line-soft:#e6dcc8;
  --gold:#e0a928;
  --gold-deep:#c4901a;
  --red:#b5412e;
  --green:#2f6f56;
  --blue:#255f85;
  --slate:#42515c;
  /* The Gambia national flag */
  --gm-red:#ce1126;
  --gm-blue:#0c1c8c;
  --gm-green:#3a7728;
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,"Times New Roman",serif;
  --sans:"Avenir Next","Segoe UI",system-ui,-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","Cascadia Mono",Menlo,Consolas,monospace;
  --shadow:0 1px 0 rgba(21,37,50,.04),0 18px 40px -28px rgba(21,37,50,.45);
  --shadow-lg:0 24px 60px -34px rgba(21,37,50,.6);
  --r:14px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
h1,h2,h3,h4{margin:0;font-family:var(--serif);font-weight:700;line-height:1.04;letter-spacing:-.01em}
p{margin:0}
.wrap{width:min(var(--maxw),calc(100% - 40px));margin-inline:auto}
.eyebrow{
  font-family:var(--mono);font-size:12px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--green);
  display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
.eyebrow.red{color:var(--red)} .eyebrow.blue{color:var(--blue)} .eyebrow.gold{color:var(--gold-deep)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:48px;padding:0 22px;border-radius:999px;
  font-family:var(--sans);font-weight:800;font-size:15px;letter-spacing:.01em;
  cursor:pointer;border:2px solid transparent;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:#0d1b26;box-shadow:var(--shadow-lg)}
.btn-gold{background:var(--gold);color:var(--ink);box-shadow:0 10px 24px -12px rgba(224,169,40,.9)}
.btn-gold:hover{background:#eeb83a}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-ondark{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ondark:hover{background:#fff;color:var(--ink)}
.btn-wa{background:#1f8f4e;color:#fff}
.btn-wa:hover{background:#1a7b43}
.btn svg{width:18px;height:18px;flex:none}

/* ---- header ---- */
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.skip:focus{left:0}
header.site{
  position:sticky;top:0;z-index:120;
  background:rgba(244,239,229,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;
}
header.site.scrolled{border-bottom-color:var(--line);box-shadow:0 8px 24px -22px rgba(21,37,50,.7)}
.nav{display:flex;align-items:center;gap:18px;height:72px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto;color:var(--ink)}
.brand .mark{width:42px;height:42px;flex:none}
.brand .name{display:flex;flex-direction:column;line-height:1}
.brand .name b{font-family:var(--serif);font-size:19px;letter-spacing:-.01em}
.brand .name span{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{
  display:inline-flex;align-items:center;gap:7px;
  color:var(--ink-soft);font-weight:700;font-size:14.5px;padding:9px 12px;border-radius:8px;
  transition:background .15s ease,color .15s ease;
}
.nav-links a svg{width:16px;height:16px;flex:none;color:var(--gold-deep)}
.nav-links a:hover{background:var(--paper-2);color:var(--ink)}
.nav-links a.active{background:var(--paper-2);color:var(--ink);box-shadow:inset 0 -2px 0 var(--gold)}
.nav-links a.active svg{color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:10px}
.hamburger{
  display:none;width:46px;height:46px;border:1px solid var(--line);background:var(--card);
  border-radius:10px;cursor:pointer;align-items:center;justify-content:center;flex:none;
}
.hamburger span{display:block;width:20px;height:2px;background:var(--ink);position:relative;transition:.2s}
.hamburger span::before,.hamburger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);transition:.2s}
.hamburger span::before{top:-6px}.hamburger span::after{top:6px}
body.menu-open .hamburger span{background:transparent}
body.menu-open .hamburger span::before{top:0;transform:rotate(45deg)}
body.menu-open .hamburger span::after{top:0;transform:rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed;inset:72px 0 0;z-index:115;background:var(--paper);
  transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  padding:18px 20px calc(28px + env(safe-area-inset-bottom));overflow-y:auto;display:flex;flex-direction:column;gap:6px;
}
body.menu-open .drawer{transform:translateX(0)}
.drawer a.dl{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 6px;border-bottom:1px solid var(--line-soft);
  font-family:var(--serif);font-size:23px;color:var(--ink);font-weight:700;
}
.drawer a.dl .di{display:flex;align-items:center;gap:15px}
.drawer a.dl .di svg{width:22px;height:22px;flex:none;color:var(--gold-deep)}
.drawer a.dl .num{font-family:var(--mono);font-size:12px;color:var(--gold-deep)}
.drawer a.dl.active{color:var(--red)}
.drawer a.dl.active .di svg{color:var(--red)}
.drawer .btn{margin-top:14px;width:100%}

/* ---- hero ---- */
.hero{position:relative;padding:64px 0 56px;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 88% -10%,rgba(224,169,40,.16),transparent 55%),
    radial-gradient(90% 70% at -10% 110%,rgba(37,95,133,.10),transparent 55%);
}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(40px,6.4vw,76px);margin:20px 0 0}
.hero h1 .hl{color:var(--red)}
.hero h1 .u{position:relative;white-space:nowrap}
.hero h1 .u::after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:.18em;background:var(--gold);z-index:-1;border-radius:3px}
.motto{font-family:var(--mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--green);margin-top:22px;font-weight:700}
.hero-lead{max-width:54ch;color:var(--muted);font-size:19px;margin-top:14px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.hero-trust{display:flex;flex-wrap:wrap;gap:22px;margin-top:30px;padding-top:22px;border-top:1px dashed var(--line)}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust b{font-family:var(--serif);font-size:30px;color:var(--ink);line-height:1}
.hero-trust span{font-size:12.5px;color:var(--muted);font-weight:700;margin-top:5px;letter-spacing:.02em}

.hero-art{position:relative}
.hero-art .frame{
  background:var(--ink);border-radius:20px;padding:14px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden
}
.hero-art .frame::after{
  content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.10),transparent 40%);pointer-events:none
}
.hero-art .screen{border-radius:12px;overflow:hidden;display:block;background:#0d1b26}
.hero-badge{
  position:absolute;background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:12px 14px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:11px
}
.hero-badge .ic{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:none}
.hero-badge b{display:block;font-family:var(--serif);font-size:17px;line-height:1.1}
.hero-badge small{color:var(--muted);font-size:12px;font-weight:700}
.hero-badge.b1{top:-16px;left:-18px}
.hero-badge.b2{bottom:-18px;right:-14px}

/* ---- page hero (sub-pages) ---- */
.pagehero{position:relative;padding:54px 0 40px;border-bottom:1px solid var(--line);overflow:hidden}
.pagehero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(120% 90% at 92% -20%,rgba(224,169,40,.16),transparent 55%);
}
.pagehero .wrap{position:relative;z-index:1}
.crumb{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:14px}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--ink)}
.crumb .sep{margin:0 8px;color:var(--line)}
.pagehero h1{font-size:clamp(34px,5.2vw,62px);margin-top:6px}
.pagehero .lead{color:var(--muted);font-size:19px;margin-top:16px;max-width:62ch}

/* ---- marquee strip ---- */
.strip{background:var(--ink);color:#f4efe5;overflow:hidden;border-block:3px solid var(--gold)}
.strip .track{display:flex;gap:0;white-space:nowrap;animation:marq 32s linear infinite}
.strip .track:hover{animation-play-state:paused}
.strip span{display:inline-flex;align-items:center;gap:16px;padding:13px 0;font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.strip span::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);margin:0 26px}
@keyframes marq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.strip .track{animation:none}}

/* ---- generic section ---- */
section.s{padding:84px 0;position:relative}
.s-head{max-width:60ch;margin-bottom:44px}
.s-head h2{font-size:clamp(30px,4.2vw,50px);margin-top:16px}
.s-head p{color:var(--muted);font-size:19px;margin-top:16px}
.center{margin-inline:auto;text-align:center}
.center .eyebrow{justify-content:center}
.more{text-align:center;margin-top:36px}

/* ---- divider road dashes ---- */
.roaddash{height:2px;width:100%;background:repeating-linear-gradient(90deg,var(--gold) 0 26px,transparent 26px 46px);opacity:.7}

/* ---- Gambian national-flag motifs ---- */
.flagbar{
  height:9px;width:100%;
  background:linear-gradient(to bottom,
    var(--gm-red) 0 38%, #fff 38% 43%, var(--gm-blue) 43% 57%, #fff 57% 62%, var(--gm-green) 62% 100%);
}
.gm-ribbon{display:flex;height:6px;width:100%;border-radius:3px;overflow:hidden;box-shadow:var(--shadow)}
.gm-ribbon i{flex:1}
.gm-ribbon i:nth-child(1){background:var(--gm-red);flex:6}
.gm-ribbon i:nth-child(2){background:#fff;flex:1}
.gm-ribbon i:nth-child(3){background:var(--gm-blue);flex:4}
.gm-ribbon i:nth-child(4){background:#fff;flex:1}
.gm-ribbon i:nth-child(5){background:var(--gm-green);flex:6}
.flag-chip{
  display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:800;color:var(--slate);
  background:var(--card);border:1px solid var(--line);padding:6px 13px 6px 7px;border-radius:999px;box-shadow:var(--shadow)
}
.flag-chip .gf{width:26px;height:18px;border-radius:3px;flex:none;border:1px solid rgba(0,0,0,.12);
  background:linear-gradient(to bottom,
    var(--gm-red) 0 38%, #fff 38% 43%, var(--gm-blue) 43% 57%, #fff 57% 62%, var(--gm-green) 62% 100%)}
/* baobab silhouette behind a section */
.baobab-bg{position:relative;overflow:hidden}
.baobab-bg .baobab{position:absolute;right:-10px;bottom:0;width:280px;height:auto;opacity:.07;pointer-events:none;z-index:0}
.baobab-bg .wrap{position:relative;z-index:1}

/* ---- simulation difference ---- */
.diff{background:var(--paper-2)}
.diff-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.diff-list{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:16px}
.diff-list li{display:flex;gap:15px;align-items:flex-start}
.diff-list .n{font-family:var(--mono);font-weight:700;font-size:13px;color:#fff;background:var(--blue);min-width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex:none;margin-top:2px}
.diff-list h4{font-size:19px;font-family:var(--sans);font-weight:800}
.diff-list p{color:var(--muted);font-size:15.5px;margin-top:3px}
.diff-art{background:var(--ink);border-radius:20px;padding:16px;box-shadow:var(--shadow-lg)}

/* ---- courses ---- */
.courses{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.course{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;
  display:flex;flex-direction:column;position:relative;overflow:hidden;
  border-top:5px solid var(--accent,var(--gold));transition:transform .2s ease,box-shadow .2s ease;
}
.course:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.course .badge{position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent,var(--gold-deep));background:color-mix(in srgb,var(--accent,var(--gold)) 14%,transparent);padding:5px 9px;border-radius:6px}
.course .cic{width:54px;height:54px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 14%,transparent);margin-bottom:18px}
.course h3{font-size:23px}
.course .lvl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:6px;display:block}
.course p{color:var(--muted);font-size:15px;margin-top:12px}
.course ul{list-style:none;padding:0;margin:16px 0 20px;display:grid;gap:9px}
.course ul li{display:flex;gap:9px;align-items:flex-start;font-size:14.5px;color:var(--ink-soft)}
.course ul li svg{width:17px;height:17px;color:var(--green);flex:none;margin-top:2px}
.course .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:16px;border-top:1px dashed var(--line)}
.course .foot .btn{width:100%}
.course .price b{font-family:var(--serif);font-size:24px}
.course .price small{display:block;font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.course .price-link{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);white-space:nowrap}
.course .price-link:hover{color:var(--ink)}

/* ---- OADA method ---- */
.oada{background:var(--ink);color:#f4efe5;overflow:hidden}
.oada .eyebrow{color:var(--gold)}
.oada .eyebrow::before{background:var(--gold)}
.oada h2{color:#fff;font-size:clamp(30px,4.2vw,50px);margin-top:16px}
.oada .s-head p{color:#c4cdd4}
.oada-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px}
.oada-step{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:24px;position:relative}
.oada-step .ring{width:58px;height:58px;border-radius:50%;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:26px;color:var(--gold);font-weight:700}
.oada-step h4{font-family:var(--serif);font-size:24px;color:#fff;margin-top:18px}
.oada-step .k{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:6px;display:block}
.oada-step p{color:#b9c3cb;font-size:14.5px;margin-top:12px}
.oada-step .arrow{position:absolute;top:42px;right:-20px;color:var(--gold);opacity:.5;z-index:2}
.oada-step:last-child .arrow{display:none}

/* ---- why / features ---- */
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.feat .fic{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feat h4{font-size:19px;font-family:var(--sans);font-weight:800}
.feat p{color:var(--muted);font-size:15px;margin-top:9px}

/* ---- steps ---- */
.steps{background:var(--paper-2)}
.step-row{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:st}
.step{position:relative;padding-top:18px}
.step .num{font-family:var(--serif);font-size:64px;color:var(--gold);line-height:.8;opacity:.9}
.step h4{font-size:20px;margin-top:12px;font-family:var(--sans);font-weight:800}
.step p{color:var(--muted);font-size:15px;margin-top:8px}

/* ---- testimonials ---- */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px;display:flex;flex-direction:column}
.tcard .quote{font-family:var(--serif);font-size:19px;line-height:1.5;color:var(--ink)}
.tcard .stars{color:var(--gold);letter-spacing:3px;margin-bottom:14px;font-size:15px}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:18px}
.tcard .av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;color:#fff;flex:none;font-size:17px}
.tcard .who b{display:block;font-family:var(--sans);font-size:15px}
.tcard .who small{color:var(--muted);font-size:13px}
.rating-line{margin-top:14px;font-size:17px;color:var(--ink-soft);display:inline-flex;align-items:center;gap:9px}
.rating-line .rstars{color:var(--gold);letter-spacing:2px;font-size:17px}
.rating-line b{font-family:var(--serif);font-size:20px;color:var(--ink)}
.rating-band{display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:32px 36px;box-shadow:var(--shadow)}
.rb-score{text-align:center;padding-right:36px;border-right:1px solid var(--line)}
.rb-num{font-family:var(--serif);font-size:64px;line-height:1;color:var(--ink)}
.rb-num span{font-size:24px;color:var(--muted)}
.rb-stars{color:var(--gold);letter-spacing:4px;font-size:22px;margin-top:8px}
.rb-sub{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:10px}
.rb-points{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.rb-points li{display:flex;gap:10px;align-items:flex-start;font-size:16px;color:var(--ink-soft);font-weight:600}
.rb-points li svg{width:20px;height:20px;color:var(--green);flex:none;margin-top:2px}
@media (max-width:680px){
  .rating-band{grid-template-columns:1fr;gap:24px;text-align:center}
  .rb-score{padding:0 0 24px;border-right:none;border-bottom:1px solid var(--line)}
  .rb-points{grid-template-columns:1fr;text-align:left;max-width:24rem;margin:0 auto}
}

/* ---- pricing ---- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.plan{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:28px;display:flex;flex-direction:column;position:relative}
.plan.pop{border:2px solid var(--gold);box-shadow:var(--shadow-lg);transform:scale(1.02)}
.plan .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--ink);font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.plan h3{font-size:23px}
.plan .pdesc{color:var(--muted);font-size:14px;margin-top:6px;min-height:40px}
.plan .amt{font-family:var(--serif);font-size:46px;margin:16px 0 2px;display:flex;align-items:baseline;gap:6px}
.plan .amt small{font-family:var(--sans);font-size:14px;color:var(--muted);font-weight:700}
.plan .cur{font-size:22px;color:var(--green)}
.plan ul{list-style:none;padding:0;margin:18px 0 24px;display:grid;gap:11px}
.plan ul li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--ink-soft)}
.plan ul li svg{width:18px;height:18px;color:var(--green);flex:none;margin-top:1px}
.plan ul li.off{color:var(--muted);opacity:.6}
.plan ul li.off svg{color:var(--muted)}
.plan .btn{margin-top:auto;width:100%}
.pricing-note{text-align:center;color:var(--muted);font-size:14px;margin-top:26px;max-width:60ch;margin-left:auto;margin-right:auto}
/* dual manual/automatic pricing (real package price list) */
.plans-6{grid-template-columns:repeat(3,1fr)}
.plans-6 .plan{padding:24px}
.plans-6 .plan h3{font-size:25px}
.plans-6 .plan .pdesc{min-height:0}
.plan .duo{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0 6px}
.plan .pcol{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.plan.pop .pcol{background:color-mix(in srgb,var(--gold) 10%,var(--paper));border-color:color-mix(in srgb,var(--gold) 40%,var(--line))}
.plan .pcol .lbl{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.plan .pcol .num{font-family:var(--serif);font-size:25px;line-height:1.1;color:var(--ink);display:flex;align-items:baseline;gap:2px}
.plan .pcol .num .cur{font-family:var(--serif);font-size:14px;color:var(--green)}

/* ---- FAQ ---- */
.faq{max-width:820px;margin-inline:auto}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq summary{
  list-style:none;cursor:pointer;padding:20px 22px;font-family:var(--serif);font-size:19px;font-weight:700;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{width:26px;height:26px;flex:none;position:relative}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--gold-deep);transition:.2s;border-radius:2px}
.faq summary .pm::before{top:12px;left:4px;width:18px;height:2px}
.faq summary .pm::after{top:4px;left:12px;width:2px;height:18px}
.faq details[open] summary .pm::after{transform:rotate(90deg);opacity:0}
.faq details p{padding:0 22px 22px;color:var(--muted);font-size:16px}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(135deg,#eab63e,#e0a928);color:var(--ink);text-align:center;padding:66px 0;position:relative;overflow:hidden}
.cta-band h2{font-size:clamp(28px,4vw,46px)}
.cta-band p{max-width:54ch;margin:14px auto 0;color:#4a3a14;font-size:18px;font-weight:600}
.cta-band .actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:26px}

/* ---- contact / CTA ---- */
.contact{background:var(--ink);color:#f4efe5}
.contact .eyebrow{color:var(--gold)}.contact .eyebrow::before{background:var(--gold)}
.contact h2{color:#fff;font-size:clamp(30px,4.2vw,50px);margin-top:16px}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start;margin-top:8px}
.contact-lead{color:#c4cdd4;font-size:18px;margin-top:16px;max-width:46ch}
.cinfo{display:grid;gap:14px;margin-top:28px}
.cinfo a,.cinfo div{display:flex;gap:14px;align-items:center;color:#e7ecef;font-size:15.5px;font-weight:600}
.cinfo .ic{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;flex:none}
.cinfo a:hover{color:var(--gold)}
.cinfo small{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#8b97a0;font-weight:700}
.cform{background:var(--card);border-radius:18px;padding:28px;color:var(--ink);box-shadow:var(--shadow-lg)}
.cform h3{font-size:24px}
.cform p.sub{color:var(--muted);font-size:14px;margin-top:6px}
.field{margin-top:16px}
.field label{display:block;font-size:13px;font-weight:800;letter-spacing:.02em;margin-bottom:7px;color:var(--ink-soft)}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:16px;padding:13px 14px;border:1px solid var(--line);
  border-radius:10px;background:#fffdf7;color:var(--ink);transition:border-color .15s ease,box-shadow .15s ease
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,169,40,.22)}
.field textarea{resize:vertical;min-height:86px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform .btn{width:100%;margin-top:20px}
.cform .micro{font-size:12.5px;color:var(--muted);text-align:center;margin-top:12px}
.csocial{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.csocial a{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:#e7ecef;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:8px 13px}
.csocial a:hover{color:var(--gold);border-color:var(--gold)}
.csocial svg{flex:none}

/* ---- booking (Picktime) ---- */
.book{padding-top:8px}
.book-intro{max-width:60ch;margin:0 auto;text-align:center}
.book-lead{color:var(--muted);font-size:18px;margin-top:16px}
.book-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:26px}
.book-actions .btn svg{width:18px;height:18px}
.book-frame{margin:34px auto 0;background:var(--card);border:1px solid var(--line);border-radius:18px;
  overflow:hidden;box-shadow:var(--shadow-lg)}
.book-frame iframe{display:block;width:100%;height:78vh;min-height:680px;border:0;background:#fffdf7}
.book-fallback{text-align:center;color:var(--muted);font-size:14px;margin:18px auto 0;max-width:56ch}
@media (max-width:620px){
  .book-frame iframe{height:84vh;min-height:560px}
  .book-actions .btn{width:100%;justify-content:center}
}

/* ---- footer ---- */
footer.site{background:#0d1b26;color:#aeb9c1;padding:56px 0 30px}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
footer .brand .name b{color:#fff}
footer .fabout{margin-top:16px;font-size:14.5px;max-width:34ch;line-height:1.6}
footer h5{color:#fff;font-family:var(--sans);font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 16px}
footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.f-social{display:flex;flex-wrap:wrap;gap:14px;margin-top:16px}
.f-social a{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:700;color:#cfd8de}
.f-social a:hover{color:var(--gold)}
.f-social svg{flex:none}
footer ul a{color:#aeb9c1;font-size:14.5px}
footer ul a:hover{color:var(--gold)}
.f-bottom{margin-top:44px;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;font-size:13px}
.f-bottom .motto-f{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}

/* ---- reveal animation ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* floating WhatsApp */
.fab{
  position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));z-index:90;
  width:58px;height:58px;border-radius:50%;background:#1f8f4e;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -10px rgba(31,143,78,.8);transition:transform .15s ease
}
.fab:hover{transform:scale(1.06)}
.fab svg{width:30px;height:30px}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1000px){
  .hero-grid,.diff-grid,.contact-grid{grid-template-columns:1fr;gap:38px}
  .courses,.feats,.tcards,.plans{grid-template-columns:1fr 1fr}
  .oada-grid{grid-template-columns:1fr 1fr}
  .oada-step .arrow{display:none}
  .step-row{grid-template-columns:1fr 1fr}
  .f-grid{grid-template-columns:1fr 1fr}
  .plan.pop{transform:none}
}
@media (max-width:760px){
  .nav-links,.nav-cta .btn{display:none}
  .hamburger{display:flex}
  .nav-cta{margin-left:0}
}
@media (max-width:620px){
  body{font-size:16px}
  .wrap{width:calc(100% - 32px)}
  section.s{padding:60px 0}
  .courses,.feats,.tcards,.plans,.oada-grid,.step-row,.f-grid,.frow{grid-template-columns:1fr}
  .hero{padding:40px 0 44px}
  .hero-badge.b1{top:-12px;left:-6px;transform:scale(.88)}
  .hero-badge.b2{bottom:-12px;right:-4px;transform:scale(.88)}
  .hero-trust{gap:18px}
  .f-bottom{flex-direction:column;align-items:flex-start}
}
