/* ============================================================
   gnoapps — mobile app studio
   design system + layout
   editorial / monospace / dark-rail · light-stage
   ============================================================ */

/* ---- tokens ---- */
:root{
  /* palette */
  --ink:        #0b0b0c;   /* near-black */
  --ink-soft:   #16171a;
  --paper:      #eceae4;   /* warm light stage */
  --paper-2:    #e3e1da;
  --cream:      #edece7;   /* sidebar text */
  --cream-dim:  #8b8a83;
  --ink-dim:    #5d5c56;   /* muted text on light — WCAG AA on --paper */
  --line:       #cfcdc4;   /* hairlines on light */
  --line-dark:  #2a2b2e;   /* hairlines on dark */
  --accent:     #c6ff3a;   /* electric lime — used sparingly */
  --accent-ink: #0b0b0c;

  /* type */
  --mono: "Space Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --disp: "Archivo", "Helvetica Neue", Arial, sans-serif;

  /* metrics */
  --rail: 312px;            /* sidebar width */
  --pad:  clamp(20px, 4.5vw, 76px);
  --ease: cubic-bezier(.16,1,.3,1);
  --ease-2: cubic-bezier(.7,0,.2,1);

  --r: 14px;
}

/* dark "stage" variant via theme toggle */
body[data-theme="dark"]{
  --paper:   #101012;
  --paper-2: #17181b;
  --ink:     #ededea;
  --ink-soft:#cbcac4;
  --line:    #2a2b2e;
}

/* ---- reset ---- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--mono);
  background:var(--ink);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* native cursor stays unless JS confirms a fine pointer and enables the custom dot */
body.cursor-custom,
body.cursor-custom *{ cursor:none; }
@media (pointer:coarse){ body{ cursor:auto; } .cursor{ display:none; } }

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
em{ font-style:italic; }
sup{ font-size:.5em; vertical-align:super; }

::selection{ background:var(--accent); color:var(--accent-ink); }

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

/* custom cursor */
.cursor{
  position:fixed; top:0; left:0; z-index:9500; pointer-events:none;
  width:9px; height:9px; border-radius:50%; background:var(--accent);
  transform:translate(-50%,-50%);
  transition:width .25s var(--ease), height .25s var(--ease),
             background .25s var(--ease), opacity .3s;
  mix-blend-mode:difference;
}
.cursor.is-link{ width:46px; height:46px; background:#fff; }
.cursor.is-view{ width:74px; height:74px; background:transparent;
  border:1px solid var(--accent); mix-blend-mode:normal; }
.cursor.is-view::after{ content:"view"; position:absolute; inset:0;
  display:grid; place-items:center; font:700 9px/1 var(--mono);
  letter-spacing:.15em; text-transform:uppercase; color:var(--accent); }

/* ============================================================
   INTRO
   ============================================================ */
.intro{
  position:fixed; inset:0; z-index:9800; background:var(--ink);
  display:flex; align-items:flex-end; justify-content:space-between;
  padding:var(--pad);
  transition:transform 1s var(--ease-2) .2s;
}
.intro.is-done{ transform:translateY(-101%); }
.intro__count{ font:700 clamp(60px,18vw,220px)/.85 var(--disp); color:var(--cream);
  letter-spacing:-.04em; }
.intro__count i{ font-size:.28em; font-style:normal; color:var(--accent); vertical-align:super; }
.intro__word{ font:400 13px/1 var(--mono); color:var(--cream-dim);
  text-transform:lowercase; letter-spacing:.3em; padding-bottom:.6em; }

/* ============================================================
   SIDEBAR (dark rail)
   ============================================================ */
.sidebar{
  position:fixed; top:0; left:0; z-index:120;
  width:var(--rail); height:100vh;
  background:var(--ink); color:var(--cream);
  padding:clamp(22px,3vh,34px) 30px;
  display:flex; flex-direction:column; justify-content:space-between;
  border-right:1px solid var(--line-dark);
}

.brand{ display:flex; align-items:center; gap:11px; color:var(--cream); }
.brand__mark{ color:var(--cream); display:flex; line-height:0;
  transition:transform .5s var(--ease); }
.brand:hover .brand__mark{ transform:rotate(-8deg) scale(1.05); }
.brand__name{ font:700 17px/1 var(--mono); letter-spacing:-.02em; }
.brand__live{ width:7px; height:7px; border-radius:50%; background:var(--accent);
  margin-left:2px; box-shadow:0 0 0 0 var(--accent); animation:pulse 2.4s infinite; }
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(198,255,58,.55); }
  70%{ box-shadow:0 0 0 7px rgba(198,255,58,0); }
  100%{ box-shadow:0 0 0 0 rgba(198,255,58,0); }
}

