/* =============================================================
   landing.<brand> — snap-scroll cinematic landing with SVG anims.
   Standard browser scrollbar, no wheel hijack. Mirrors site/ tokens.
   ============================================================= */
:root {
  --bg-000:#0e0f12;
  --bg-050:#14161a;
  --bg-100:#1a1d22;
  --bg-150:#232730;
  --bg-200:#2b2f39;
  --bg-300:#383d49;
  --fg-000:#f7f6f2;
  --fg-100:#d9d8d2;
  --fg-300:#9aa0ac;
  --fg-500:#6c727e;
  --fg-700:#444a55;
  --accent:#e0a046;
  --accent-soft:#c0791e;
  --accent-ink:#2a1a08;
  --rule:#262932;
  --rule-soft:#1f2229;
  --wrap:1240px;
  --gutter:24px;
  --radius:4px;
  --radius-lg:8px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-display:"Söhne Halbfett","Neue Haas Grotesk Display","GT America","IBM Plex Sans Condensed",system-ui,sans-serif;
  --font-body:"Söhne Buch","Inter Tight","Neue Haas Grotesk Text",system-ui,sans-serif;
  --font-mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none !important}
body,h1,h2,h3,p,ul{margin:0}
html{scroll-behavior:smooth}
html,body{
  background:var(--bg-000);color:var(--fg-000);
  font-family:var(--font-body);font-size:15px;line-height:1.55;
  overflow-x:hidden;max-width:100%;
  font-feature-settings:"ss01","cv02","tnum";
}
img{display:block;max-width:100%;height:auto}
ul{padding:0;list-style:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s var(--ease),color .15s var(--ease)}
a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter);width:100%}
.muted{color:var(--fg-500)}

h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.015em;line-height:1.08;color:var(--fg-000)}
h1{font-size:clamp(2.4rem,5.4vw,3.8rem);letter-spacing:-.025em}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:1.18rem}

/* ===== Ambient backdrop (animated grid + drifting orbs) ===== */
.ambient{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.9}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;font-weight:700;font-size:.92rem;letter-spacing:.005em;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease),transform .15s var(--ease)}
.btn-solid{background:var(--accent);color:var(--accent-ink)}
.btn-solid:hover{background:var(--fg-000);color:var(--bg-000);border-bottom-color:transparent;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--fg-000);border-color:var(--bg-300)}
.btn-ghost:hover{background:var(--bg-150);border-color:var(--accent);color:var(--accent)}

/* ===== Preloader ===== */
.preloader{position:fixed;inset:0;background:var(--bg-000);display:flex;align-items:center;justify-content:center;z-index:200;transition:opacity .6s var(--ease)}
.preloader.is-hidden{opacity:0;pointer-events:none}
.preloader__logo{width:260px;height:auto}

/* ===== Age gate ===== */
.age-gate{position:fixed;inset:0;background:rgba(7,8,10,.86);display:flex;align-items:center;justify-content:center;z-index:180;padding:24px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.age-gate__panel{background:var(--bg-050);padding:36px;max-width:560px;border:1px solid var(--rule);border-radius:var(--radius-lg);box-shadow:0 30px 60px -20px rgba(0,0,0,.55);animation:gate-in .55s var(--ease)}
@keyframes gate-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.age-gate__kicker{font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:14px}
.age-gate__panel h2{margin-bottom:14px;font-size:1.45rem}
.age-gate__panel p{color:var(--fg-300);margin-bottom:22px}
.age-gate__actions{display:flex;flex-wrap:wrap;gap:10px}

/* ===== Header ===== */
.lp-header{position:sticky;top:0;z-index:50;background:rgba(14,16,18,.86);border-bottom:1px solid var(--rule);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px)}
.lp-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-block:12px}
.brand img{height:30px;width:auto}
.lp-header__cta{padding:9px 16px;font-size:.86rem}

/* ===== RG bar ===== */
.rg-bar{background:var(--accent-ink);color:var(--fg-100);font-size:.82rem;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;padding:7px 16px;border-bottom:1px solid var(--rule);position:relative;z-index:40}
.rg-bar a{color:var(--accent)}
.rg-bar a:hover{color:var(--fg-000);border-bottom-color:var(--accent)}
.rg-bar__sep{color:var(--fg-700)}

/* ===== Scene-dots (right rail) ===== */
.scene-nav{position:fixed;right:18px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:14px;z-index:55}
.scene-nav a{
  width:10px;height:10px;border-radius:50%;
  border:1px solid var(--fg-500);background:transparent;
  transition:all .25s var(--ease);
}
.scene-nav a:hover{border-color:var(--accent)}
.scene-nav a.is-current{background:var(--accent);border-color:var(--accent);transform:scale(1.4);box-shadow:0 0 0 4px rgba(224,160,70,.12)}
@media (max-width:780px){.scene-nav{display:none}}

