/* ============================================================
   Components
   ============================================================ */

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:16px var(--gut);border-bottom:var(--hair) solid transparent;
  transition:background .5s var(--ease),border-color .5s var(--ease),backdrop-filter .5s}
.nav.scrolled{background:color-mix(in srgb,var(--ink) 78%,transparent);
  backdrop-filter:blur(14px) saturate(1.2);border-bottom-color:var(--line)}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);
  font-size:21px;font-weight:500;letter-spacing:.16em;white-space:nowrap}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 16px var(--accent-lit);flex:none}
.brand .ph{font-family:var(--mono);font-size:9px;letter-spacing:.16em;color:var(--earth);
  align-self:flex-start;margin-top:3px}
.navlinks{display:flex;gap:30px;align-items:center;font-size:14px;color:var(--bone-dim)}
.navlinks a{position:relative;transition:color .3s}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;
  background:var(--accent);transition:width .35s var(--ease)}
.navlinks a:hover,.navlinks a[aria-current="page"]{color:var(--bone)}
.navlinks a:hover::after,.navlinks a[aria-current="page"]::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-signin{display:flex;align-items:center;font-size:14px;color:var(--bone-dim);transition:color .3s}
.nav-signin:hover{color:var(--bone)}
.nav-menu-signin{display:none}   /* the Anmelden link inside the dropdown — mobile only */
/* hamburger — hidden on desktop, shown ≤860 */
.nav-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;
  background:none;border:0;cursor:pointer;color:var(--bone);-webkit-tap-highlight-color:transparent}
.nav-toggle__bars{position:relative;display:block;width:22px;height:14px}
.nav-toggle__bars span{position:absolute;left:0;width:22px;height:1.5px;background:currentColor;
  transition:transform .25s var(--ease),top .25s var(--ease),opacity .2s}
.nav-toggle__bars span:nth-child(1){top:3px}
.nav-toggle__bars span:nth-child(2){top:9px}
.nav-toggle[aria-expanded="true"] .nav-toggle__bars span:nth-child(1){top:6px;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bars span:nth-child(2){top:6px;transform:rotate(-45deg)}
@media(max-width:860px){
  .nav-toggle{display:flex}
  #primary-nav{position:absolute;top:100%;left:0;right:0;display:none;flex-direction:column;
    gap:2px;padding:14px var(--gut) 20px;
    background:color-mix(in srgb,var(--ink) 94%,transparent);backdrop-filter:blur(16px) saturate(1.2);
    -webkit-backdrop-filter:blur(16px) saturate(1.2);border-bottom:var(--hair) solid var(--line)}
  #primary-nav.open{display:flex}
  #primary-nav a{padding:13px 4px;font-size:1.05rem}
  .nav-signin{display:none}   /* Anmelden moves into the dropdown on mobile */
  .nav-menu-signin{display:block;margin-top:8px;padding-top:16px;border-top:var(--hair) solid var(--line)}
}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--grotesk);
  font-size:13.5px;font-weight:500;letter-spacing:.01em;padding:11px 21px;border-radius:var(--radius);
  cursor:pointer;transition:all .35s var(--ease);border:var(--hair) solid var(--line-strong);
  background:transparent;color:var(--bone);white-space:nowrap}
.btn--accent{background:var(--accent);color:var(--ink);border-color:var(--accent)}
.btn--accent:hover{background:var(--accent-lit);box-shadow:0 0 30px var(--accent-soft);transform:translateY(-1px)}
.btn--ghost:hover{border-color:var(--bone);background:color-mix(in srgb,var(--bone) 6%,transparent)}
.btn--sm{padding:8px 15px;font-size:12.5px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.cta-note{font-family:var(--mono);font-size:11px;color:var(--earth);letter-spacing:.03em}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;
  padding-top:88px;padding-bottom:64px;overflow:hidden;isolation:isolate}
/* ---- Hero "The Long Exposure": abstract golden light field, pure CSS (no WebGL, no subject) ----
   Warm light rakes in from the right and lands as a halation pool; the headline rests in the dark left.
   Global .grain (z9000) + .vignette (z8000) from base.css sit on top. Breathing is killed automatically
   under [data-motion=off] / prefers-reduced-motion via base.css `*{animation:none}`. */
