/* ============================================================
   ELENCO — direção SIMPLISTIC
   Light premium, editorial, muito respiro. Acento verde raro.
   Cor em OKLCH, neutros tintados para o verde da marca.
   ============================================================ */

:root{
  /* ---- tokens que NÃO mudam entre temas ---- */
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:34px;

  --ease: cubic-bezier(.22,1,.36,1);          /* ease-out-expo-ish */
  --ease-soft: cubic-bezier(.16,1,.3,1);

  --maxw: 1180px;
  --pad: clamp(20px, 5vw, 64px);

  --font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
}

/* ============================================================
   TEMA CLARO — default (também em [data-theme="light"])
   Light premium, editorial. Efeitos = sombras suaves / washes claros.
   ============================================================ */
:root,
:root[data-theme="light"]{
  color-scheme: light;

  /* canvas: off-white levemente quente/esverdeado, nunca #fff */
  --bg:        oklch(98.6% 0.004 150);
  --bg-2:      oklch(97% 0.006 150);
  --paper:     oklch(99.2% 0.003 150);
  --ink:       oklch(22% 0.02 160);     /* near-black tintado p/ verde */
  --ink-soft:  oklch(43% 0.018 160);
  --ink-mute:  oklch(58% 0.014 160);
  --ink-on-solid: var(--bg);            /* texto sobre botão sólido --ink */
  --line:      oklch(90% 0.01 160);
  --line-soft: oklch(93.5% 0.008 160);

  /* acento: o verde vivo do app, usado com parcimônia */
  --green:     oklch(63% 0.16 158);
  --green-ink: oklch(46% 0.15 158);
  --green-wash:oklch(95% 0.04 158);

  /* avatares — vivos o bastante sobre claro */
  --ava1: oklch(58% 0.14 280); --ava2: oklch(60% 0.15 230); --ava3: oklch(62% 0.14 200);
  --ava4: oklch(60% 0.15 30);  --ava5: oklch(58% 0.16 320); --ava6: oklch(60% 0.14 60);

  --shadow-1: 0 1px 2px oklch(20% 0.02 160 / .04), 0 4px 14px oklch(20% 0.02 160 / .05);
  --shadow-2: 0 2px 6px oklch(20% 0.02 160 / .05), 0 22px 50px -18px oklch(20% 0.02 160 / .18);
  --shadow-win: 0 4px 12px oklch(20% 0.02 160 / .08), 0 40px 90px -30px oklch(20% 0.03 160 / .35);

  /* ---- camada de EFEITOS (no claro: washes suaves, sem glow) ---- */
  --ambient-1: oklch(95% 0.04 158);     /* aurora wash verde */
  --ambient-2: oklch(96% 0.02 200);     /* aurora wash azul */
  --ambient-blur: 20px;
  --ambient-op: .7;
  --grain-op: .025;
  --grain-blend: normal;
  --spot-color: var(--green-wash);      /* spotlight nos cards */
  --shot-glow: radial-gradient(220px 220px at var(--mx,50%) var(--my,40%), oklch(40% 0.02 160 / .08), transparent 60%);
  --nav-blur-bg: oklch(98.6% 0.004 150 / .72);
  --solid-hover-glow: 0 8px 24px -8px var(--green);
  --field-bg: var(--bg);
}

/* ============================================================
   TEMA ESCURO — [data-theme="dark"]
   Obsidiana tintada de verde. Efeitos = glow / aurora / beams vivos.
   ============================================================ */
