/* ============================================================
   Salam.AI — design tokens
   Ink Teal + Songket Gold + Hibiscus Coral. A live-translation
   platform's site, built like a Nusantara textile: warm, woven,
   in motion.
============================================================ */
:root{
  --ink:        #0D2B2E;
  --ink-deep:   #071A1C;
  --ink-raise:  #123A3D;
  --line:       rgba(247,239,221,0.14);
  --line-soft:  rgba(247,239,221,0.08);

  --parchment:  #F7EFDD;
  --parchment-dim: #E8DCC0;

  --gold:       #D9A441;
  --gold-bright:#F0C36B;
  --coral:      #E8465A;
  --coral-soft: #F0808F;
  --teal:       #2FBF9F;
  --teal-chart: #1FA98A;

  --ink-text:   #10262A;

  --font-display: "Fraunces", "Noto Serif", serif;
  --font-body:    "Space Grotesk", "Noto Sans", "Noto Sans SC", "Noto Sans Thai",
                   "Noto Sans Devanagari", "Noto Sans Arabic", "Noto Sans Bengali",
                   "Noto Sans Tamil", "Noto Sans Khmer", "Noto Sans Myanmar",
                   "Noto Sans Javanese", -apple-system, sans-serif;
  --font-mono:    "Space Mono", "SF Mono", ui-monospace, "Noto Sans", "Noto Sans SC",
                   "Noto Sans Thai", "Noto Sans Devanagari", "Noto Sans Arabic", "Noto Sans Bengali",
                   "Noto Sans Tamil", "Noto Sans Khmer", "Noto Sans Myanmar", "Noto Sans Javanese", monospace;

  --container: 1180px;
  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;

  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

body{
  margin:0;
  background:var(--ink);
  color:var(--parchment);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img,svg{ display:block; max-width:100%; }
a{ color:inherit; }
::selection{ background:var(--coral); color:var(--parchment); }

.wrap{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}

/* ---------- type ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0 0 0.4em;
  color:var(--parchment);
}
h1{ font-size:clamp(2.6rem, 6vw, 5.2rem); line-height:1.02; font-weight:500; }
h2{ font-size:clamp(2rem, 4vw, 3.1rem); line-height:1.08; }
h3{ font-size:clamp(1.25rem, 2vw, 1.6rem); }
p{ margin:0 0 1em; color:var(--parchment-dim); }
.lede{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--parchment-dim); max-width:52ch; }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--gold-bright);
  margin-bottom:1.1em;
}
.eyebrow::before{
  content:""; width:22px; height:1px; background:var(--gold-bright);
}

.italic{ font-style:italic; font-weight:400; color:var(--coral-soft); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-weight:500; font-size:0.95rem;
  padding:0.85em 1.5em;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  text-decoration:none;
  transition:transform .35s var(--ease-out), box-shadow .35s var(--ease-out), background .25s;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--coral); color:var(--parchment); box-shadow:0 8px 30px -8px rgba(232,70,90,.6); }
.btn-primary:hover{ box-shadow:0 14px 36px -8px rgba(232,70,90,.75); }
.btn-ghost{ background:transparent; border-color:var(--line); color:var(--parchment); }
.btn-ghost:hover{ border-color:var(--gold-bright); color:var(--gold-bright); }
.btn-row{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(13,43,46,0.72);
  border-bottom:1px solid var(--line-soft);
}
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:16px; }
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-size:1.3rem; font-weight:600; text-decoration:none; flex:none; }
.brand small{ font-family:var(--font-mono); font-size:0.6rem; letter-spacing:.16em; color:var(--gold-bright); display:block; text-transform:uppercase; margin-top:2px; }
.nav-links{ display:flex; gap:30px; list-style:none; margin:0; padding:0; font-size:0.92rem; }
.nav-links a{ text-decoration:none; color:var(--parchment-dim); position:relative; padding:4px 0; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--gold-bright); transition:width .3s var(--ease-out); }
.nav-links a:hover{ color:var(--parchment); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:18px; flex:none; }
.nav-cta .btn{ white-space:nowrap; }

.nav-toggle{
  display:none;
  flex:none;
  width:40px; height:40px;
  align-items:center; justify-content:center;
  background:transparent; border:1px solid var(--line); border-radius:10px;
  cursor:pointer; padding:0; position:relative;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after{
  content:""; position:absolute; width:18px; height:1.5px; background:var(--parchment); border-radius:2px;
  transition:transform .3s var(--ease-out), opacity .3s var(--ease-out);
}
.nav-toggle span::before{ transform:translateY(-6px); }
.nav-toggle span::after{ transform:translateY(6px); }
.nav-toggle[aria-expanded="true"] span{ background:transparent; }
.nav-toggle[aria-expanded="true"] span::before{ transform:translateY(0) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span::after{ transform:translateY(0) rotate(-45deg); }

@media (max-width: 860px){
  .nav .wrap{ height:66px; }
  .nav-links{
    display:flex; flex-direction:column; gap:0;
    position:absolute; top:66px; left:0; right:0;
    background:var(--ink-deep);
    border-bottom:1px solid var(--line-soft);
    max-height:0; overflow:hidden;
    transition:max-height .35s var(--ease-out);
  }
  .nav-links.open{ max-height:70vh; overflow-y:auto; }
  .nav-links a{ padding:16px 28px; display:block; border-bottom:1px solid var(--line-soft); }
  .nav-links a::after{ display:none; }
  .nav-links .nav-cta-mobile{ display:block; padding:18px 28px 22px; }
  .nav-cta{ display:none; }
  .nav-toggle{ display:inline-flex; }
}
@media (min-width:861px){
  .nav-cta-mobile{ display:none; }
}

/* ---------- section rhythm ---------- */
section{ position:relative; padding:118px 0; }
.section-tight{ padding:80px 0; }
.section-head{ max-width:640px; margin-bottom:64px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

.panel{
  background:var(--ink-raise);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
}

/* wave divider */
.wave-divider{ width:100%; height:64px; display:block; margin:-1px 0; }
.wave-divider path{ animation:waveShift 14s linear infinite; }
@keyframes waveShift{ from{ transform:translateX(0);} to{ transform:translateX(-200px);} }

/* ---------- HERO ---------- */
.hero{
  padding-top:76px;
  min-height:92vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.hero-bg .blob{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.55; mix-blend-mode:screen; }
.blob-1{ width:520px; height:520px; background:radial-gradient(circle at 30% 30%, var(--coral), transparent 70%); top:-120px; left:-80px; animation:driftA 26s ease-in-out infinite; }
.blob-2{ width:460px; height:460px; background:radial-gradient(circle at 60% 40%, var(--teal), transparent 70%); bottom:-140px; right:-60px; animation:driftB 32s ease-in-out infinite; }
.blob-3{ width:340px; height:340px; background:radial-gradient(circle at 50% 50%, var(--gold), transparent 70%); top:30%; right:18%; animation:driftC 22s ease-in-out infinite; }
@keyframes driftA{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(60px,40px) scale(1.15);} }
@keyframes driftB{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(-50px,-30px) scale(1.1);} }
@keyframes driftC{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(-30px,50px) scale(.9);} }

.hero .wrap{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr 0.95fr; gap:40px; align-items:center; }
@media (max-width: 980px){ .hero .wrap{ grid-template-columns:1fr; } }

.hero h1{ margin-bottom:0.32em; }
.hero-sub{ margin-bottom:2em; }
.hero-trust{ margin-top:2.4em; font-family:var(--font-mono); font-size:0.75rem; color:var(--parchment-dim); letter-spacing:.02em; display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.hero-trust span.dot{ width:5px; height:5px; border-radius:50%; background:var(--gold-bright); display:inline-block; }

/* --- signature piece: voice-to-script --- */
.signature{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  max-width:460px;
  margin:0 auto;
  align-self:center;
  justify-self:center;
}
.sig-ring{
  position:absolute; inset:0; border-radius:50%;
  border:1px dashed rgba(240,195,107,.3);
  animation:spin 60s linear infinite;
}
.sig-ring.inner{ inset:9%; animation-duration:44s; animation-direction:reverse; border-color:rgba(232,70,90,.3); }
@keyframes spin{ to{ transform:rotate(360deg); } }

.sig-card{
  position:absolute; inset:16%;
  border-radius:50%;
  background:radial-gradient(circle at 35% 25%, rgba(240,195,107,0.22), var(--ink-raise) 68%);
  border:1px solid rgba(247,239,221,0.3);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:18px;
  box-shadow: inset 0 0 60px rgba(0,0,0,.4), 0 30px 90px -24px rgba(0,0,0,.7), 0 0 0 1px rgba(240,195,107,.08);
}

.wave{ display:flex; align-items:center; justify-content:center; gap:5px; height:56px; }
.wave i{
  display:block; width:5px; border-radius:3px;
  background:linear-gradient(180deg, var(--gold-bright), var(--coral));
  animation:waveBar 1.6s ease-in-out infinite;
}
.wave i:nth-child(1){ height:18px; animation-delay:-1.4s; }
.wave i:nth-child(2){ height:34px; animation-delay:-1.1s; }
.wave i:nth-child(3){ height:50px; animation-delay:-0.8s; }
.wave i:nth-child(4){ height:28px; animation-delay:-0.5s; }
.wave i:nth-child(5){ height:44px; animation-delay:-1.6s; }
.wave i:nth-child(6){ height:20px; animation-delay:-0.3s; }
.wave i:nth-child(7){ height:38px; animation-delay:-0.9s; }
@keyframes waveBar{ 0%,100%{ transform:scaleY(0.35); opacity:.75;} 50%{ transform:scaleY(1); opacity:1; } }

.morph-word{ position:relative; height:2.4em; width:84%; text-align:center; }
.morph-word span{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:clamp(1.05rem, 4vw, 1.5rem); font-weight:500;
  color:var(--parchment);
  opacity:0; transform:translateY(10px);
  animation:morphCycle 16s var(--ease-soft) infinite;
}
.morph-word span:nth-child(1){ animation-delay:0s; }
.morph-word span:nth-child(2){ animation-delay:2s; }
.morph-word span:nth-child(3){ animation-delay:4s; }
.morph-word span:nth-child(4){ animation-delay:6s; }
.morph-word span:nth-child(5){ animation-delay:8s; }
.morph-word span:nth-child(6){ animation-delay:10s; }
.morph-word span:nth-child(7){ animation-delay:12s; }
.morph-word span:nth-child(8){ animation-delay:14s; }
@keyframes morphCycle{
  0%{ opacity:0; transform:translateY(10px) scale(.94); }
  4%{ opacity:1; transform:translateY(0) scale(1); }
  11%{ opacity:1; transform:translateY(0) scale(1); }
  15%{ opacity:0; transform:translateY(-10px) scale(.96); }
  100%{ opacity:0; }
}
.morph-caption{ font-family:var(--font-mono); font-size:0.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-bright); }

.chip{
  position:absolute;
  font-family:var(--font-mono); font-size:0.72rem;
  background:var(--ink-deep); border:1px solid var(--line);
  padding:6px 12px; border-radius:999px;
  color:var(--parchment-dim);
  animation:floatChip 9s ease-in-out infinite;
  white-space:nowrap;
}
.chip-1{ top:2%; left:-6%; animation-delay:0s; }
.chip-2{ top:16%; right:-10%; animation-delay:1.2s; }
.chip-3{ bottom:10%; left:-12%; animation-delay:2.4s; }
.chip-4{ bottom:-4%; right:6%; animation-delay:3.6s; }
.chip-5{ top:48%; left:-18%; animation-delay:4.8s; }
.chip-6{ top:60%; right:-16%; animation-delay:6s; }
@keyframes floatChip{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-14px); } }