.hero__light{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero__beam{position:absolute;inset:-15% -10%;
  background:linear-gradient(122deg,transparent 34%,rgba(200,134,43,.10) 46%,
    rgba(224,162,60,.20) 51%,rgba(255,230,168,.13) 55%,transparent 70%);
  filter:blur(46px);animation:hero-beam 22s ease-in-out infinite alternate}
.hero__fringe{position:absolute;inset:-15% -10%;opacity:.5;mix-blend-mode:screen;
  background:linear-gradient(122deg,transparent 53%,rgba(244,233,214,.10) 55%,transparent 58%);
  filter:blur(8px)}
.hero__pool{position:absolute;right:-6%;bottom:-18%;width:74%;height:104%;
  background:radial-gradient(58% 52% at 64% 58%,rgba(255,230,168,.30),rgba(224,162,60,.22) 26%,
    rgba(200,134,43,.12) 46%,rgba(120,78,23,.05) 64%,transparent 78%);
  filter:blur(26px);animation:hero-pool 26s ease-in-out infinite alternate}
.hero__core{position:absolute;right:16%;bottom:24%;width:min(300px,38vw);height:160px;
  background:radial-gradient(closest-side,rgba(255,236,190,.5),rgba(255,222,155,.16) 55%,transparent 78%);
  filter:blur(22px);mix-blend-mode:screen;animation:hero-core 18s ease-in-out infinite alternate}
.hero__leftdamp{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(14,11,8,.78) 0%,rgba(14,11,8,.40) 30%,transparent 56%)}
@keyframes hero-beam{from{transform:translate(0,0)}to{transform:translate(-1.4%,1.6%)}}
@keyframes hero-pool{from{transform:scale(1);opacity:.92}to{transform:scale(1.06);opacity:1}}
@keyframes hero-core{from{opacity:.66}to{opacity:1}}
/* workflow rail: Concept-2's lit hairline distilled to a quiet detail under the headline —
   a light-table edge that doubles as the sichten→entwickeln→schneiden timeline */
.hero__rail{position:relative;display:flex;max-width:460px;margin:30px 0 2px}
.hero__rail::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--accent),color-mix(in srgb,var(--accent) 24%,transparent) 56%,transparent);
  box-shadow:0 0 16px color-mix(in srgb,var(--accent-lit) 42%,transparent)}
.hero__rail-tick{flex:1;position:relative;padding-top:13px;font-family:var(--mono);
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--earth)}
.hero__rail-tick::before{content:"";position:absolute;top:-2px;left:0;width:5px;height:5px;
  border-radius:50%;background:var(--hairline)}
.hero__rail-tick.is-now{color:var(--accent-lit)}
.hero__rail-tick.is-now::before{background:var(--accent);box-shadow:0 0 9px var(--accent-lit)}
@media(max-width:560px){.hero__rail{max-width:330px;margin-top:24px}}

/* P11 — on-device / ownership promise: Opura's strongest, least-sold differentiator as a calm Fraunces line
   (never bullets, zero AI/robot imagery). A quiet provenance stamp rides the right edge. */
.promise{padding-block:var(--s-4);border-top:var(--hair) solid var(--line);border-bottom:var(--hair) solid var(--line)}
.promise__in{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:14px 28px}
.promise__line{font-family:var(--serif);font-weight:340;font-size:clamp(21px,2.7vw,34px);
  line-height:1.16;letter-spacing:-.01em;color:var(--bone);max-width:22ch}
.promise__line em{font-style:italic;color:var(--accent-lit)}
.promise__stamp{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-quiet);white-space:nowrap}
@media(max-width:520px){.promise__stamp{white-space:normal}}
/* recurring on-device trust stamp in each product hero margin (record-red dot on cinema, for free) */
.devstamp{margin-top:32px;padding-top:14px;border-top:var(--hair) solid var(--line);
  display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--earth)}
.devstamp__dot{width:5px;height:5px;border-radius:50%;background:var(--accent-quiet);flex:none}
.hero__scrim{position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,color-mix(in srgb,var(--ink) 55%,transparent) 0%,
    color-mix(in srgb,var(--ink) 18%,transparent) 40%,
    color-mix(in srgb,var(--ink) 84%,transparent) 100%)}
.hero__inner{position:relative;z-index:5;width:100%}
.hero h1{font-family:var(--serif);font-weight:340;font-variation-settings:"opsz" 144,"wght" 340;font-size:var(--fs-display);
  line-height:.96;letter-spacing:-.02em;max-width:15ch;margin-top:22px}
.hero h1 em{font-style:italic;color:var(--accent-lit);font-weight:360}
.hero h1 .ln,.phero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln>span,.phero h1 .ln>span{display:block;will-change:transform}
.hero__sub{margin-top:28px;max-width:48ch}
.hero__cta{margin-top:34px}
.scrollcue{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:6;
  font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--earth);text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:8px}
