/* ===== Theme: FABLE 5 — WebGL2 cinematic =====
   Cloned 2026-07-02 from ULTRA (ultra.css untouched). The living backdrop
   is assets/js/themes/fable-5.js (WebGL2); overrides below keep the chrome thin & edge-lit. */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap');
/* ULTRA */

/* ============================================================
   Arthur Romanov · Professional Studio — public site
   Monochrome luxe. Silver-on-black, thin wide-tracked geometric
   type, aurora light streaks + floating ghost-words atmosphere.
   ============================================================ */

:root{
  --bg:        #060607;
  --bg-2:      #0a0a0c;
  --panel:     #0e0e11;
  --raise:     rgba(255,255,255,.022);
  --text:      #f2f2f5;
  --silver:    #c7c8cd;
  --muted:     rgba(242,242,245,.52);
  --faint:     rgba(242,242,245,.30);
  --line:      rgba(255,255,255,.10);
  --line-2:    rgba(255,255,255,.055);
  --glow-cool: rgba(168,196,232,.16);
  --glow-violet:rgba(150,150,210,.12);

  --radius:    16px;
  --radius-sm: 11px;
  --ease:      cubic-bezier(.22,1,.36,1);
  --maxw:      1180px;

  --display:   "Montserrat", system-ui, sans-serif;
  --sans:      "Inter", system-ui, -apple-system, sans-serif;
  --mono:      "JetBrains Mono", ui-monospace, Menlo, monospace;
  --track:     .26em;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:clip; }
body{
  font-family:var(--sans); background:var(--bg); color:var(--text);
  line-height:1.6; overflow-x:clip; width:100%; max-width:100%; min-height:100vh; opacity:1;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; color:inherit; }
::selection{ background:rgba(255,255,255,.18); }
:focus-visible{ outline:1px solid rgba(255,255,255,.6); outline-offset:3px; }
body.leaving{ opacity:0; transition:opacity .24s var(--ease); }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px,5vw,44px); }

/* ---------- Atmospheric background ---------- */
.bg{ position:fixed; inset:0; z-index:0; overflow:hidden; pointer-events:none;
  background:radial-gradient(125% 80% at 50% -12%, #141419 0%, #0a0a0c 42%, #060607 72%); }
.aurora{ position:absolute; inset:0; }
.aurora i{
  position:absolute; top:-12%; height:124%; width:clamp(90px,12vw,180px);
  filter:blur(46px); mix-blend-mode:screen; opacity:.55; border-radius:50%;
  background:linear-gradient(180deg, transparent, rgba(196,210,234,.22) 45%, rgba(196,210,234,.05) 70%, transparent);
  animation:streak 18s ease-in-out infinite alternate;
}
.aurora i:nth-child(1){ left:8%;  animation-delay:0s;   opacity:.5; }
.aurora i:nth-child(2){ left:24%; animation-delay:-4s;  height:110%; background:linear-gradient(180deg,transparent,rgba(150,150,210,.18),transparent); }
.aurora i:nth-child(3){ left:42%; animation-delay:-8s;  opacity:.65; width:clamp(120px,16vw,240px); }
.aurora i:nth-child(4){ left:62%; animation-delay:-2s;  background:linear-gradient(180deg,transparent,rgba(168,196,232,.2),transparent); }
.aurora i:nth-child(5){ left:80%; animation-delay:-6s;  opacity:.45; }
.aurora::after{ content:""; position:absolute; right:-8%; top:8%; width:46vmax; height:46vmax;
  background:radial-gradient(circle, var(--glow-violet), transparent 62%); filter:blur(20px); }
@keyframes streak{ from{ transform:translateY(-3%) scaleY(1); opacity:.4; } to{ transform:translateY(3%) scaleY(1.08); opacity:.7; } }

.ghosts{ position:absolute; inset:0; }
.ghost{
  position:absolute; font-family:var(--display); font-weight:300; white-space:nowrap;
  color:#fff; opacity:.05; filter:blur(1.4px); letter-spacing:.06em; user-select:none;
  animation:floaty 22s ease-in-out infinite alternate;
}
.ghost.far{ opacity:.034; filter:blur(3px); }
.ghost.near{ opacity:.07; filter:blur(.6px); }
@keyframes floaty{ from{ transform:translateY(8px); } to{ transform:translateY(-8px); } }
@media (prefers-reduced-motion:reduce){ .aurora i,.ghost{ animation:none; } }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  height:46px; padding:0 24px; border:1px solid transparent; border-radius:100px;
  font-family:var(--display); font-size:12px; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  background:var(--text); color:#08080a; transition:transform .22s var(--ease), background .22s, color .22s, border-color .22s, opacity .22s;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-1px); background:#fff; }
.btn svg{ width:15px; height:15px; }
.btn.ghost{ background:transparent; color:var(--text); border-color:var(--line); }
.btn.ghost:hover{ background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.35); }
.btn.sm{ height:38px; padding:0 17px; font-size:11px; }
.btn.lg{ height:52px; padding:0 30px; font-size:12.5px; }
.btn.block{ width:100%; }

/* ---------- Top nav ---------- */
.nav{ position:fixed; top:0; left:0; right:0; z-index:100; height:74px; display:flex; align-items:center;
  transition:background .3s, border-color .3s, height .3s; border-bottom:1px solid transparent; }
.nav .wrap{ display:flex; align-items:center; gap:24px; }
.nav.scrolled{ height:62px; background:rgba(6,6,7,.72); backdrop-filter:blur(18px) saturate(130%); -webkit-backdrop-filter:blur(18px) saturate(130%); border-bottom:1px solid var(--line-2); }
.brand{ display:flex; align-items:center; flex-shrink:0; color:var(--text); }
.brand .lockup{ height:30px; width:auto; }
/* theme-aware signature: white on dark theme, dark signature on light theme */
.lockup-themed .sig-l{ display:none; }
.lockup-themed .sig-d{ display:block; }
[data-theme="light"] .lockup-themed .sig-d{ display:none; }
[data-theme="light"] .lockup-themed .sig-l{ display:block; }
.brand .txt{ display:flex; flex-direction:column; line-height:1; margin-left:11px; }
.brand .txt b{ font-family:var(--display); font-weight:400; font-size:15px; letter-spacing:.2em; text-transform:uppercase; }
.brand .txt span{ font-size:8.5px; letter-spacing:.34em; text-transform:uppercase; color:var(--muted); margin-top:4px; }
.nav-links{ display:flex; align-items:center; gap:2px; margin:0 auto; }
.nav-links a{ font-family:var(--display); font-size:12px; font-weight:400; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); padding:10px 16px; border-radius:8px; transition:color .2s, background .2s; }
.nav-links a:hover{ color:var(--text); }
.nav-right{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.nav-right .tel{ font-size:12.5px; color:var(--muted); font-family:var(--mono); }
.nav-right .tel:hover{ color:var(--text); }
.nav-toggle{ display:none; width:42px; height:42px; border-radius:10px; border:1px solid var(--line); background:transparent; color:var(--text); align-items:center; justify-content:center; }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:96vh; min-height:96svh; display:flex; align-items:center; justify-content:center; text-align:center; padding:140px 0 90px; }
.hero .wrap{ position:relative; z-index:3; }
.hero .mark{ width:66px; height:66px; margin:0 auto 30px; color:var(--text); opacity:.92; }
.hero .mark svg{ width:66px; height:66px; }
.eyebrow{ display:inline-flex; align-items:center; gap:10px; font-family:var(--display); font-size:11.5px; font-weight:500; letter-spacing:var(--track); text-transform:uppercase; color:var(--silver); margin-bottom:30px; }
.eyebrow .ln{ width:34px; height:1px; background:linear-gradient(90deg,transparent,var(--silver)); }
.eyebrow .ln.r{ background:linear-gradient(90deg,var(--silver),transparent); }
h1.head{ font-family:var(--display); font-weight:200; font-size:clamp(38px,6.6vw,82px); line-height:1.06; letter-spacing:-.01em; max-width:18ch; margin:0 auto 26px; }
h1.head b{ font-weight:500; }
h1.head .thin{ color:var(--silver); }
.hero .sub{ font-size:clamp(15px,1.55vw,18.5px); color:var(--muted); line-height:1.65; max-width:58ch; margin:0 auto 38px; font-weight:300; }
.hero .cta{ display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.scroll-cue{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:9px;
  font-family:var(--display); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--faint); }
.scroll-cue .d{ width:1px; height:34px; background:linear-gradient(180deg,var(--silver),transparent); animation:cue 2.2s var(--ease) infinite; }
@keyframes cue{ 0%,100%{ opacity:.3; transform:scaleY(.7); } 50%{ opacity:1; transform:scaleY(1); } }

/* ---------- Sections ---------- */
.section{ position:relative; z-index:2; padding:clamp(76px,12vh,160px) 0; }
.section.tight{ padding:clamp(46px,7vh,84px) 0; }
.sec-head{ max-width:60ch; margin-bottom:58px; }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.kicker{ display:inline-block; font-family:var(--display); font-size:11px; font-weight:500; letter-spacing:var(--track); text-transform:uppercase; color:var(--silver); margin-bottom:20px; }
h2.sec{ font-family:var(--display); font-weight:200; font-size:clamp(27px,4vw,46px); line-height:1.12; letter-spacing:-.01em; margin-bottom:18px; }
h2.sec b{ font-weight:500; }
.section .dek{ color:var(--muted); font-size:clamp(15px,1.5vw,17.5px); line-height:1.65; font-weight:300; }

/* divider line accent */
.rule{ width:100%; height:1px; background:linear-gradient(90deg,transparent,var(--line),transparent); }