@media (max-width: 980px){
  .signature{ max-width:340px; margin-top:40px; }
  .chip{ display:none; }
}

/* ---------- how it works ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
@media (max-width:860px){ .steps{ grid-template-columns:1fr; } }
.step{ padding:34px 30px; }
.step .num{ font-family:var(--font-display); font-size:2.6rem; color:var(--gold-bright); opacity:.7; line-height:1; margin-bottom:.3em; }
.step h3{ margin-bottom:.5em; }

.latency-diagram{ margin-top:70px; padding:44px; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:24px; }
@media (max-width:700px){ .latency-diagram{ grid-template-columns:1fr; text-align:center; } }
.ld-node{ text-align:center; }
.ld-node .icon{ width:64px; height:64px; margin:0 auto 14px; }
.ld-node small{ display:block; font-family:var(--font-mono); font-size:.7rem; color:var(--parchment-dim); margin-top:6px; }
.ld-path{ position:relative; height:2px; background:var(--line); width:100%; min-width:120px; }
.ld-path::after{
  content:""; position:absolute; top:-3px; left:0; width:8px; height:8px; border-radius:50%;
  background:var(--teal); box-shadow:0 0 12px 2px var(--teal);
  animation:travel 2.4s linear infinite;
}
@keyframes travel{ 0%{ left:0; opacity:0;} 8%{opacity:1;} 92%{opacity:1;} 100%{ left:calc(100% - 8px); opacity:0; } }
.ld-server{ text-align:center; grid-column:1/-1; margin-top:8px; }
.ld-server small{ font-family:var(--font-mono); font-size:.68rem; color:var(--parchment-dim); }

/* ---------- use cases ---------- */
.usecase-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:980px){ .usecase-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .usecase-grid{ grid-template-columns:1fr; } }
.usecase{
  padding:30px 28px; display:flex; flex-direction:column; gap:14px;
  transition:transform .4s var(--ease-out), border-color .4s;
}
.usecase:hover{ transform:translateY(-6px); border-color:var(--gold-bright); }
.usecase .icon{ width:44px; height:44px; color:var(--teal); }
.usecase h3{ font-size:1.15rem; }
.usecase p{ font-size:0.92rem; margin-bottom:0; }
.usecase .tag{ font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--gold-bright); }

