/* ============================================================
   FINAXIL ACADEMY — Institutional Design System
   ============================================================ */

:root{
  /* Surfaces */
  --bg:#08090E;
  --surface:#0F1117;
  --break:#141720;
  --parchment:#F2E8D8;
  --parchment-ink:#1A1208;

  /* Accents */
  --teal:#00C896;
  --gold:#C9A84C;
  --violet:#8B7FE8;

  /* Text */
  --t1:#EEEEE8;
  --t2:#7A8394;
  --t3:#4A5260;

  /* Lines */
  --line:#1E2430;

  /* Type */
  --serif:'Cormorant Garamond', Georgia, serif;
  --grotesk:'Hanken Grotesk', system-ui, sans-serif;
  --body:'Lora', Georgia, serif;
  --mono:'IBM Plex Mono', ui-monospace, monospace;

  --maxw:1320px;
  --gutter:clamp(20px,5vw,64px);
  --ease:cubic-bezier(0.16,1,0.3,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{
  margin:0;background:var(--bg);color:var(--t1);
  font-family:var(--body);font-size:18px;line-height:1.8;
  overflow-x:hidden;
}
::selection{background:rgba(0,200,150,.25);color:#fff;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
canvas#atmosphere{position:fixed;inset:0;width:100vw;height:100vh;z-index:-2;pointer-events:none;}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
section{position:relative;}
.section-pad{padding-block:clamp(80px,11vw,150px);}
.bg-break{background:var(--break);}
.bg-surface{background:var(--surface);}

/* ---- Typographic primitives ---- */
.serif{font-family:var(--serif);}
.display{
  font-family:var(--serif);font-weight:500;line-height:1.02;
  letter-spacing:-.012em;color:var(--t1);margin:0;
  font-size:clamp(48px,8.2vw,96px);
}
.display--xl{font-size:clamp(52px,9vw,112px);}
.h-section{
  font-family:var(--serif);font-weight:500;line-height:1.06;
  font-size:clamp(34px,5vw,52px);letter-spacing:-.01em;margin:0;color:var(--t1);
}
.lede{font-family:var(--body);font-size:clamp(18px,1.4vw,20px);line-height:1.8;color:var(--t2);max-width:62ch;}
p{text-wrap:pretty;}

.label{
  font-family:var(--mono);font-size:11px;font-weight:500;text-transform:uppercase;
  letter-spacing:.16em;color:var(--t2);
}
.label--gold{color:var(--gold);}
.label--teal{color:var(--teal);}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;
  color:var(--gold);border:1px solid rgba(201,168,76,.4);
  padding:9px 16px;border-radius:100px;background:rgba(201,168,76,.04);
}

/* The signature gold line that draws in on reveal */
.gold-rule{height:1px;width:60px;background:var(--gold);transform-origin:left;transform:scaleX(0);transition:transform .7s var(--ease);}
.gold-rule.in{transform:scaleX(1);}
.gold-rule--wide{width:100%;}
.gold-rule--center{margin-inline:auto;width:80px;}
.gold-rule--center.in{transform:scaleX(1);}

.text-teal{color:var(--teal);}
.text-gold{color:var(--gold);}
.text-violet{color:var(--violet);}
.text-2{color:var(--t2);}
.text-3{color:var(--t3);}

/* Underline-draw on a single word */
.ul-gold{position:relative;white-space:nowrap;}
.ul-gold::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform 1s var(--ease) .4s;}
.ul-gold.in::after{transform:scaleX(1);}

/* ---- Reveal animation (single institutional motion) ---- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}
[data-stagger]>*{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
[data-stagger].in>*{opacity:1;transform:none;}

@media (prefers-reduced-motion: reduce){
  .reveal,[data-stagger]>*{opacity:1!important;transform:none!important;}
  .gold-rule,.gold-rule--center{transform:scaleX(1)!important;}
  .ul-gold::after{transform:scaleX(1)!important;}
  html{scroll-behavior:auto;}
}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--grotesk);font-weight:600;
  font-size:15px;letter-spacing:.01em;padding:15px 28px;border-radius:2px;cursor:pointer;
  border:1px solid transparent;transition:background .25s ease,color .2s ease,box-shadow .3s ease,border-color .25s ease;}
.btn-teal{background:var(--teal);color:#04130E;}
.btn-teal:hover{background:#13d6a6;box-shadow:inset 0 0 0 1px rgba(201,168,76,.5),0 0 24px rgba(0,200,150,.18);}
.btn-gold{background:transparent;color:var(--gold);border-color:var(--gold);}
.btn-gold:hover{background:var(--gold);color:#0B0A05;}
.btn-text{background:none;padding:14px 4px;color:var(--t1);position:relative;}
.btn-text::after{content:"";position:absolute;left:4px;right:4px;bottom:8px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);}
.btn-text:hover{color:var(--gold);}
.btn-text:hover::after{transform:scaleX(1);}
.btn-lg{font-size:16px;padding:18px 34px;}
.btn .arr{transition:transform .25s var(--ease);}
.btn:hover .arr{transform:translateX(4px);}

/* link with gold hover */
.link-gold{color:var(--teal);font-family:var(--grotesk);font-weight:600;font-size:15px;display:inline-flex;gap:8px;align-items:center;transition:color .2s;}
.link-gold:hover{color:var(--gold);}
.link-gold .arr{transition:transform .25s var(--ease);}
.link-gold:hover .arr{transform:translateX(4px);}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s ease,border-color .3s ease,backdrop-filter .3s ease;border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(15,17,23,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--line);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px;}
.nav-brand{display:flex;align-items:center;gap:13px;}
.nav-brand img{width:34px;height:34px;}
.nav-brand .bn{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--t1);font-weight:500;}
.nav-links{display:flex;gap:26px;align-items:center;}
.nav-links a{font-family:var(--grotesk);font-size:14px;font-weight:500;color:var(--t2);position:relative;padding:6px 0;transition:color .2s;}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .15s var(--ease);}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--t1);}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{transform:scaleX(1);}
.nav-right{display:flex;align-items:center;gap:20px;}
.nav-portal{font-family:var(--grotesk);font-size:14px;font-weight:500;color:var(--t2);transition:color .2s;}
.nav-portal:hover{color:var(--gold);}
.nav-burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px;}
.nav-burger span{width:24px;height:1.5px;background:var(--t1);transition:.3s;}