.scrollcue .bar{width:1px;height:42px;background:linear-gradient(var(--earth),transparent);
  animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* floating mono UI chip */
.uichip{border:var(--hair) solid var(--line-strong);border-radius:6px;
  background:color-mix(in srgb,var(--ink-2) 66%,transparent);backdrop-filter:blur(8px);
  padding:13px 15px;font-family:var(--mono);font-size:11px;color:var(--bone-dim)}
.uichip .row{display:flex;justify-content:space-between;gap:18px;padding:4px 0;border-bottom:var(--hair) solid var(--line)}
.uichip .row:last-child{border-bottom:0}
.uichip .k{color:var(--earth)}.uichip .v{color:var(--bone)}.uichip .pick{color:var(--accent)}
.hero__chip{position:absolute;right:var(--gut);bottom:9vh;z-index:6;width:min(330px,42vw)}
@media(max-width:860px){.hero__chip{display:none}}

/* ---------- travelling-file step typography ----------
   (the old 3-card workflow-spine layout was replaced by the travelling-file in the
   genre-neutral redesign; only these label classes are still reused by tfile__step) */
.beat__stage{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--accent);text-transform:uppercase}
.beat__nm{font-family:var(--serif);font-size:clamp(26px,3vw,40px);font-weight:360;margin:14px 0 4px;letter-spacing:-.01em;line-height:1.02}
.beat__nm em{font-style:italic;color:var(--bone-dim);font-size:.46em;letter-spacing:0}
.beat__meta{margin-top:22px;font-family:var(--mono);font-size:11px;color:var(--earth);display:flex;flex-direction:column;gap:6px}
.beat__meta b{color:var(--bone);font-weight:400}

/* ---------- before / after ---------- */
.ba-stage{display:grid;grid-template-columns:1.4fr .9fr;gap:48px;align-items:center}
@media(max-width:820px){.ba-stage{grid-template-columns:1fr;gap:32px}}
.ba{position:relative;aspect-ratio:16/10;border-radius:var(--radius-lg);overflow:hidden;
  border:var(--hair) solid var(--line-strong);cursor:ew-resize;user-select:none;touch-action:none}
.ba__layer{position:absolute;inset:0}
.ba__layer svg{width:100%;height:100%}
.ba__after{z-index:2}
.ba__handle{position:absolute;top:0;bottom:0;width:2px;background:var(--bone);z-index:5;left:50%;
  transform:translateX(-50%);box-shadow:0 0 18px color-mix(in srgb,var(--bone) 50%,transparent)}
.ba__grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:6;
  width:46px;height:46px;border-radius:50%;background:color-mix(in srgb,var(--ink-2) 75%,transparent);
  backdrop-filter:blur(6px);border:var(--hair) solid var(--bone);display:flex;align-items:center;justify-content:center;
  color:var(--bone);font-family:var(--mono);font-size:14px}
.ba__tag{position:absolute;top:13px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  padding:5px 9px;border-radius:2px;background:color-mix(in srgb,var(--ink) 70%,transparent);z-index:4}
.ba__tag.l{left:13px;color:var(--bone-dim)}.ba__tag.r{right:13px;color:var(--accent)}
/* P09 — grade slider as a weighted signature: spring settle on keyboard/auto-wipe end, instant during drag, grab highlight */
.ba__after,.ba__handle{transition:clip-path .42s cubic-bezier(.2,.7,.2,1),left .42s cubic-bezier(.2,.7,.2,1)}
.ba.is-dragging .ba__after,.ba.is-dragging .ba__handle{transition:none}
.ba:active .ba__grip,.ba:focus-visible .ba__grip{border-color:var(--accent-lit);
  box-shadow:0 0 16px color-mix(in srgb,var(--accent-lit) 55%,transparent)}
/* P10 — masked warm halation on the graded (after) side: a screen-blend bloom at the scene's bright region,
   clipped together with the after layer so it only lights the graded portion. Record-red on cinema via --accent-quiet. */
.ba__after::after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;
  background:radial-gradient(40% 48% at 64% 50%,color-mix(in srgb,var(--accent-quiet) 50%,transparent) 0%,transparent 68%)}
.ba-copy h3{font-family:var(--serif);font-weight:360;font-size:var(--fs-h3);line-height:1.1;letter-spacing:-.01em}
.feat{margin-top:22px;display:flex;flex-direction:column;gap:11px}
.feat>div{display:flex;gap:11px;align-items:baseline;font-size:14.5px}
.feat .d{width:5px;height:5px;border-radius:50%;background:var(--accent);flex:none;transform:translateY(-2px)}

/* P02 — the Opura window: a reusable macOS app-chrome that frames a product surface so every placeholder
   reads as a real, lifted app surface. ONE soft theme-amber shadow + a 0.5px hairline + a Space-Mono
   filename bar (record-red on the cinema theme for free). Reserved for proof surfaces, never decorative SVG. */