/* ===== Snap-scroll container ===== */
.snap{position:relative;z-index:1}

/* ===== Scenes ===== */
.scene{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:clamp(2rem,5vw,4rem) 0;
  overflow:hidden;
  scroll-snap-align:start;
}
.scene__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.scene__photo{position:absolute;inset:0;background-position:right center;background-size:cover;background-repeat:no-repeat;transform:translateY(calc(var(--parallax,0) * 1px));transition:transform .15s linear}
.scene__veil{position:absolute;inset:0;background:linear-gradient(90deg,var(--bg-000) 0%,rgba(14,15,18,.92) 28%,rgba(14,15,18,.55) 60%,rgba(14,15,18,.25) 100%)}
.scene__veil--strong{background:linear-gradient(180deg,rgba(14,15,18,.92),rgba(14,15,18,.95))}
.scene__inner{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.5fr 1fr;gap:42px;align-items:center}
.scene__inner--centered{display:block;max-width:880px}
.scene__inner--final{display:grid;grid-template-columns:1.6fr 1fr;gap:36px;align-items:center}
.scene__head{margin-bottom:32px}
.scene__copy{min-width:0}
.scene__cta{display:flex;gap:10px;flex-wrap:wrap}

@media (max-width:900px){
  .scene__inner,.scene__inner--final{grid-template-columns:1fr;gap:28px}
}

/* Scene-reveal: copy slides up + fades on enter */
.scene .scene__copy,.scene .scene-card,.scene .pillars,.scene__inner--centered>*,.scene__inner--final>*{
  opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);
}
.scene.is-in .scene__copy,.scene.is-in .scene-card{opacity:1;transform:none}
.scene.is-in .scene-card{transition-delay:.18s}
.scene.is-in .pillars{opacity:1;transform:none}
.scene.is-in .scene__inner--centered>*{opacity:1;transform:none}
.scene.is-in .scene__inner--centered>*:nth-child(1){transition-delay:.05s}
.scene.is-in .scene__inner--centered>*:nth-child(2){transition-delay:.18s}
.scene.is-in .scene__inner--centered>*:nth-child(3){transition-delay:.32s}
.scene.is-in .scene__inner--final>*{opacity:1;transform:none}
.scene.is-in .scene__inner--final>*:nth-child(2){transition-delay:.2s}

/* SVG path-draw — initial state set inline, JS clears strokeDashoffset on reveal */
[data-draw]{transition:stroke-dashoffset 1.8s var(--ease)}

/* Decorative SVG slot — positioned by per-scene rules */
.scene-art{position:absolute;z-index:1;pointer-events:none}
.scene-art--bars{right:8%;bottom:18%;width:160px;height:auto;opacity:.85;mix-blend-mode:screen}
.scene-art--wave{left:50%;transform:translateX(-50%);bottom:10%;width:min(80%,720px);opacity:.55}

/* ===== Hero scene ===== */
.scene--hero{background:var(--bg-000)}
.scene--hero .scene__photo{background-image:url('assets/hero-afl.webp')}

.kicker{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:16px;display:inline-flex;align-items:center;gap:8px}
.kicker::before{content:"";width:22px;height:1px;background:var(--accent)}
.scene--hero h1{max-width:18ch;margin-bottom:18px}
.lede{max-width:52ch;font-size:1.05rem;color:var(--fg-300);margin-bottom:14px}
.helpline{font-size:.88rem;color:var(--fg-100);margin-bottom:22px;padding:8px 14px;background:var(--bg-100);border:1px solid var(--rule);border-radius:var(--radius);display:inline-block}

.scene-card{
  background:rgba(20,22,26,.78);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:0 24px 60px -30px rgba(0,0,0,.7);
  position:relative;overflow:hidden;
}
.scene-card .meta{font-size:.82rem;color:var(--fg-300);margin:14px 0 12px;line-height:1.5}
.bullets{display:flex;flex-direction:column;gap:8px;font-size:.86rem;color:var(--fg-100)}
.bullets li{position:relative;padding-left:18px;line-height:1.5}
.bullets li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border:1px solid var(--accent);border-radius:50%}
.card-topo{display:block;width:100%;margin-top:18px;height:60px;opacity:.7}

.licence-plate{display:inline-flex;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 16px;border:1px solid var(--accent-soft);border-radius:var(--radius);background:linear-gradient(180deg,rgba(224,160,70,.08),transparent)}
.licence-plate__tag{font-family:var(--font-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.14em;color:var(--fg-500)}
.licence-plate__acr{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--accent);line-height:1}
.licence-plate__no{font-family:var(--font-mono);font-size:.7rem;color:var(--fg-300);letter-spacing:.04em}

/* Scroll-down chevron */
.scene-down{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);width:36px;height:36px;color:var(--fg-300);z-index:3;animation:scene-down 2.4s var(--ease) infinite}
.scene-down svg{width:100%;height:100%}
@keyframes scene-down{0%,100%{transform:translate(-50%,0);opacity:.5}50%{transform:translate(-50%,6px);opacity:1}}