/* mobile overlay */
.nav-overlay{position:fixed;inset:0;z-index:99;background:rgba(8,9,14,.96);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;padding:0 var(--gutter);
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;}
.nav-overlay.open{opacity:1;visibility:visible;}
.nav-overlay a{font-family:var(--serif);font-size:clamp(30px,7vw,46px);color:var(--t1);padding:10px 0;font-weight:500;transition:color .2s;}
.nav-overlay a:hover{color:var(--gold);}
.nav-overlay .ov-foot{margin-top:48px;display:flex;gap:16px;flex-wrap:wrap;}

@media (max-width:1080px){
  .nav-links{display:none;}
  .nav-portal{display:none;}
  .nav-burger{display:flex;}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:90px;overflow:hidden;}
.hero-ambient{position:absolute;top:18%;left:8%;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,150,.10),transparent 62%);filter:blur(40px);pointer-events:none;z-index:-1;}
.hero-grid{display:grid;grid-template-columns:minmax(0,680px) 1fr;gap:40px;align-items:center;width:100%;}
.hero-content{max-width:680px;}
.hero h1{margin:26px 0 0;}
.hero-art{position:relative;height:78vh;min-height:520px;}
.hero-art canvas{position:absolute;inset:0;width:100%;height:100%;}
.hero-credits{display:flex;flex-direction:column;gap:16px;margin-top:38px;}
.hero-credit{display:flex;gap:14px;align-items:flex-start;font-family:var(--grotesk);font-size:15px;color:var(--t2);line-height:1.5;}
.hero-credit .ic{flex:none;width:22px;height:22px;color:var(--gold);margin-top:1px;}
.hero-ctas{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:34px;}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);width:1px;height:46px;background:linear-gradient(var(--teal),transparent);overflow:hidden;}
.scroll-cue::after{content:"";position:absolute;top:0;left:0;width:100%;height:14px;background:var(--teal);animation:cue 1.8s var(--ease) infinite;}
@keyframes cue{0%{transform:translateY(-14px);opacity:0;}40%{opacity:1;}100%{transform:translateY(46px);opacity:0;}}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-art{display:none;}
}

/* ============================================================
   QUOTE / STATEMENT
   ============================================================ */