.usecase-feature{
  margin-top:30px; padding:48px; display:grid; grid-template-columns:1.2fr 1fr; gap:40px; align-items:center;
  background:linear-gradient(135deg, rgba(217,164,65,0.08), rgba(232,70,90,0.06));
}
@media (max-width:860px){ .usecase-feature{ grid-template-columns:1fr; } }
.malaysia-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.malaysia-tags span{ font-family:var(--font-mono); font-size:.72rem; padding:5px 10px; border:1px solid var(--line); border-radius:999px; color:var(--parchment-dim); }

/* ---------- language board ---------- */
.flap-row{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; margin-bottom:50px; }
.flap{
  position:relative; height:64px; overflow:hidden;
  background:var(--ink-deep); border:1px solid var(--line); border-radius:10px;
}
.flap span{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:.85rem; color:var(--parchment);
  opacity:0; transform:translateY(100%);
  animation:flapCycle 12s var(--ease-soft) infinite;
}
.flap span:nth-child(1){ animation-delay:0s; }
.flap span:nth-child(2){ animation-delay:3s; }
.flap span:nth-child(3){ animation-delay:6s; }
.flap span:nth-child(4){ animation-delay:9s; }
@keyframes flapCycle{
  0%{ opacity:0; transform:translateY(60%);} 3%{ opacity:1; transform:translateY(0);} 22%{ opacity:1; transform:translateY(0);} 27%{ opacity:0; transform:translateY(-60%);} 100%{opacity:0;}
}
.flap::before{ content:""; position:absolute; left:0; right:0; top:50%; height:1px; background:var(--line); z-index:2; }