.swin{position:relative;border:var(--hair) solid var(--line-strong);border-radius:var(--radius-lg);
  background:var(--panel);overflow:hidden;
  box-shadow:0 40px 120px color-mix(in srgb,var(--accent) 11%,transparent);
  transition:box-shadow .6s var(--ease)}
.swin:hover{box-shadow:0 46px 132px color-mix(in srgb,var(--accent) 15%,transparent)}
.swin__bar{display:flex;align-items:center;gap:8px;height:30px;padding:0 13px;
  border-bottom:var(--hair) solid var(--line);background:color-mix(in srgb,var(--ink) 55%,var(--panel))}
.swin__dot{width:9px;height:9px;border-radius:50%;background:var(--hairline);flex:none}
.swin__file{flex:1;text-align:center;font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;
  color:var(--earth);transform:translateX(-12.5px)}   /* optically centre past the three dots */
.swin .ba{border:0;border-radius:0}                    /* the window provides the frame now */
/* P13 — one Fraunces drop-cap versal opens a long-form prose block (graceful: a larger first letter where initial-letter is unsupported) */
.dropcap::first-letter{-webkit-initial-letter:3;initial-letter:3;font-family:var(--serif);font-weight:360;color:var(--accent-lit);margin-right:.09em}
/* P01 polish — the frozen filename is the travelling-file's thesis: lift it just above the dim chrome */
.tfile__win .swin__file{color:var(--bone-dim);font-size:11.5px}

/* ---------- P01 The Travelling File: scroll-pinned suite story ---------- */
.tfile__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,88px);align-items:start;position:relative}
.tfile__copy{display:flex;flex-direction:column}
.tfile__step{min-height:86vh;display:flex;flex-direction:column;justify-content:center;padding-block:var(--s-3)}
.tfile__step .beat__stage{margin-bottom:6px}
/* the pinned window */
.tfile__sticky{position:sticky;top:13vh;height:74vh;display:flex;flex-direction:column;justify-content:center}
.tfile__win{width:100%}
.tfile__stages{position:relative;aspect-ratio:16/10.5;min-height:300px}
.tfile__stage{position:absolute;inset:0;display:flex;flex-direction:column;opacity:0;transform:translateY(10px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);pointer-events:none}
.tfile__win[data-stage="1"] .tfile__stage.is-1,
.tfile__win[data-stage="2"] .tfile__stage.is-2,
.tfile__win[data-stage="3"] .tfile__stage.is-3{opacity:1;transform:none}
/* the app-panel chrome inside each stage */
.tfp__bar{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:var(--hair) solid var(--line);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--earth)}
.tfp__app{color:var(--accent-quiet);font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.tfp__mid{flex:1}.tfp__live{color:var(--bone-dim)}
.tfp__main{flex:1;min-height:clamp(170px,23vh,230px)}
.tfp__main svg{width:100%;height:100%;display:block}
.tfp__foot{display:flex;justify-content:space-between;padding:9px 14px;border-top:var(--hair) solid var(--line);
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--earth)}
.tfp__pick{color:var(--accent-quiet)}
/* progress rail (driven by the window's data-stage via :has) */
.tfile__rail{display:flex;gap:7px;justify-content:center;margin-top:16px}
.tfile__rail span{width:24px;height:2px;background:var(--line-strong);transition:background .5s var(--ease)}
.tfile__sticky:has(.tfile__win[data-stage="1"]) .tfile__rail span:nth-child(1),
.tfile__sticky:has(.tfile__win[data-stage="2"]) .tfile__rail span:nth-child(2),
.tfile__sticky:has(.tfile__win[data-stage="3"]) .tfile__rail span:nth-child(3){background:var(--accent)}
/* static fallback — mobile, reduced-motion, motion-off: drop the pin, stack the three stages */
@media(max-width:820px){
  .tfile__grid{grid-template-columns:1fr;gap:var(--s-4)}
  .tfile__sticky{position:static;height:auto}.tfile__step{min-height:0;padding-block:0}
  .tfile__stages{aspect-ratio:auto;min-height:0}.tfile__rail{display:none}
  .tfile__stage{position:relative;opacity:1;transform:none;pointer-events:auto;border:var(--hair) solid var(--line);
    border-radius:var(--radius);margin-bottom:14px}
}
@media(prefers-reduced-motion:reduce){
  .tfile__grid{grid-template-columns:1fr}
  .tfile__sticky{position:static;height:auto}.tfile__step{min-height:0}
  .tfile__stages{aspect-ratio:auto;min-height:0}.tfile__rail{display:none}
  .tfile__stage{position:relative;opacity:1;transform:none;border-top:var(--hair) solid var(--line)}
}
[data-motion="off"] .tfile__grid{grid-template-columns:1fr}
[data-motion="off"] .tfile__sticky{position:static;height:auto}
[data-motion="off"] .tfile__step{min-height:0}
[data-motion="off"] .tfile__stages{aspect-ratio:auto;min-height:0}
[data-motion="off"] .tfile__rail{display:none}
[data-motion="off"] .tfile__stage{position:relative;opacity:1;transform:none;border-top:var(--hair) solid var(--line)}

