/* ============================================================
   Axxell — Design system (impeccable-aligned)
   Fonts: Bricolage Grotesque (display) + Hanken Grotesk (text)
   Color: OKLCH, deep-teal commit + warm clay accent, tinted neutrals
   ============================================================ */

:root{
  /* neutrals, tinted toward the brand hue (cool, not cream) */
  --bg:        oklch(98.6% 0.006 215);
  --surface:   oklch(96.4% 0.011 215);
  --surface-2: oklch(93.6% 0.016 216);
  --ink:       oklch(24% 0.032 236);
  --ink-soft:  oklch(37% 0.03 234);
  --muted:     oklch(47% 0.026 232);
  --line:      oklch(89.5% 0.014 222);
  --line-2:    oklch(83% 0.02 222);

  /* brand: deep teal (committed), warm clay accent (delight) */
  --brand:     oklch(53% 0.115 196);
  --brand-700: oklch(44% 0.10 199);
  --brand-900: oklch(30% 0.072 205);
  --accent:    oklch(69% 0.158 47);
  --accent-700:oklch(56% 0.15 44);

  /* foreground on a brand fill (flips per theme); faint brand tint */
  --on-brand:  oklch(98.5% 0.01 200);
  --brand-wash:color-mix(in oklch, var(--brand) 9%, transparent);

  /* drenched dark section */
  --ink-bg:    oklch(26.5% 0.05 224);
  --ink-bg-2:  oklch(31% 0.055 220);
  --on-ink:    oklch(96% 0.012 210);
  --on-ink-soft: oklch(82% 0.035 205);

  /* type */
  --font-display:"Bricolage Grotesque","Hanken Grotesk",ui-sans-serif,sans-serif;
  --font:"Hanken Grotesk",ui-sans-serif,system-ui,sans-serif;
  --mono:ui-monospace,SFMono-Regular,Menlo,"Cascadia Mono",monospace;

  /* rhythm */
  --maxw:1180px;
  --gut:clamp(20px,4.2vw,44px);
  --section:clamp(72px,9.5vw,128px);
  --r:14px; --r-lg:22px; --r-pill:999px;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --ease-soft:cubic-bezier(0.33,1,0.68,1);

  /* z-index scale (semantic) */
  --z-base:1; --z-sticky:100; --z-menu:300; --z-overlay:500;

  --shadow-1:0 1px 2px oklch(24% 0.03 236 / .05), 0 10px 24px -16px oklch(24% 0.03 236 / .25);
  --shadow-2:0 2px 6px oklch(24% 0.03 236 / .06), 0 28px 50px -28px oklch(24% 0.03 236 / .30);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);background:var(--bg);color:var(--ink-soft);
  font-size:clamp(1rem,0.97rem + 0.2vw,1.0625rem);line-height:1.62;
  font-feature-settings:"ss01","cv01";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
::selection{background:var(--brand);color:oklch(98% 0.01 210)}
img,svg{display:block;max-width:100%}
a{color:var(--brand-700);text-decoration-thickness:1px;text-underline-offset:2px}
:where(a,button,summary,select,input,[tabindex]):focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:4px}
.qa summary:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.skip-link{position:absolute;left:12px;top:-56px;z-index:var(--z-overlay);background:var(--brand);color:var(--on-brand);
  padding:.7em 1.1em;border-radius:var(--r);font-weight:600;text-decoration:none;transition:top .2s var(--ease)}
.skip-link:focus{top:12px}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);font-weight:700;line-height:1.06;margin:0;text-wrap:balance;font-optical-sizing:auto}
h1{font-size:clamp(2.7rem,1.85rem + 3.7vw,4.7rem);letter-spacing:-0.03em}
h2{font-size:clamp(1.95rem,1.5rem + 1.9vw,2.85rem);letter-spacing:-0.02em}
h3{font-size:clamp(1.18rem,1.08rem + 0.5vw,1.42rem);letter-spacing:-0.012em}
p{margin:0}
p.prose{max-width:66ch;text-wrap:pretty}

/* layout */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:var(--section)}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-size:.78rem;font-weight:600;
  letter-spacing:.10em;text-transform:uppercase;color:var(--brand-700)}
.eyebrow::before{content:"";width:1.6em;height:1px;background:var(--brand);opacity:.6}
.lead{font-size:clamp(1.08rem,1rem + 0.5vw,1.28rem);color:var(--ink-soft);max-width:60ch;text-wrap:pretty}
.kicker{color:var(--accent-700);font-weight:600}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font);font-weight:600;
  font-size:.98rem;line-height:1;padding:.85em 1.25em;border-radius:var(--r);border:1px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),background .2s var(--ease),border-color .2s,color .2s;text-decoration:none}