.statement{text-align:center;}
.statement-quote{font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(28px,4vw,46px);line-height:1.28;max-width:900px;margin:0 auto;letter-spacing:-.005em;}
.statement-attr{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--t2);text-transform:uppercase;margin-top:22px;}

/* ============================================================
   STATS
   ============================================================ */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:56px;}
.stat{background:var(--bg);padding:40px 34px 34px;}
.stat .num{font-family:var(--serif);font-weight:500;font-size:clamp(56px,6vw,80px);line-height:1;color:var(--teal);letter-spacing:-.02em;font-variant-numeric:tabular-nums;}
.stat.is-gold .num{color:var(--gold);}
.stat .desc{font-family:var(--grotesk);font-size:15px;color:var(--t1);margin-top:16px;line-height:1.5;max-width:30ch;}
.stat .src{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--t3);margin-top:14px;text-transform:uppercase;}
@media (max-width:820px){.stat-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:520px){.stat-grid{grid-template-columns:1fr;}}

/* ============================================================
   PARCHMENT (the FT moment)
   ============================================================ */
.parchment{background:var(--parchment);color:var(--parchment-ink);position:relative;overflow:hidden;}
.parchment .h-section,.parchment .display{color:var(--parchment-ink);}
.parchment .lede{color:rgba(26,18,8,.7);}
.parchment .gold-rule{background:#9C7B1E;}
.parchment-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start;}
.diff{display:flex;flex-direction:column;gap:40px;margin-top:48px;}
.diff-item{display:grid;grid-template-columns:64px 1fr;gap:8px;}
.diff-num{font-family:var(--serif);font-size:40px;font-weight:500;color:#9C7B1E;line-height:1;}
.diff-item h4{font-family:var(--serif);font-size:27px;font-weight:600;margin:0 0 10px;color:var(--parchment-ink);letter-spacing:-.01em;}
.diff-item p{margin:0;font-size:17px;line-height:1.7;color:rgba(26,18,8,.78);}
.parchment-pull{position:relative;padding:40px 0;}
.parchment-pull .seal-wm{position:absolute;top:-30px;right:-20px;width:340px;opacity:.10;filter:grayscale(1) brightness(.4) sepia(1);}
.parchment-pull blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(24px,2.6vw,32px);line-height:1.4;margin:0;color:var(--parchment-ink);position:relative;}
@media (max-width:900px){.parchment-grid{grid-template-columns:1fr;gap:40px;}.parchment-pull .seal-wm{width:200px;}}

/* ============================================================
   CARDS / PROGRAMMES
   ============================================================ */
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px;align-items:stretch;}
.prog-card{background:var(--surface);border:1px solid var(--line);padding:0;display:flex;flex-direction:column;
  transition:border-color .35s ease,background .35s ease;position:relative;overflow:hidden;}