.role{ margin-top:26px; }
.role__title{ font:700 12px/1 var(--mono); letter-spacing:.04em; }
.role__desc{ margin-top:11px; font:400 12px/1.6 var(--mono);
  color:var(--cream-dim); max-width:23ch; }

.nav{ margin-top:30px; border-top:1px solid var(--line-dark); padding-top:18px; }
.nav__link{
  display:block; font:400 13px/1 var(--mono); color:var(--cream);
  padding:9px 0; position:relative; width:max-content;
  transition:color .3s, padding-left .35s var(--ease); opacity:.78;
}
.nav__link::before{
  content:""; position:absolute; left:-14px; top:50%; width:0; height:1px;
  background:var(--accent); transition:width .35s var(--ease);
}
.nav__num{ color:var(--cream-dim); margin-right:8px; font-size:11px; }
.nav__link:hover,
.nav__link.is-active{ opacity:1; padding-left:18px; color:var(--cream); }
.nav__link:hover::before,
.nav__link.is-active::before{ width:8px; }
.nav__link.is-active .nav__num{ color:var(--accent); }

/* bottom cluster */
.sidebar__bottom{ display:flex; flex-direction:column; gap:22px; }
.connect__label{ font:700 11px/1 var(--mono); }
.connect__links{ margin-top:8px; font:400 12px/1.7 var(--mono); color:var(--cream-dim); }
.connect__links a{ position:relative; }
.connect__links a:hover{ color:var(--cream); }
.connect__links a::after{
  content:""; position:absolute; left:0; bottom:-1px; width:0; height:1px;
  background:var(--accent); transition:width .3s var(--ease);
}
.connect__links a:hover::after{ width:100%; }

/* language switcher */
.lang__label{ font:700 11px/1 var(--mono); }
.lang__row{ margin-top:9px; display:flex; gap:5px; flex-wrap:wrap; }
.lang__btn{
  font:400 12px/1 var(--mono); text-transform:lowercase;
  background:none; border:none; color:var(--cream-dim); cursor:pointer;
  padding:3px 2px; position:relative; transition:color .25s var(--ease);
}
.lang__btn::after{ content:""; position:absolute; left:2px; right:2px; bottom:0;
  height:1px; background:var(--accent); transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease); }
.lang__btn:hover{ color:var(--cream); }
.lang__btn:hover::after{ transform:scaleX(1); }
.lang__btn.is-active{ color:var(--accent); }
.lang__btn.is-active::after{ transform:scaleX(1); }

/* mobile top-bar tools (hidden on desktop) */
.bar-right{ display:contents; }
.lang-mini{ display:none; }

.clocks{ display:grid; grid-template-columns:repeat(4,1fr); gap:6px;
  border-top:1px solid var(--line-dark); padding-top:16px; }
.clock{ display:flex; flex-direction:column; gap:4px; }
.clock__city{ font:700 9px/1 var(--mono); color:var(--cream-dim); letter-spacing:.1em; }
.clock__time{ font:400 12px/1 var(--mono); font-variant-numeric:tabular-nums; }

.utility{ display:flex; align-items:center; gap:10px;
  border-top:1px solid var(--line-dark); padding-top:14px; }
.util-btn{
  font-family:var(--mono); font-size:15px; line-height:1;
  background:none; border:1px solid var(--line-dark); color:var(--cream);
  width:30px; height:30px; border-radius:50%; cursor:pointer;
  display:grid; place-items:center;
  transition:background .3s, color .3s, transform .3s var(--ease);
}
.util-btn:hover{ background:var(--accent); color:var(--accent-ink); transform:translateY(-2px); }
.util-year{ margin-left:auto; font:400 11px/1 var(--mono); color:var(--cream-dim);
  font-variant-numeric:tabular-nums; }

.menu-toggle{ display:none; }

/* ============================================================
   MAIN STAGE
   ============================================================ */
.main{
  margin-left:var(--rail);
  background:var(--paper);
  color:var(--ink);
  min-height:100vh;
  transition:background .6s var(--ease), color .6s var(--ease);
}

/* ---------- HERO ---------- */
.hero{ padding:clamp(26px,4vh,46px) var(--pad) clamp(60px,8vh,110px); position:relative; }

.hero__head{ display:flex; justify-content:space-between; align-items:center; }
.eyebrow{ font:400 11px/1 var(--mono); letter-spacing:.12em; text-transform:lowercase;
  color:var(--ink); display:inline-flex; align-items:center; gap:9px; opacity:.7; }
.eyebrow__dot{ width:7px; height:7px; border-radius:50%; background:var(--accent);
  display:inline-block; }

.display{
  font-family:var(--disp); font-weight:900;
  font-size:clamp(74px, 21.5vw, 430px);
  line-height:.78; letter-spacing:-.045em;
  margin:clamp(14px,2.5vh,30px) 0 0; color:var(--ink);
  text-transform:uppercase;
  display:flex; flex-wrap:wrap; gap:0 .04em;
}
.display__line{ display:inline-block; }