/* ---------- performance band ---------- */
.band{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--hair);background:var(--line);
  border:var(--hair) solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.chip{background:var(--ink);padding:30px 24px}
.chip__big{font-family:var(--serif);font-size:clamp(30px,3.6vw,46px);font-weight:360;letter-spacing:-.01em;color:var(--bone)}
.chip__big em{font-style:normal;color:var(--accent-lit);font-size:.55em}
.chip__lab{margin-top:8px;font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--bone-dim);line-height:1.5}
@media(max-width:820px){.band{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.band{grid-template-columns:1fr}}

/* ---------- pillars ---------- */
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:720px){.pillars{grid-template-columns:1fr}}
.pillar{border:var(--hair) solid var(--line);border-radius:var(--radius-lg);padding:30px 30px 34px;background:var(--surf-2)}
.pillar__ic{font-family:var(--mono);color:var(--accent);font-size:12px;letter-spacing:.16em}
.pillar h3{font-family:var(--serif);font-weight:360;font-size:24px;margin:14px 0 10px;letter-spacing:-.01em;line-height:1.15}
.pillar p{color:var(--bone-dim);font-size:14.5px;line-height:1.7}

/* ---------- suite teaser / product cross-links ---------- */
.prodgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.prodgrid{grid-template-columns:1fr}}
.prodcard{position:relative;border:var(--hair) solid var(--line);border-radius:var(--radius-lg);
  padding:28px 26px 30px;background:var(--surf-2);overflow:hidden;transition:border-color .4s var(--ease),transform .4s var(--ease),background .4s var(--ease)}
.prodcard:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.prodcard__stage{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--accent);text-transform:uppercase}
.prodcard__nm{font-family:var(--serif);font-size:30px;font-weight:360;margin:12px 0 8px;letter-spacing:-.01em}
.prodcard p{color:var(--bone-dim);font-size:14px;line-height:1.6}
.prodcard__link{margin-top:18px;font-family:var(--mono);font-size:12px;color:var(--accent-quiet);display:inline-flex;gap:6px;transition:gap .3s var(--ease)}
.prodcard:hover .prodcard__link{gap:12px}

/* ---------- closing ---------- */
.closing{text-align:center}
.closing h2{font-family:var(--serif);font-weight:330;font-variation-settings:"opsz" 140,"wght" 330;font-size:var(--fs-mega);line-height:1.02;letter-spacing:-.02em;max-width:18ch;margin-inline:auto}
.closing h2 em{font-style:italic;color:var(--accent-lit)}
.closing .cta-row{justify-content:center;margin-top:var(--s-4)}

/* ---------- footer ---------- */
.footer{border-top:var(--hair) solid var(--line);padding-block:var(--s-4)}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
@media(max-width:720px){.footer__grid{grid-template-columns:1fr 1fr}}
.footer .brand{font-size:18px;margin-bottom:12px}
.footer__col h2{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--earth);margin-bottom:14px}
.footer__col a{display:block;font-size:13.5px;color:var(--bone-dim);padding:4px 0;transition:color .3s}
.footer__col a:hover{color:var(--bone)}
.footer__legal{margin-top:var(--s-4);padding-top:var(--s-3);border-top:var(--hair) solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:11px;color:var(--earth)}

/* ---------- product page hero variant ---------- */
.phero{position:relative;min-height:66vh;display:flex;align-items:center;padding-top:128px;padding-bottom:var(--s-5);overflow:hidden;isolation:isolate}
/* P15 — Incisa celluloid frame-burn: the one reserved WebGL canvas, behind the .phero SVG. The dark scene
   background fades under .gl-on so the red light-pass shows; the REC/S-Log3 chrome stays. width/height:100%
   so the canvas fills (the hero-gl replaced-element lesson). No WebGL / motion-off → SVG poster is the fallback. */
.phero__gl{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;pointer-events:none}
.phero__bg{transition:opacity 1.2s var(--ease)}
.phero.gl-on .phero__bg{opacity:.12}
.phero__chip{position:absolute;right:var(--gut);top:122px;z-index:6;width:min(320px,40vw)}
@media(max-width:980px){.phero__chip{display:none}}
.phero__scene{position:absolute;inset:0;z-index:0}
.phero__scene svg{width:100%;height:100%;object-fit:cover}
.phero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,
  color-mix(in srgb,var(--ink) 40%,transparent),color-mix(in srgb,var(--ink) 88%,transparent))}