.lang-callout{ display:flex; gap:20px; align-items:flex-start; padding:26px 28px; margin-bottom:44px; border-left:3px solid var(--coral); }
.lang-callout .num{ font-family:var(--font-display); font-size:2.2rem; color:var(--coral-soft); }

.lang-groups{ display:grid; gap:28px; }
.lang-group h4{ font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--gold-bright); margin-bottom:14px; }
.lang-pills{ display:flex; flex-wrap:wrap; gap:8px; }
.lang-pills span{
  font-size:.85rem; padding:7px 13px; border-radius:999px; border:1px solid var(--line);
  background:var(--ink-raise); color:var(--parchment-dim);
}
.lang-pills span b{ color:var(--parchment); font-weight:500; }

/* ---------- broadcast map ---------- */
.broadcast-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
@media (max-width:900px){ .broadcast-wrap{ grid-template-columns:1fr; } }
.map-svg{ width:100%; height:auto; }
.map-node{ fill:var(--gold-bright); }
.map-node.source{ fill:var(--coral); }
.map-pulse{ animation:pulseRing 3s ease-out infinite; transform-origin:center; }
.map-pulse.d2{ animation-delay:1s; }
.map-pulse.d3{ animation-delay:2s; }
@keyframes pulseRing{ 0%{ transform:scale(0.3); opacity:.9;} 100%{ transform:scale(2.6); opacity:0; } }
.map-line{ stroke-dasharray:6 6; animation:dashFlow 2.5s linear infinite; }
@keyframes dashFlow{ to{ stroke-dashoffset:-24; } }