.hero__sub{
  max-width:46ch; margin:clamp(20px,3vh,40px) 0 0;
  font:400 14px/1.7 var(--mono); color:var(--ink);
}
.hero__sub .ix{ display:block; font-size:10px; letter-spacing:.2em; color:var(--cream-dim);
  text-transform:uppercase; margin-bottom:14px; animation:blink 2.5s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:.25; } }
.hero__sub em{ background:linear-gradient(transparent 62%, var(--accent) 0); }

/* ---------- WORK GRID (asymmetric) ---------- */
.grid{
  margin-top:clamp(40px,7vh,96px);
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:clamp(28px,5vw,64px) clamp(20px,3vw,48px);
}
.card{ opacity:1; }
.card--feature{ grid-column:1 / span 5;  align-self:start; }
.card--b{ grid-column:8 / span 4; margin-top:clamp(60px,11vw,180px); }
.card--c{ grid-column:3 / span 6; margin-top:-2vw; }

.card__media{
  display:block; position:relative; border-radius:var(--r); overflow:hidden;
  background:linear-gradient(155deg,#cdcbc3,#b9b7af 60%, #a9a79f);
  aspect-ratio:4/3; transition:transform .7s var(--ease);
}
.card--feature .card__media{ aspect-ratio:5/6;
  background:linear-gradient(160deg,#3a3d44,#1a1c20 70%); }
.card--b .card__media{ aspect-ratio:4/5;
  background:linear-gradient(160deg,#d7d5cd,#c4c2ba); }
.card__media--flat{ aspect-ratio:16/10;
  background:linear-gradient(160deg,#161719,#0c0d0e); }
.card:hover .card__media{ transform:translateY(-6px); }

.card__badge{
  position:absolute; top:14px; left:14px; z-index:3;
  font:700 9px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase;
  background:var(--accent); color:var(--accent-ink); padding:7px 10px; border-radius:40px;
}
.card__meta{ margin-top:16px; }
.card__title{ font:700 clamp(18px,2vw,26px)/1 var(--mono); letter-spacing:-.02em;
  display:flex; align-items:baseline; }
.card__dot{ color:var(--accent); }
.card__desc{ margin-top:7px; font:400 12.5px/1.5 var(--mono); color:var(--ink); opacity:.72; }
.card__tag{ margin-top:9px; font:400 10.5px/1 var(--mono); letter-spacing:.08em;
  text-transform:uppercase; color:var(--cream-dim); }
.repl{ background:rgba(198,255,58,.28); padding:0 .25em; border-radius:3px; }

/* ---------- DEVICE MOCKUPS ---------- */
.device{
  position:absolute; left:50%; top:54%; transform:translate(-50%,-50%);
  width:62%; aspect-ratio:9/19; background:#0a0a0a; border-radius:30px;
  padding:8px; box-shadow:0 30px 60px -20px rgba(0,0,0,.6), inset 0 0 0 2px #2a2a2a;
}
.device--tilt{ transform:translate(-50%,-50%) rotate(-7deg); width:58%; }
.card:hover .device{ transform:translate(-50%,-57%); transition:transform .7s var(--ease); }
.card:hover .device--tilt{ transform:translate(-50%,-57%) rotate(-4deg); }
.device__notch{ position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:34%; height:16px; background:#0a0a0a; border-radius:0 0 12px 12px; z-index:4; }

.screen{ width:100%; height:100%; border-radius:23px; overflow:hidden; position:relative;
  padding:30px 14px 16px; }

/* stardust screen — cosmic palette (deep space / indigo / cyan / resonance pink) */
.screen--orbit{ background:radial-gradient(120% 90% at 50% 18%, #1b2347, #0A0E1A 72%); }
.orbit__halo{ position:absolute; left:50%; top:34%; transform:translate(-50%,-50%);
  width:124px; height:124px; border-radius:50%;
  background:radial-gradient(circle, rgba(108,99,255,.40), rgba(0,212,255,.12) 55%, transparent 70%); filter:blur(5px); }
.orbit__sphere{ position:absolute; left:50%; top:34%; transform:translate(-50%,-50%);
  width:90px; height:90px; border-radius:50%;
  background:
    radial-gradient(2px 2px at 30% 30%, #b9c8ff 99%, transparent),
    radial-gradient(2px 2px at 70% 40%, #00D4FF 99%, transparent),
    radial-gradient(1.5px 1.5px at 50% 60%, #fff 99%, transparent),
    radial-gradient(1.5px 1.5px at 40% 75%, #8B83FF 99%, transparent),
    radial-gradient(1.5px 1.5px at 65% 70%, #cfe4ff 99%, transparent),
    radial-gradient(circle at 50% 50%, rgba(108,99,255,.30), transparent 70%);
  box-shadow:inset 0 0 32px rgba(108,99,255,.4), 0 0 24px rgba(0,212,255,.18);
  animation:spin 16s linear infinite; }
@keyframes spin{ to{ transform:translate(-50%,-50%) rotate(360deg); } }
.screen__field{ position:absolute; bottom:16px; left:14px; right:14px; height:26px;
  border-radius:13px; background:rgba(255,255,255,.07); color:rgba(255,255,255,.4);
  font:400 9px/26px var(--mono); padding:0 12px; }

.sd-top{ position:absolute; top:14px; left:14px; right:14px; z-index:5;
  display:flex; align-items:center; justify-content:space-between; }
.sd-brand{ font:700 9px/1 var(--mono); letter-spacing:.16em; text-transform:lowercase; color:#cdd6ff; }
.sd-resonance{ font:700 8px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase;
  color:#FF6B9D; background:rgba(255,107,157,.14); border:1px solid rgba(255,107,157,.3);
  padding:5px 8px; border-radius:20px; }
.sd-match{ position:absolute; bottom:56px; left:14px; right:14px; z-index:5;
  display:flex; align-items:center; justify-content:center; gap:12px; }
.sd-sign{ font-size:19px; color:#e6ebff; text-shadow:0 0 10px rgba(108,99,255,.7); }
.sd-conn{ position:relative; flex:0 0 46px; height:1px;
  background:linear-gradient(90deg,transparent,#6C63FF,#00D4FF,transparent); }
.sd-conn::after{ content:"✦"; position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%); font-size:10px; color:#00D4FF;
  text-shadow:0 0 8px rgba(0,212,255,.8); }
.sd-cta{ text-align:center; font-weight:700; letter-spacing:.06em; text-transform:lowercase;
  background:linear-gradient(90deg, rgba(108,99,255,.22), rgba(255,107,157,.22));
  color:#eaf0ff; border:1px solid rgba(139,131,255,.45); }

/* gallery screen */
.screen--gallery{ background:linear-gradient(180deg,#f4f3ee,#e7e5dd); padding:26px 12px 12px; }
.screen__hdr{ height:30px; border-radius:8px;
  background:linear-gradient(90deg,#dcd9d0,#cecabf); margin-bottom:10px; }
.tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:6px; }
.tiles span{ aspect-ratio:1; border-radius:7px;
  background:linear-gradient(135deg,#c9c6bc,#b7b4aa); }
.tiles span:nth-child(2){ background:linear-gradient(135deg,#b8c6d6,#9fb0c4); }
.tiles span:nth-child(4){ background:linear-gradient(135deg,#d8c3b3,#c7ac98); }
.tiles span:nth-child(5){ background:linear-gradient(135deg,#c0cbb6,#a8b79b); }
.screen__pill{ position:absolute; bottom:14px; left:50%; transform:translateX(-50%);
  background:#0a0a0a; color:#ededea; font:700 9px/1 var(--mono); letter-spacing:.1em;
  text-transform:uppercase; padding:9px 18px; border-radius:30px; }

/* flat panel / lab */
.panel{ position:absolute; inset:0; padding:26px; overflow:hidden; }
.panel--graph .panel__grid{ position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:34px 34px; }
.panel__line{ position:absolute; inset:0; width:100%; height:100%; }
.panel__line polyline{ fill:none; stroke:var(--accent); stroke-width:2;
  stroke-linejoin:round; stroke-linecap:round;
  filter:drop-shadow(0 0 6px rgba(198,255,58,.5)); }
.panel__nodes{ position:absolute; inset:26px; display:flex; align-items:flex-end;
  justify-content:space-between; }
.panel__nodes i{ width:6px; height:6px; border-radius:50%; background:#fff; opacity:.5; }

/* ============================================================
   CONTENT BLOCKS
   ============================================================ */
.block{ padding:clamp(70px,12vh,150px) var(--pad);
  border-top:1px solid var(--line); }
.block--dark{ background:var(--ink); color:var(--cream); border-top:none; }

.block__head{ max-width:60ch; }
.kicker{ font:700 11px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink); display:inline-block; margin-bottom:24px; opacity:.55; }
.kicker--inv{ color:var(--cream); opacity:.5; }
.block__title{ font:800 clamp(28px,4.6vw,68px)/1.04 var(--disp);
  letter-spacing:-.03em; color:var(--ink); }
.block__title em{ color:var(--cream-dim); }
.block__title--inv{ color:var(--cream); }
.block__title--inv em{ color:var(--accent); }

/* about */
.about{ margin-top:clamp(40px,6vh,80px); }
.about__lead{ max-width:54ch; font:400 15px/1.75 var(--mono); }
.team{ margin-top:clamp(40px,6vh,72px);
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,42px); }
.member{ border-top:1px solid var(--line); padding-top:20px; position:relative; }
.member__idx{ font:400 11px/1 var(--mono); color:var(--cream-dim); }
.member__face{ display:block; font-size:48px; line-height:1; margin:18px 0 16px;
  color:var(--ink); transition:transform .5s var(--ease); }
.member:hover .member__face{ transform:rotate(180deg); color:var(--accent); }
.member__name{ font:700 19px/1 var(--mono); letter-spacing:-.02em; }
.member__role{ margin-top:7px; font:400 12px/1 var(--mono); color:var(--cream-dim);
  text-transform:uppercase; letter-spacing:.08em; }

.facts{ list-style:none; margin-top:clamp(48px,7vh,90px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
  border-top:1px solid var(--line); padding-top:34px; }
.facts li{ display:flex; flex-direction:column; gap:8px; }
.facts b{ font:800 clamp(34px,4.4vw,58px)/.9 var(--disp); letter-spacing:-.03em;
  font-variant-numeric:tabular-nums; }
.facts span{ font:400 11px/1.3 var(--mono); color:var(--cream-dim);
  text-transform:uppercase; letter-spacing:.06em; }

/* process steps */
.steps{ list-style:none; margin-top:clamp(40px,6vh,80px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,2.5vw,40px); }
.step{ border-top:1px solid var(--line-dark); padding-top:22px; }
.step__no{ font:700 13px/1 var(--mono); color:var(--accent); }
.step__name{ margin-top:22px; font:700 22px/1 var(--mono); letter-spacing:-.02em; }
.step__txt{ margin-top:14px; font:400 12.5px/1.65 var(--mono); color:var(--cream-dim);
  max-width:26ch; }

/* marquee */
.marquee{ margin-top:clamp(60px,9vh,120px); overflow:hidden; white-space:nowrap;
  border-top:1px solid var(--line-dark); border-bottom:1px solid var(--line-dark);
  padding:24px 0; }
.marquee__track{ display:inline-flex; animation:scroll 28s linear infinite; }
.marquee__track span{ font:800 clamp(30px,5vw,72px)/1 var(--disp); text-transform:uppercase;
  letter-spacing:-.02em; color:var(--cream); }
.marquee__track span:nth-child(even){ color:transparent;
  -webkit-text-stroke:1px var(--cream-dim); }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* contact */
.contact{ padding:clamp(80px,14vh,180px) var(--pad) clamp(30px,5vh,60px);
  border-top:1px solid var(--line); }
.contact__big{ margin-top:24px; font:900 clamp(44px,9.5vw,170px)/.92 var(--disp);
  letter-spacing:-.045em; text-transform:lowercase; color:var(--ink); }
.contact__mail{ display:inline-block; margin-top:clamp(28px,4vh,50px);
  font:700 clamp(16px,2.4vw,30px)/1 var(--mono); letter-spacing:-.01em;
  border-bottom:2px solid var(--ink); padding-bottom:6px;
  transition:color .3s, border-color .3s, transform .4s var(--ease); }
.contact__mail:hover{ color:var(--accent); border-color:var(--accent); transform:translateX(8px); }

.foot{ margin-top:clamp(70px,12vh,140px); padding-top:24px;
  border-top:1px solid var(--line); display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:14px;
  font:400 11px/1.4 var(--mono); color:var(--cream-dim);
  text-transform:uppercase; letter-spacing:.06em; }

/* ============================================================
   RIGHT EDGE BADGE
   ============================================================ */
.edge{
  position:fixed; right:0; top:50%; transform:translateY(-50%); z-index:110;
  background:var(--ink); color:var(--cream);
  display:flex; flex-direction:column; align-items:center; gap:14px;
  padding:18px 8px; border-radius:10px 0 0 10px;
  border:1px solid var(--line-dark); border-right:none;
}
.edge__big{ font:900 22px/1 var(--disp); color:var(--accent); }
.edge__rot{ writing-mode:vertical-rl; font:700 9px/1 var(--mono);
  letter-spacing:.22em; text-transform:uppercase; }

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.skip{ position:fixed; top:10px; left:10px; z-index:9700;
  background:var(--accent); color:var(--accent-ink); padding:10px 16px;
  border-radius:8px; font:700 12px/1 var(--mono); transform:translateY(-160%);
  transition:transform .25s var(--ease); }
.skip:focus{ transform:none; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:2px; }
.sidebar :focus-visible,.block--dark :focus-visible,.waitlist :focus-visible{ outline-color:var(--accent); }
/* keep custom cursor but never hide native focus for keyboard users */
body:not(.using-mouse) *:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }

/* ============================================================
   STARDUST SHOWCASE
   ============================================================ */
.stardust .block__title em{ color:var(--cream-dim); }
.sd-show{ margin-top:clamp(40px,6vh,76px); display:grid;
  grid-template-columns:0.82fr 1fr; gap:clamp(30px,5vw,76px); align-items:center; }
.sd-stage{ position:relative; border-radius:var(--r); overflow:hidden;
  aspect-ratio:5/6; background:linear-gradient(160deg,#3a3d44,#16181c 72%);
  box-shadow:0 40px 80px -40px rgba(0,0,0,.5); }
.sd-stage .device{ animation:floaty 6.5s ease-in-out infinite; }
@keyframes floaty{ 0%,100%{ transform:translate(-50%,-50%); }
  50%{ transform:translate(-50%,calc(-50% - 12px)); } }

.sd-show__intro{ font:400 clamp(15px,1.7vw,18px)/1.7 var(--mono); max-width:42ch; }
.sd-props{ list-style:none; margin-top:clamp(24px,3vh,34px); }
.sd-prop{ border-top:1px solid var(--line); padding:20px 0; }
.sd-prop__tag{ display:inline-block; font:700 9px/1 var(--mono); letter-spacing:.14em;
  text-transform:uppercase; color:var(--accent-ink); background:var(--accent);
  padding:5px 9px; border-radius:30px; }
.sd-prop__title{ font:700 clamp(18px,2vw,22px)/1 var(--mono); letter-spacing:-.02em; margin-top:15px; }
.sd-prop__desc{ font:400 13px/1.6 var(--mono); color:var(--ink-dim); margin-top:8px; max-width:44ch; }

.btn-cta{ display:inline-flex; align-items:center; gap:8px; margin-top:clamp(26px,3.5vh,38px);
  font:700 13px/1 var(--mono); letter-spacing:.02em; text-transform:lowercase;
  background:var(--ink); color:var(--paper); padding:16px 28px; border-radius:40px;
  transition:transform .35s var(--ease), background .35s, color .35s; }
.btn-cta:hover{ background:var(--accent); color:var(--accent-ink); transform:translateY(-3px); }
.sd-disclaimer{ margin-top:18px; max-width:46ch; font:400 11px/1.6 var(--mono);
  color:var(--ink-dim); letter-spacing:.01em; }

/* sidebar waitlist CTA */
.rail-cta{ display:block; margin-top:24px; text-align:center; color:var(--accent);
  font:700 12px/1 var(--mono); letter-spacing:.03em; text-transform:lowercase;
  border:1px solid rgba(198,255,58,.4); padding:13px; border-radius:30px;
  transition:background .3s var(--ease), color .3s; }
.rail-cta:hover{ background:var(--accent); color:var(--accent-ink); }

/* ============================================================
   WAITLIST
   ============================================================ */
.waitlist .wl__sub{ margin-top:18px; max-width:48ch;
  font:400 14px/1.7 var(--mono); color:var(--cream-dim); }
.wl-form{ margin-top:clamp(34px,5vh,58px); max-width:640px; }
.wl-form__row{ display:flex; gap:12px; align-items:center;
  border-bottom:2px solid var(--line-dark); padding-bottom:14px; transition:border-color .3s; }
.wl-form__row:focus-within{ border-color:var(--accent); }
.wl-form__input{ flex:1; min-width:0; background:none; border:none; color:var(--cream);
  font:400 clamp(16px,2.2vw,22px)/1.3 var(--mono); outline:none; }
.wl-form__input::placeholder{ color:var(--cream-dim); }
.wl-form__btn{ display:inline-flex; align-items:center; gap:8px; white-space:nowrap;
  background:var(--accent); color:var(--accent-ink); border:none;
  font:700 13px/1 var(--mono); text-transform:lowercase; letter-spacing:.02em;
  padding:14px 22px; border-radius:40px; cursor:pointer;
  transition:transform .3s var(--ease), opacity .3s; }
.wl-form__btn:hover{ transform:translateX(4px); }
.wl-form__btn[disabled]{ opacity:.5; transform:none; }
.wl-form__arr{ transition:transform .3s var(--ease); }
.wl-form__btn:hover .wl-form__arr{ transform:translateX(3px); }
.wl-form__msg{ min-height:1.3em; margin-top:14px; font:400 13px/1.5 var(--mono); }
.wl-form__msg.ok{ color:var(--accent); }
.wl-form__msg.err{ color:#ff8585; }
.wl-form__note{ margin-top:18px; display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:10px 24px; font:400 11px/1.6 var(--mono); color:var(--cream-dim); }
.wl-count b{ color:var(--cream); margin-right:5px; font-variant-numeric:tabular-nums; }
.wl-priv a{ color:var(--cream-dim); text-decoration:underline; text-underline-offset:3px; }
.wl-priv a:hover{ color:var(--accent); }
.wl-hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px;
  opacity:0; pointer-events:none; }
.wl-consent{ display:flex; gap:10px; align-items:flex-start; margin-top:18px;
  font:400 12px/1.55 var(--mono); color:var(--cream-dim); cursor:pointer; max-width:560px; }
.wl-consent input{ flex:0 0 auto; margin-top:2px; width:16px; height:16px;
  accent-color:var(--accent); cursor:pointer; }
.wl-consent a{ color:var(--cream); text-decoration:underline; text-underline-offset:3px; }
.wl-consent a:hover{ color:var(--accent); }

/* motion kill-switch (in-page toggle + reduced-motion) */
body.motion-off *,
body.motion-off *::before,
body.motion-off *::after{
  animation:none !important; transition:none !important; scroll-behavior:auto !important; }

/* ============================================================
   FAQ (accordion)
   ============================================================ */
.faq{ margin-top:clamp(34px,5vh,58px); border-top:1px solid var(--line); }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{ width:100%; display:flex; align-items:center; gap:18px; text-align:left;
  background:none; border:none; cursor:pointer; padding:clamp(20px,2.6vh,28px) 0;
  font:700 clamp(15px,1.9vw,21px)/1.35 var(--mono); letter-spacing:-.01em; color:var(--ink); }
.faq__q .faq__ix{ font:400 12px/1 var(--mono); color:var(--accent); flex:0 0 auto;
  width:26px; text-align:center; transition:transform .35s var(--ease); }
.faq__item[aria-expanded="true"] .faq__ix{ transform:rotate(45deg); }
.faq__qtext{ flex:1; }
.faq__a{ overflow:hidden; max-height:0; transition:max-height .45s var(--ease); }
.faq__a-inner{ padding:0 0 26px 44px; max-width:62ch;
  font:400 13.5px/1.7 var(--mono); color:var(--ink-dim); }
@media (max-width:560px){ .faq__a-inner{ padding-left:0; } }

/* ============================================================
   EXPANDED FOOTER
   ============================================================ */
.foot{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:30px; }
.foot__col{ display:flex; flex-direction:column; gap:10px;
  font:400 11px/1.5 var(--mono); text-transform:uppercase; letter-spacing:.06em; }
.foot__brand{ color:var(--ink); font-weight:700; }
.foot__muted{ color:var(--ink-dim); text-transform:none; letter-spacing:0; }
.foot__nav a,.foot__legal a{ color:var(--ink); position:relative; width:max-content; }
.foot__nav a::after,.foot__legal a::after{ content:""; position:absolute; left:0; bottom:-2px;
  width:0; height:1px; background:var(--accent); transition:width .3s var(--ease); }
.foot__nav a:hover::after,.foot__legal a:hover::after{ width:100%; }

/* ============================================================
   COOKIE / CONSENT
   ============================================================ */
.consent{ position:fixed; left:clamp(14px,3vw,28px); bottom:clamp(14px,3vw,28px);
  z-index:9600; max-width:360px; background:var(--ink); color:var(--cream);
  border:1px solid var(--line-dark); border-radius:14px; padding:20px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.5); }
.consent[hidden]{ display:none; }
.consent__txt{ font:400 12px/1.6 var(--mono); color:var(--cream); }
.consent__btns{ margin-top:14px; display:flex; gap:10px; }
.consent__btn{ flex:1; cursor:pointer; border-radius:30px; padding:11px;
  font:700 11px/1 var(--mono); text-transform:lowercase; letter-spacing:.04em; }
.consent__btn--no{ background:none; color:var(--cream-dim); border:1px solid var(--line-dark); }
.consent__btn--yes{ background:var(--accent); color:var(--accent-ink); border:none; }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(26px);
  transition:opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].is-in{ opacity:1; transform:none; }
.display[data-reveal]{ transform:translateY(40px); }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; }
  .orbit__sphere,.marquee__track,.brand__live,.sd-stage .device{ animation:none !important; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .steps{ grid-template-columns:repeat(2,1fr); row-gap:40px; }
  .facts{ grid-template-columns:repeat(2,1fr); row-gap:34px; }
  .sd-show{ grid-template-columns:0.9fr 1fr; gap:40px; }
}

@media (max-width:900px){
  .sd-show{ grid-template-columns:1fr; gap:36px; }
  .sd-stage{ max-width:360px; width:100%; }
  .foot{ grid-template-columns:1fr 1fr; }
}

@media (max-width:860px){
  :root{ --rail:0px; }
  body{ cursor:auto; }
  .cursor{ display:none; }

  .sidebar{
    width:100%; height:auto; position:sticky; top:0;
    flex-direction:row; align-items:center; justify-content:space-between;
    padding:14px var(--pad);
    border-right:none; border-bottom:1px solid var(--line-dark);
  }
  .sidebar__top{ display:flex; align-items:center; gap:0; }
  .role,.nav,.sidebar__bottom{ display:none; }

  .bar-right{ display:flex; align-items:center; gap:10px; }
  .lang-mini{
    display:block; background:none; border:1px solid var(--line-dark);
    color:var(--accent); font:700 11px/1 var(--mono); text-transform:uppercase;
    letter-spacing:.1em; padding:10px 12px; border-radius:30px; cursor:pointer;
    min-width:42px; text-align:center;
  }
  .menu-toggle{
    display:block; background:none; border:1px solid var(--line-dark);
    color:var(--cream); font:700 11px/1 var(--mono); text-transform:uppercase;
    letter-spacing:.1em; padding:10px 16px; border-radius:30px; cursor:pointer;
  }

  /* expanded mobile menu */
  .sidebar.is-open{ flex-direction:column; align-items:flex-start; height:100vh;
    justify-content:flex-start; gap:26px; overflow-y:auto; padding-top:64px; }
  .sidebar.is-open .sidebar__top{ display:flex; flex-direction:column;
    align-items:flex-start; gap:24px; width:100%; }
  .sidebar.is-open .role,
  .sidebar.is-open .nav{ display:block; width:100%; }
  .sidebar.is-open .sidebar__bottom{ display:flex; flex-direction:column; gap:20px; width:100%; }
  .sidebar.is-open .nav__link{ font-size:22px; padding:11px 0; opacity:1; }
  .sidebar.is-open .bar-right{ position:absolute; top:14px; right:var(--pad); }

  .main{ margin-left:0; }
  .display{ font-size:clamp(58px,26vw,150px); }

  .sd-stage{ margin:0 auto; }
  .wl-form__row{ flex-wrap:wrap; }
  .wl-form__btn{ width:100%; justify-content:center; }

  .edge{ display:none; }
  .rail-cta{ display:none; }
  .sidebar.is-open .rail-cta{ display:block; }
}

@media (max-width:480px){
  .team{ grid-template-columns:1fr; }
  .facts{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr; }
  .foot{ grid-template-columns:1fr; gap:24px; }
}

/* ============================================================
   LEGAL PAGES (privacy / terms) + 404
   ============================================================ */
.legal-wrap{ background:var(--paper); color:var(--ink); min-height:100vh; }
.legal-bar{ position:sticky; top:0; z-index:20; display:flex; align-items:center;
  justify-content:space-between; gap:16px; padding:15px clamp(20px,4.5vw,76px);
  background:var(--ink); color:var(--cream); border-bottom:1px solid var(--line-dark); }
.legal-bar .brand{ color:var(--cream); }
.legal-bar .brand__name{ color:var(--cream); }
.legal-bar__right{ display:flex; gap:18px; align-items:center; font:400 12px/1 var(--mono); }
.legal-langs{ display:flex; gap:8px; }
.legal-langs button{ background:none; border:none; color:var(--cream-dim);
  font:400 12px/1 var(--mono); cursor:pointer; padding:2px; }
.legal-langs button.is-active{ color:var(--accent); }
.legal-back{ color:var(--cream); text-decoration:none; }
.legal-back:hover{ color:var(--accent); }
.legal{ max-width:72ch; margin:0 auto;
  padding:clamp(40px,8vh,92px) clamp(20px,5vw,40px) 120px; }
.legal h1{ font:800 clamp(30px,5vw,52px)/1.05 var(--disp); letter-spacing:-.03em;
  text-transform:lowercase; color:var(--ink); }
.legal__meta{ margin-top:14px; font:400 12px/1.6 var(--mono); color:var(--ink-dim); }
.legal h2{ font:700 clamp(18px,2.4vw,24px)/1.3 var(--mono); letter-spacing:-.01em; margin:42px 0 12px; }
.legal h3{ font:700 15px/1.4 var(--mono); margin:26px 0 10px; }
.legal p, .legal li{ font:400 14px/1.78 var(--mono); color:var(--ink); }
.legal p{ margin:12px 0; }
.legal ul{ margin:12px 0 12px 20px; }
.legal li{ margin:6px 0; }
.legal a{ color:#586b1f; text-decoration:underline; text-underline-offset:3px; }
.legal a:hover{ color:var(--ink); }
.legal__lang{ display:none; }
.legal__lang.is-active{ display:block; }

.nf{ min-height:100vh; display:grid; place-items:center; text-align:center;
  background:var(--ink); color:var(--cream); padding:40px; }
.nf__big{ font:900 clamp(90px,24vw,280px)/.86 var(--disp); letter-spacing:-.05em; color:var(--cream); }
.nf__big em{ color:var(--accent); font-style:normal; }
.nf__txt{ margin-top:14px; font:400 14px/1.6 var(--mono); color:var(--cream-dim); }
.nf__home{ margin-top:32px; display:inline-block; font:700 13px/1 var(--mono);
  text-transform:lowercase; background:var(--accent); color:var(--accent-ink);
  padding:16px 28px; border-radius:40px; }
.nf__home:hover{ filter:brightness(1.08); }