.btn:focus-visible{outline:2px solid var(--brand);outline-offset:3px}
.btn-primary{background:var(--brand);color:var(--on-brand)}
.btn-primary:hover{background:var(--brand-700);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-outline:hover{border-color:var(--brand);color:var(--brand-700);transform:translateY(-2px)}
.btn-on-ink{background:var(--on-ink);color:var(--ink)}
.btn-on-ink:hover{background:oklch(100% 0 0);transform:translateY(-2px)}
.btn-ghost-ink{background:transparent;color:var(--on-ink);border-color:oklch(80% 0.03 210 / .35)}
.btn-ghost-ink:hover{border-color:var(--on-ink)}
.link-arrow{display:inline-flex;align-items:center;gap:.4em;font-weight:600;color:var(--brand-700);text-decoration:none}
.link-arrow svg{transition:transform .3s var(--ease)}
.link-arrow:hover svg{transform:translateX(4px)}

/* tags / chips */
.tag{display:inline-flex;align-items:center;gap:.45em;font-size:.82rem;font-weight:600;color:var(--ink);
  background:var(--surface);border:1px solid var(--line);padding:.42em .78em;border-radius:var(--r-pill)}
.tag .dot{width:.5em;height:.5em;border-radius:50%;background:var(--brand)}
.tag.accent .dot{background:var(--accent)}

/* header */
.site-header{position:sticky;top:0;z-index:var(--z-sticky);
  background:oklch(98.6% 0.006 215 / .8);backdrop-filter:blur(12px) saturate(1.4);
  border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;height:70px;gap:1.5rem}
.brand{display:inline-flex;align-items:baseline;gap:.12em;font-family:var(--font-display);font-weight:800;
  font-size:1.42rem;letter-spacing:-0.03em;color:var(--ink);text-decoration:none}
.brand .tld{color:var(--brand)}
.nav{display:flex;align-items:center;gap:1.9rem}
.nav a{color:var(--ink-soft);text-decoration:none;font-weight:500;font-size:.96rem;transition:color .2s}
.nav a:hover{color:var(--brand-700)}
.header-actions{display:flex;align-items:center;gap:1rem}
.lang{display:inline-flex;border:1px solid var(--line-2);border-radius:var(--r-pill);overflow:hidden;font-size:.8rem;font-weight:700}
.lang button{border:0;background:transparent;color:var(--muted);padding:.5em .85em;cursor:pointer;transition:.2s;min-height:40px;display:inline-flex;align-items:center;justify-content:center}
.lang button[aria-pressed="true"]{background:var(--ink);color:var(--on-ink)}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:.4em;color:var(--ink)}

/* hero */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(60% 50% at 88% 0%, oklch(53% 0.115 196 / .10), transparent 70%),
    radial-gradient(40% 40% at 0% 100%, oklch(69% 0.158 47 / .07), transparent 70%)}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,5vw,64px);
  align-items:center;padding-block:clamp(56px,8vw,104px)}