.phero__inner{position:relative;z-index:5;width:100%}
.phero h1{font-family:var(--serif);font-weight:340;font-variation-settings:"opsz" 140,"wght" 340;font-size:clamp(46px,8vw,104px);line-height:.95;letter-spacing:-.02em;margin-top:18px}
.phero h1 em{font-style:italic;color:var(--accent-lit)}
.phero__sub{margin-top:24px;max-width:52ch}

/* feature constellation grid — fixed 3 cols so the 6 cells tile cleanly (no orphan tracks) */
.constellation{counter-reset:cell;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--hair);
  background:var(--line);border:var(--hair) solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
@media(max-width:880px){.constellation{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.constellation{grid-template-columns:1fr}}
.cell{counter-increment:cell;background:var(--ink);padding:28px 24px;transition:background .4s var(--ease)}
.cell:hover{background:var(--surf-3)}
/* cinema theme (true black): lightening the hover surface drops --earth text below 4.5:1.
   Instead lift the small text + a border highlight on a near-black bg so contrast stays AA (WCAG 1.4.3). */
[data-theme="cinema"] .cell:hover{background:#0C0F11;border-color:var(--line-strong)}
[data-theme="cinema"] .cell:hover p{color:var(--bone)}
[data-theme="cinema"] .cell:hover .cell__tag{color:var(--bone-dim)}
.cell::before{content:counter(cell,decimal-leading-zero);display:block;font-family:var(--mono);font-size:12px;
  letter-spacing:.18em;color:var(--accent);margin-bottom:18px}
.cell h3{font-family:var(--serif);font-weight:380;font-size:19px;letter-spacing:-.01em;margin-bottom:7px}
.cell p{font-size:13.5px;color:var(--bone-dim);line-height:1.6}
.cell__tag{margin-top:12px;font-family:var(--mono);font-size:10.5px;color:var(--earth);letter-spacing:.04em}
/* P03 — editorial asymmetry: at 3-col, promote alternating cells to a wide "hero feature" so the toolbox
   reads as an editorial rhythm, not a symmetric grid. Pure CSS; ≤880px falls back to the plain 2/1-col grid. */
@media(min-width:881px){
  .cell:nth-child(6n+1),.cell:nth-child(6n+4),.cell:nth-child(6n+5){grid-column:span 2}
  .cell:nth-child(6n+1) h3,.cell:nth-child(6n+4) h3,.cell:nth-child(6n+5) h3{font-size:22px}
  .cell:nth-child(6n+1) p,.cell:nth-child(6n+4) p,.cell:nth-child(6n+5) p{max-width:52ch}
}

/* big feature rows (alternating) */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.frow+.frow{margin-top:var(--s-6)}
.frow--rev .frow__media{order:2}
@media(max-width:820px){.frow{grid-template-columns:1fr;gap:28px}.frow--rev .frow__media{order:0}}
.frow__media{aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;border:var(--hair) solid var(--line-strong);background:var(--ink-2)}
.frow__media svg{width:100%;height:100%}
.frow h3{font-family:var(--serif);font-weight:360;font-size:var(--fs-h3);line-height:1.1;letter-spacing:-.01em}
.frow .eyebrow{margin-bottom:14px;display:block}
.frow p{margin-top:14px;color:var(--bone-dim);line-height:1.7}

/* ---------- pricing ---------- */
.toggle{display:inline-flex;align-items:center;gap:0;border:var(--hair) solid var(--line-strong);border-radius:var(--radius-pill);
  padding:4px;background:var(--ink-2);font-family:var(--mono);font-size:12px}
.toggle button{padding:8px 18px;border-radius:var(--radius-pill);color:var(--bone-dim);transition:all .35s var(--ease);letter-spacing:.03em}
.toggle button[aria-pressed="true"]{background:var(--accent);color:var(--ink)}
.toggle .save{color:var(--accent);margin-left:6px}

.prices{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:stretch}
@media(max-width:980px){.prices{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.prices{grid-template-columns:1fr}}
.price{display:flex;flex-direction:column;border:var(--hair) solid var(--line);border-radius:var(--radius-lg);
  padding:28px 26px 30px;background:var(--surf-2);position:relative;transition:border-color .4s var(--ease),transform .4s var(--ease)}
.price:hover{transform:translateY(-3px)}
.price--hero{background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 14%,var(--ink-2)),var(--ink-2));
  border:1.5px solid var(--accent);box-shadow:0 0 64px var(--accent-soft);transform:translateY(-12px)}
.price--hero:hover{transform:translateY(-16px)}
@media(max-width:980px){.price--hero{transform:none}.price--hero:hover{transform:translateY(-3px)}}
.price__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;background:var(--accent);color:var(--ink);padding:6px 15px;border-radius:var(--radius-pill);white-space:nowrap;box-shadow:0 4px 18px var(--accent-soft)}
.price__stage{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--accent-quiet);text-transform:uppercase}
.price__nm{font-family:var(--serif);font-size:26px;font-weight:360;margin:10px 0 4px;letter-spacing:-.01em}
.price__desc{font-size:13px;color:var(--bone-dim);line-height:1.5;min-height:38px}
.price__amt{font-family:var(--serif);font-size:46px;font-weight:360;margin:18px 0 2px;display:flex;align-items:baseline;gap:6px}
.price__amt .cur{font-size:22px;color:var(--bone-dim)}
.price__amt .struck{font-size:18px;color:var(--earth);text-decoration:line-through;margin-left:8px;align-self:center}
.price__per{font-family:var(--mono);font-size:11px;color:var(--earth);letter-spacing:.04em}
.price ul{list-style:none;margin:20px 0 24px;display:flex;flex-direction:column;gap:10px}
.price li{display:flex;gap:10px;align-items:baseline;font-size:13.5px;color:var(--bone-dim)}
.price li .ck{color:var(--accent);flex:none}
.price .btn{margin-top:auto;justify-content:center}