/* trust strip */
.trust{ border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); }
.trust .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.trust .t{ text-align:center; padding:6px 0; }
.trust .t b{ display:block; font-family:var(--display); font-weight:200; font-size:clamp(28px,3.6vw,42px); letter-spacing:.01em; }
.trust .t span{ font-family:var(--display); font-size:10.5px; font-weight:400; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:8px; display:block; }
@media (max-width:640px){ .trust .wrap{ grid-template-columns:1fr 1fr; gap:30px 20px; } }

/* card grids */
.grid3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-2); border:1px solid var(--line-2); border-radius:var(--radius); overflow:hidden; }
.grid3 .card{ border-radius:0; border:0; background:var(--bg); }
.grid2{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media (max-width:900px){ .grid3{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .grid3{ grid-template-columns:1fr; } .grid2{ grid-template-columns:1fr; } }

.card{ position:relative; padding:32px 30px; background:var(--raise); border:1px solid var(--line); border-radius:var(--radius);
  transition:background .3s var(--ease), border-color .3s, transform .3s var(--ease); }
.card:hover{ background:rgba(255,255,255,.045); }
.grid2 .card:hover{ transform:translateY(-3px); border-color:rgba(255,255,255,.2); }
.card .ic{ width:44px; height:44px; display:grid; place-items:center; border:1px solid var(--line); border-radius:11px; color:var(--text); margin-bottom:22px; }
.card .ic svg{ width:21px; height:21px; }
.card h3{ font-family:var(--display); font-weight:400; font-size:17px; letter-spacing:.02em; margin-bottom:11px; }
.card p{ color:var(--muted); font-size:14px; line-height:1.65; font-weight:300; }
.card .meta{ font-family:var(--display); font-size:10.5px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:14px; }
.card .tags{ display:flex; flex-wrap:wrap; gap:7px; margin-top:18px; }
.card .tags span{ font-family:var(--mono); font-size:10.5px; color:var(--muted); padding:4px 10px; border-radius:100px; border:1px solid var(--line); }
.card .arrow{ display:inline-flex; align-items:center; gap:6px; margin-top:18px; font-family:var(--mono); font-size:12px; color:var(--silver); }
a.card{ display:block; }
.card{ overflow:hidden; }
.card-cover{ margin:-32px -30px 22px; height:176px; background:#0c0c0f center/cover no-repeat; border-bottom:1px solid var(--line); }

/* split feature */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:center; }
@media (max-width:880px){ .split{ grid-template-columns:1fr; gap:38px; } }
.feat-list{ margin-top:32px; display:flex; flex-direction:column; gap:2px; }
.feat-list .f{ display:flex; gap:16px; padding:18px 0; border-top:1px solid var(--line-2); }
.feat-list .f:last-child{ border-bottom:1px solid var(--line-2); }
.feat-list .f .fi{ width:30px; height:30px; flex-shrink:0; display:grid; place-items:center; color:var(--silver); }
.feat-list .f .fi svg{ width:19px; height:19px; }
.feat-list .f h4{ font-family:var(--display); font-weight:400; font-size:15px; letter-spacing:.02em; margin-bottom:4px; }
.feat-list .f p{ color:var(--muted); font-size:13.6px; line-height:1.6; font-weight:300; }

.panel-card{ position:relative; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:linear-gradient(180deg,#0d0d10,#08080a); padding:34px 32px; }
.panel-card::before{ content:""; position:absolute; right:-30%; top:-40%; width:80%; height:120%; background:radial-gradient(circle,var(--glow-cool),transparent 60%); pointer-events:none; }
.panel-card .pc-mark{ position:absolute; right:24px; top:22px; width:30px; height:30px; color:rgba(255,255,255,.16); }
.metric-row{ position:relative; display:flex; gap:14px; margin-bottom:24px; }
.metric{ flex:1; text-align:left; }
.metric b{ display:block; font-family:var(--display); font-weight:200; font-size:30px; letter-spacing:.01em; }
.metric span{ font-family:var(--display); font-size:9.5px; font-weight:400; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:6px; display:block; }
.stat-line{ position:relative; font-family:var(--mono); font-size:12.5px; color:var(--muted); padding:11px 0; border-top:1px solid var(--line-2); display:flex; gap:12px; align-items:center; }
.stat-line .ok{ color:var(--silver); }

/* process steps */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-2); border:1px solid var(--line-2); border-radius:var(--radius); overflow:hidden; }
@media (max-width:760px){ .steps{ grid-template-columns:1fr; } }
.step{ padding:34px 30px; background:var(--bg); }
.step .n{ font-family:var(--display); font-weight:200; font-size:34px; color:var(--silver); margin-bottom:18px; letter-spacing:.02em; }
.step h4{ font-family:var(--display); font-weight:400; font-size:16px; letter-spacing:.02em; margin-bottom:10px; }
.step p{ color:var(--muted); font-size:13.8px; line-height:1.65; font-weight:300; }

/* new age of tech */
.na-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:8px; }
@media (max-width:900px){ .na-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .na-grid{ grid-template-columns:1fr; } }
.na-card{ position:relative; padding:30px 28px; border:1px solid var(--line); border-radius:var(--radius); background:var(--raise); transition:background .3s, border-color .3s, transform .3s var(--ease); overflow:hidden; }
.na-card::after{ content:""; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(420px 200px at 18% -10%, rgba(255,255,255,.06), transparent 70%); opacity:0; transition:opacity .4s; pointer-events:none; }
.na-card:hover{ transform:translateY(-4px); border-color:rgba(255,255,255,.22); background:rgba(255,255,255,.045); }
.na-card:hover::after{ opacity:1; }
.na-ic{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; border:1px solid var(--line-2); color:var(--text); margin-bottom:18px; transition:border-color .3s; }
.na-ic svg{ width:21px; height:21px; }
.na-card:hover .na-ic{ border-color:rgba(255,255,255,.35); }
.na-card h4{ font-family:var(--display); font-weight:400; font-size:16px; letter-spacing:.02em; margin-bottom:9px; }
.na-card p{ color:var(--muted); font-size:13.8px; line-height:1.66; font-weight:300; }
.na-cta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:34px; }