.prog-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--line);}
.prog-card.is-gold::before{background:var(--gold);}
.prog-card.is-teal::before{background:var(--teal);}
.prog-card:hover{border-color:rgba(0,200,150,.4);}
.prog-card.featured{border-color:rgba(201,168,76,.55);background:#10120A;}
.prog-card.featured::before{display:none;}
.prog-card.featured{border:1px solid rgba(201,168,76,.55);}
.prog-card-body{padding:34px 30px 30px;display:flex;flex-direction:column;flex:1;}
.prog-card .seal-wm{position:absolute;top:18px;right:18px;width:60px;opacity:.5;}
.prog-card h3{font-family:var(--serif);font-size:28px;font-weight:600;margin:14px 0 0;line-height:1.12;letter-spacing:-.01em;}
.prog-card .pdesc{font-family:var(--body);font-size:16px;color:var(--t2);margin:16px 0 22px;line-height:1.65;flex:1;}
.prog-meta{border-top:1px solid var(--line);padding-top:16px;margin-top:auto;display:flex;flex-direction:column;gap:8px;}
.prog-meta .row{display:flex;gap:10px;font-family:var(--grotesk);font-size:13.5px;color:var(--t2);}
.prog-meta .row b{color:var(--t1);font-weight:600;min-width:74px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding-top:2px;}
.prog-card .cta{margin-top:22px;}

@media (max-width:900px){.prog-grid{grid-template-columns:1fr;max-width:520px;margin-inline:auto;}}

/* ============================================================
   CERTIFICATE
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:48px;}}
.points{list-style:none;padding:0;margin:32px 0 0;display:flex;flex-direction:column;gap:18px;}
.points li{display:grid;grid-template-columns:24px 1fr;gap:14px;font-family:var(--body);font-size:17px;color:var(--t1);line-height:1.55;}
.points li .tick{color:var(--teal);font-family:var(--mono);font-size:14px;margin-top:3px;}

.certificate{background:linear-gradient(160deg,#0E1016,#0A0B11);border:1px solid var(--line);
  padding:8px;position:relative;box-shadow:0 30px 80px -30px rgba(0,0,0,.8);}
.cert-inner{border:1px solid rgba(201,168,76,.5);padding:38px 36px;position:relative;}
.cert-inner::before{content:"";position:absolute;inset:7px;border:1px solid rgba(201,168,76,.18);pointer-events:none;}
.cert-seal{width:74px;margin:0 auto 18px;}
.cert-top{text-align:center;}
.cert-kicker{font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--gold);text-transform:uppercase;}
.cert-conferred{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--t2);text-transform:uppercase;margin-top:24px;}
.cert-name{font-family:var(--serif);font-size:38px;font-weight:500;margin:8px 0 4px;letter-spacing:-.01em;}
.cert-line{height:1px;background:rgba(201,168,76,.3);width:60%;margin:14px auto;}
.cert-prog{font-family:var(--body);font-style:italic;font-size:17px;color:var(--t2);}
.cert-score{display:flex;align-items:flex-end;justify-content:center;gap:6px;margin:22px 0 6px;}
.cert-score .s{font-family:var(--serif);font-size:64px;font-weight:500;color:var(--teal);line-height:.9;font-variant-numeric:tabular-nums;}
.cert-score .o{font-family:var(--serif);font-size:28px;color:var(--t2);}
.cert-foot{display:flex;justify-content:space-between;margin-top:26px;border-top:1px solid var(--line);padding-top:16px;}
.cert-foot .cf{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--t3);text-transform:uppercase;}
.cert-foot .cf b{display:block;color:var(--t2);margin-top:4px;font-weight:500;}

/* ============================================================
   DASHBOARD TABLE (organisations)
   ============================================================ */
.dash{background:var(--surface);border:1px solid var(--line);overflow:hidden;}
.dash-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line);}
.dash-head .dt{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--t2);}
table.tbl{width:100%;border-collapse:collapse;font-family:var(--grotesk);}
table.tbl th{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);text-align:left;padding:14px 22px;font-weight:500;border-bottom:1px solid var(--line);}
table.tbl td{padding:15px 22px;font-size:14px;color:var(--t1);border-bottom:1px solid var(--line);}
table.tbl tr:last-child td{border-bottom:0;}
table.tbl .sc{font-family:var(--mono);color:var(--teal);font-variant-numeric:tabular-nums;}
table.tbl .badge{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);}
.bar{height:5px;background:var(--line);border-radius:4px;overflow:hidden;width:90px;}
.bar>span{display:block;height:100%;background:var(--teal);}

/* ============================================================
   EDITORIAL CARDS (research)
   ============================================================ */