/* comparison matrix */
.matrix{width:100%;border-collapse:collapse;font-size:14px;margin-top:var(--s-3)}
.matrix th,.matrix td{text-align:left;padding:14px 16px;border-bottom:var(--hair) solid var(--line)}
.matrix thead th{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--bone-dim);font-weight:400}
.matrix thead th:nth-child(n+2){text-align:center}
.matrix tbody th{font-weight:400;color:var(--bone)}
.matrix td{text-align:center;color:var(--bone-dim)}
.matrix .grp{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-quiet);padding-top:24px}
.matrix .yes{color:var(--accent-lit)}
.matrix .no{color:var(--earth)}
/* draw the eye to the suite: tint the Studio column */
.matrix th:last-child,.matrix td:last-child{background:color-mix(in srgb,var(--accent) 7%,transparent)}
.matrix thead th:last-child{color:var(--accent-lit)}

.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:var(--s-4)}
@media(max-width:720px){.trust{grid-template-columns:1fr}}
.trust__item{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--bone-dim)}
.trust__item .ic{color:var(--accent);flex:none;margin-top:2px}
.trust__item b{color:var(--bone);font-weight:500;display:block;margin-bottom:3px}

/* ---------- dashboard (license admin) ---------- */
.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
@media(max-width:860px){.app-shell{grid-template-columns:1fr}}
.app-side{display:flex;flex-direction:column;border-right:var(--hair) solid var(--line);padding:24px 18px;background:var(--surf-1);position:sticky;top:0;height:100vh;min-width:0}
@media(max-width:860px){.app-side{position:static;height:auto;border-right:0;border-bottom:var(--hair) solid var(--line)}}
.app-user{margin-top:auto;padding-top:24px;font-family:var(--mono);font-size:11px;color:var(--earth);line-height:1.6}
.app-user .who{color:var(--bone-dim)}
.app-user a{color:var(--accent)}
@media(max-width:860px){.app-user{margin-top:18px;padding-top:18px;border-top:var(--hair) solid var(--line)}}
.app-side .brand{font-size:18px;margin-bottom:28px;padding-left:6px}
.app-nav{display:flex;flex-direction:column;gap:2px}
.app-nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius);
  font-size:14px;color:var(--bone-dim);transition:background .3s,color .3s}
.app-nav a .ic{width:17px;height:17px;flex:none;color:var(--earth)}
.app-nav a:hover{background:color-mix(in srgb,var(--bone) 5%,transparent);color:var(--bone)}
.app-nav a.active{background:var(--accent-soft);color:var(--bone)}
.app-nav a.active .ic{color:var(--accent)}
.app-main{padding:32px var(--gut);min-width:0}
.app-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:var(--s-4)}
.app-head h1{font-family:var(--serif);font-weight:360;font-size:clamp(28px,3vw,40px);letter-spacing:-.01em}
.app-head p{color:var(--bone-dim);font-size:14px;margin-top:4px}