.hero h1{margin:.5rem 0 0}
.hero .lead{margin-top:1.4rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.hero-proof{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
.hero h1 .mark{position:relative;color:var(--brand);white-space:nowrap}
.hero h1 .mark::after{content:"";position:absolute;left:0;right:0;bottom:.07em;height:.10em;
  background:var(--accent);opacity:.5;border-radius:2px}

/* hero side: a precise "specimen" instead of a glowing code card */
.specimen{border:1px solid var(--line-2);border-radius:var(--r-lg);background:var(--surface);overflow:hidden}
.specimen-top{display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1.1rem;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:.74rem;
  letter-spacing:.04em;color:var(--muted);text-transform:uppercase}
.specimen-body{padding:1.4rem 1.4rem 1.5rem}
.specimen-row{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  padding:.7rem 0;border-bottom:1px dashed var(--line)}
.specimen-row:last-child{border-bottom:0;padding-bottom:0}
.specimen-row .k{font-family:var(--mono);font-size:.78rem;color:var(--muted)}
.specimen-row .v{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.05rem;font-variant-numeric:tabular-nums}
.specimen-row .v small{font-family:var(--font);font-weight:500;color:var(--muted);font-size:.78rem}
.specimen-foot{margin-top:1.1rem;display:flex;align-items:center;gap:.5rem;font-size:.84rem;color:var(--brand-700);font-weight:600}

/* marquee trust strip */
.strip{background:var(--ink-bg);color:var(--on-ink-soft)}
.strip .wrap{display:flex;flex-wrap:wrap;gap:1.2rem 2.4rem;align-items:center;justify-content:center;
  padding-block:1.05rem;font-size:.92rem;font-weight:500;text-align:center}
.strip b{color:var(--on-ink);font-weight:600}
.strip .v-sep{width:1px;height:1.1em;background:oklch(80% 0.03 210 / .3)}

/* section head */
.s-head{max-width:54ch}
.s-head h2{margin:.7rem 0 0}
.s-head .lead{margin-top:1rem}
.s-head.center{margin-inline:auto;text-align:center}
.s-head.center .eyebrow{justify-content:center}
.s-head.center .lead{margin-inline:auto}

/* personas as an editorial index (no icon-tile cards) */
.index-list{margin-top:3rem;border-top:1px solid var(--line)}
.row{display:grid;grid-template-columns:1fr auto;gap:clamp(1rem,3vw,2.4rem);align-items:center;
  padding:clamp(1.3rem,2.5vw,1.9rem) 0;border-bottom:1px solid var(--line);
  text-decoration:none;color:inherit;transition:background .25s var(--ease)}
.row:hover{background:linear-gradient(90deg,var(--surface),transparent 80%)}
.row .num{font-family:var(--mono);font-size:.92rem;color:var(--muted);min-width:2.4ch}
.row .row-main{display:flex;flex-direction:column;gap:.25rem}
.row .row-title{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.row .row-title h3{color:var(--ink)}
.row:hover .row-title h3{color:var(--brand-700)}
.row .row-desc{color:var(--muted);max-width:62ch;font-size:.98rem}
.row .row-go{color:var(--brand);opacity:0;transform:translateX(-6px);transition:.3s var(--ease)}
.row:hover .row-go{opacity:1;transform:none}
.row.signature{background:
   linear-gradient(100deg, oklch(30% 0.072 205), oklch(38% 0.085 200));
   color:var(--on-ink);border-radius:var(--r-lg);border-bottom:0;margin:.4rem 0;
   padding-inline:clamp(1.1rem,3vw,2rem)}
.row.signature .num{color:var(--on-ink-soft)}
.row.signature .row-title h3,.row.signature:hover .row-title h3{color:var(--on-ink)}
.row.signature .row-desc{color:var(--on-ink-soft)}
.row.signature .row-go{color:var(--accent);opacity:1;transform:none}
.badge-flag{font-family:var(--font);font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);background:var(--accent);padding:.3em .6em;border-radius:6px}

/* dev track */
.track{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);margin-top:3rem;align-items:start}
#dev{padding-block:calc(var(--section) * 1.14)}
#dev .s-head{max-width:64ch}
.ladder{display:flex;flex-direction:column}
.step{display:block;padding:1.05rem 0 1.05rem 1.1rem;border-top:1px solid var(--line);position:relative}
.step:first-child{border-top:0}
.step::before{content:"";position:absolute;left:0;top:1.2rem;width:3px;height:1.1rem;background:var(--brand);border-radius:2px}
.step:nth-child(2)::before{background:var(--brand-700)}
.step:nth-child(3)::before{background:var(--brand)}
.step:nth-child(4)::before{background:var(--accent)}
.step .lvl{display:none}
.step .step-t{font-family:var(--font-display);font-weight:700;font-size:1.04rem;color:var(--ink);margin:0 0 .15rem}
.step p{color:var(--muted);font-size:.95rem}
.modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,230px),1fr));gap:.2rem 2rem}
.module{padding:1rem 0;border-top:1px solid var(--line)}
.module .m-h{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1rem}
.module .m-h .star{color:var(--accent);font-size:.8rem}
.module p{color:var(--muted);font-size:.92rem;margin-top:.2rem}

/* method / why - asymmetric */
.method{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:start;margin-top:2.5rem}
.method-list{display:flex;flex-direction:column;gap:1.4rem}
.method-item{display:block;padding-left:1.1rem;border-left:1px solid var(--line-2)}
.method-item .n{display:none}
.method-item .mi-t{font-family:var(--font-display);font-weight:700;font-size:1.08rem;color:var(--ink);margin:0 0 .2rem}
.method-item p{color:var(--muted);font-size:.96rem}

/* financing — clean columns, inline marks (no icon tiles) */
.fin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:1.6rem 2rem;margin-top:2.6rem}
.fin-item{padding-top:1.1rem;border-top:2px solid var(--brand)}
.fin-item:nth-child(2){border-top-color:var(--accent)}
.fin-item:nth-child(3){border-top-color:var(--brand-700)}
.fin-item:nth-child(4){border-top-color:var(--ink-soft)}
.fin-item h3{font-size:1.1rem;color:var(--ink)}
.fin-item p{color:var(--muted);font-size:.95rem;margin-top:.4rem}
.fin-note{margin-top:2.2rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.1rem,2.5vw,1.6rem);display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start}
.fin-note .ico{color:var(--accent-700);padding-top:.1rem}
.fin-note p{color:var(--ink-soft);font-size:.96rem;max-width:80ch}
.fin-note b{color:var(--ink)}