.edit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;}
.edit-card{border-top:1px solid var(--line);padding-top:24px;transition:border-color .3s;}
.edit-card:hover{border-top-color:rgba(0,200,150,.5);}
.edit-card .cat{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);}
.edit-card h4{font-family:var(--serif);font-size:25px;font-weight:600;line-height:1.16;margin:14px 0 12px;letter-spacing:-.01em;}
.edit-card .ex{font-family:var(--body);font-size:15.5px;color:var(--t2);line-height:1.6;}
.edit-card .meta{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--t3);text-transform:uppercase;margin-top:16px;display:flex;justify-content:space-between;align-items:center;}
@media (max-width:900px){.edit-grid{grid-template-columns:1fr;}}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{min-height:96vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;}
.final .display{max-width:13ch;}
.final-strip{margin-top:auto;padding-top:60px;text-align:center;}
.final-strip img{width:64px;margin:0 auto 18px;}
.final-strip .fs{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--t2);text-transform:uppercase;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--surface);border-top:1px solid var(--line);position:relative;overflow:hidden;padding-block:72px 28px;}
.footer-wm{position:absolute;bottom:-120px;left:50%;transform:translateX(-50%);width:560px;opacity:.035;pointer-events:none;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:48px;position:relative;}
.footer-brand img{width:48px;margin-bottom:18px;}
.footer-brand .fn{font-family:var(--serif);font-size:24px;font-weight:600;}
.footer-brand .tag{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;margin-top:8px;}
.footer-brand p{font-size:15px;color:var(--t2);margin-top:16px;max-width:32ch;line-height:1.6;}
.footer-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--t2);margin:0 0 18px;}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.footer-col a{font-family:var(--grotesk);font-size:14.5px;color:var(--t2);transition:color .2s;}
.footer-col a:hover{color:var(--gold);}
.footer-news{display:flex;border:1px solid var(--line);margin-top:16px;}
.footer-news input{flex:1;background:none;border:0;color:var(--t1);font-family:var(--grotesk);font-size:14px;padding:12px 14px;outline:none;}
.footer-news button{background:none;border:0;border-left:1px solid var(--line);color:var(--gold);padding:0 16px;cursor:pointer;font-family:var(--mono);font-size:16px;}
.footer-bar{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);margin-top:56px;padding-top:24px;position:relative;}
.footer-bar .fb{font-family:var(--grotesk);font-size:13px;color:var(--t3);display:flex;gap:18px;flex-wrap:wrap;}
.footer-bar .fb a:hover{color:var(--gold);}
.footer-bar img{width:30px;opacity:.8;}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px;}.footer-bar{flex-direction:column;gap:18px;text-align:center;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}

/* ============================================================
   TERMINAL (curriculum)
   ============================================================ */
.terminal{background:#0A0B11;border:1px solid var(--line);font-family:var(--mono);font-size:14px;line-height:1.9;overflow:hidden;}
.terminal-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line);}
.terminal-bar .dot{width:9px;height:9px;border-radius:50%;background:var(--line);}
.terminal-bar .tt{margin-left:10px;font-size:11px;letter-spacing:.1em;color:var(--t3);text-transform:uppercase;}
.terminal-body{padding:22px 24px;min-height:280px;}
.term-line{white-space:pre-wrap;}
.term-prompt{color:var(--teal);}
.term-user{color:var(--t1);}
.term-resp{color:var(--t2);}
.term-cursor{display:inline-block;width:8px;height:16px;background:var(--teal);vertical-align:-2px;animation:blink 1s steps(2) infinite;margin-left:2px;}
@keyframes blink{50%{opacity:0;}}

/* ============================================================
   TABS / ACCORDION (programmes)
   ============================================================ */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-top:40px;flex-wrap:wrap;}
.tab{font-family:var(--grotesk);font-size:16px;font-weight:600;color:var(--t2);background:none;border:0;border-bottom:2px solid transparent;
  padding:16px 28px 16px 0;margin-right:36px;cursor:pointer;transition:color .2s;position:relative;}
.tab .tn{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:.1em;margin-right:10px;}
.tab[aria-selected="true"]{color:var(--t1);}
.tab[aria-selected="true"]::after{content:"";position:absolute;left:0;bottom:-1px;width:calc(100% - 36px);height:2px;background:var(--gold);}
.panel{display:none;padding-top:48px;}
.panel.active{display:block;animation:fadeup .6s var(--ease);}
@keyframes fadeup{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}

.outcomes{list-style:none;counter-reset:o;padding:0;margin:24px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:18px 40px;}
.outcomes li{counter-increment:o;display:grid;grid-template-columns:34px 1fr;gap:6px;font-family:var(--body);font-size:16px;color:var(--t1);line-height:1.55;}
.outcomes li::before{content:counter(o,decimal-leading-zero);font-family:var(--mono);font-size:13px;color:var(--teal);padding-top:3px;}
@media (max-width:760px){.outcomes{grid-template-columns:1fr;}}

.accordion{margin-top:24px;border-top:1px solid var(--line);}
.acc-item{border-bottom:1px solid var(--line);}
.acc-head{width:100%;background:none;border:0;cursor:pointer;text-align:left;padding:22px 8px 22px 0;
  display:flex;justify-content:space-between;align-items:center;gap:20px;color:var(--t1);}