:root[data-theme="dark"]{
  color-scheme: dark;

  --bg:        oklch(17% 0.012 165);
  --bg-2:      oklch(20.5% 0.014 165);
  --paper:     oklch(22.5% 0.015 165);
  --ink:       oklch(95% 0.01 160);
  --ink-soft:  oklch(78% 0.014 160);
  --ink-mute:  oklch(62% 0.014 160);
  --ink-on-solid: oklch(18% 0.02 160); /* botão sólido vira claro -> texto escuro */
  --line:      oklch(30% 0.014 165);
  --line-soft: oklch(26% 0.012 165);

  --green:     oklch(72% 0.17 158);
  --green-ink: oklch(80% 0.16 158);     /* mais claro p/ contraste AA sobre escuro */
  --green-wash:oklch(34% 0.06 158);

  --ava1: oklch(68% 0.15 280); --ava2: oklch(70% 0.15 230); --ava3: oklch(72% 0.14 200);
  --ava4: oklch(70% 0.15 30);  --ava5: oklch(68% 0.16 320); --ava6: oklch(72% 0.14 60);

  --shadow-1: 0 1px 2px oklch(0% 0 0 / .3), 0 4px 14px oklch(0% 0 0 / .35);
  --shadow-2: 0 2px 6px oklch(0% 0 0 / .35), 0 24px 56px -18px oklch(0% 0 0 / .6);
  --shadow-win: 0 6px 16px oklch(0% 0 0 / .45), 0 50px 110px -34px oklch(60% 0.18 158 / .28);

  /* ---- EFEITOS vivos no escuro: aurora/glow/beams ---- */
  --ambient-1: oklch(60% 0.22 158 / .42);   /* aurora verde luminosa */
  --ambient-2: oklch(55% 0.2 250 / .3);     /* aurora azul-violeta */
  --ambient-blur: 60px;
  --ambient-op: .9;
  --grain-op: .04;
  --grain-blend: overlay;
  --spot-color: oklch(72% 0.18 158 / .22);  /* glow verde nos cards */
  --shot-glow: radial-gradient(240px 240px at var(--mx,50%) var(--my,40%), oklch(85% 0.16 158 / .22), transparent 60%);
  --nav-blur-bg: oklch(17% 0.012 165 / .68);
  --solid-hover-glow: 0 0 0 1px oklch(72% 0.17 158 / .4), 0 10px 34px -6px oklch(60% 0.2 158 / .55);
  --field-bg: oklch(19% 0.012 165);
}