/* engage bar (thumbs + share) — shared by article + project pages */
.art-engage{ display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between; margin:30px 0 0; padding-top:22px; border-top:1px solid var(--line-2); }
.vote{ display:flex; align-items:center; gap:10px; }
.vote-l,.share-l{ font-size:12.5px; color:var(--faint); }
.vbtn{ display:inline-flex; align-items:center; gap:7px; font-size:13px; color:var(--silver); background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:100px; padding:7px 13px; cursor:pointer; transition:.15s; }
.vbtn:hover{ border-color:rgba(255,255,255,.4); color:var(--text); }
.vbtn.on{ background:var(--text); color:#08080a; border-color:var(--text); }
.vbtn svg{ width:15px; height:15px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.share{ display:flex; align-items:center; gap:8px; }
.sh{ width:34px; height:34px; display:grid; place-items:center; border-radius:50%; border:1px solid var(--line); color:var(--silver); font-family:var(--display); font-size:14px; text-decoration:none; transition:.15s; cursor:pointer; }
.sh:hover{ border-color:rgba(255,255,255,.45); color:var(--text); transform:translateY(-1px); }
.sh.copied{ background:var(--text); color:#08080a; }
[data-theme="light"] .vbtn{ background:rgba(0,0,0,.03); }
[data-theme="light"] .vbtn:hover{ border-color:rgba(0,0,0,.4); }
[data-theme="light"] .vbtn.on{ color:#fff; }
[data-theme="light"] .sh:hover{ border-color:rgba(0,0,0,.45); }
[data-theme="light"] .sh.copied{ color:#fff; }
[data-theme="light"] .na-card:hover{ background:rgba(0,0,0,.03); border-color:rgba(0,0,0,.2); }
[data-theme="light"] .na-card::after{ background:radial-gradient(420px 200px at 18% -10%, rgba(0,0,0,.05), transparent 70%); }
[data-theme="light"] .na-card:hover .na-ic,[data-theme="light"] .na-ic{ border-color:var(--line-2); }

/* posts */
.posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width:900px){ .posts{ grid-template-columns:1fr; } }
.post{ display:flex; flex-direction:column; padding:30px; border:1px solid var(--line); border-radius:var(--radius); background:var(--raise); transition:background .3s, border-color .3s, transform .25s; }
.post:hover{ background:rgba(255,255,255,.045); border-color:rgba(255,255,255,.2); transform:translateY(-3px); }
.post .pc{ font-family:var(--display); font-size:10px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); }
.post h3{ font-family:var(--display); font-weight:400; font-size:18px; letter-spacing:.01em; margin:14px 0 12px; line-height:1.35; }
.post p{ color:var(--muted); font-size:13.6px; line-height:1.6; flex:1; font-weight:300; }
.post .by{ font-family:var(--mono); font-size:11.5px; color:var(--faint); margin-top:18px; }
.post{ overflow:hidden; }
.post-cover{ margin:-30px -30px 18px; height:160px; background:#0c0c0f center/cover no-repeat; border-bottom:1px solid var(--line); }

/* big CTA */
.cta-block{ position:relative; border:1px solid var(--line); border-radius:22px; overflow:hidden; padding:clamp(48px,8vw,90px) 30px; text-align:center; background:linear-gradient(180deg,#0d0d10,#08080a); }
.cta-block::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 80% at 50% 0%, var(--glow-cool), transparent 65%); pointer-events:none; }
.cta-block > *{ position:relative; z-index:2; }
.cta-block .mk{ width:54px; height:54px; margin:0 auto 24px; color:var(--text); opacity:.9; }
.cta-block h2{ font-family:var(--display); font-weight:200; font-size:clamp(28px,4.4vw,48px); letter-spacing:-.01em; line-height:1.1; margin-bottom:16px; }
.cta-block h2 b{ font-weight:500; }
.cta-block p{ color:var(--muted); font-size:16.5px; max-width:48ch; margin:0 auto 30px; font-weight:300; }
.cta-block .cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- Slide-in sheets ---------- */
.scrim{ position:fixed; inset:0; z-index:200; background:rgba(3,3,4,.66); backdrop-filter:blur(5px); opacity:0; pointer-events:none; transition:opacity .35s var(--ease); }
.scrim.on{ opacity:1; pointer-events:auto; }
.sheet-wrap{ position:fixed; inset:0; z-index:210; display:flex; justify-content:flex-end; pointer-events:none; overflow:hidden; }
.sheet{ width:min(640px,100%); height:100%; overflow-y:auto; background:var(--bg-2); border-left:1px solid var(--line); transform:translateX(100%); transition:transform .5s var(--ease); padding:32px clamp(20px,3.4vw,42px) 60px; }
.sheet-wrap.on{ pointer-events:auto; }
.sheet-wrap.on .sheet{ transform:translateX(0); }
.sheet-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:18px; margin-bottom:28px; padding-bottom:24px; border-bottom:1px solid var(--line-2); }
.sheet-head .k{ font-family:var(--display); font-size:10.5px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:12px; }
.sheet-head h3{ font-family:var(--display); font-weight:200; font-size:clamp(22px,3.2vw,30px); line-height:1.15; letter-spacing:-.01em; }
.sheet-head p{ color:var(--muted); margin-top:11px; line-height:1.6; font-size:14px; font-weight:300; }
.sheet-head .x{ flex-shrink:0; width:38px; height:38px; border-radius:50%; border:1px solid var(--line); background:transparent; color:var(--text); font-size:15px; display:grid; place-items:center; transition:background .2s, transform .2s; }
.sheet-head .x:hover{ background:rgba(255,255,255,.08); transform:rotate(90deg); }

/* forms */
.field{ margin-bottom:15px; }
.field label{ display:block; font-family:var(--display); font-size:10.5px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:9px; }
.field input,.field select,.field textarea{ width:100%; background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:11px; padding:13px 15px; font-size:14.5px; font-family:var(--sans); color:var(--text); transition:border-color .2s, box-shadow .2s, background .2s; -webkit-appearance:none; appearance:none; }
.field textarea{ min-height:120px; resize:vertical; }
.field input::placeholder,.field textarea::placeholder{ color:var(--faint); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:rgba(255,255,255,.4); background:rgba(255,255,255,.055); box-shadow:0 0 0 3px rgba(255,255,255,.06); }
.field select{ background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'><path stroke='%23999' stroke-width='1.5' d='m1 1 5 5 5-5'/></svg>"); background-repeat:no-repeat; background-position:right 15px center; padding-right:38px; }
.frow{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:560px){ .frow{ grid-template-columns:1fr; } }
.note-ok{ padding:14px 16px; border-radius:12px; background:rgba(255,255,255,.05); border:1px solid var(--line); margin-bottom:16px; font-size:14px; }
.contact-meta{ display:flex; gap:28px; flex-wrap:wrap; margin-top:26px; padding-top:24px; border-top:1px solid var(--line-2); font-size:13.5px; color:var(--muted); }
.contact-meta .l{ font-family:var(--display); font-size:10px; font-weight:500; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); margin-bottom:6px; }

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

/* ---------- Footer ---------- */
.foot{ position:relative; z-index:2; border-top:1px solid var(--line-2); padding:70px 0 40px; margin-top:30px; }
.foot-cols{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:38px; padding-bottom:44px; border-bottom:1px solid var(--line-2); }
@media (max-width:760px){
  .foot-cols{ grid-template-columns:1fr 1fr; gap:32px 24px; }
  .foot-col:first-child{ grid-column:1 / -1; }
  .foot-nl{ max-width:none; width:100%; }
}
@media (max-width:460px){
  .foot-cols{ grid-template-columns:1fr; gap:30px; }
  .foot-bottom{ flex-direction:column; align-items:flex-start; gap:14px; }
}
.foot-col .brand{ margin-bottom:6px; }
.foot-col h5{ font-family:var(--display); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--faint); margin-bottom:18px; font-weight:500; }
.foot-col a,.foot-col p{ display:block; color:var(--muted); font-size:13.6px; line-height:2.05; transition:color .2s; }
.foot-col a:hover{ color:var(--text); }
.foot-about{ color:var(--muted); font-size:13.6px; line-height:1.7; margin:16px 0; max-width:34ch; font-weight:300; }
.foot-nl{ display:flex; gap:8px; max-width:340px; margin-top:6px; }
.foot-nl input{ flex:1; background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:100px; padding:11px 16px; color:var(--text); font-size:13.5px; }
.foot-nl input:focus{ outline:none; border-color:rgba(255,255,255,.4); }
.parent-co{ font-family:var(--mono); font-size:11px; color:var(--faint); margin-top:10px; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; padding-top:28px; font-size:12.5px; color:var(--faint); }
.foot-bottom .links{ display:flex; gap:20px; flex-wrap:wrap; }
.foot-bottom a:hover{ color:var(--text); }

/* ---------- Lenis momentum scroll (desktop only) ---------- */
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }
.lenis.lenis-stopped{ overflow:hidden; }
.lenis.lenis-smooth iframe{ pointer-events:none; }

/* ---------- responsive nav ---------- */
@media (max-width:860px){
  .nav .wrap{ gap:12px; }
  .nav-right{ margin-left:auto; }
  .nav-links{ position:fixed; top:62px; left:0; right:0; flex-direction:column; gap:2px; padding:16px 22px 24px; margin:0;
    background:rgba(6,6,7,.97); backdrop-filter:blur(18px); border-bottom:1px solid var(--line);
    transform:translateY(-130%); transition:transform .35s var(--ease); }
  .nav-links.open{ transform:none; }
  .nav-links a{ width:100%; padding:14px; font-size:13px; }
  .nav-right .tel{ display:none; }
  .nav-toggle{ display:flex; }
}

/* ---------- mobile polish ---------- */
@media (max-width:680px){
  .hero{ min-height:auto; padding:128px 0 70px; }
  .hero .mark, .hero .mark svg{ width:56px; height:56px; }
  .eyebrow{ margin-bottom:24px; }
  .eyebrow .ln{ width:22px; }
  h1.head{ font-size:clamp(32px,9vw,46px); }
  .card{ padding:26px 24px; }
  .card-cover{ margin:-26px -24px 18px; height:150px; }
  .panel-card{ padding:26px 22px; }
  .metric-row{ flex-wrap:wrap; gap:18px 14px; }
  .metric{ flex:1 1 40%; }
  .metric b{ font-size:26px; }
  /* tame the ghost-words so they never crowd small screens */
  .ghost{ font-size:18px !important; opacity:.045; filter:blur(2px); }
  .ghost.near{ opacity:.06; }
  .ghost.far{ opacity:.03; }
  .sheet{ padding:26px 18px 50px; }
  .cta-block{ padding:44px 22px; }
}
@media (max-width:380px){
  .nav-right .btn.sm{ padding:0 13px; font-size:10px; letter-spacing:.1em; }
  .brand .lockup{ height:24px; }
  h1.head{ font-size:clamp(28px,8.6vw,40px); }
}

/* ---------- Project detail page ---------- */
.pd-wrap{ position:relative; z-index:2; max-width:960px; margin:0 auto; padding:130px clamp(20px,5vw,40px) 90px; }
.pd-back{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--muted); margin-bottom:30px; }
.pd-back:hover{ color:var(--text); }
.pd-kicker{ display:block; font-family:var(--display); font-size:11px; font-weight:500; letter-spacing:var(--track); text-transform:uppercase; color:var(--silver); margin-bottom:16px; }
.pd-title{ font-family:var(--display); font-weight:200; font-size:clamp(32px,5.6vw,60px); line-height:1.05; letter-spacing:-.01em; margin-bottom:18px; }
.pd-blurb{ color:var(--muted); font-size:clamp(15px,1.7vw,19px); font-weight:300; line-height:1.65; max-width:62ch; }
.pd-meta{ display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; margin:28px 0 40px; }
.pd-tags{ display:flex; flex-wrap:wrap; gap:8px; }
.pd-tags span{ font-family:var(--mono); font-size:11px; color:var(--muted); padding:6px 12px; border-radius:100px; border:1px solid var(--line); }
.pd-lead{ width:100%; aspect-ratio:16/9; border-radius:var(--radius); border:1px solid var(--line); background:#0c0c0f center/cover no-repeat; cursor:zoom-in; }
.pd-gallery{ display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:12px; margin-top:14px; }
.pd-thumb{ aspect-ratio:4/3; border-radius:12px; border:1px solid var(--line); background:#0c0c0f center/cover no-repeat; cursor:zoom-in; transition:border-color .2s, transform .2s; }
.pd-thumb:hover{ border-color:rgba(255,255,255,.4); transform:translateY(-2px); }
.pd-noimg{ text-align:center; padding:70px 20px; border:1px solid var(--line-2); border-radius:var(--radius); color:var(--faint); }
.pd-noimg svg{ margin:0 auto 16px; opacity:.5; }
.pd-noimg p{ font-weight:300; }
.pd-cta{ text-align:center; margin-top:70px; padding-top:50px; border-top:1px solid var(--line-2); }
.pd-cta h2{ font-family:var(--display); font-weight:200; font-size:clamp(24px,3.4vw,38px); letter-spacing:-.01em; }

/* ---------- Lightbox ---------- */
.lightbox{ position:fixed; inset:0; z-index:300; background:rgba(4,4,6,.92); display:flex; align-items:center; justify-content:center; padding:30px; opacity:0; pointer-events:none; transition:opacity .3s var(--ease); }
.lightbox.on{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:92vw; max-height:88vh; border-radius:10px; box-shadow:0 40px 100px -30px rgba(0,0,0,.9); }
.lb-close{ position:absolute; top:22px; right:24px; width:44px; height:44px; border-radius:50%; border:1px solid var(--line); background:rgba(255,255,255,.05); color:var(--text); font-size:17px; display:grid; place-items:center; transition:background .2s; }
.lb-close:hover{ background:rgba(255,255,255,.14); }
@media (max-width:560px){ .pd-lead{ aspect-ratio:4/3; } }

/* ---------- Floating assistant launcher ---------- */
.ag-launch{ position:fixed; right:22px; bottom:22px; z-index:120; display:inline-flex; align-items:center; gap:9px; height:50px; padding:0 22px 0 16px; border-radius:100px; background:var(--text); color:#08080a; font-family:var(--display); font-size:12px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; box-shadow:0 16px 40px -14px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.12); transition:transform .2s var(--ease); }
.ag-launch:hover{ transform:translateY(-2px); }
.ag-launch-ic{ width:22px; height:22px; display:grid; place-items:center; }
.ag-launch-ic svg{ width:20px; height:20px; }
@media (max-width:560px){ .ag-launch{ right:16px; bottom:16px; height:52px; width:52px; padding:0; justify-content:center; } .ag-launch-tx{ display:none; } }

/* ============================================================
   Custom vertical scrollbar — monochrome, slim, on-brand
   ============================================================ */
html{ scrollbar-width:thin; scrollbar-color:rgba(255,255,255,.20) transparent; }
::-webkit-scrollbar{ width:12px; height:12px; }
::-webkit-scrollbar-track{ background:transparent; }
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,.10));
  border-radius:100px; border:3px solid transparent; background-clip:padding-box;
}
::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,rgba(255,255,255,.40),rgba(255,255,255,.20));
  background-clip:padding-box;
}
::-webkit-scrollbar-corner{ background:transparent; }