.acc-head .at{font-family:var(--serif);font-size:22px;font-weight:600;letter-spacing:-.01em;}
.acc-head .ai{font-family:var(--mono);font-size:11px;color:var(--t3);letter-spacing:.06em;}
.acc-head .plus{font-family:var(--mono);font-size:22px;color:var(--gold);transition:transform .3s var(--ease);flex:none;}
.acc-item.open .plus{transform:rotate(45deg);}
.acc-body{max-height:0;overflow:hidden;transition:max-height .45s var(--ease);}
.acc-body-inner{padding:0 8px 26px 0;color:var(--t2);}
.acc-body-inner p{margin:0 0 14px;font-size:16px;line-height:1.7;}
.acc-skills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.acc-skills .chip{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--teal);border:1px solid rgba(0,200,150,.3);padding:5px 11px;border-radius:100px;}
.acc-time{font-family:var(--mono);font-size:11px;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;margin-top:14px;}

/* FAQ */
.faq .acc-head .at{font-size:19px;font-family:var(--grotesk);font-weight:600;}

/* ============================================================
   FORM
   ============================================================ */
.form{display:flex;flex-direction:column;gap:20px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--t2);}
.field input,.field select,.field textarea{background:var(--bg);border:1px solid var(--line);color:var(--t1);
  font-family:var(--grotesk);font-size:15px;padding:13px 15px;border-radius:2px;outline:none;transition:border-color .2s;width:100%;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:rgba(0,200,150,.6);}
.field textarea{resize:vertical;min-height:120px;font-family:var(--body);}
.field.err input,.field.err select,.field.err textarea{border-color:#C0564A;}
.field .msg{font-family:var(--grotesk);font-size:12px;color:#D27A6E;display:none;}
.field.err .msg{display:block;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media (max-width:640px){.form-row{grid-template-columns:1fr;}}
.form-success{background:rgba(0,200,150,.08);border:1px solid rgba(0,200,150,.4);padding:18px 22px;font-family:var(--grotesk);font-size:15px;color:var(--t1);display:none;}
.form-success.show{display:block;}

/* ============================================================
   GENERIC HELPERS
   ============================================================ */
.col-narrow{max-width:780px;}
.mt-s{margin-top:18px;}.mt-m{margin-top:32px;}.mt-l{margin-top:48px;}
.center{text-align:center;}
.prose p{color:var(--t2);font-size:18px;line-height:1.85;margin:0 0 22px;max-width:64ch;}
.prose p.drop:first-letter{font-family:var(--serif);font-size:64px;float:left;line-height:.8;padding:6px 12px 0 0;color:var(--gold);}
.kicker-row{display:flex;flex-direction:column;gap:18px;}

/* timeline */
.timeline{position:relative;margin-top:56px;padding-left:0;}
.tl-track{position:absolute;left:11px;top:6px;bottom:6px;width:1px;background:var(--line);}
.tl-track .fill{position:absolute;top:0;left:0;width:100%;background:var(--teal);height:0;transition:height 1.4s var(--ease);}
.tl-item{position:relative;padding-left:48px;padding-bottom:40px;}
.tl-item:last-child{padding-bottom:0;}
.tl-dot{position:absolute;left:5px;top:6px;width:13px;height:13px;border-radius:50%;border:1px solid var(--line);background:var(--bg);transition:.5s;z-index:2;}
.tl-item.hot .tl-dot{border-color:var(--gold);background:var(--gold);box-shadow:0 0 0 5px rgba(201,168,76,.12);}
.tl-year{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--teal);line-height:1;}
.tl-item.hot .tl-year{color:var(--gold);}
.tl-item h4{font-family:var(--grotesk);font-size:17px;font-weight:600;margin:8px 0 6px;}
.tl-item p{margin:0;font-size:15.5px;color:var(--t2);line-height:1.6;max-width:52ch;}

/* team */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;}
@media (max-width:760px){.team-grid{grid-template-columns:1fr;}}
.team-card{background:var(--surface);border:1px solid var(--line);padding:34px;display:flex;gap:24px;transition:border-color .3s;}
.team-card:hover{border-color:rgba(201,168,76,.4);}
.team-mark{flex:none;width:84px;height:84px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:36px;font-weight:600;color:var(--gold);background:var(--bg);}
.team-card h4{font-family:var(--serif);font-size:25px;font-weight:600;margin:0;letter-spacing:-.01em;}
.team-card .role{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin:6px 0 14px;}
.team-card p{margin:0;font-size:15px;color:var(--t2);line-height:1.65;}

/* generic placeholder image */
.ph{background:
  repeating-linear-gradient(135deg,rgba(122,131,148,.06) 0 2px,transparent 2px 9px),
  var(--surface);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);text-align:center;padding:20px;}