/* transição suave ao alternar tema */
html{transition:background-color .5s var(--ease)}
body{
  transition:background-color .5s var(--ease), color .35s var(--ease);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  letter-spacing:-0.011em;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- ambient + grain (extremamente sutil) ---------- */
.ambient{
  position:fixed; inset:-30vh -10vw auto; height:80vh; z-index:-2;
  background:
    radial-gradient(40% 50% at 70% 0%, var(--ambient-1), transparent 70%),
    radial-gradient(35% 45% at 15% 10%, var(--ambient-2), transparent 70%);
  filter:blur(var(--ambient-blur));
  opacity:var(--ambient-op);
  animation:drift 26s var(--ease) infinite alternate;
  transition:opacity .6s var(--ease), filter .6s var(--ease);
}
@keyframes drift{
  from{transform:translate3d(-3%,0,0) scale(1)}
  to{transform:translate3d(4%,2%,0) scale(1.06)}
}
.grain{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  opacity:var(--grain-op); mix-blend-mode:var(--grain-blend);
  transition:opacity .6s var(--ease);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- buttons ---------- */
.btn{
  --bx:0; --by:0;
  display:inline-flex; align-items:center; gap:.5em;
  font-size:.95rem; font-weight:560; letter-spacing:-0.01em;
  padding:.72em 1.25em; border-radius:999px;
  cursor:pointer; border:1px solid transparent;
  transition:transform .4s var(--ease), background .3s var(--ease), border-color .3s var(--ease), box-shadow .4s var(--ease), color .3s var(--ease);
  transform:translate3d(var(--bx),var(--by),0);
  will-change:transform;
}
.btn svg{transition:transform .4s var(--ease)}
.btn-solid{
  background:var(--ink); color:var(--ink-on-solid);
  box-shadow:0 1px 0 oklch(100% 0 0 / .15) inset, var(--shadow-1);
}
.btn-solid:hover{background:var(--green-ink); color:var(--bg); box-shadow:var(--solid-hover-glow)}
.btn-solid:hover svg{transform:translateX(3px)}
.btn-ghost{border-color:var(--line); color:var(--ink); background:var(--paper)}
.btn-ghost:hover{border-color:var(--green); background:var(--green-ink); color:var(--bg)}
.btn-quiet{color:var(--ink-soft); padding-left:.4em; padding-right:.4em}
.btn-quiet:hover{color:var(--ink)}
.btn:active{transform:translate3d(var(--bx),var(--by),0) scale(.97)}

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  padding:14px var(--pad);
  transition:padding .5s var(--ease), background .5s var(--ease), border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  padding-top:9px; padding-bottom:9px;
  background:var(--nav-blur-bg);
  backdrop-filter:blur(16px) saturate(1.2);
  border-bottom-color:var(--line-soft);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto;
  display:flex; align-items:center; gap:24px;
}
.brand{display:inline-flex; align-items:center; gap:10px; font-weight:640; letter-spacing:-0.02em}
.brand-mark{display:inline-flex; align-items:flex-end; gap:3px; height:22px}
.brand-mark i{
  width:4px; height:var(--h); border-radius:2px; background:var(--ink-mute);
  transition:height .5s var(--ease);
}
.brand-mark i.live{background:var(--green); animation:eq 1.6s var(--ease) infinite alternate}
@keyframes eq{from{height:11px}to{height:22px}}
.brand:hover .brand-mark i:first-child{height:16px}
.brand:hover .brand-mark i:last-child{height:18px}
.brand-word{font-size:1.06rem}
.nav-links{display:flex; gap:26px; margin-left:auto}
.nav-links a{
  font-size:.92rem; color:var(--ink-soft); position:relative; padding:4px 0;
  transition:color .3s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1.5px; width:100%;
  background:var(--green); transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{margin-left:8px}

/* ---------- theme toggle (discreto, coerente) ---------- */
.theme-toggle{
  position:relative; flex-shrink:0;
  width:38px; height:38px; padding:0; margin-left:4px;
  display:inline-grid; place-items:center;
  border-radius:999px; cursor:pointer;
  color:var(--ink-soft);
  background:var(--paper);
  border:1px solid var(--line);
  transition:color .3s var(--ease), background .3s var(--ease),
             border-color .3s var(--ease), box-shadow .4s var(--ease), transform .3s var(--ease);
}
.theme-toggle:hover{
  color:var(--ink); border-color:var(--green);
  box-shadow:0 0 0 4px var(--green-wash);
  transform:translateY(-1px);
}
.theme-toggle:active{transform:scale(.94)}
.theme-toggle:focus-visible{outline:none; border-color:var(--green); box-shadow:0 0 0 4px var(--green-wash)}
.theme-toggle svg{
  grid-area:1/1; transition:opacity .4s var(--ease), transform .5s var(--ease);
}
/* claro mostra a LUA (o que você pode ativar); escuro mostra o SOL */
.theme-toggle .ic-moon{opacity:1; transform:rotate(0) scale(1)}
.theme-toggle .ic-sun{opacity:0; transform:rotate(-70deg) scale(.6)}
:root[data-theme="dark"] .theme-toggle .ic-moon{opacity:0; transform:rotate(70deg) scale(.6)}
:root[data-theme="dark"] .theme-toggle .ic-sun{opacity:1; transform:rotate(0) scale(1)}
@media (max-width:880px){.nav-links{display:none} .theme-toggle{margin-left:auto} .nav-cta{margin-left:8px}}

/* ---------- layout primitives ---------- */
main{display:block}
.section{
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(80px,11vw,150px) var(--pad);
}
.section-head{max-width:760px; margin-bottom:clamp(40px,6vw,68px)}
.kicker{
  display:inline-block; font-size:.74rem; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--green-ink); margin-bottom:18px;
}
h2{
  font-size:clamp(1.85rem,3.7vw,2.85rem); line-height:1.08; font-weight:600;
  letter-spacing:-0.03em; margin:0;
}
.section-lede{
  color:var(--ink-soft); font-size:clamp(1.02rem,1.5vw,1.15rem);
  max-width:62ch; margin:22px 0 0;
}
.kicker + h2{margin-top:0}

/* ---------- reveal (IntersectionObserver) ---------- */
.reveal{
  opacity:0; transform:translateY(22px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
  transition-delay:calc(var(--d,0) * 80ms);
}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============ HERO ============ */
.hero{
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(130px,17vw,200px) var(--pad) clamp(40px,7vw,80px);
}
.hero-inner{max-width:880px}
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:.85rem; color:var(--ink-soft);
  background:var(--paper); border:1px solid var(--line);
  padding:7px 14px 7px 12px; border-radius:999px; margin:0 0 30px;
  box-shadow:var(--shadow-1);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 var(--green);animation:ping 2.4s var(--ease) infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 oklch(63% 0.16 158 / .5)}70%,100%{box-shadow:0 0 0 8px oklch(63% 0.16 158 / 0)}}