/* pricing — featured plan breaks the uniformity */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,230px),1fr));gap:1.2rem;margin-top:2.8rem;align-items:stretch}
.plan{display:flex;flex-direction:column;padding:1.6rem;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--bg)}
.plan .p-name{font-weight:600;color:var(--brand-700);font-size:.92rem}
.plan .p-price{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.7rem;margin:.5rem 0 0;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.plan .p-price small{font-family:var(--font);font-weight:500;color:var(--muted);font-size:.82rem;letter-spacing:0}
.plan ul{list-style:none;margin:1.1rem 0 1.5rem;padding:0;display:flex;flex-direction:column;gap:.6rem}
.plan li{display:flex;gap:.6rem;align-items:flex-start;font-size:.93rem;color:var(--ink-soft)}
.plan li svg{color:var(--brand);flex:none;margin-top:.18rem}
.plan .btn{margin-top:auto;justify-content:center}
.plan.featured{background:var(--ink-bg);border-color:transparent;color:var(--on-ink);box-shadow:var(--shadow-2)}
.plan.featured .p-name{color:var(--accent)}
.plan.featured .p-price{color:var(--on-ink)}
.plan.featured .p-price small{color:var(--on-ink-soft)}
.plan.featured li{color:var(--on-ink-soft)}
.plan.featured li svg{color:var(--accent)}
.plan .flag{align-self:flex-start;font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--ink);background:var(--accent);padding:.3em .6em;border-radius:6px;margin-bottom:.8rem}

/* FAQ — native details (no JS height animation) */
.faq{max-width:780px;margin:2.6rem auto 0}
.qa{border-top:1px solid var(--line)}
.qa:last-child{border-bottom:1px solid var(--line)}
.qa summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.35rem .2rem;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.06rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary .pm{flex:none;width:1.4rem;height:1.4rem;position:relative;transition:transform .35s var(--ease)}
.qa summary .pm::before,.qa summary .pm::after{content:"";position:absolute;background:var(--brand);border-radius:2px}
.qa summary .pm::before{top:50%;left:0;right:0;height:2px;transform:translateY(-50%)}
.qa summary .pm::after{left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%);transition:opacity .3s}
.qa[open] summary .pm{transform:rotate(180deg)}
.qa[open] summary .pm::after{opacity:0}
.qa .a{padding:0 .2rem 1.4rem;color:var(--muted);max-width:72ch}

/* dark CTA (drenched, no glow) */
.cta{background:var(--ink-bg);color:var(--on-ink)}
.cta .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.cta h2{color:var(--on-ink)}
.cta .lead{color:var(--on-ink-soft)}
.form{display:flex;flex-direction:column;gap:.9rem;background:var(--ink-bg-2);
  border:1px solid oklch(80% 0.03 210 / .16);border-radius:var(--r-lg);padding:clamp(1.3rem,3vw,1.9rem)}
.form label{font-size:.82rem;color:var(--on-ink-soft);font-weight:600;margin-bottom:-.4rem}
.form input,.form select{width:100%;padding:.85em 1em;border-radius:var(--r);border:1px solid oklch(80% 0.03 210 / .22);
  background:oklch(99% 0.005 210);color:var(--ink);font:inherit;font-size:.98rem}
.form input:focus-visible,.form select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}
.form .btn{margin-top:.3rem}
.form .fine{font-size:.78rem;color:var(--on-ink-soft);text-align:center;margin-top:.2rem}

/* footer */
.site-footer{background:var(--brand-900);color:var(--on-ink-soft);padding-block:clamp(48px,7vw,76px) 28px}
.f-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem clamp(1.5rem,3vw,2.5rem)}
.site-footer .brand{color:var(--on-ink)}
.site-footer .brand .tld{color:var(--accent)}
.f-about{color:var(--on-ink-soft);max-width:34ch;margin-top:.8rem;font-size:.95rem}
.f-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.1rem}
.f-badges span{font-size:.74rem;border:1px solid oklch(80% 0.03 210 / .22);border-radius:8px;padding:.35em .7em;color:var(--on-ink)}
.site-footer h3{font-family:var(--font);font-weight:600;color:var(--on-ink);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 1rem}
.site-footer nav{display:flex;flex-direction:column;gap:.65rem}
.site-footer nav a{color:var(--on-ink-soft);text-decoration:none;font-size:.95rem;transition:color .2s}
.site-footer nav a:hover{color:var(--on-ink)}
.f-bottom{border-top:1px solid oklch(80% 0.03 210 / .16);margin-top:2.6rem;padding-top:1.4rem;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;font-size:.85rem;color:var(--on-ink-soft)}

