/* ============================================================
   VENTRAX — design system
   Light · editorial · premium. Warm paper, deep ink, electric accent.
   ============================================================ */

:root{
  /* surfaces — warm paper whites, subtle tone */
  --bg:        #FBFAF7;
  --bg-2:      #F4F2EC;
  --bg-3:      #ECE9E1;
  --panel:     #FFFFFF;

  /* ink — warm near-black scale */
  --ink:       #17161C;
  --ink-2:     #54515C;
  --ink-3:     #8B8893;
  --ink-4:     #B5B2BA;

  --line:      rgba(23,22,28,.09);
  --line-2:    rgba(23,22,28,.14);

  /* accent — overridden by Tweaks. electric indigo default */
  --accent:    #4B54F0;
  --accent-ink:#2b2fb0;

  /* product brand hues */
  --bizlaw:    #079669;
  --konvox:    #6C3AED;
  --creator:   #FF5D3A;

  /* type */
  --font-display: 'Schibsted Grotesk', system-ui, sans-serif;
  --font-body:    'Schibsted Grotesk', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 18px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{ background:color-mix(in oklab, var(--accent) 24%, transparent); }

a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
img{ max-width:100%; display:block; }

/* paper grain texture */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.5; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}

/* ---------- layout primitives ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.section{ position:relative; z-index:1; }
.eyebrow{
  font-family:var(--font-mono); font-size:12px; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3);
  display:inline-flex; align-items:center; gap:9px;
}
.eyebrow .dot{
  width:6px; height:6px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 18%, transparent);
}
.h-display{
  font-family:var(--font-display);
  font-weight:600; letter-spacing:-.022em; line-height:1.02;
  text-wrap:balance; margin:0;
}
.lede{ color:var(--ink-2); font-size:clamp(17px,1.55vw,21px); line-height:1.55; text-wrap:pretty; }

/* ---------- buttons ---------- */
.btn{
  --bh:#fff;
  display:inline-flex; align-items:center; gap:9px; cursor:pointer;
  font-family:var(--font-display); font-weight:500; font-size:15.5px;
  padding:13px 22px; border-radius:999px; border:1px solid transparent;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), background .25s, box-shadow .25s, color .25s;
  white-space:nowrap; line-height:1;
}
.btn .arr{ transition:transform .3s cubic-bezier(.2,.8,.2,1); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-primary{
  background:var(--ink); color:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.18), 0 8px 24px -10px rgba(0,0,0,.4);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 2px 4px rgba(0,0,0,.2),0 16px 34px -12px rgba(0,0,0,.5); }
.btn-accent{ background:var(--accent); color:#fff; box-shadow:0 8px 24px -10px var(--accent); }
.btn-accent:hover{ transform:translateY(-2px); filter:saturate(1.1) brightness(1.04); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-2px); }