.hero-title{
  font-size:clamp(2.7rem,7.2vw,5.1rem); line-height:0.99; font-weight:600;
  letter-spacing:-0.045em; margin:0;
}
.hero-title .line{display:block}
.accent-line{color:var(--ink)}
.ink-swap{
  color:var(--green-ink); position:relative; display:inline-block;
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.ink-swap.swapping{opacity:0; transform:translateY(8px)}

.hero-sub{
  font-size:clamp(1.08rem,1.7vw,1.27rem); color:var(--ink-soft);
  max-width:60ch; margin:30px 0 0; line-height:1.62;
}
.hero-cta{display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin:38px 0 0}
.hero-foot{font-size:.9rem; color:var(--ink-mute); margin:20px 0 0}

.hero-shot{margin:clamp(56px,8vw,90px) 0 0}
.window{
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  border:1px solid var(--line); background:var(--paper);
  box-shadow:var(--shadow-win);
  transform-style:preserve-3d;
}
.window.soft{box-shadow:var(--shadow-2)}
.window-bar{
  display:flex; align-items:center; gap:12px;
  padding:11px 16px; background:var(--bg-2); border-bottom:1px solid var(--line-soft);
}
.traffic{display:inline-flex; gap:7px}
.traffic i{width:11px;height:11px;border-radius:50%;background:var(--line);display:block}
.traffic i:nth-child(1){background:oklch(80% 0.09 30)}
.traffic i:nth-child(2){background:oklch(85% 0.1 90)}
.traffic i:nth-child(3){background:oklch(82% 0.12 150)}
.window-title{font-size:.82rem; color:var(--ink-mute); font-weight:520}
.window-status{
  margin-left:auto; display:inline-flex; align-items:center; gap:7px;
  font-size:.74rem; color:var(--green-ink); font-family:var(--mono);
}
.pulse{width:7px;height:7px;border-radius:50%;background:var(--green);position:relative}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--green);animation:ping 2s var(--ease) infinite}
.window img{width:100%;display:block}
.shot-glow{
  position:absolute; inset:0; pointer-events:none; opacity:0;
  background:var(--shot-glow);
  transition:opacity .4s var(--ease);
}
.hero-shot:hover .shot-glow{opacity:1}
.shot-cap{text-align:center; font-size:.88rem; color:var(--ink-mute); margin:18px 0 0}

/* tilt target */
[data-tilt]{transition:transform .5s var(--ease)}
[data-tilt] .window{transition:box-shadow .5s var(--ease)}

/* ============ STRIP / stats ============ */
.strip{border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); background:var(--bg-2)}
.strip-inner{
  max-width:var(--maxw); margin:0 auto; padding:clamp(40px,6vw,64px) var(--pad);
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,4vw,56px);
}
.stat{display:flex; flex-direction:column; gap:8px}
.stat-num{font-size:clamp(2.4rem,5vw,3.4rem); font-weight:600; letter-spacing:-0.04em; line-height:1; color:var(--ink); font-variant-numeric:tabular-nums}
.stat-label{font-size:.96rem; color:var(--ink-soft); max-width:30ch}
@media (max-width:760px){.strip-inner{grid-template-columns:1fr; gap:32px}}

/* ============ FRENTES ============ */
.frentes{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line)}
.frente{
  position:relative; padding:34px 30px 38px; border-bottom:1px solid var(--line);
  border-right:1px solid var(--line); overflow:hidden;
  transition:background .4s var(--ease);
}
.frente:nth-child(3n){border-right:none}
.frente::before{ /* spotlight */
  content:""; position:absolute; inset:0; opacity:0; pointer-events:none;
  background:radial-gradient(280px 280px at var(--mx,50%) var(--my,50%), var(--spot-color), transparent 60%);
  transition:opacity .4s var(--ease);
}
.frente:hover::before{opacity:1}
.frente:hover{background:var(--paper)}
.frente-idx{font-family:var(--mono); font-size:.8rem; color:var(--green-ink); position:relative}
.frente h3{font-size:1.22rem; font-weight:580; margin:14px 0 10px; letter-spacing:-0.02em; position:relative}
.frente p{font-size:.97rem; color:var(--ink-soft); margin:0; position:relative}
@media (max-width:860px){.frentes{grid-template-columns:1fr} .frente{border-right:none}}