.lic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.lic{display:flex;flex-direction:column;border:var(--hair) solid var(--line);border-radius:var(--radius-lg);padding:22px 22px 24px;background:var(--surf-2)}
.lic__foot{margin-top:auto;padding-top:18px}
.lic__foot .btn{width:100%;justify-content:center}
.lic__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}
.lic__app{display:flex;gap:12px;align-items:center}
.lic__icon{width:40px;height:40px;border-radius:9px;background:var(--accent-soft);border:var(--hair) solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;color:var(--accent);font-family:var(--serif);font-size:18px;flex:none}
.lic__name{font-family:var(--serif);font-size:19px;font-weight:380;letter-spacing:-.01em}
.lic__plan{font-family:var(--mono);font-size:11px;color:var(--earth)}
.pill{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:var(--radius-pill);white-space:nowrap}
.pill--active{background:color-mix(in srgb,var(--ok) 16%,transparent);color:var(--ok)}
.pill--trial{background:var(--accent-soft);color:var(--accent-lit)}
.pill--expired{background:rgba(120,80,60,.18);color:var(--bone-dim)}
.lic__key{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;color:var(--bone-dim);
  background:var(--ink);border:var(--hair) solid var(--line);border-radius:var(--radius);padding:9px 12px;margin-bottom:14px}
.lic__key .val{flex:1;min-width:0;letter-spacing:.05em;color:var(--bone);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lic__key button{color:var(--accent);font-family:var(--mono);font-size:11px}
.lic__row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:var(--earth);padding:6px 0;border-top:var(--hair) solid var(--line)}
.lic__row b{color:var(--bone);font-weight:400}
.meter{height:5px;border-radius:3px;background:var(--ink);overflow:hidden;margin-top:8px;border:var(--hair) solid var(--line)}
.meter>span{display:block;height:100%;background:var(--accent)}

.panel{border:var(--hair) solid var(--line);border-radius:var(--radius-lg);background:var(--surf-1);overflow:hidden;margin-top:var(--s-3)}
.panel__head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:var(--hair) solid var(--line)}
.panel__head h2{font-family:var(--serif);font-size:19px;font-weight:380}
.dev{display:flex;align-items:center;gap:16px;padding:16px 22px;border-bottom:var(--hair) solid var(--line)}
.dev:last-child{border-bottom:0}
.dev__ic{width:34px;height:34px;color:var(--bone-dim);flex:none}
.dev__main{flex:1;min-width:0}
.dev__name{font-size:14.5px;color:var(--bone)}
.dev__meta{font-family:var(--mono);font-size:11px;color:var(--earth);margin-top:2px}
.dev__act{font-family:var(--mono);font-size:11.5px;color:var(--bone-dim);transition:color .3s}
.dev__act:hover{color:var(--accent)}
/* destructive seat action — a restrained pill, distinct from benign download links (never brand amber) */
.dev__act--danger{border:var(--hair) solid var(--line-strong);padding:6px 13px;border-radius:var(--radius-pill);transition:color .3s,border-color .3s}
.dev__act--danger:hover{color:#D98B6E;border-color:#D98B6E}
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th,.table td{text-align:left;padding:14px 22px;border-bottom:var(--hair) solid var(--line)}
.table th{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--earth);font-weight:400}
.table td{color:var(--bone-dim)}
.table td b{color:var(--bone);font-weight:400}
.table tr:last-child td{border-bottom:0}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:560px){
  .table{min-width:480px}
  .table th,.table td{padding:12px 14px}
  .matrix th,.matrix td{padding:12px 10px;font-size:13px}
}

/* generic placeholder note */
.pholder{position:fixed;left:16px;bottom:16px;z-index:9400;font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;
  color:var(--earth);background:color-mix(in srgb,var(--ink) 72%,transparent);border:var(--hair) solid var(--line);
  padding:7px 11px;border-radius:var(--radius);max-width:250px;line-height:1.5}
@media(max-width:860px){.pholder{display:none}}

/* --- FAQ: native <details> accordion (keyboard-accessible, no JS) --- */
.faq__list{max-width:760px;margin-top:var(--s-3)}
.faq__item{border-top:var(--hair) solid var(--line)}
.faq__item:last-child{border-bottom:var(--hair) solid var(--line)}
.faq__item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:baseline;gap:24px;
  padding:22px 4px;font-family:var(--serif);font-weight:400;font-size:19px;letter-spacing:-.01em;color:var(--bone);
  transition:color .2s}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--mono);font-size:21px;line-height:1;color:var(--accent-quiet);
  flex:0 0 auto;transition:color .2s}
.faq__item[open] summary::after{content:"–";color:var(--accent)}
.faq__item summary:hover{color:var(--accent-quiet)}
.faq__item summary:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.faq__a{padding:0 4px 24px;color:var(--bone-dim);line-height:1.75;font-size:15px;max-width:62ch}
.faq__a a{color:var(--accent-quiet)}