/* page hero (interior) */
.page-hero{padding-top:160px;padding-bottom:60px;position:relative;}
.page-hero .display{max-width:16ch;}

/* three-col argument */
.argue{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:48px;}
.argue .col h4{font-family:var(--serif);font-size:26px;font-weight:600;line-height:1.18;margin:0 0 14px;letter-spacing:-.01em;}
.argue .col p{margin:0;color:var(--t2);font-size:16px;line-height:1.7;}
.argue .col .n{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:.1em;margin-bottom:16px;display:block;}
@media (max-width:820px){.argue{grid-template-columns:1fr;gap:32px;}}

/* tier cards */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;align-items:stretch;}
.tier{background:var(--surface);border:1px solid var(--line);padding:32px 30px;display:flex;flex-direction:column;transition:border-color .3s;}
.tier:hover{border-color:rgba(0,200,150,.4);}
.tier.feat{border-color:rgba(201,168,76,.5);}
.tier .tk{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);}
.tier h4{font-family:var(--serif);font-size:28px;font-weight:600;margin:10px 0 14px;letter-spacing:-.01em;}
.tier p{font-size:15px;color:var(--t2);line-height:1.6;margin:0 0 20px;}
.tier ul{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:10px;flex:1;}
.tier ul li{font-family:var(--grotesk);font-size:14px;color:var(--t1);display:grid;grid-template-columns:18px 1fr;gap:10px;}
.tier ul li .tick{color:var(--teal);}
@media (max-width:820px){.tiers{grid-template-columns:1fr;max-width:480px;margin-inline:auto;}}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:48px;}
.step{border-top:1px solid var(--line);padding-top:20px;position:relative;}
.step .sn{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:.1em;}
.step h5{font-family:var(--serif);font-size:21px;font-weight:600;margin:12px 0 8px;}
.step p{font-size:14px;color:var(--t2);line-height:1.55;margin:0;}
@media (max-width:900px){.steps{grid-template-columns:1fr 1fr;}}
@media (max-width:520px){.steps{grid-template-columns:1fr;}}

/* method flow */
.flow{display:flex;align-items:stretch;gap:0;margin-top:48px;flex-wrap:wrap;}
.flow-node{flex:1;min-width:160px;background:var(--surface);border:1px solid var(--line);padding:26px 22px;position:relative;}
.flow-node h5{font-family:var(--serif);font-size:22px;font-weight:600;margin:0 0 8px;}
.flow-node p{font-size:14px;color:var(--t2);line-height:1.55;margin:0;}
.flow-arrow{display:flex;align-items:center;color:var(--gold);font-family:var(--mono);font-size:18px;padding:0 4px;}
@media (max-width:760px){.flow{flex-direction:column;}.flow-arrow{transform:rotate(90deg);justify-content:center;padding:6px 0;}}

/* pathway */
.pathway{display:flex;align-items:center;gap:0;margin-top:48px;flex-wrap:wrap;}
.path-node{flex:1;min-width:200px;border:1px solid var(--line);background:var(--surface);padding:28px 26px;text-align:center;}
.path-node.gold{border-color:rgba(201,168,76,.5);}
.path-node .pl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);}
.path-node.gold .pl{color:var(--gold);}
.path-node h5{font-family:var(--serif);font-size:24px;font-weight:600;margin:10px 0 6px;}
.path-node p{font-size:14px;color:var(--t2);margin:0;line-height:1.5;}
.path-arrow{color:var(--gold);font-family:var(--mono);font-size:20px;padding:0 14px;}
@media (max-width:760px){.pathway{flex-direction:column;}.path-arrow{transform:rotate(90deg);padding:8px 0;}}

/* skip link */
.skip{position:absolute;left:-999px;top:8px;z-index:200;background:var(--gold);color:#0B0A05;padding:10px 16px;font-family:var(--grotesk);font-weight:600;border-radius:2px;}
.skip:focus{left:16px;}