/* ============ SPLIT (contratar) ============ */
.split{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,6vw,80px); align-items:center}
.split-text h2{margin-bottom:0}
.spec-list{list-style:none; margin:34px 0 0; padding:0; display:flex; flex-direction:column}
.spec-list li{
  display:flex; flex-direction:column; gap:3px;
  padding:18px 0; border-top:1px solid var(--line);
}
.spec-list li:last-child{border-bottom:1px solid var(--line)}
.spec-list strong{font-weight:580; font-size:1.02rem}
.spec-list span{color:var(--ink-mute); font-size:.94rem}

.hire-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:26px; box-shadow:var(--shadow-2);
}
.hire-head{display:flex; align-items:center; gap:14px; margin-bottom:22px}
.hire-avatar{
  width:46px;height:46px;border-radius:14px; display:grid;place-items:center;
  background:var(--green-wash); color:var(--green-ink); font-weight:640; font-size:1.1rem;
}
.hire-label{display:block; font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-mute)}
.hire-name{font-size:1.12rem; letter-spacing:-0.02em}
.hire-name::after{content:"";display:inline-block;width:2px;height:1em;background:var(--green);margin-left:2px;vertical-align:-2px;animation:caret 1s step-end infinite}
@keyframes caret{50%{opacity:0}}
.hire-tag{
  margin-left:auto; font-size:.72rem; font-family:var(--mono); color:var(--ink-mute);
  border:1px solid var(--line); padding:3px 9px; border-radius:999px;
}
.hire-fields{margin:0; display:flex; flex-direction:column}
.hire-fields > div{display:flex; justify-content:space-between; gap:16px; padding:13px 0; border-top:1px solid var(--line-soft)}
.hire-fields dt{color:var(--ink-mute); font-size:.9rem; margin:0}
.hire-fields dd{margin:0; font-size:.94rem; text-align:right; color:var(--ink)}
.hire-foot{display:flex; align-items:center; gap:12px; margin-top:22px; padding-top:18px; border-top:1px solid var(--line)}
.meter{flex:1; height:5px; border-radius:99px; background:var(--bg-2); overflow:hidden}
.meter i{display:block; height:100%; width:30%; border-radius:99px; background:var(--green); animation:fill 3.4s var(--ease) infinite}
@keyframes fill{0%{width:8%}50%{width:78%}100%{width:8%}}
.hire-foot-txt{font-size:.82rem; color:var(--ink-mute); font-family:var(--mono)}
@media (max-width:880px){.split{grid-template-columns:1fr}}