/* legal page */
.legal{max-width:760px;margin-inline:auto;padding-block:clamp(48px,7vw,88px)}
.legal h1{margin-bottom:.4rem}
.legal .updated{color:var(--muted);font-size:.9rem;margin-bottom:2.4rem}
.legal h2{font-size:1.5rem;margin:2.4rem 0 .7rem}
.legal h3{margin:1.4rem 0 .4rem}
.legal p,.legal li{color:var(--ink-soft);max-width:72ch}
.legal ul{padding-left:1.1rem;display:flex;flex-direction:column;gap:.4rem;margin:.6rem 0}
.legal .ph{background:var(--surface-2);border-radius:5px;padding:.05em .4em;font-family:var(--mono);font-size:.85em;color:var(--brand-700)}
.legal .back{display:inline-flex;align-items:center;gap:.4em;margin-top:3rem;font-weight:600;text-decoration:none;color:var(--brand-700)}

/* utilities */
.center{text-align:center}
.mt-s{margin-top:1rem}.mt-m{margin-top:2rem}
.hide{display:none !important}

/* intentional, load-only entrance (content visible at rest) */
@media (prefers-reduced-motion: no-preference){
  .enter{animation:enter .8s var(--ease) both}
  .enter-2{animation:enter .8s var(--ease) .08s both}
  .enter-3{animation:enter .8s var(--ease) .16s both}
  @keyframes enter{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
}

/* responsive */
@media (max-width:920px){
  .hero-inner{grid-template-columns:1fr;gap:2.4rem}
  .specimen{order:-1;max-width:440px}
  .track,.method,.cta .grid{grid-template-columns:1fr;gap:2.2rem}
  .f-grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .nav.open{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:flex-start;
    gap:1.1rem;background:var(--bg);border-bottom:1px solid var(--line);padding:1.3rem var(--gut);box-shadow:var(--shadow-1)}
  .menu-btn{display:inline-flex}
}
@media (max-width:560px){
  .row{grid-template-columns:1fr}
  .row .row-go{display:none}
  .f-grid{grid-template-columns:1fr}
  .strip .v-sep{display:none}
  .bar{gap:.5rem}
  .header-actions{gap:.45rem}
  .header-actions>.btn-primary{display:none}
}

/* ============================================================
   MOTION LAYER — impeccable-safe (ease-out-expo, transform/opacity,
   content visible at rest, full reduced-motion fallback)
   ============================================================ */

/* hero ambiance: a slow animated aurora behind the content (light bg) */
.hero::after{content:"";position:absolute;inset:-25% -12% 30% -12%;z-index:0;pointer-events:none;
  background:
    radial-gradient(36% 48% at 22% 32%, oklch(53% 0.115 196 / .18), transparent 70%),
    radial-gradient(32% 44% at 82% 18%, oklch(69% 0.158 47 / .14), transparent 72%),
    radial-gradient(30% 40% at 64% 86%, oklch(53% 0.115 196 / .12), transparent 70%);
  filter:blur(10px);animation:aurora 20s var(--ease-soft) infinite alternate}
@keyframes aurora{
  0%{transform:translate3d(-2%,0,0) scale(1)}
  50%{transform:translate3d(4%,-2%,0) scale(1.07) rotate(1.5deg)}
  100%{transform:translate3d(-1%,1.5%,0) scale(1.03)}
}

/* hero headline underline draws itself in */
.hero h1 .mark::after{transform:scaleX(0);transform-origin:left center;animation:draw .9s var(--ease) .65s forwards}
@keyframes draw{to{transform:scaleX(1)}}

/* specimen gently floats + tilts on hover */
.specimen{animation:float 8s var(--ease-soft) 1.2s infinite alternate;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.specimen:hover{transform:translateY(-6px) rotate(-.4deg);box-shadow:var(--shadow-2)}
@keyframes float{from{transform:translateY(0)}to{transform:translateY(-8px)}}

/* keyword marquee (built by motion.js, inserted after the strip) */
.marquee{background:var(--bg);border-bottom:1px solid var(--line);overflow:hidden;padding:.78rem 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee-track{display:inline-flex;align-items:center;gap:1.5rem;white-space:nowrap;will-change:transform;animation:marq 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--font-display);font-weight:600;font-size:.98rem;letter-spacing:-0.01em;color:var(--ink)}
.marquee-track .sep{color:var(--brand);font-weight:700}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* scroll reveals — applied by motion.js to BELOW-fold elements only,
   so above-fold content and no-JS/headless renders are never hidden */
.reveal{opacity:0;transform:translateY(26px)}
.reveal.in{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .85s var(--ease)}
.reveal-x{opacity:0;transform:translateX(-28px)}
.reveal-x.in{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .75s var(--ease)}

/* primary CTA: a periodic light sweep to draw the eye */
.btn-primary{position:relative;overflow:hidden;isolation:isolate}
.btn-primary::after{content:"";position:absolute;inset:0 auto 0 0;width:45%;z-index:-1;
  background:linear-gradient(100deg,transparent,oklch(100% 0 0 / .34),transparent);
  transform:translateX(-260%) skewX(-18deg)}
.btn-primary:hover::after{animation:sweep 1.1s var(--ease)}
@keyframes sweep{0%{transform:translateX(-260%) skewX(-18deg)}100%{transform:translateX(440%) skewX(-18deg)}}

/* lively hover lifts */
.plan{transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow-2)}
.plan.featured:hover{transform:translateY(-6px) scale(1.012)}
.fin-item{transition:transform .3s var(--ease)}
.fin-item:hover{transform:translateY(-4px)}
.module{transition:transform .25s var(--ease),border-color .25s}
.module:hover{transform:translateX(4px)}
.tag{transition:transform .25s var(--ease),border-color .25s}
.tag:hover{transform:translateY(-2px);border-color:var(--brand)}

/* header condenses on scroll (shadow only, no layout shift) */
.site-header{transition:box-shadow .3s var(--ease),background .3s}
.site-header.scrolled{box-shadow:0 8px 30px -20px oklch(24% 0.03 236 / .5)}

/* dark CTA: slow living sheen in the background */
.cta{position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(50% 70% at 85% 10%, oklch(53% 0.115 196 / .35), transparent 70%);
  animation:ctaglow 14s var(--ease-soft) infinite alternate}
.cta .wrap{position:relative;z-index:1}
@keyframes ctaglow{from{transform:translate3d(0,0,0) scale(1);opacity:.8}to{transform:translate3d(-6%,4%,0) scale(1.15);opacity:1}}

@media (prefers-reduced-motion: reduce){
  .hero::after,.cta::before,.marquee-track,.btn-primary::after,.specimen,.specimen-foot svg,.hero h1 .mark::after{animation:none}
  .hero h1 .mark::after{transform:scaleX(1)}
  .btn-primary::after{display:none}
  .reveal,.reveal-x{opacity:1;transform:none}
  html{scroll-behavior:auto}
  *{transition-duration:.01ms !important}
}

/* ============================================================
   ENRICHED CONTENT + FUNCTIONALITY COMPONENTS
   ============================================================ */

/* announce bar */
.announce{background:var(--brand-900);color:var(--on-ink);border-bottom:1px solid var(--line)}
.announce .wrap{display:flex;align-items:center;justify-content:center;gap:.8rem;flex-wrap:wrap;padding:.55rem 24px;font-size:.9rem}
.announce strong{color:var(--accent)}
.announce button{background:transparent;border:1px solid var(--line-2);color:var(--on-ink);border-radius:999px;
  padding:.3em .9em;font:inherit;font-weight:600;font-size:.84rem;cursor:pointer;transition:.2s}
.announce button:hover{border-color:var(--brand);transform:translateY(-1px)}

/* scroll progress + back to top */
.progress{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);transform-origin:left;background:linear-gradient(90deg,var(--brand),var(--accent));z-index:var(--z-sticky);transition:transform .1s linear}
.to-top{position:fixed;right:20px;bottom:20px;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:var(--brand);color:var(--on-brand);border:none;cursor:pointer;box-shadow:var(--shadow-2);opacity:0;pointer-events:none;
  transform:translateY(12px);transition:.3s var(--ease);z-index:var(--z-menu)}