/* ===== Pillars scene ===== */
.scene--pillars{background:var(--bg-050);border-top:1px solid var(--rule)}
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}
.pillar{padding:30px 26px;background:var(--bg-050);transition:background .2s var(--ease)}
.pillar:hover{background:var(--bg-100)}
.pillar__no{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.14em;color:var(--accent);margin-bottom:14px;font-feature-settings:"tnum"}
.pillar__art{width:100%;height:60px;margin-bottom:14px;color:var(--accent);display:block}
.pillar h3{margin-bottom:10px}
.pillar p{color:var(--fg-300);font-size:.92rem;line-height:1.55}

/* ===== RG scene ===== */
.scene--rg{background:var(--bg-000);border-top:1px solid var(--rule)}
.scene--rg .scene__photo--rg{background-image:url('assets/bg-markets.webp');background-position:center;background-size:cover;opacity:.6}
.rg-line{font-family:var(--font-display);font-size:clamp(1.6rem,3.2vw,2.4rem);margin-bottom:14px;color:var(--fg-000);line-height:1.15}
.scene--rg p{color:var(--fg-300);margin-bottom:14px;line-height:1.6}
.rg-links{display:flex;flex-wrap:wrap;gap:10px 14px;font-size:.88rem;color:var(--fg-500);margin-top:8px}
.rg-links a{color:var(--fg-100);border-bottom-color:var(--fg-700)}
.rg-links a:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* ===== Final scene + footer ===== */
.scene--final{background:var(--bg-050);border-top:1px solid var(--rule);padding-block:0;align-items:stretch;flex-direction:column;min-height:0;scroll-snap-align:none}
.scene--final>.wrap{padding-block:clamp(2.5rem,6vw,5rem)}
.final-line{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:22px;color:var(--fg-000);line-height:1.15}
.final-id{padding-left:36px;border-left:1px solid var(--rule);display:flex;flex-direction:column;gap:14px}
.final-id svg{width:100px;height:100px}
.final-id p{font-size:.92rem;color:var(--fg-300)}
@media (max-width:900px){
  .final-id{padding-left:0;border-left:0;padding-top:24px;border-top:1px solid var(--rule)}
}

.lp-footer{background:#07080a;color:var(--fg-100);font-size:.85rem;padding:3rem 0 5rem;border-top:1px solid var(--rule)}
.lp-footer p{max-width:80ch;margin-bottom:10px;color:var(--fg-500)}
.lp-footer em{font-style:italic}
.lp-footer a{color:var(--accent);border-bottom-color:var(--accent-soft)}
.lp-footer a:hover{color:var(--fg-000)}

/* ===== NCPF mandatory plate ===== */
.ncpf-plate{position:fixed;left:0;right:0;bottom:0;background:#fff;color:#000;text-align:center;font-size:.82rem;padding:9px 16px;border-top:2px solid #000;z-index:60}
.ncpf-plate a{color:#000;text-decoration:underline}

/* ===== Cookie banner ===== */
.cookie-banner{position:fixed;left:0;right:0;bottom:38px;background:var(--bg-050);color:var(--fg-000);border-top:2px solid var(--accent);z-index:90;box-shadow:0 -24px 60px -30px rgba(0,0,0,.7)}
.cookie-banner__inner{max-width:var(--wrap);margin:0 auto;padding:16px 20px;display:grid;grid-template-columns:1.4fr auto;gap:18px;align-items:center}
.cookie-banner__title{font-weight:700;margin-bottom:4px}
.cookie-banner p{font-size:.85rem;color:var(--fg-300);margin-bottom:8px}
.cookie-banner__choices{display:flex;gap:18px;border:0;padding:0;margin-bottom:6px}
.cookie-banner__choices label{display:flex;align-items:center;gap:6px;font-size:.85rem}
.cookie-banner__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
@media (max-width:760px){.cookie-banner__inner{grid-template-columns:1fr}}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .scene .scene__copy,.scene .scene-card,.scene .pillars,.scene__inner--centered>*,.scene__inner--final>*{
    opacity:1;transform:none;transition:none;
  }
  [data-draw]{stroke-dashoffset:0 !important;transition:none}
  .scene-down,.ambient circle,.scene-art--bars rect{animation:none !important}
}

/* ===== Mobile breakpoints ===== */
@media (max-width:680px){
  :root{--gutter:14px}
  .lp-header__cta{display:none}
  .scene{min-height:auto;padding:3rem 0}
  .scene-art--bars{width:110px;right:4%}
  .scene-down{display:none}
  .helpline{font-size:.82rem;padding:7px 12px}
  .ncpf-plate{font-size:.74rem;padding:8px 12px}
  .final-id svg{width:80px;height:80px}
}