/* ============ TALK / thread ============ */
.thread{
  max-width:760px; margin:clamp(36px,5vw,52px) auto 0; display:flex; flex-direction:column; gap:14px;
}
.msg{
  background:var(--paper); border:1px solid var(--line); border-radius:18px;
  padding:18px 20px; max-width:80%; box-shadow:var(--shadow-1);
  opacity:0; transform:translateY(14px) scale(.98);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.msg.show{opacity:1; transform:none}
.msg:nth-child(even){align-self:flex-end}
.msg.done{align-self:center; max-width:90%; background:var(--green-wash); border-color:transparent; text-align:center}
.msg-who{display:flex; align-items:center; gap:9px; font-size:.82rem; font-weight:560; color:var(--ink-soft); margin-bottom:7px}
.msg.done .msg-who{justify-content:center; color:var(--green-ink)}
.msg p{margin:0; font-size:.98rem; color:var(--ink)}
.ava{
  width:24px;height:24px;border-radius:7px;display:grid;place-items:center;
  font-size:.72rem; font-weight:640; color:#fff; flex-shrink:0;
}
.ava.c1{background:var(--ava1)}
.ava.c2{background:var(--ava2)}
.ava.c3{background:var(--ava3)}
.ava.c4{background:var(--ava4)}
.ava.c5{background:var(--ava5)}
.ava.c6{background:var(--ava6)}
.ava.ok{background:var(--green)}

/* ============ CLONE ============ */
.clone-grid{display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:center}
.clone-text h2{margin-bottom:0}
.clone-aside{
  margin:26px 0 0; padding:18px 22px; border-radius:var(--r-md);
  background:var(--bg-2); border:1px solid var(--line-soft);
  color:var(--ink-soft); font-size:.98rem;
}
.clone-stage{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:26px; box-shadow:var(--shadow-2); min-height:300px;
}
.clone-source,.clone-chip{
  display:flex; align-items:center; gap:13px;
  padding:14px 16px; border:1px solid var(--line); border-radius:14px; background:var(--bg);
}
.clone-source strong{display:block; font-size:.96rem; font-weight:580}
.clone-meta{font-size:.82rem; color:var(--ink-mute)}
.clone-source .ava{width:36px;height:36px;border-radius:11px;font-size:.95rem}
.clone-btn{
  margin-left:auto; display:inline-flex; align-items:center; gap:7px;
  font-size:.84rem; font-weight:560; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:999px;
  padding:8px 14px; cursor:pointer;
  transition:transform .3s var(--ease), background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.clone-btn:hover{background:var(--ink); color:var(--bg); border-color:var(--ink); transform:translateY(-1px)}
.clone-btn:active{transform:scale(.95)}
.clone-pool{display:flex; flex-direction:column; gap:10px; margin-top:14px}
.clone-chip{
  padding:11px 14px; animation:pop .5s var(--ease) both;
}
.clone-chip .ava{width:30px;height:30px;border-radius:9px;font-size:.8rem}
.clone-chip strong{font-size:.9rem; font-weight:560}
.clone-chip .clone-meta{margin-left:auto; font-family:var(--mono); font-size:.74rem; color:var(--green-ink)}
.clone-chip.leaving{animation:leave .4s var(--ease) forwards}
@keyframes pop{from{opacity:0; transform:translateY(-8px) scale(.96)}to{opacity:1; transform:none}}
@keyframes leave{to{opacity:0; transform:translateX(20px) scale(.95); height:0; margin:0; padding-top:0; padding-bottom:0}}
.clone-hint{font-size:.86rem; color:var(--ink-mute); margin:18px 0 0; text-align:center}
@media (max-width:880px){.clone-grid{grid-template-columns:1fr}}

/* ============ MEMORY ============ */
.memory-inner{max-width:820px; margin:0 auto; text-align:center}
.memory-inner .kicker{display:inline-block}
.memory-inner .section-lede{margin-left:auto;margin-right:auto}
.memory-shot{margin:clamp(40px,6vw,64px) 0 0}

/* ============ HOW / steps ============ */
.steps{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line)}
.step{padding:34px 26px 36px 0; border-top:0; position:relative}
.step:not(:last-child){border-right:1px solid var(--line); padding-right:30px}
.step-n{
  font-family:var(--mono); font-size:.82rem; color:var(--green-ink);
  width:30px;height:30px; border-radius:50%; border:1px solid var(--line);
  display:grid; place-items:center; margin-bottom:18px;
  transition:border-color .4s var(--ease), background .4s var(--ease), color .4s var(--ease);
}
.step:hover .step-n{background:var(--ink); color:var(--bg); border-color:var(--ink)}
.step h3{font-size:1.12rem; font-weight:580; margin:0 0 8px; letter-spacing:-0.02em}
.step p{font-size:.94rem; color:var(--ink-soft); margin:0; max-width:24ch}
@media (max-width:880px){.steps{grid-template-columns:1fr 1fr} .step{border-right:none!important;padding-right:24px}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}

/* ============ TEAM ============ */
.team-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
  border-top:1px solid var(--line); border-left:1px solid var(--line);
}
.member{
  position:relative; overflow:hidden;
  padding:26px 26px 28px; border-bottom:1px solid var(--line); border-right:1px solid var(--line);
  transition:background .4s var(--ease);
}
.member::before{
  content:""; position:absolute; inset:0; opacity:0; pointer-events:none;
  background:radial-gradient(240px 240px at var(--mx,50%) var(--my,50%), var(--spot-color), transparent 60%);
  transition:opacity .4s var(--ease);
}
.member:hover::before{opacity:1}
.member:hover{background:var(--paper)}
.member header{display:flex; align-items:center; gap:12px; margin-bottom:13px; position:relative}
.member header .ava{width:38px;height:38px;border-radius:11px;font-size:.95rem}
.member strong{display:block; font-size:.99rem; font-weight:580; letter-spacing:-0.01em}
.member header span{font-size:.82rem; color:var(--green-ink)}
.member p{font-size:.92rem; color:var(--ink-soft); margin:0; position:relative}
@media (max-width:880px){.team-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.team-grid{grid-template-columns:1fr}}
.team-shot{margin:clamp(44px,6vw,68px) 0 0}