.to-top.show{opacity:1;pointer-events:auto;transform:none}
.to-top:hover{background:var(--brand-700);transform:translateY(-3px)}

/* tech logos band */
.logos h2,.stats h2{font-size:1rem;color:var(--muted);font-family:var(--font);font-weight:600;text-align:center;text-transform:uppercase;letter-spacing:.08em}
.logos-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.4rem 2.4rem;margin-top:1.8rem}
.logos-row span{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--ink-soft);opacity:.75;transition:.25s}
.logos-row span:hover{opacity:1;color:var(--brand-700)}

/* stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,200px),1fr));gap:1.4rem;margin-top:2.4rem}
.stat-tile{text-align:center;padding:1.4rem 1rem;border-top:2px solid var(--brand)}
.stat-tile:nth-child(2){border-top-color:var(--accent)}
.stat-tile:nth-child(3){border-top-color:var(--brand-700)}
.stat-tile:nth-child(4){border-top-color:var(--ink-soft)}
.stat-tile b{display:block;font-family:var(--font-display);font-size:clamp(2.2rem,1.6rem+2vw,3.1rem);color:var(--ink);line-height:1;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.stat-tile span{display:block;margin-top:.6rem;color:var(--muted);font-size:.95rem}
.stat-note{text-align:center;color:var(--muted);font-size:.85rem;margin-top:1.6rem;max-width:60ch;margin-inline:auto}

/* process */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:1.6rem;margin-top:2.8rem;counter-reset:step}
.pstep{position:relative;padding-top:2.6rem}
.pstep::before{counter-increment:step;content:counter(step);position:absolute;top:0;left:0;width:2rem;height:2rem;border-radius:50%;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;color:var(--on-brand);background:var(--brand);font-size:.95rem}
.pstep::after{content:"";position:absolute;top:1rem;left:2.3rem;right:-1rem;height:1px;background:var(--line-2)}
.pstep:last-child::after{display:none}
.pstep h3{font-size:1.1rem;margin-bottom:.35rem}
.pstep p{color:var(--muted);font-size:.95rem}
@media(max-width:680px){.pstep::after{display:none}}