/* ---------- security ---------- */
.sec-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
@media (max-width:760px){ .sec-grid{ grid-template-columns:1fr; } }
.sec-card{ padding:28px; display:flex; gap:18px; }
.sec-card .icon{ width:34px; height:34px; flex:none; color:var(--gold-bright); }
.cipher{ font-family:var(--font-mono); font-size:.72rem; color:var(--teal); letter-spacing:.03em; opacity:.85; }
.cipher span{ display:inline-block; animation:cipherFlicker 2.4s steps(1) infinite; }
@keyframes cipherFlicker{ 0%,90%{ opacity:1;} 92%{ opacity:.2;} 94%{opacity:1;} }

/* ---------- pricing / usage dashboard ---------- */
.dash-mock{ padding:32px; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:760px){ .dash-mock{ grid-template-columns:repeat(2,1fr); } }
.stat{ background:var(--ink-deep); border:1px solid var(--line); border-radius:14px; padding:18px; }
.stat .label{ font-family:var(--font-mono); font-size:.65rem; text-transform:uppercase; letter-spacing:.08em; color:var(--parchment-dim); margin-bottom:8px; }
.stat .value{ font-family:var(--font-display); font-size:1.7rem; color:var(--parchment); }
.bar-track{ height:6px; border-radius:99px; background:var(--line); margin-top:10px; overflow:hidden; }
.bar-fill{ height:100%; border-radius:99px; background:linear-gradient(90deg,var(--teal),var(--gold-bright)); width:0%; animation:fillBar 2s var(--ease-out) forwards; animation-delay:.4s; }
@keyframes fillBar{ to{ width:78%; } }

.roles{ display:flex; gap:0; margin-top:40px; align-items:stretch; }
.role{ flex:1; padding:22px; text-align:center; border:1px solid var(--line); position:relative; }
.role:not(:first-child){ border-left:none; }
.role:first-child{ border-radius:14px 0 0 14px; }
.role:last-child{ border-radius:0 14px 14px 0; }
.role .k{ font-family:var(--font-mono); font-size:.65rem; color:var(--gold-bright); text-transform:uppercase; }
@media (max-width:700px){ .roles{ flex-direction:column; } .role:first-child,.role:last-child{ border-radius:14px; } .role:not(:first-child){ border-left:1px solid var(--line); border-top:none; } }