/* ============ FEATS ============ */
.feat-list{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden}
.feat-list li{background:var(--bg); padding:28px 26px; transition:background .4s var(--ease)}
.feat-list li:hover{background:var(--paper)}
.feat-list h3{font-size:1.06rem; font-weight:580; margin:0 0 8px; letter-spacing:-0.02em}
.feat-list p{font-size:.93rem; color:var(--ink-soft); margin:0}
@media (max-width:880px){.feat-list{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.feat-list{grid-template-columns:1fr}}

/* ============ BETA ============ */
.beta-card{
  position:relative; overflow:hidden;
  max-width:760px; margin:0 auto; text-align:center;
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl);
  padding:clamp(40px,6vw,68px) clamp(28px,5vw,60px); box-shadow:var(--shadow-2);
}
.beta-card::before{
  content:""; position:absolute; inset:0; opacity:0; pointer-events:none;
  background:radial-gradient(420px 320px at var(--mx,50%) var(--my,50%), var(--spot-color), transparent 65%);
  transition:opacity .5s var(--ease);
}
.beta-card:hover::before{opacity:1}
.beta-card .kicker{display:inline-block}
.beta-card .section-lede{margin:22px auto 0}
.beta-form{margin:34px auto 0; max-width:460px; position:relative}
.field{
  display:flex; gap:8px; padding:7px; border:1px solid var(--line); border-radius:999px;
  background:var(--field-bg); transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.field:focus-within{border-color:var(--green); box-shadow:0 0 0 4px var(--green-wash)}
.field input{
  flex:1; border:0; background:transparent; padding:0 14px; font-size:.98rem;
  color:var(--ink); font-family:var(--font); min-width:0;
}
.field input:focus{outline:none}
.field input::placeholder{color:var(--ink-mute)}
.beta-note{font-size:.85rem; color:var(--ink-mute); margin:16px 0 0; transition:color .3s var(--ease)}
.beta-note.ok{color:var(--green-ink)}

/* ============ FAQ ============ */
.faq-list{display:flex; flex-direction:column; border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{
  list-style:none; cursor:pointer; padding:24px 0;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  font-size:1.08rem; font-weight:540; letter-spacing:-0.015em;
  transition:color .3s var(--ease);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--green-ink)}
.chev{position:relative; width:13px; height:13px; flex-shrink:0}
.chev::before,.chev::after{content:""; position:absolute; top:50%; left:50%; background:var(--ink-soft); transition:transform .35s var(--ease)}
.chev::before{width:13px;height:1.6px;transform:translate(-50%,-50%)}
.chev::after{width:1.6px;height:13px;transform:translate(-50%,-50%)}
.faq-item[open] .chev::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-item[open] summary{color:var(--ink)}
.faq-item p{
  margin:0; padding:0 0 26px; max-width:64ch; color:var(--ink-soft); font-size:1rem;
  animation:fade .5s var(--ease) both;
}
@keyframes fade{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ============ FOOTER ============ */
.footer{border-top:1px solid var(--line); background:var(--bg-2)}
.footer-inner{
  max-width:var(--maxw); margin:0 auto; padding:clamp(56px,7vw,80px) var(--pad) 40px;
  display:grid; grid-template-columns:1.3fr 2fr; gap:clamp(32px,5vw,64px);
}
.footer-brand p{color:var(--ink-soft); font-size:.95rem; max-width:34ch; margin:16px 0 0}
.footer-nav{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.footer-nav > div{display:flex; flex-direction:column; gap:11px}
.footer-nav span{font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-mute); margin-bottom:4px}
.footer-nav a{font-size:.93rem; color:var(--ink-soft); transition:color .3s var(--ease)}
.footer-nav a:hover{color:var(--ink)}
.footer-base{
  max-width:var(--maxw); margin:0 auto; padding:22px var(--pad);
  border-top:1px solid var(--line-soft);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:.85rem; color:var(--ink-mute);
}
.footer-pulse{display:inline-flex; align-items:center; gap:8px}
@media (max-width:760px){.footer-inner{grid-template-columns:1fr} .footer-nav{grid-template-columns:repeat(3,1fr)}}
@media (max-width:480px){.footer-nav{grid-template-columns:1fr 1fr}}