/* people / formateurs */
.people-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:1.4rem;margin-top:2.6rem}
.person{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.4rem;transition:transform .3s var(--ease),border-color .3s}
.person:hover{transform:translateY(-4px);border-color:var(--brand)}
.person .ph{width:60px;height:60px;border-radius:50%;background:var(--surface-2);color:var(--brand);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin-bottom:1rem;border:1px solid var(--line)}
.person h3{font-size:1.08rem}
.person .role{color:var(--brand-700);font-size:.9rem;font-weight:600;margin-top:.15rem}
.person p{color:var(--muted);font-size:.92rem;margin-top:.5rem}

/* testimonials */
.quotes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:1.4rem;margin-top:2.6rem}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}
.quote p{color:var(--ink-soft);font-size:1rem;line-height:1.6}
.quote .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.quote .who .ph{width:42px;height:42px;border-radius:50%;background:var(--surface-2);border:1px solid var(--line);flex:none}
.quote .who b{display:block;font-size:.95rem;color:var(--ink)}
.quote .who span{font-size:.84rem;color:var(--muted)}
.quote .stars{color:var(--accent);font-size:.95rem;letter-spacing:.1em}

/* comparison */
.compare-wrap{margin-top:2.6rem;overflow-x:auto}
.compare{width:100%;border-collapse:collapse;min-width:560px}
.compare th,.compare td{text-align:left;padding:.95rem 1.1rem;border-bottom:1px solid var(--line);font-size:.95rem}
.compare thead th{font-family:var(--font-display);color:var(--ink);font-size:1rem}
.compare thead th.us{color:var(--brand-700)}
.compare tbody td:first-child{color:var(--ink-soft)}
.compare td.us{background:var(--brand-wash);color:var(--ink);font-weight:600}
.compare .yes{color:var(--brand)}
.compare .no{color:var(--muted-2,var(--muted))}

/* sessions */
.sessions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:1.2rem;margin-top:2.6rem}
.session{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.4rem;display:flex;flex-direction:column;gap:.5rem}
.session .live{display:inline-flex;align-items:center;gap:.4em;font-size:.78rem;font-weight:700;color:var(--accent-700);text-transform:uppercase;letter-spacing:.04em}
.session .live .pulse{width:.55em;height:.55em;border-radius:50%;background:var(--accent)}
.session h3{font-size:1.06rem}
.session .meta{color:var(--muted);font-size:.9rem}
.session .seats{font-size:.86rem;color:var(--brand-700);font-weight:600}
.session .btn{margin-top:.6rem;justify-content:center}

/* b2b */
.b2b{background:var(--ink-bg);color:var(--on-ink);border-radius:26px;padding:clamp(2rem,5vw,3.4rem);position:relative;overflow:hidden}
.b2b h2{color:var(--on-ink)}
.b2b .lead{color:var(--on-ink-soft)}
.b2b-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr));gap:1.4rem;margin-top:2rem}
.b2b-card{background:var(--ink-bg-2);border:1px solid oklch(80% 0.03 210 / .16);border-radius:var(--r-lg);padding:1.4rem}
.b2b-card h3{color:var(--on-ink);font-size:1.1rem;margin-bottom:.6rem}
.b2b-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.b2b-card li{color:var(--on-ink-soft);font-size:.93rem;display:flex;gap:.5rem}
.b2b-card li::before{content:"→";color:var(--accent)}
.b2b-form{margin-top:2rem;max-width:580px}
.b2b-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
@media(max-width:560px){.b2b-form .row2{grid-template-columns:1fr}}