/* ============================================================
   Theme toggle control (injected into the nav by site.js)
   ============================================================ */
.theme-toggle{
  width:38px; height:38px; border-radius:50%; flex-shrink:0;
  border:1px solid var(--line); background:transparent; color:var(--muted);
  display:grid; place-items:center;
  transition:color .2s, border-color .2s, background .2s, transform .5s var(--ease);
}
.theme-toggle:hover{ color:var(--text); border-color:rgba(255,255,255,.34); background:rgba(255,255,255,.05); transform:rotate(18deg); }
.theme-toggle svg{ width:17px; height:17px; }
.theme-toggle .ic-sun{ display:none; }
[data-theme="light"] .theme-toggle .ic-sun{ display:block; }
[data-theme="light"] .theme-toggle .ic-moon{ display:none; }
@media (max-width:380px){ .theme-toggle{ width:34px; height:34px; } }

/* ============================================================
   LIGHT THEME VARIATION  — [data-theme="light"]
   A soft, paper-bright counterpart to the dark monochrome.
   ============================================================ */
:root[data-theme="light"]{
  --bg:        #f3f3f6;
  --bg-2:      #ececed;
  --panel:     #ffffff;
  --raise:     rgba(0,0,0,.022);
  --text:      #15161a;
  --silver:    #3b3c44;
  --muted:     rgba(21,22,26,.60);
  --faint:     rgba(21,22,26,.40);
  --line:      rgba(0,0,0,.13);
  --line-2:    rgba(0,0,0,.07);
  --glow-cool: rgba(120,150,200,.16);
  --glow-violet:rgba(120,120,180,.12);
}
[data-theme="light"] .bg{
  background:radial-gradient(125% 80% at 50% -12%, #ffffff 0%, #eef0f4 44%, #e6e7ec 74%);
}
[data-theme="light"] .aurora i{ opacity:.30; mix-blend-mode:multiply; filter:blur(50px); }
[data-theme="light"] .aurora i:nth-child(1),
[data-theme="light"] .aurora i:nth-child(3),
[data-theme="light"] .aurora i:nth-child(5){ opacity:.22; }
[data-theme="light"] .aurora::after{ opacity:.5; }
[data-theme="light"] .ghost{ color:#0b0c12; opacity:.05; }
[data-theme="light"] .ghost.far{ opacity:.035; }
[data-theme="light"] .ghost.near{ opacity:.07; }
[data-theme="light"] ::selection{ background:rgba(0,0,0,.14); }
[data-theme="light"] :focus-visible{ outline-color:rgba(0,0,0,.6); }

/* buttons invert cleanly: dark fill + light text on light page */
[data-theme="light"] .btn{ color:#fff; }
[data-theme="light"] .btn:hover{ background:#000; color:#fff; }
[data-theme="light"] .btn.ghost{ color:var(--text); border-color:var(--line); }
[data-theme="light"] .btn.ghost:hover{ background:rgba(0,0,0,.05); border-color:rgba(0,0,0,.34); }
[data-theme="light"] .ag-launch{ color:#fff; }

/* nav */
[data-theme="light"] .nav.scrolled{ background:rgba(255,255,255,.78); border-bottom-color:var(--line-2); }
[data-theme="light"] .theme-toggle:hover{ border-color:rgba(0,0,0,.34); background:rgba(0,0,0,.05); }
@media (max-width:860px){
  [data-theme="light"] .nav-links{ background:rgba(255,255,255,.97); border-bottom-color:var(--line); }
}

/* form fields */
[data-theme="light"] .field input,
[data-theme="light"] .field select,
[data-theme="light"] .field textarea,
[data-theme="light"] .foot-nl input{ background:rgba(0,0,0,.03); }
[data-theme="light"] .field input:focus,
[data-theme="light"] .field select:focus,
[data-theme="light"] .field textarea:focus{ border-color:rgba(0,0,0,.4); background:rgba(0,0,0,.05); box-shadow:0 0 0 3px rgba(0,0,0,.05); }
[data-theme="light"] .field select{ background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'><path stroke='%23666' stroke-width='1.5' d='m1 1 5 5 5-5'/></svg>"); }
[data-theme="light"] .note-ok{ background:rgba(0,0,0,.04); }

/* cards / surfaces that hardcoded dark fills */
[data-theme="light"] .pd-lead,
[data-theme="light"] .pd-thumb{ background-color:#e6e7ec; }
[data-theme="light"] .lightbox{ background:rgba(230,231,236,.94); }
[data-theme="light"] .lb-close{ background:rgba(0,0,0,.06); }
[data-theme="light"] .lb-close:hover{ background:rgba(0,0,0,.14); }
[data-theme="light"] .ag-launch{ box-shadow:0 16px 40px -14px rgba(0,0,0,.35), 0 0 0 1px rgba(0,0,0,.10); }
[data-theme="light"] .sheet-head .x:hover{ background:rgba(0,0,0,.08); }

/* hover tints & borders flip to dark on a light page */
[data-theme="light"] .card:hover,
[data-theme="light"] .post:hover{ background:rgba(0,0,0,.03); }
[data-theme="light"] .grid2 .card:hover,
[data-theme="light"] .post:hover{ border-color:rgba(0,0,0,.2); }
[data-theme="light"] .pd-thumb:hover{ border-color:rgba(0,0,0,.42); }
[data-theme="light"] .card-cover,
[data-theme="light"] .post-cover{ background-color:#e6e7ec; }
[data-theme="light"] .foot-nl input:focus{ border-color:rgba(0,0,0,.4); }
[data-theme="light"] .nav-toggle{ border-color:var(--line); }

/* dark accent panels stay dark in both themes — keep their interior light */
[data-theme="light"] .panel-card,
[data-theme="light"] .cta-block{ color:#f3f3f6; border-color:rgba(255,255,255,.10); }
[data-theme="light"] .panel-card .metric span,
[data-theme="light"] .panel-card .stat-line,
[data-theme="light"] .cta-block p{ color:rgba(243,243,246,.62); }
[data-theme="light"] .panel-card .stat-line .ok{ color:#c7c8cd; }
[data-theme="light"] .cta-block .mk{ color:#f3f3f6; }
[data-theme="light"] .panel-card .pc-mark{ color:rgba(255,255,255,.18); }
/* buttons that sit on the dark panels behave like the dark-theme pill */
[data-theme="light"] .cta-block .btn{ background:#f3f3f6; color:#08080a; border-color:#f3f3f6; }
[data-theme="light"] .cta-block .btn:hover{ background:#fff; }
[data-theme="light"] .cta-block .btn.ghost{ background:transparent; color:#f3f3f6; border-color:rgba(255,255,255,.26); }
[data-theme="light"] .cta-block .btn.ghost:hover{ background:rgba(255,255,255,.10); border-color:rgba(255,255,255,.5); }

/* light scrollbar */
[data-theme="light"]{ scrollbar-color:rgba(0,0,0,.26) transparent; }
[data-theme="light"] ::-webkit-scrollbar-thumb{ background:linear-gradient(180deg,rgba(0,0,0,.26),rgba(0,0,0,.12)); background-clip:padding-box; }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover{ background:linear-gradient(180deg,rgba(0,0,0,.42),rgba(0,0,0,.22)); background-clip:padding-box; }

/* ============ ULTRA OVERRIDE LAYER ============ */
/* ============================================================
   ROMANOV SOLUTIONS · ULTRA skin — "Bioluminescent"
   immunefi-style living particle field + big, wide, spaced layout +
   de-blur/ignite reveal. Appended after site.css when composing
   themes/ultra.css; these rules load last and win. Maps the approved
   premium-bioluminescent preview onto the real site's classes.
   ============================================================ */

/* ---------- tokens ---------- */
:root{
  /* accent stops — overridden per-site by Admin → Theme FX (fx_head) */
  --c1: #ff2e9a;  --c1-rgb: 255,46,154;
  --c2: #9a5cff;  --c2-rgb: 154,92,255;
  --c3: #34e3ff;  --c3-rgb: 52,227,255;
  --bg:        #06060a;
  --bg-2:      #0a0a12;
  --panel:     #0d0d16;
  --raise:     rgba(255,255,255,.03);
  --text:      #f4f2fb;
  --silver:    #cfcce2;
  --muted:     rgba(244,242,251,.62);
  --faint:     rgba(244,242,251,.36);
  --line:      rgba(255,255,255,.085);
  --line-2:    rgba(255,255,255,.05);

  --magenta:   var(--c1);
  --pink:      var(--c1);
  --violet:    var(--c2);
  --cyan:      var(--c3);
  --rs-accent: var(--c1);
  --grad:      linear-gradient(100deg, var(--c1) 0%, var(--c1) 34%, var(--c2) 72%, var(--c3) 120%);
  --grad-text: linear-gradient(96deg, var(--c1) 0%, var(--c1) 36%, var(--c2) 70%, var(--c3) 110%);
  --glow-cool:  rgba(var(--c3-rgb),.16);
  --glow-violet:rgba(var(--c1-rgb),.18);

  --display:   "Space Grotesk", "Inter", system-ui, sans-serif;
  --sans:      "Inter", system-ui, -apple-system, sans-serif;
  --mono:      "Space Grotesk", "JetBrains Mono", ui-monospace, monospace;
  --track:     .22em;
  --maxw:      1280px;
}

/* ---------- atmosphere: the particle field replaces the aurora ---------- */
.bg{ display:none; }                 /* LUX aurora off — the canvas is the backdrop */
body{ background:var(--bg); }
::selection{ background:rgba(var(--c1-rgb),.35); color:#fff; }

/* injected by ultra.js */
#rs-field{ position:fixed; inset:0; width:100%; height:100%; z-index:0; display:block; pointer-events:none; }
.rs-field-fallback{
  position:fixed; inset:0; z-index:0; pointer-events:none; opacity:0; transition:opacity .8s ease;
  background:
    radial-gradient(1100px 620px at 50% 118%, rgba(var(--c1-rgb),.42), transparent 60%),
    radial-gradient(820px 520px at 22% 96%, rgba(var(--c2-rgb),.34), transparent 62%),
    radial-gradient(760px 480px at 82% 104%, rgba(var(--c3-rgb),.22), transparent 60%),
    radial-gradient(620px 420px at 50% 30%, rgba(var(--c2-rgb),.12), transparent 70%);
}
.rs-field-fallback.show{ opacity:1; }
.rs-scrim{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(6,6,10,.42) 0%, rgba(6,6,10,0) 16%, rgba(6,6,10,0) 72%, rgba(6,6,10,.40) 92%, rgba(6,6,10,.7) 100%);
}

/* ---------- typography ---------- */
h1.head, h2.sec, h1.pd-title, .cat-hero h1, .pdp-info h1, .cta-band h2, .cta-block h2, .metric b, .trust .t b, .step .n{
  font-family:var(--display); letter-spacing:-.025em;
}
h1.head{ font-weight:500; }
h2.sec{ font-weight:500; }
/* the gradient "moment" — emphasis words inside headings */
h1.head b, h2.sec b, .cat-hero h1 b, .cta-band h2 b, .cta-block h2 b, .pd-title b, h1.head .grad, h2.sec .grad{
  font-weight:700; position:relative;
  background:var(--grad-text); background-size:200% auto;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  animation:rs-gradshift 8s ease infinite;
}
h1.head b::after, h2.sec b::after, .cat-hero h1 b::after, .cta-band h2 b::after, .cta-block h2 b::after{
  content:""; position:absolute; left:-4%; right:-4%; bottom:6%; height:46%;
  background:radial-gradient(60% 100% at 50% 50%, rgba(var(--c1-rgb),.26), transparent 75%);
  filter:blur(22px); z-index:-1; pointer-events:none;
}
@keyframes rs-gradshift{ 0%,100%{ background-position:0% 50% } 50%{ background-position:100% 50% } }
.kicker, .cat-kicker, .wwb-eyebrow, .sec-eyebrow, .shop-cat, .post .pc, .pd-kicker{ color:var(--magenta); }
.eyebrow{ color:var(--silver); }

/* ---------- premium reveal: de-blur + rise + clip (site.js toggles .in) ---------- */
.reveal{
  opacity:0; transform:translateY(22px);
  transition:opacity .55s cubic-bezier(.16,.84,.24,1), transform .6s cubic-bezier(.16,.84,.24,1);
  will-change:opacity, transform;
}
.reveal.in{ opacity:1; transform:none; }
/* one-shot "ignite" glow as headings settle in */
.sec-head.reveal.in h2, .cat-hero h1, .hero .reveal.in h1{ animation:rs-ignite 1.3s cubic-bezier(.2,.7,.3,1) .12s 1 both; }
@keyframes rs-ignite{
  0%{ text-shadow:0 0 0 rgba(var(--c1-rgb),0) } 30%{ text-shadow:0 0 26px rgba(255,91,176,.45), 0 0 50px rgba(var(--c2-rgb),.26) }
  100%{ text-shadow:0 0 0 rgba(var(--c1-rgb),0) }
}

/* ---------- nav ---------- */
.nav.scrolled{ background:rgba(6,6,10,.72); border-bottom:1px solid var(--line); }
.nav-links a, .wwb-trigger{ position:relative; }
.nav-links a:hover, .wwb-trigger:hover, .wwb-trigger[aria-expanded=true]{ color:var(--text); }
.nav-links a::after{ content:""; position:absolute; left:16px; right:16px; bottom:4px; height:1.5px; background:var(--grad); transform:scaleX(0); transform-origin:left; transition:transform .3s ease; }
.nav-links a:hover::after{ transform:scaleX(1); }

/* ---------- buttons → gradient ---------- */
.btn, .btn-accent, .shop-btn, .wwb-plan{
  background:var(--grad); background-size:180% 180%; color:#fff; border:1px solid transparent;
  box-shadow:0 8px 26px -8px rgba(var(--c1-rgb),.5), inset 0 0 0 1px rgba(255,255,255,.12);
  animation:rs-gradshift 9s ease infinite;
}
.btn:hover, .btn-accent:hover, .shop-btn:hover, .wwb-plan:hover{ transform:translateY(-2px); background:#fff; color:#0a0410; -webkit-text-fill-color:#0a0410; filter:none; box-shadow:0 16px 42px -10px rgba(var(--c1-rgb),.55), 0 0 0 1px rgba(255,255,255,.35); }
/* keep any inner arrow/spans dark too on the white hover */
.btn:hover *, .btn-accent:hover *, .shop-btn:hover *, .wwb-plan:hover *{ color:#0a0410; -webkit-text-fill-color:#0a0410; }
.btn.ghost, .btn-line{ background:rgba(255,255,255,.02); color:var(--text); border:1px solid var(--line-2); box-shadow:none; animation:none; }
.btn.ghost:hover, .btn-line:hover{ border-color:rgba(var(--c1-rgb),.6); background:rgba(255,255,255,.05); }

/* ---------- cards: glass + mouse-tracking inner glow + gradient border ---------- */
.panel-card, .cta-block, .cta-band-in, .seo-local-in, .pdp-media{
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012)); border:1px solid var(--line);
}
/* the lift cards: a soft radial glow that follows the cursor (vars set by ultra.js).
   --my defaults to 120% so the glow rests off-card until the pointer enters. */
.card, .na-card, .post, .shop-card, .fam-card, .cat-item, .rt-card{
  --mx:50%; --my:120%;
  position:relative; overflow:hidden; border:1px solid var(--line);
  background:
    radial-gradient(420px 420px at var(--mx) var(--my), rgba(var(--c1-rgb),.36), rgba(var(--c2-rgb),.18) 38%, rgba(var(--c3-rgb),.08) 58%, transparent 74%),
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  transition:transform .45s cubic-bezier(.16,.84,.24,1), border-color .4s ease, box-shadow .45s ease;
}
/* true gradient border, revealed on hover via a masked ::before ring */
.card::before, .na-card::before, .post::before, .shop-card::before, .fam-card::before, .cat-item::before, .rt-card::before{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .4s ease; pointer-events:none;
}
.card:hover, .na-card:hover, .post:hover, .shop-card:hover, .fam-card:hover, .cat-item:hover, .rt-card:hover{
  transform:translateY(-7px); border-color:rgba(var(--c1-rgb),.4);
  box-shadow:0 36px 84px -34px rgba(var(--c1-rgb),.45);
}
.card:hover::before, .na-card:hover::before, .post:hover::before, .shop-card:hover::before, .fam-card:hover::before, .cat-item:hover::before, .rt-card:hover::before{ opacity:.9; }

/* ---------- chips / accents ---------- */
.cat-chip{ color:var(--cyan-2,#6ee7f4); border-color:rgba(var(--c3-rgb),.32); }
.cat-mode-h{ color:var(--text); }
.shop-badge{ background:var(--grad); color:#fff; }
.wwb-fam.on{ background:rgba(var(--c1-rgb),.12); }
.wwb-fam.on svg, .wwb-fam.on .wwb-fam-n, .wwb-cat:hover, .wwb-panel-cta, .wwb-more, .wwb-tab-all, .wwb-foot a{ color:var(--magenta); }
.rt-cta, .cat-item .ci-modes i{ color:var(--magenta); border-color:rgba(var(--c1-rgb),.3); }

/* ---------- spacing: big + wide + airy ---------- */
.section{ padding:clamp(84px,13vh,170px) 0; }
.hero{ min-height:100vh; padding:clamp(150px,24vh,230px) 0 clamp(90px,14vh,160px); }
h1.head{ font-size:clamp(42px,7.4vw,92px); line-height:1.02; max-width:17ch; }
h2.sec{ font-size:clamp(30px,4.6vw,56px); line-height:1.06; }
.hero .sub, .section .dek{ font-size:clamp(16px,1.9vw,20px); line-height:1.62; color:var(--silver); }
.sec-head{ margin-bottom:clamp(40px,6vh,70px); }

/* keep page-scene heroes transparent so the field shows through */
.page-scene{ background:transparent !important; }
.page-scene::after, .page-scene::before{ opacity:.18 !important; }

/* ---------- footer ---------- */
.foot{ border-top:1px solid var(--line); }
.foot h5{ color:var(--magenta); }

/* ============================================================
   IDLE SCREENSAVER — re-tinted to the bioluminescent palette
   (structure defined here; ultra.js builds + drives it)
   ============================================================ */
body.rs-saver-open{ overflow:hidden; }
.rs-saver{ position:fixed; inset:0; z-index:100000; display:none; opacity:0;
  background:radial-gradient(140% 120% at 50% 30%, rgba(12,10,20,.93), rgba(6,6,10,.97) 70%);
  transition:opacity .6s ease; overflow:hidden; }
.rs-saver.show{ opacity:1; }
.rs-saver-grain{ position:absolute; inset:0; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.rs-saver-vig{ position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 220px 60px rgba(0,0,0,.8); }
.rs-saver.flash{ animation:rs-flash .22s ease; }
@keyframes rs-flash{ 0%{ filter:brightness(1) } 30%{ filter:brightness(1.5) } 100%{ filter:brightness(1) } }
.rs-saver-bg{ position:absolute; inset:0; }
.rs-bg-layer{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; filter:saturate(.7) brightness(.5); transform:scale(1.06); transition:opacity 2.4s ease, transform 10s ease; }
.rs-bg-layer.on{ opacity:.16; transform:scale(1.12); }
.rs-saver-hint-x{ position:absolute; top:22px; left:50%; transform:translateX(-50%); z-index:3; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); }
.rs-saver-hint-x .k{ border:1px solid var(--line); border-radius:5px; padding:2px 7px; color:var(--silver); }
.rs-saver-stage{ position:absolute; inset:0; z-index:4; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:0 24px; gap:6px; }
.rs-saver-mark{ margin-bottom:12px; }
.rs-saver-mark img{ height:30px; width:auto; display:block; opacity:.96; }
.rs-saver-eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--pink); }
.rs-saver-q{ font-family:var(--display); font-weight:600; font-size:clamp(28px,5vw,58px); line-height:1.04; letter-spacing:-.03em; color:#fff; margin:6px 0; }
.rs-saver-q em{ font-style:normal; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.rs-saver-form{ width:min(720px,92vw); margin-top:10px; }
.rs-saver-inwrap{ position:relative; display:flex; align-items:center; gap:10px; background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:16px; padding:8px 8px 8px 22px; box-shadow:0 0 0 1px rgba(var(--c1-rgb),.08), 0 30px 80px -30px rgba(0,0,0,.8); transition:border-color .25s, box-shadow .25s; }
.rs-saver-inwrap:focus-within{ border-color:rgba(var(--c1-rgb),.5); box-shadow:0 0 0 1px rgba(var(--c1-rgb),.25), 0 30px 80px -30px rgba(0,0,0,.8); }
#rsInput{ flex:1; background:none; border:0; outline:none; color:#fff; font-family:var(--display); font-size:clamp(16px,2.2vw,22px); letter-spacing:-.01em; padding:14px 0; caret-color:var(--pink); }
.rs-saver-ph{ position:absolute; left:22px; top:50%; transform:translateY(-50%); pointer-events:none; color:var(--muted); font-family:var(--display); font-size:clamp(16px,2.2vw,22px); white-space:nowrap; overflow:hidden; max-width:calc(100% - 160px); }
.rs-saver-ph::after{ content:"▋"; color:var(--pink); margin-left:1px; animation:rs-blink 1.05s steps(1) infinite; }
@keyframes rs-blink{ 0%,49%{ opacity:1 } 50%,100%{ opacity:0 } }
.rs-saver-go{ flex:none; font-family:var(--mono); font-size:13px; color:#fff; background:var(--grad); border-radius:12px; padding:13px 20px; font-weight:600; transition:transform .2s, filter .2s; }
.rs-saver-go:hover{ transform:translateY(-1px); filter:brightness(1.08); }
.rs-saver-sub{ color:var(--silver); font-size:13.5px; line-height:1.6; max-width:64ch; margin:16px auto 0; font-weight:300; }
.rs-saver-hint{ margin-top:26px; min-height:96px; width:min(640px,92vw); }
.rs-hint-in{ opacity:0; transform:translateY(8px); transition:opacity .6s ease, transform .6s ease; display:flex; flex-direction:column; gap:5px; align-items:center; }
.rs-hint-in.on{ opacity:1; transform:none; }
.rs-hint-k{ font-family:var(--mono); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--pink); }
.rs-hint-t{ font-family:var(--display); font-weight:600; font-size:19px; color:#fff; }
.rs-hint-d{ color:var(--silver); font-size:13.5px; line-height:1.55; max-width:60ch; font-weight:300; }
.rs-hint-cta{ font-family:var(--mono); font-size:12px; color:var(--cyan); margin-top:4px; border-bottom:1px solid rgba(var(--c3-rgb),.4); }
.rs-saver-card{ position:absolute; z-index:4; width:min(330px,42vw); }
.rs-card-tl{ top:11%; left:5%; } .rs-card-br{ bottom:12%; right:5%; }
.rs-card-in{ opacity:0; transform:translateY(10px); transition:opacity .7s ease, transform .7s ease; display:flex; flex-direction:column; gap:6px; padding:18px 20px; border:1px solid var(--line); border-radius:16px; background:rgba(12,10,20,.6); backdrop-filter:blur(8px); text-align:left; }
.rs-card-in.on{ opacity:1; transform:none; }
.rs-card-cta{ display:inline-block; margin-top:9px; font-family:var(--mono); font-size:11px; color:var(--c3); border-bottom:1px solid rgba(var(--c3-rgb),.4); text-decoration:none; }
.rs-card-cta:hover{ color:#fff; }
.rs-card-in.rs-float{ transform:none; transition:opacity .85s ease; }
.rs-card-in.rs-float.on{ animation:rs-cardrift 7.5s linear; }
@keyframes rs-cardrift{ from{ transform:translateY(12px) } to{ transform:translateY(-18px) } }
.rs-card-k{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--violet); }
.rs-card-t{ font-family:var(--display); font-weight:600; font-size:16px; color:#fff; }
.rs-card-d{ color:var(--silver); font-size:12.8px; line-height:1.55; font-weight:300; }
.rs-saver-foot{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:4; font-family:var(--mono); font-size:12px; color:var(--muted); letter-spacing:.02em; text-align:center; white-space:nowrap; }
.rs-saver-foot b{ color:var(--pink); font-weight:500; } .rs-saver-foot a{ color:var(--cyan); border-bottom:1px solid rgba(var(--c3-rgb),.4); }
@media (max-width:820px){ .rs-saver-card{ display:none; } .rs-saver-foot{ font-size:10.5px; white-space:normal; width:88vw; } .rs-saver-sub{ font-size:12.5px; } }

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  #rs-field{ display:none; } .rs-field-fallback{ opacity:1 !important; }
  .reveal{ opacity:1 !important; transform:none !important; filter:none !important; clip-path:none !important; transition:none !important; }
  h1.head b, h2.sec b, .btn, .btn-accent, .shop-btn, .wwb-plan, .rs-saver-mark{ animation:none !important; }
}

/* ============ ULTRA HERO — "studio light": spotlight stage + edge vignette ============
   One coherent idea: a soft light shaft from above lights the center stage where the
   headline + panels live; the embers are dust lit by that beam; the edges fall into
   shadow (vignette / inner-shadow). Mostly static — cheap, purposeful, premium. */
.uhero{ --glass-edge:rgba(255,255,255,.14);
  position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:center; overflow:hidden; isolation:isolate; }
.uhero .stage{ position:absolute; inset:0; z-index:0; pointer-events:none; contain:layout paint; }

/* the SOURCE — a soft volumetric light shaft falling from above */
.uhero .ushaft{ position:absolute; left:50%; top:-8%; width:min(560px,50vw); height:94%; transform:translateX(-50%);
  background:linear-gradient(to bottom, rgba(206,228,255,.26) 0%, rgba(170,200,255,.13) 42%, rgba(150,185,255,.04) 74%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 30%, #000 70%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0%, #000 30%, #000 70%, transparent 100%);
  filter:blur(10px); opacity:.85; animation:rs-breathe 9s ease-in-out infinite; }
@keyframes rs-breathe{0%,100%{opacity:.7}50%{opacity:.95}}
/* the lit STAGE — a calm spotlight pool the content sits inside */
.uhero .uspot{ position:absolute; left:50%; top:42%; width:min(1500px,124vw); height:130%; transform:translate(-50%,-50%);
  background:radial-gradient(44% 38% at 50% 44%, rgba(120,150,255,.16) 0%, rgba(130,95,210,.09) 40%, transparent 72%); }
/* dust lit by the beam */
.uhero #embers{ position:absolute; left:50%; bottom:-6%; width:min(760px,62vw); height:86%; transform:translateX(-50%); z-index:2; }
/* the FRAME — clear center, edges darken like an inner shadow of the screen */
.uhero .uvignette{ position:absolute; inset:0; z-index:3;
  background:radial-gradient(132% 116% at 50% 40%, transparent 45%, rgba(6,6,10,.40) 74%, rgba(6,6,10,.85) 100%); }
.uhero .uvignette::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 190px 44px rgba(0,0,0,.5), inset 0 0 70px rgba(0,0,0,.38); }

.uhero .uhero-grid{ position:relative; z-index:10; display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr); align-items:center; gap:30px; padding-top:104px; padding-bottom:40px; }
.uhero .ucopy{ max-width:640px; position:relative; }
.uhero .ucopy::before{ content:""; position:absolute; left:-30px; top:-20px; right:-40px; bottom:-20px; z-index:-1;
  background:radial-gradient(70% 100% at 18% 50%, rgba(6,6,10,.32) 0%, transparent 72%); filter:blur(10px); border-radius:40px; }
.uhero .ueyebrow{ display:inline-flex; align-items:center; gap:10px; font-family:var(--mono); font-size:12px; letter-spacing:.2em; font-weight:500; color:var(--silver); text-transform:uppercase; margin-bottom:26px; padding:7px 14px; border:1px solid var(--line); border-radius:999px; background:rgba(255,255,255,.03); }
.uhero .ulive{ position:relative; width:8px; height:8px; border-radius:50%; background:var(--c3); }
.uhero .ulive::after{ content:""; position:absolute; inset:0; border-radius:50%; background:var(--c3); animation:rs-ping 2.4s ease-out infinite; }
@keyframes rs-ping{0%{transform:scale(1);opacity:.7}70%,100%{transform:scale(3.4);opacity:0}}
.uhero .uheadline{ font-family:var(--display); font-weight:700; letter-spacing:-.028em; line-height:.97; font-size:clamp(42px,6.8vw,90px); margin-bottom:24px; color:var(--text); }
.uhero .moment{ background:linear-gradient(96deg, var(--c3) 0%, var(--c2) 55%, var(--c1) 100%); -webkit-background-clip:text; background-clip:text; color:transparent; background-size:220% 100%; animation:rs-shimmerText 8s ease-in-out infinite; }
@keyframes rs-shimmerText{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.uhero .ulede{ font-size:clamp(16px,1.4vw,19px); line-height:1.6; color:var(--silver); max-width:520px; margin-bottom:36px; font-weight:300; }
.uhero .ulede strong{ color:var(--text); font-weight:600; }
.uhero .uactions{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.uhero .ubtn{ position:relative; display:inline-flex; align-items:center; gap:9px; font-family:var(--sans); font-weight:600; font-size:14px; padding:11px 22px; border-radius:999px; color:#0a0410; cursor:pointer; border:0; text-decoration:none; background:linear-gradient(180deg,#fff,#e7d8ff); box-shadow:0 0 0 1px rgba(255,255,255,.5), 0 0 24px rgba(var(--c2-rgb),.55), 0 0 60px rgba(var(--c1-rgb),.35); transition:transform .2s ease, box-shadow .35s ease; }
.uhero .ubtn:hover{ transform:translateY(-1px); box-shadow:0 0 0 1px rgba(255,255,255,.7),0 0 34px rgba(var(--c2-rgb),.8),0 0 86px rgba(var(--c1-rgb),.5); }
.uhero .ubtn-lg{ padding:15px 28px; font-size:15px; }
.uhero .ubtn .dot{ width:7px; height:7px; border-radius:50%; background:linear-gradient(180deg,var(--c1),var(--c2)); }
.uhero .ughost-link{ display:inline-flex; align-items:center; gap:9px; font-size:15px; color:var(--text); font-weight:500; transition:color .25s; }
.uhero .ughost-link .arr{ transition:transform .25s; } .uhero .ughost-link:hover .arr{ transform:translateX(4px); }
.uhero .utrust{ margin-top:42px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.uhero .utrust-label{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--faint); font-weight:500; }
.uhero .utrust-names{ display:flex; gap:22px; flex-wrap:wrap; font-family:var(--display); font-weight:500; font-size:13px; color:var(--muted); }

/* agentic verticals line + idea input (screensaver soul, inline) */
@keyframes rs-caret{0%,49%{opacity:1}50%,100%{opacity:0}}
.uhero .uverticals{ font-family:var(--display); font-size:clamp(15px,1.5vw,18px); color:var(--silver); margin:0 0 18px; font-weight:300; }
.uhero .uvert{ font-weight:600; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; white-space:nowrap; }
.uhero .uask{ position:relative; display:flex; align-items:center; gap:8px; max-width:540px; background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:16px; padding:7px 7px 7px 18px; box-shadow:0 0 0 1px rgba(var(--c1-rgb),.08), 0 30px 70px -34px rgba(0,0,0,.8); transition:border-color .25s, box-shadow .25s; margin-bottom:22px; }
.uhero .uask:focus-within{ border-color:rgba(var(--c1-rgb),.5); box-shadow:0 0 0 1px rgba(var(--c1-rgb),.28), 0 30px 70px -34px rgba(0,0,0,.8); }
.uhero .uask-in{ flex:1; min-width:0; background:none; border:0; outline:none; color:#fff; font-family:var(--display); font-size:clamp(15px,1.5vw,18px); padding:12px 0; caret-color:var(--c1); }
.uhero .uask-ph{ position:absolute; left:18px; top:50%; transform:translateY(-50%); pointer-events:none; color:var(--muted); font-family:var(--display); font-size:clamp(15px,1.5vw,18px); white-space:nowrap; overflow:hidden; max-width:calc(100% - 150px); }
.uhero .uask-ph::after{ content:"▋"; color:var(--c1); margin-left:1px; animation:rs-caret 1.05s steps(1) infinite; }
.uhero .uask-go{ flex:none; font-family:var(--sans); font-weight:600; font-size:14px; color:#0a0410; background:linear-gradient(180deg,#fff,#e7d8ff); border:0; border-radius:11px; padding:12px 18px; cursor:pointer; box-shadow:0 0 22px rgba(var(--c2-rgb),.45); transition:transform .2s, box-shadow .3s; }
.uhero .uask-go:hover{ transform:translateY(-1px); box-shadow:0 0 32px rgba(var(--c2-rgb),.7); }
/* agentic-live: the "we've built this" answer */
.uhero .uask-live{ display:none; margin:-6px 0 18px; max-width:540px; opacity:0; transform:translateY(8px); transition:opacity .45s ease, transform .45s ease; }
.uhero .uask-live.on{ display:block; opacity:1; transform:none; }
.uhero .ual-head{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; font-family:var(--display); font-size:14.5px; color:var(--silver); font-weight:400; }
.uhero .ual-check{ flex:none; width:19px; height:19px; border-radius:50%; display:grid; place-items:center; background:linear-gradient(180deg,#7df0c4,#34e3ff); color:#04221a; font-size:11px; font-weight:800; box-shadow:0 0 16px rgba(var(--c3-rgb),.5); }
.uhero .ual-head b{ color:#fff; font-weight:700; }
.uhero .ual-head a{ color:var(--c3); text-decoration:none; border-bottom:1px solid rgba(var(--c3-rgb),.4); }
.uhero .ual-chips{ display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.uhero .ual-chip{ font-size:10.5px; font-family:var(--mono); letter-spacing:.02em; padding:4px 10px; border-radius:999px; border:1px solid rgba(var(--c2-rgb),.32); color:#d8c6ff; background:rgba(var(--c2-rgb),.1); opacity:0; transform:translateY(4px); transition:opacity .35s ease, transform .35s ease; }
.uhero .uask-live.on .ual-chip{ opacity:1; transform:none; }
.uhero .uask-live.on .ual-chip:nth-child(1){transition-delay:.05s}.uhero .uask-live.on .ual-chip:nth-child(2){transition-delay:.12s}.uhero .uask-live.on .ual-chip:nth-child(3){transition-delay:.19s}.uhero .uask-live.on .ual-chip:nth-child(4){transition-delay:.26s}.uhero .uask-live.on .ual-chip:nth-child(5){transition-delay:.33s}
/* matched product card lights up + comes forward */
.uhero .uprods.dimmed .uprod:not(.lit){ opacity:.45; }
.uhero .uprod.lit{ transform:translateX(-12px) scale(1.045); border-color:rgba(var(--c3-rgb),.6); box-shadow:0 32px 72px -28px rgba(var(--c3-rgb),.6), 0 0 0 1px rgba(var(--c3-rgb),.42); }

/* real product cards (right column) — the #1 promotion */
.uhero .uprods{ position:relative; z-index:10; display:flex; flex-direction:column; gap:10px; align-self:center; }
.uhero .uprods-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:2px; }
.uhero .uprods-k{ font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--faint); font-weight:600; }
.uhero .uprods-all{ font-family:var(--mono); font-size:11px; color:var(--c3); text-decoration:none; }
.uhero .uprod{ display:flex; align-items:center; gap:13px; padding:11px; border-radius:14px; text-decoration:none; border:1px solid var(--glass-edge);
  background:linear-gradient(160deg, rgba(28,30,48,.6), rgba(14,15,26,.55)); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(255,255,255,.05) inset, 0 24px 60px -36px rgba(0,0,0,.8); transition:transform .3s cubic-bezier(.16,.84,.24,1), border-color .3s, box-shadow .3s; }
.uhero .uprod:hover{ transform:translateY(-3px); border-color:rgba(var(--c1-rgb),.4); box-shadow:0 30px 64px -34px rgba(var(--c1-rgb),.5); }
.uhero .uprod-cover{ flex:none; width:64px; height:48px; border-radius:9px; background:#0c0e1a center/cover no-repeat; border:1px solid rgba(255,255,255,.08); }
.uhero .uprod-body{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.uhero .uprod-cat{ font-family:var(--mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:#9fd0ff; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uhero .uprod-name{ font-family:var(--display); font-weight:600; font-size:15px; color:#fff; line-height:1.15; }
.uhero .uprod-blurb{ font-size:11.5px; color:var(--muted); line-height:1.4; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }
.uhero .uprod-cta{ border-style:dashed; background:rgba(var(--c1-rgb),.06); }
.uhero .uprod-cta .uprod-cat{ color:#ffc2e3; }

.uhero .upanels{ position:relative; z-index:10; height:560px; will-change:transform; }
.uhero .upanel{ position:absolute; border-radius:16px; padding:18px; text-decoration:none; color:var(--text);
  background:linear-gradient(160deg, rgba(28,30,48,.74), rgba(14,15,26,.68)); border:1px solid var(--glass-edge);
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset, 0 30px 80px -30px rgba(0,0,0,.8), 0 0 50px -10px rgba(120,160,255,.3);
  backdrop-filter:blur(16px) saturate(120%); -webkit-backdrop-filter:blur(16px) saturate(120%);
  opacity:0; filter:blur(8px); transform:translateY(46px) scale(.96) var(--rot,rotate(0)); animation:rs-assemble 1s var(--ease,cubic-bezier(.16,1,.3,1)) forwards; animation-delay:var(--d,0s); }
.uhero .upanel::before{ content:""; position:absolute; inset:0; border-radius:16px; padding:1px; background:linear-gradient(150deg, rgba(180,200,255,.45), transparent 40%); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
@keyframes rs-assemble{0%{opacity:0;filter:blur(8px);transform:translateY(46px) scale(.96) var(--rot,rotate(0))}100%{opacity:1;filter:blur(0);transform:translateY(0) scale(1) var(--rot,rotate(0))}}
.uhero .upanel.afloat{ opacity:1; filter:none; animation:rs-floatY 9s ease-in-out infinite; animation-delay:var(--fd,0s); }
@keyframes rs-floatY{0%,100%{transform:translateY(0) var(--rot,rotate(0))}50%{transform:translateY(-12px) var(--rot,rotate(0))}}
.uhero .p-catalog{ top:14px; left:0; width:300px; --rot:rotate(-2deg); --d:.18s; --fd:-1s; }
.uhero .p-metrics{ top:30px; right:-6px; width:248px; --rot:rotate(2.2deg); --d:.46s; --fd:-4s; }
.uhero .p-chat{ bottom:8px; left:44px; width:312px; --rot:rotate(1.4deg); --d:.74s; --fd:-2.5s; z-index:11; }
.uhero .p-project{ bottom:128px; right:-12px; width:230px; --rot:rotate(-2.6deg); --d:1.02s; --fd:-6s; }
.uhero .p-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.uhero .p-title{ font-size:12px; font-weight:600; letter-spacing:.04em; color:var(--text); }
.uhero .p-sub{ font-size:10px; color:var(--faint); letter-spacing:.14em; text-transform:uppercase; font-weight:600; }
.uhero .p-dots{ display:flex; gap:5px; } .uhero .p-dots i{ width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.18); }
.uhero .fam{ display:flex; align-items:center; justify-content:space-between; padding:8px 0; border-bottom:1px solid rgba(255,255,255,.06); font-size:13px; }
.uhero .fam:last-of-type{ border-bottom:0; }
.uhero .fam .nmf{ color:var(--text); font-weight:500; display:flex; align-items:center; gap:9px; }
.uhero .fam .ic{ width:18px; height:18px; border-radius:6px; display:grid; place-items:center; font-size:9.5px; background:rgba(var(--c2-rgb),.2); color:#d8c6ff; font-family:var(--mono); }
.uhero .fam .cnt{ color:var(--faint); font-size:12px; font-variant-numeric:tabular-nums; }
.uhero .chips{ display:flex; flex-wrap:wrap; gap:6px; margin-top:13px; }
.uhero .chip{ font-size:10.5px; padding:4px 9px; border-radius:999px; border:1px solid rgba(255,255,255,.12); color:var(--muted); background:rgba(255,255,255,.03); text-decoration:none; }
.uhero .chip.hot{ border-color:rgba(var(--c1-rgb),.4); color:#ffc2e3; background:rgba(var(--c1-rgb),.12); }
.uhero .m-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.uhero .m-cell{ background:rgba(255,255,255,.04); border-radius:10px; padding:11px 12px; }
.uhero .m-val{ font-family:var(--display); font-weight:600; font-size:21px; color:#fff; line-height:1; } .uhero .m-val.ok{ color:#7df0c4; }
.uhero .m-lab{ font-size:10px; color:var(--faint); letter-spacing:.08em; text-transform:uppercase; margin-top:6px; font-weight:600; }
.uhero .spark{ margin-top:12px; height:34px; display:flex; align-items:flex-end; gap:3px; }
.uhero .spark i{ flex:1; border-radius:2px 2px 0 0; background:linear-gradient(180deg,var(--c3),rgba(var(--c2-rgb),.5)); }
.uhero .bubble{ font-size:12.5px; line-height:1.45; padding:9px 12px; border-radius:12px; margin-bottom:9px; max-width:90%; }
.uhero .bubble.user{ margin-left:auto; background:rgba(255,255,255,.08); color:var(--text); border-bottom-right-radius:4px; }
.uhero .bubble.bot{ background:rgba(var(--c2-rgb),.16); border:1px solid rgba(var(--c2-rgb),.25); color:#ece4ff; border-bottom-left-radius:4px; }
.uhero .typing{ display:inline-flex; gap:3px; align-items:center; } .uhero .typing i{ width:5px; height:5px; border-radius:50%; background:#d8c6ff; animation:rs-blink 1.4s infinite; }
.uhero .typing i:nth-child(2){animation-delay:.2s}.uhero .typing i:nth-child(3){animation-delay:.4s}
@keyframes rs-blink{0%,60%,100%{opacity:.3}30%{opacity:1}}
.uhero .chat-input{ margin-top:6px; display:flex; align-items:center; gap:8px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:999px; padding:5px 6px 5px 14px; }
.uhero .chat-input input{ flex:1; background:none; border:0; outline:none; color:var(--text); font:inherit; font-size:12px; min-width:0; }
.uhero .chat-input input::placeholder{ color:var(--faint); }
.uhero .chat-input .send{ width:28px; height:28px; flex:none; border-radius:50%; display:grid; place-items:center; background:linear-gradient(180deg,#fff,#e7d8ff); color:#0a0410; font-size:13px; border:0; cursor:pointer; }
.uhero .proj-tag{ font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:#9fd0ff; font-weight:600; }
.uhero .proj-name{ font-family:var(--display); font-weight:600; font-size:16px; color:#fff; margin:7px 0 4px; line-height:1.15; }
.uhero .proj-meta{ font-size:11.5px; color:var(--muted); line-height:1.5; }
.uhero .proj-foot{ margin-top:13px; display:flex; align-items:center; gap:8px; }
.uhero .pill-mini{ font-size:10px; padding:3px 9px; border-radius:999px; background:rgba(var(--c3-rgb),.12); border:1px solid rgba(var(--c3-rgb),.3); color:#c6f4ff; }
.uhero .uscroll{ position:absolute; left:50%; bottom:22px; transform:translateX(-50%); z-index:12; display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--faint); font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; opacity:0; animation:rs-cueIn .8s ease 1.5s forwards; }
@keyframes rs-cueIn{to{opacity:1}}
.uhero .mouse{ width:22px; height:34px; border:1.5px solid rgba(255,255,255,.25); border-radius:12px; position:relative; }
.uhero .mouse::after{ content:""; position:absolute; left:50%; top:7px; width:3px; height:6px; border-radius:2px; background:var(--text); transform:translateX(-50%); animation:rs-scrolldot 1.8s ease-in-out infinite; }
@keyframes rs-scrolldot{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

@media (max-width:1080px){ .uhero .uhero-grid{ grid-template-columns:1fr; gap:20px } .uhero .upanels{ height:480px; margin-top:8px } .uhero .p-metrics{ right:0 } .uhero .p-project{ right:6px } }
@media (max-width:760px){
  .uhero .ushaft{ width:78vw } .uhero #embers{ width:84vw }
  .uhero .uhero-grid{ padding-top:92px } .uhero .utrust{ margin-top:30px } .uhero .upanels{ height:300px }
  .uhero .p-catalog,.uhero .p-project,.uhero .p-chat{ display:none }
  .uhero .p-metrics{ position:relative; top:0; right:auto; left:50%; width:min(320px,92%); margin:0 auto; --rot:translateX(-50%) rotate(0); --fd:0s }
}
@media (max-width:420px){ .uhero .uheadline{ font-size:clamp(34px,11vw,46px) } }
@media (prefers-reduced-motion:reduce){
  .uhero *,.uhero *::before,.uhero *::after{ animation:none !important; }
  .uhero .upanel{ opacity:1 !important; filter:none !important; transform:translateY(0) scale(1) var(--rot,rotate(0)) !important }
  .uhero .p-metrics{ transform:translateX(-50%) rotate(0) }
  .uhero .uscroll{ opacity:1 }
}

/* ===================== FABLE 5 OVERRIDES ===================== */
/* Thin-line cinema typography — the odontOS lineage */
h1,h2{ font-weight:300; }
h1{ letter-spacing:-.015em; }
.uhero h1 b,.uhero h1 strong{ font-weight:500; }
/* hair-thin edge-lit chrome */
header.nav{ border-bottom:1px solid rgba(160,190,255,.10); }
header.nav.scrolled{ border-bottom-color:rgba(160,190,255,.16); }
/* deep-space base behind the WebGL stage (kills any flash-of-white) */
html,body{ background:#05060c; }
/* the 2D field fallback stays available — fable-5.js only disables it when WebGL2 is live */