/* ---------- NAV ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .3s, box-shadow .3s, border-color .3s, backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:color-mix(in oklab, var(--bg) 78%, transparent);
  -webkit-backdrop-filter:blur(18px) saturate(160%); backdrop-filter:blur(18px) saturate(160%);
  border-bottom-color:var(--line);
}
.nav-in{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{
  font-size:15px; color:var(--ink-2); font-weight:450; position:relative; transition:color .2s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; border-radius:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .28s cubic-bezier(.2,.8,.2,1);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-burger{ display:none; }

/* ---------- LOGO ---------- */
.logo{ display:inline-flex; align-items:center; gap:11px; }
.logo-mark{ width:30px; height:30px; flex:none; }
.logo-word{
  font-family:var(--font-display); font-weight:600; font-size:21px;
  letter-spacing:-.02em; color:var(--ink);
}

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top:170px; padding-bottom:96px; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero-grid{
  position:absolute; inset:-2px;
  background-image:
    linear-gradient(to right, var(--line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 90% at 70% 0%, #000 30%, transparent 78%);
          mask-image:radial-gradient(120% 90% at 70% 0%, #000 30%, transparent 78%);
}
.hero-orb{
  position:absolute; border-radius:50%; filter:blur(60px); opacity:.5;
  background:radial-gradient(circle at 30% 30%, var(--accent), transparent 70%);
  animation:float 18s ease-in-out infinite;
}
.hero-orb.a{ width:520px; height:520px; top:-120px; right:-60px; }
.hero-orb.b{ width:380px; height:380px; top:160px; right:300px; background:radial-gradient(circle at 30% 30%, var(--konvox), transparent 70%); opacity:.32; animation-delay:-6s; }
.hero-orb.c{ width:300px; height:300px; top:30px; left:-80px; background:radial-gradient(circle at 30% 30%, var(--creator), transparent 70%); opacity:.28; animation-delay:-11s; }
@keyframes float{
  0%,100%{ transform:translate(0,0) scale(1); }
  33%{ transform:translate(-26px,30px) scale(1.06); }
  66%{ transform:translate(22px,-18px) scale(.96); }
}

.hero-in{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }
.hero-h1{ font-size:clamp(40px, 5.6vw, 78px); margin:22px 0 0; }
.hero-h1 .accent{ color:var(--accent); }
.hero-sub{ margin-top:26px; max-width:30ch; }
.hero-actions{ margin-top:38px; display:flex; gap:14px; flex-wrap:wrap; }
.hero-meta{ margin-top:46px; display:flex; gap:34px; flex-wrap:wrap; }
.hero-meta .m{ display:flex; flex-direction:column; gap:3px; }
.hero-meta .m b{ font-family:var(--font-display); font-size:26px; font-weight:600; letter-spacing:-.02em; }
.hero-meta .m span{ font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }

/* hero visual — orbiting product nodes */
.hero-vis{ position:relative; aspect-ratio:1/1; }
.hero-card{
  position:absolute; background:var(--panel); border:1px solid var(--line);
  border-radius:16px; padding:16px 18px; box-shadow:0 20px 50px -28px rgba(23,22,28,.35);
  display:flex; align-items:center; gap:13px; backdrop-filter:blur(4px);
}
.hero-card .ic{ width:38px; height:38px; border-radius:11px; flex:none; display:grid; place-items:center; color:#fff; }
.hero-card .tt{ display:flex; flex-direction:column; gap:1px; }
.hero-card .tt b{ font-family:var(--font-display); font-size:15px; font-weight:600; }
.hero-card .tt span{ font-family:var(--font-mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.hc-1{ top:8%; left:6%; animation:bob 7s ease-in-out infinite; }
.hc-2{ top:42%; right:0%; animation:bob 7s ease-in-out infinite -2.3s; }
.hc-3{ bottom:8%; left:14%; animation:bob 7s ease-in-out infinite -4.6s; }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
.hero-core{
  position:absolute; inset:24% 24%; border-radius:50%;
  display:grid; place-items:center;
  background:radial-gradient(circle at 50% 40%, color-mix(in oklab,var(--accent) 16%, var(--panel)), var(--panel));
  border:1px solid var(--line); box-shadow:0 30px 80px -40px var(--accent), inset 0 0 0 1px rgba(255,255,255,.6);
}
.hero-core .ring{ position:absolute; inset:0; border-radius:50%; border:1px dashed var(--line-2); animation:spin 40s linear infinite; }
.hero-core .ring.r2{ inset:-16%; animation-duration:60s; animation-direction:reverse; border-style:solid; border-color:var(--line); }
@keyframes spin{ to{ transform:rotate(360deg); } }
.hero-core .core-mark{ width:54px; height:54px; }

/* connecting SVG lines */
.hero-vis svg.links{ position:absolute; inset:0; width:100%; height:100%; overflow:visible; z-index:-1; }
.hero-vis svg.links path{ stroke:var(--accent); stroke-width:1.4; fill:none; opacity:.4;
  stroke-dasharray:5 7; animation:dash 1.4s linear infinite; }
@keyframes dash{ to{ stroke-dashoffset:-24; } }

/* ---------- marquee trust strip ---------- */
.strip{ border-block:1px solid var(--line); background:var(--bg-2); padding:22px 0; overflow:hidden; }
.strip-in{ display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; }
.strip-lbl{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.strip-items{ display:flex; gap:40px; flex-wrap:wrap; }
.strip-items .si{ display:flex; align-items:baseline; gap:8px; }
.strip-items .si b{ font-family:var(--font-display); font-weight:600; font-size:19px; }
.strip-items .si span{ font-size:13.5px; color:var(--ink-2); }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec-pad{ padding-block:clamp(80px,9vw,140px); }
.sec-head{ max-width:680px; }
.sec-head .h-display{ font-size:clamp(30px,3.6vw,50px); margin-top:18px; }
.sec-head p{ margin-top:18px; }
.sec-head.center{ margin-inline:auto; text-align:center; }

/* ============================================================
   PORTFOLIO
   ============================================================ */
.pf{ display:flex; flex-direction:column; gap:30px; margin-top:60px; }

/* shared product card chrome */
.pcard{
  position:relative; background:var(--panel); border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s, border-color .4s;
}
.pcard:hover{ transform:translateY(-4px); box-shadow:0 30px 70px -40px rgba(23,22,28,.4); border-color:var(--line-2); }
.pcard .accent-line{ position:absolute; top:0; left:0; right:0; height:3px; background:var(--brand); transform:scaleX(0); transform-origin:left; transition:transform .5s cubic-bezier(.2,.8,.2,1); }
.pcard:hover .accent-line{ transform:scaleX(1); }

.pf-head{ padding:30px 30px 0; display:flex; align-items:flex-start; justify-content:space-between; gap:20px; }
.pf-tag{
  display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono);
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--brand);
  background:color-mix(in oklab, var(--brand) 10%, transparent);
  padding:6px 11px; border-radius:999px; font-weight:500;
}
.pf-idx{ font-family:var(--font-mono); font-size:13px; color:var(--ink-4); letter-spacing:.05em; }
.pf-name{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,3vw,38px); letter-spacing:-.02em; margin:18px 0 0; padding:0 30px; }
.pf-name .pn-brand{ color:var(--brand); }
.pf-desc{ padding:0 30px; margin:14px 0 0; color:var(--ink-2); max-width:46ch; }
.pf-status{ padding:16px 30px 0; }
.pf-status-pill{ display:inline-flex; align-items:center; gap:9px; padding:7px 13px; border:1px solid var(--line); border-radius:999px; font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--ink-2); background:var(--bg); }
.pf-status-pill i{ width:7px; height:7px; border-radius:50%; background:var(--brand); box-shadow:0 0 0 4px color-mix(in oklab,var(--brand) 16%, transparent); }
.pf-metrics{ display:flex; gap:34px; padding:24px 30px 0; flex-wrap:wrap; }
.pf-metrics .met b{ font-family:var(--font-display); font-weight:600; font-size:30px; letter-spacing:-.02em; display:block; }
.pf-metrics .met b .u{ color:var(--brand); }
.pf-metrics .met span{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-3); }
.pf-link{ display:inline-flex; align-items:center; gap:8px; padding:0 30px; margin-top:22px;
  font-weight:500; color:var(--brand); font-size:15px; }
.pf-link .arr{ transition:transform .3s; }
.pcard:hover .pf-link .arr{ transform:translateX(4px); }
.pf-visual{ position:relative; }

/* layout: alternating rows (default) */
.pf[data-layout="rows"] .pcard{ display:grid; grid-template-columns:1fr 1fr; align-items:stretch; }
.pf[data-layout="rows"] .pcard:nth-child(even) .pf-body{ order:2; }
.pf[data-layout="rows"] .pf-body{ padding:38px 8px 40px; display:flex; flex-direction:column; }
.pf[data-layout="rows"] .pf-body .pf-link{ margin-top:auto; padding-top:26px; }
.pf[data-layout="rows"] .pf-visual{ background:var(--bg-2); border-left:1px solid var(--line); display:grid; place-items:center; padding:34px; min-height:380px; }
.pf[data-layout="rows"] .pcard:nth-child(even) .pf-visual{ border-left:0; border-right:1px solid var(--line); }

/* layout: cards (3-up) */
.pf[data-layout="cards"]{ display:grid; grid-template-columns:repeat(3,1fr); align-items:start; gap:24px; }
.pf[data-layout="cards"] .pf-visual{ background:var(--bg-2); border-bottom:1px solid var(--line); min-height:240px; display:grid; place-items:center; padding:24px; order:-1; }
.pf[data-layout="cards"] .pf-body{ padding-bottom:30px; display:flex; flex-direction:column; }
.pf[data-layout="cards"] .pf-metrics{ gap:22px; }
.pf[data-layout="cards"] .pf-metrics .met b{ font-size:23px; }

/* layout: bento */
.pf[data-layout="bento"]{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:minmax(10px,auto); gap:24px; }
.pf[data-layout="bento"] .pcard:nth-child(1){ grid-column:span 6; display:grid; grid-template-columns:1fr 1fr; }
.pf[data-layout="bento"] .pcard:nth-child(1) .pf-visual{ background:var(--bg-2); border-left:1px solid var(--line); display:grid; place-items:center; padding:34px; }
.pf[data-layout="bento"] .pcard:nth-child(1) .pf-body{ padding:38px 8px; display:flex; flex-direction:column; }
.pf[data-layout="bento"] .pcard:nth-child(1) .pf-body .pf-link{ margin-top:auto; padding-top:24px; }
.pf[data-layout="bento"] .pcard:nth-child(2),
.pf[data-layout="bento"] .pcard:nth-child(3){ grid-column:span 3; display:flex; flex-direction:column; }
.pf[data-layout="bento"] .pcard:nth-child(2) .pf-visual,
.pf[data-layout="bento"] .pcard:nth-child(3) .pf-visual{ background:var(--bg-2); border-top:1px solid var(--line); min-height:260px; display:grid; place-items:center; padding:24px; margin-top:24px; }
.pf[data-layout="bento"] .pf-body{ padding-bottom:30px; }

/* ============================================================
   PRODUCT MOCKUPS
   ============================================================ */
.mock{ width:100%; max-width:440px; font-family:var(--font-display); }

/* — BizLaw legal memo — */
.memo{ background:#fff; border:1px solid var(--line); border-radius:13px; box-shadow:0 24px 60px -34px rgba(23,22,28,.45); overflow:hidden; }
.memo-top{ display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--line); background:var(--bg); }
.memo-top .mt-l{ display:flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:var(--ink-2); }
.memo-top .pill{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--bizlaw); background:color-mix(in oklab,var(--bizlaw) 12%,transparent); padding:4px 8px; border-radius:6px; }
.memo-body{ padding:18px 18px 20px; }
.memo-body h4{ margin:0; font-size:14px; letter-spacing:.02em; }
.memo-body .sub{ font-family:var(--font-mono); font-size:10.5px; color:var(--ink-3); margin:4px 0 14px; }
.memo-line{ height:8px; border-radius:4px; background:var(--bg-3); margin:8px 0; }
.memo-line.w1{ width:100%; } .memo-line.w2{ width:92%; } .memo-line.w3{ width:78%; }
.cite{ display:inline; background:color-mix(in oklab,var(--bizlaw) 14%,transparent); color:var(--bizlaw); font-family:var(--font-mono); font-size:11px; padding:2px 6px; border-radius:5px; font-weight:500; }
.memo-para{ font-size:12.5px; line-height:1.7; color:var(--ink-2); margin:12px 0; }
.memo-cites{ border-top:1px solid var(--line); margin-top:6px; padding-top:14px; }
.memo-cites .cl{ display:flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:11px; color:var(--ink-2); padding:5px 0; }
.memo-cites .cl .ck{ width:14px;height:14px;border-radius:4px;background:var(--bizlaw);color:#fff;display:grid;place-items:center;font-size:9px;flex:none; }

/* — Konvox dashboard — */
.dash{ background:#16151C; color:#fff; border:1px solid rgba(255,255,255,.08); border-radius:13px; box-shadow:0 24px 60px -30px rgba(23,22,28,.6); overflow:hidden; font-size:12px; }
.dash-top{ display:flex; align-items:center; justify-content:space-between; padding:12px 15px; border-bottom:1px solid rgba(255,255,255,.07); }
.dash-top .dt-l{ display:flex; align-items:center; gap:9px; }
.dash-top .live{ display:inline-flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:#9be9c4; }
.dash-top .live i{ width:7px;height:7px;border-radius:50%;background:#34d399; box-shadow:0 0 0 0 rgba(52,211,153,.6); animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(52,211,153,.6);} 70%{ box-shadow:0 0 0 7px rgba(52,211,153,0);} 100%{ box-shadow:0 0 0 0 rgba(52,211,153,0);} }
.dash-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.07); }
.dash-stats .ds{ background:#16151C; padding:13px 14px; }
.dash-stats .ds b{ font-family:var(--font-display); font-size:21px; font-weight:600; letter-spacing:-.02em; display:block; }
.dash-stats .ds span{ font-family:var(--font-mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.45); }
.dash-spark{ padding:14px 15px 6px; }
.dash-spark .sl{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:9.5px; color:rgba(255,255,255,.4); letter-spacing:.05em; margin-bottom:8px; }
.dash-feed{ padding:6px 15px 15px; display:flex; flex-direction:column; gap:0; }
.dash-feed .fh{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.07em; text-transform:uppercase; color:rgba(255,255,255,.4); padding:8px 0; border-top:1px solid rgba(255,255,255,.07); }
.feed-row{ display:flex; align-items:center; gap:10px; padding:7px 0; opacity:0; transform:translateY(6px); }
.feed-row.show{ opacity:1; transform:none; transition:opacity .45s, transform .45s; }
.feed-row .av{ width:24px;height:24px;border-radius:50%;flex:none;background:linear-gradient(135deg,var(--konvox),#c4b5fd);display:grid;place-items:center;font-size:10px;font-weight:600; }
.feed-row .fx{ flex:1; min-width:0; }
.feed-row .fx b{ font-size:11.5px; font-weight:600; }
.feed-row .fx p{ margin:1px 0 0; font-size:10.5px; color:rgba(255,255,255,.5); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.feed-row .stat{ font-family:var(--font-mono); font-size:9px; padding:3px 7px; border-radius:5px; background:rgba(52,211,153,.15); color:#6ee7b7; letter-spacing:.04em; flex:none; }

/* — creatorbox mobile — */
.phone{ width:248px; background:#0f0f12; border-radius:34px; padding:9px; box-shadow:0 30px 70px -30px rgba(23,22,28,.55); }
.phone-scr{ background:#fff; border-radius:26px; overflow:hidden; position:relative; }
.phone-notch{ position:absolute; top:9px; left:50%; transform:translateX(-50%); width:74px; height:18px; background:#0f0f12; border-radius:12px; z-index:4; }
.cb-cover{ height:104px; background:linear-gradient(135deg,var(--creator),#ff9e7a); position:relative; }
.cb-cover .cb-grain{ position:absolute; inset:0; background-image:radial-gradient(circle at 20% 30%, rgba(255,255,255,.25),transparent 40%); }
.cb-av{ width:60px;height:60px;border-radius:50%;border:3px solid #fff;background:linear-gradient(135deg,#fde68a,#fca5a5); position:absolute; left:18px; bottom:-30px; box-shadow:0 6px 16px rgba(0,0,0,.18); }
.cb-body{ padding:38px 18px 18px; }
.cb-body h5{ margin:0; font-size:16px; font-weight:600; }
.cb-body .hd{ font-family:var(--font-mono); font-size:10.5px; color:var(--ink-3); margin:2px 0 0; }
.cb-bio{ font-size:11.5px; color:var(--ink-2); line-height:1.5; margin:10px 0 14px; }
.cb-prod{ border:1px solid var(--line); border-radius:13px; padding:10px; display:flex; align-items:center; gap:11px; margin-bottom:10px; transition:transform .3s, box-shadow .3s; }
.cb-prod:hover{ transform:translateY(-2px); box-shadow:0 10px 24px -14px rgba(0,0,0,.3); }
.cb-prod .thumb{ width:44px;height:44px;border-radius:9px;flex:none; }
.cb-prod .pi{ flex:1; min-width:0; }
.cb-prod .pi b{ font-size:12.5px; font-weight:600; display:block; }
.cb-prod .pi span{ font-size:10.5px; color:var(--ink-3); }
.cb-prod .price{ font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--creator); white-space:nowrap; }
.cb-pay{ margin-top:4px; background:var(--creator); color:#fff; text-align:center; padding:12px; border-radius:13px; font-weight:600; font-size:13.5px; }

/* ============================================================
   INFRASTRUCTURE
   ============================================================ */
.infra{ background:var(--bg-2); border-block:1px solid var(--line); }
.infra-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.icard{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:30px; transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s; }
.icard:hover{ transform:translateY(-4px); box-shadow:0 26px 60px -38px rgba(23,22,28,.4); }
.icard .iglyph{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:#fff; margin-bottom:20px; }
.icard h3{ font-family:var(--font-display); font-size:21px; font-weight:600; letter-spacing:-.01em; margin:0 0 12px; }
.icard ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.icard li{ display:flex; gap:11px; font-size:14.5px; color:var(--ink-2); line-height:1.45; }
.icard li .tick{ flex:none; width:18px; height:18px; border-radius:6px; display:grid; place-items:center; font-size:10px; color:#fff; margin-top:2px; }

/* ============================================================
   FOOTPRINT / STATS
   ============================================================ */
.foot-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-top:56px; }
.fs{ background:var(--bg); padding:34px 28px; }
.fs b{ font-family:var(--font-display); font-weight:600; font-size:clamp(52px,6vw,80px); letter-spacing:-.03em; line-height:1; display:block; white-space:nowrap; }
.fs span{ font-family:var(--font-mono); font-size:11px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-3); display:block; margin-top:10px; }

.countries{ display:flex; flex-wrap:wrap; gap:10px; margin-top:34px; }
.countries .c{ font-family:var(--font-mono); font-size:12px; letter-spacing:.05em; color:var(--ink-2); border:1px solid var(--line); border-radius:999px; padding:7px 14px; background:var(--panel); }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta{ position:relative; overflow:hidden; }
.cta-box{
  position:relative; background:var(--ink); color:#fff; border-radius:28px;
  padding:clamp(48px,6vw,84px); text-align:center; overflow:hidden;
}
.cta-box .cta-orb{ position:absolute; width:520px; height:520px; border-radius:50%; filter:blur(70px); opacity:.4;
  background:radial-gradient(circle,var(--accent),transparent 70%); top:-200px; right:-120px; }
.cta-box .cta-orb.b{ background:radial-gradient(circle,var(--konvox),transparent 70%); left:-160px; bottom:-220px; top:auto; right:auto; }
.cta-box h2{ position:relative; font-family:var(--font-display); font-weight:600; letter-spacing:-.025em; font-size:clamp(30px,4.4vw,56px); margin:0; line-height:1.04; text-wrap:balance; }
.cta-box p{ position:relative; color:rgba(255,255,255,.66); max-width:50ch; margin:20px auto 0; font-size:clamp(16px,1.5vw,19px); }
.cta-box .cta-actions{ position:relative; margin-top:36px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta-box .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.25); }
.cta-box .btn-ghost:hover{ background:#fff; color:var(--ink); border-color:#fff; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ border-top:1px solid var(--line); padding-block:64px 36px; background:var(--bg); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer-brand .lede{ font-size:15px; margin-top:18px; max-width:34ch; }
.footer-col h5{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin:0 0 16px; font-weight:500; }
.footer-col a{ display:block; color:var(--ink-2); font-size:14.5px; padding:6px 0; transition:color .2s, transform .2s; }
.footer-col a:hover{ color:var(--ink); transform:translateX(3px); }
.footer-bot{ display:flex; align-items:center; justify-content:space-between; gap:20px; margin-top:54px; padding-top:26px; border-top:1px solid var(--line); flex-wrap:wrap; }
.footer-bot span{ font-family:var(--font-mono); font-size:12px; color:var(--ink-3); letter-spacing:.03em; }

/* ============================================================
   ANIMATED PRISM — brand mark
   ============================================================ */
.apPrism{ display:block; flex:none; }
.apPrism .ap-f{ fill:var(--accent); fill-opacity:.06; }
.apPrism.full .ap-f1{ animation:vpFacet 3.4s ease-in-out infinite; }
.apPrism.full .ap-f2{ animation:vpFacet 3.4s ease-in-out infinite -.85s; }
.apPrism.full .ap-f3{ animation:vpFacet 3.4s ease-in-out infinite -1.7s; }
.apPrism.full .ap-f4{ animation:vpFacet 3.4s ease-in-out infinite -2.55s; }
.apPrism.full .ap-draw{ stroke-dasharray:1; animation:vpDraw 5.5s cubic-bezier(.4,0,.2,1) infinite; }
.apPrism.full .ap-fold{ stroke-dasharray:1; animation:vpDraw 5.5s cubic-bezier(.4,0,.2,1) .25s infinite; }
.apPrism.full .ap-glint{ animation:vpGlint 3.4s ease-in-out infinite; }
.apPrism.full .ap-core{ transform-origin:center; transform-box:fill-box; animation:vpCore 3.4s ease-in-out infinite; }
/* calm (nav/footer): solid outline, gentle opacity refraction + core fade */
.apPrism.calm .ap-glint{ opacity:0; }
.apPrism.calm .ap-f1{ animation:vpFacet 4.8s ease-in-out infinite; }
.apPrism.calm .ap-f2{ animation:vpFacet 4.8s ease-in-out infinite -1.2s; }
.apPrism.calm .ap-f3{ animation:vpFacet 4.8s ease-in-out infinite -2.4s; }
.apPrism.calm .ap-f4{ animation:vpFacet 4.8s ease-in-out infinite -3.6s; }
.apPrism.calm .ap-core{ animation:vpCoreFade 4.8s ease-in-out infinite; }
@keyframes vpDraw{ 0%{ stroke-dashoffset:1; } 24%{ stroke-dashoffset:0; } 86%{ stroke-dashoffset:0; } 100%{ stroke-dashoffset:1; } }
@keyframes vpFacet{ 0%,100%{ fill-opacity:.06; } 16%{ fill-opacity:.5; } 36%{ fill-opacity:.06; } }
@keyframes vpCore{ 0%,100%{ opacity:.5; transform:scale(.8); } 50%{ opacity:1; transform:scale(1.18); } }
@keyframes vpCoreFade{ 0%,100%{ opacity:.5; } 50%{ opacity:1; } }
@keyframes vpGlint{ 0%{ transform:translateX(-16px); opacity:0; } 12%{ opacity:1; } 48%{ transform:translateX(58px); opacity:0; } 100%{ transform:translateX(58px); opacity:0; } }
[data-motion="off"] .apPrism *{ animation:none !important; }
[data-motion="off"] .apPrism .ap-draw,[data-motion="off"] .apPrism .ap-fold{ stroke-dashoffset:0 !important; }
[data-motion="off"] .apPrism .ap-glint{ opacity:0 !important; }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

[data-motion="off"] .reveal{ opacity:1 !important; transform:none !important; }

/* Reduce-motion (OS setting): show content instantly instead of parking a fade at 0 */
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
}
[data-motion="off"] .hero-orb,
[data-motion="off"] .hc-1,[data-motion="off"] .hc-2,[data-motion="off"] .hc-3,
[data-motion="off"] .hero-core .ring,
[data-motion="off"] .hero-vis svg.links path{ animation:none !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .hero-in{ grid-template-columns:1fr; gap:40px; }
  .hero-vis{ max-width:460px; margin-inline:auto; width:100%; }
  .pf[data-layout="rows"] .pcard,
  .pf[data-layout="bento"] .pcard:nth-child(1){ grid-template-columns:1fr; }
  .pf[data-layout="rows"] .pcard:nth-child(even) .pf-body{ order:0; }
  .pf[data-layout="rows"] .pf-visual,
  .pf[data-layout="bento"] .pcard:nth-child(1) .pf-visual{ border-left:0 !important; border-right:0 !important; border-top:1px solid var(--line); order:-1; }
  .pf[data-layout="cards"]{ grid-template-columns:1fr; }
  .pf[data-layout="bento"]{ grid-template-columns:1fr; }
  .pf[data-layout="bento"] .pcard:nth-child(2),
  .pf[data-layout="bento"] .pcard:nth-child(3){ grid-column:auto; }
  .infra-grid{ grid-template-columns:1fr; }
  .foot-stats{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .nav-links{ display:none; }
}
@media (max-width:560px){
  .nav-cta .btn-ghost{ display:none; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-meta{ gap:24px; }
}