/* outcomes / capability list */
.outcomes{margin-top:2.6rem;border-top:1px solid var(--line);padding-top:1.8rem}
.outcomes .o-h{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.2rem;margin-bottom:1.1rem}
.outcome-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:.8rem 1.8rem}
.outcome-list li{position:relative;padding-left:1.5rem;color:var(--ink-soft);font-size:.98rem}
.outcome-list li::before{content:"";position:absolute;left:0;top:.62em;width:.9rem;height:2px;background:var(--brand)}

/* visually-hidden live region */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap}

/* coming-soon tag on resources */
.soon{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-left:.55rem}

/* reassurance band */
.reassure{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 1.8rem;padding:1.4rem 0}
.reassure span{display:inline-flex;align-items:center;gap:.5em;color:var(--ink-soft);font-weight:500;font-size:.96rem}
.reassure svg{color:var(--brand);flex:none}

/* resources + newsletter */
.res-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(1.5rem,4vw,3rem);margin-top:2.4rem;align-items:start}
.res-list{display:flex;flex-direction:column;gap:.4rem}
.res-item{display:flex;gap:1rem;align-items:center;padding:1.1rem;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);text-decoration:none;transition:.25s}
.res-item:hover{border-color:var(--brand);transform:translateX(4px)}
.res-item .tagk{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-700);flex:none;width:5.5rem}
.res-item b{color:var(--ink);font-size:.98rem}
.news{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem}
.news h3{font-size:1.2rem}
.news p{color:var(--muted);font-size:.94rem;margin:.5rem 0 1rem}
.news form{display:flex;flex-direction:column;gap:.7rem}
.news input{padding:.8em 1em;border-radius:var(--r);border:1px solid var(--line-2);background:var(--bg);color:var(--ink);font:inherit}
.news input:focus-visible{outline:2px solid var(--brand);outline-offset:1px}
.news .btn{justify-content:center}
.news small{color:var(--muted);font-size:.78rem}
@media(max-width:760px){.res-grid{grid-template-columns:1fr}}

/* modal (quiz + simulator) */
.modal{position:fixed;inset:0;z-index:var(--z-overlay);display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-back{position:absolute;inset:0;background:oklch(10% 0.02 240 / .72);backdrop-filter:blur(4px)}
.modal-card{position:relative;width:min(560px,100%);max-height:88vh;overflow:auto;background:var(--bg);border:1px solid var(--line-2);
  border-radius:var(--r-lg);padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--shadow-2)}
.modal-card h3{font-size:1.4rem}
.modal-close{position:absolute;top:.9rem;right:.9rem;width:36px;height:36px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--ink);cursor:pointer}
.modal-close:hover{border-color:var(--brand)}
.q-opts{display:grid;gap:.6rem;margin-top:1.2rem}
.q-opt{text-align:left;padding:.9em 1.1em;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);color:var(--ink);font:inherit;cursor:pointer;transition:.2s}
.q-opt:hover{border-color:var(--brand);transform:translateX(3px)}
.q-prog{height:4px;background:var(--surface-2);border-radius:3px;overflow:hidden;margin-top:1rem}
.q-prog i{display:block;height:100%;background:var(--brand);width:100%;transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.q-result{text-align:center}
.q-result .pick{font-family:var(--font-display);font-size:1.5rem;color:var(--brand-700);margin:.4rem 0}
.field{display:flex;flex-direction:column;gap:.4rem;margin-top:1rem}
.field label{font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.field select,.field input{padding:.8em 1em;border-radius:var(--r);border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font:inherit}
.sim-out{margin-top:1.3rem;padding:1.2rem;border-radius:var(--r);background:var(--brand-wash);border:1px solid var(--line)}
.sim-out .big{font-family:var(--font-display);font-size:1.5rem;color:var(--ink)}
.sim-out p{color:var(--ink-soft);font-size:.92rem;margin-top:.4rem}
.book-embed{margin-top:1rem;min-height:46vh;border-radius:12px;overflow:hidden;background:var(--surface)}
.book-cta{margin-top:.4rem}

/* cookie banner */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:var(--z-overlay);max-width:520px;margin-inline:auto;
  background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:1.2rem 1.3rem;box-shadow:var(--shadow-2);display:none}
.cookie.show{display:block}
.cookie p{font-size:.9rem;color:var(--ink-soft)}
.cookie a{color:var(--brand-700)}
.cookie .row{display:flex;gap:.6rem;margin-top:.9rem;flex-wrap:wrap}
.cookie .btn{padding:.6em 1.1em;font-size:.9rem}