/* ---------- comparison ---------- */
.compare-stats{ display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:36px; }
@media (max-width:760px){ .compare-stats{ grid-template-columns:1fr; } }
.compare-stat{ padding:30px; text-align:center; }
.compare-stat .big{ font-family:var(--font-display); font-size:2.6rem; }
.compare-stat.human .big{ color:var(--coral-soft); }
.compare-stat.ai .big{ color:var(--teal); }

.rangebar-wrap{ padding:34px 32px; margin-bottom:36px; }
.rangebar{ position:relative; height:14px; border-radius:99px; background:var(--ink-deep); margin:26px 0 10px; }
.rangebar .fill{ position:absolute; top:0; bottom:0; left:8%; right:38%; border-radius:99px; background:linear-gradient(90deg,var(--coral),var(--coral-soft)); }
.rangebar .marker{ position:absolute; top:-30px; font-family:var(--font-mono); font-size:.72rem; color:var(--parchment-dim); transform:translateX(-50%); }
.rangebar .marker.lo{ left:8%; } .rangebar .marker.hi{ left:62%; }
.rangebar-scale{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:.62rem; color:var(--parchment-dim); opacity:.6; }
.rangebar-note{ font-size:.85rem; color:var(--parchment-dim); }

.growth-chart{ padding:30px 32px 20px; }
.growth-svg{ width:100%; height:220px; }
.legend-row{ display:flex; gap:22px; margin-top:6px; flex-wrap:wrap; }
.legend-row .item{ display:flex; align-items:center; gap:8px; font-size:.85rem; color:var(--parchment-dim); }
.legend-row .sw{ width:14px; height:3px; border-radius:2px; }

table.compare-table{ width:100%; border-collapse:collapse; margin-top:10px; }
table.compare-table caption{ caption-side:top; text-align:left; font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--parchment-dim); margin-bottom:12px; }
table.compare-table th, table.compare-table td{ text-align:left; padding:14px 16px; border-bottom:1px solid var(--line); font-size:.92rem; vertical-align:top; }
table.compare-table thead th{ font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.06em; color:var(--gold-bright); }
table.compare-table td.human{ color:var(--coral-soft); }
table.compare-table td.ai{ color:var(--teal); }
.sr-toggle{ font-family:var(--font-mono); font-size:.75rem; color:var(--gold-bright); background:none; border:1px solid var(--line); border-radius:999px; padding:8px 16px; cursor:pointer; margin-top:18px; }
.table-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
.swipe-hint{ display:none; font-family:var(--font-mono); font-size:.68rem; color:var(--gold-bright); text-transform:uppercase; letter-spacing:.08em; margin-bottom:10px; }
@media (max-width:760px){
  .swipe-hint{ display:block; }
  table.compare-table{ min-width:640px; }
}

/* ---------- footer ---------- */
footer{ background:var(--ink-deep); padding:70px 0 34px; border-top:1px solid var(--line-soft); }
.footer-top{ display:grid; grid-template-columns:1.3fr 1fr 1fr 1fr; gap:40px; margin-bottom:50px; }
@media (max-width:800px){ .footer-top{ grid-template-columns:1fr 1fr; } }
.footer-top h4{ font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--gold-bright); margin-bottom:14px; }
.footer-top ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.footer-top a{ text-decoration:none; color:var(--parchment-dim); font-size:.9rem; }
.footer-top a:hover{ color:var(--parchment); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; padding-top:26px; border-top:1px solid var(--line-soft); font-size:.82rem; color:var(--parchment-dim); }
.footer-bottom a{ color:var(--gold-bright); text-decoration:none; }
.footer-bottom a:hover{ text-decoration:underline; }

/* reveal-on-scroll */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.in{ opacity:1; transform:translateY(0); }

/* skip link / focus */
.skip-link{ position:absolute; left:-999px; top:auto; background:var(--gold-bright); color:var(--ink); padding:10px 18px; border-radius:8px; z-index:100; }
.skip-link:focus{ left:16px; top:16px; }
a:focus-visible, button:focus-visible, .btn:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:3px; }
