/* ============================================================
   Ignicode — Shared Legal / Long-Form Page Stylesheet
   Consumed by legal/privacy.html, terms.html, faq.html
   Builds on the same design tokens used elsewhere on the site.
   ============================================================ */

:root{
  --bg:#05070d;
  --bg-2:#0a0d15;
  --panel:#0c1119;
  --line:rgba(148,163,184,.12);
  --line-strong:rgba(148,163,184,.22);
  --text:#e6ecf3;
  --muted:#8a93a2;
  --dim:#5b6372;
  --cyan:#5eead4;
  --cyan-dim:rgba(94,234,212,.15);
  --violet:#a78bfa;
  --violet-dim:rgba(167,139,250,.15);
  --amber:#fbbf24;
  --ff-sans:'Inter',system-ui,sans-serif;
  --ff-display:'Space Grotesk',system-ui,sans-serif;
  --ff-mono:'JetBrains Mono',ui-monospace,monospace;
  --ff-serif:'Cormorant Garamond',serif;
  --maxw:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff-sans);background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;line-height:1.65;
  overflow-x:hidden;font-weight:300;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

body::before{
  content:"";position:fixed;inset:0;
  background:
    radial-gradient(50vw 50vw at 10% 0%, rgba(94,234,212,.05), transparent 60%),
    radial-gradient(50vw 50vw at 90% 110%, rgba(167,139,250,.06), transparent 60%),
    linear-gradient(var(--line) 1px,transparent 1px) 0 0/48px 48px,
    linear-gradient(90deg,var(--line) 1px,transparent 1px) 0 0/48px 48px,
    var(--bg);
  mask-image:radial-gradient(ellipse 90% 60% at 50% 0%, #000 40%, transparent 85%);
  pointer-events:none;z-index:-1;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
@media (max-width:640px){.wrap{padding:0 20px}}

/* ————— Top bar ————— */
header.top{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  background:rgba(5,7,13,.55);
  border-bottom:1px solid var(--line);
}
.top-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 32px;max-width:var(--maxw);margin:0 auto;
  font-family:var(--ff-sans);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:500;
}
.brand{display:flex;align-items:center;gap:12px;color:var(--text);font-weight:600;letter-spacing:.32em}
.brand .dot{
  width:8px;height:8px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 12px var(--cyan);animation:pulse 2.6s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.95;transform:scale(1)}50%{opacity:.35;transform:scale(.85)}}
.top nav{display:flex;gap:28px;color:var(--muted)}
.top nav a{transition:color .2s}
.top nav a:hover{color:var(--cyan)}
.top .apply{
  color:var(--bg);background:var(--cyan);padding:10px 20px;border-radius:999px;
  font-weight:600;letter-spacing:.18em;transition:transform .2s, box-shadow .2s;
}
.top .apply:hover{transform:translateY(-1px);box-shadow:0 0 24px rgba(94,234,212,.35)}
@media (max-width:820px){.top nav{display:none}}

/* ————— Hero ————— */
.legal-hero{padding:120px 0 56px;border-bottom:1px solid var(--line)}
@media (max-width:640px){.legal-hero{padding:72px 0 40px}}
.breadcrumb{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--dim);margin-bottom:32px;
}
.breadcrumb a{color:var(--muted);transition:color .2s}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb .sep{margin:0 12px;color:var(--dim)}
.legal-hero .label{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--cyan);display:inline-flex;align-items:center;gap:10px;margin-bottom:24px;
}
.legal-hero .label::before{content:"";width:28px;height:1px;background:var(--cyan);display:inline-block}
.legal-hero h1{
  font-family:var(--ff-display);font-size:clamp(40px,6vw,72px);font-weight:500;
  letter-spacing:-.02em;line-height:1.05;margin-bottom:20px;max-width:18ch;
}
.legal-hero h1 em{font-family:var(--ff-serif);font-style:italic;color:var(--cyan);font-weight:500}
.legal-hero .lede{
  font-size:18px;color:#c7cfda;max-width:60ch;font-weight:300;
}
.legal-hero .meta{
  margin-top:32px;display:flex;gap:24px;flex-wrap:wrap;
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);
}
.legal-hero .meta strong{color:var(--text);font-weight:500}

/* ————— Layout: TOC + content ————— */
.legal-layout{
  display:grid;grid-template-columns:260px 1fr;gap:72px;
  padding:72px 0 120px;align-items:start;
}
@media (max-width:900px){
  .legal-layout{grid-template-columns:1fr;gap:48px;padding:56px 0 88px}
}

.toc{
  position:sticky;top:104px;
  border:1px solid var(--line-strong);border-radius:14px;
  padding:24px;background:rgba(12,17,25,.5);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.toc .toc-title{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:16px;
}
.toc ol{
  list-style:none;counter-reset:toc;
  display:flex;flex-direction:column;gap:6px;
}
.toc ol li{
  counter-increment:toc;font-size:13px;line-height:1.4;
}
.toc ol li a{
  display:block;color:var(--muted);padding:7px 10px;border-radius:6px;
  transition:background .2s, color .2s;
}
.toc ol li a::before{
  content:counter(toc,decimal-leading-zero);
  font-family:var(--ff-mono);font-size:10px;color:var(--dim);
  margin-right:10px;letter-spacing:.1em;
}
.toc ol li a:hover{background:rgba(94,234,212,.06);color:var(--text)}
@media (max-width:900px){.toc{position:static}}

/* ————— Long-form content ————— */
.legal-content{max-width:760px}
.legal-content h2{
  font-family:var(--ff-display);font-size:clamp(24px,3.2vw,32px);
  font-weight:500;letter-spacing:-.01em;line-height:1.15;
  margin:64px 0 16px;scroll-margin-top:96px;
}
.legal-content h2:first-child{margin-top:0}
.legal-content h2 .num{
  font-family:var(--ff-mono);font-size:12px;color:var(--cyan);
  letter-spacing:.28em;display:block;margin-bottom:8px;font-weight:500;
}
.legal-content h3{
  font-family:var(--ff-display);font-size:18px;font-weight:500;
  letter-spacing:-.005em;margin:32px 0 12px;color:var(--text);
}
.legal-content p{
  color:#c7cfda;font-size:16px;line-height:1.75;margin-bottom:16px;max-width:65ch;
}
.legal-content p strong{color:var(--text);font-weight:500}
.legal-content em{font-family:var(--ff-serif);font-style:italic;color:var(--cyan);font-weight:500}
.legal-content ul,.legal-content ol{
  margin:8px 0 20px 0;padding-left:0;list-style:none;
}
.legal-content ul li, .legal-content ol li{
  position:relative;padding:6px 0 6px 28px;color:#c7cfda;font-size:16px;line-height:1.7;
  max-width:65ch;
}
.legal-content ul li::before{
  content:"";position:absolute;left:8px;top:18px;
  width:6px;height:6px;border-radius:50%;background:var(--cyan);opacity:.7;
}
.legal-content ol{counter-reset:ol}
.legal-content ol li{counter-increment:ol}
.legal-content ol li::before{
  content:counter(ol) ".";position:absolute;left:0;top:6px;
  font-family:var(--ff-mono);font-size:13px;color:var(--cyan);font-weight:500;
}
.legal-content ul li strong, .legal-content ol li strong{color:var(--text);font-weight:500}

.callout{
  border-left:2px solid var(--amber);
  padding:14px 0 14px 22px;margin:24px 0;
  background:linear-gradient(90deg, rgba(251,191,36,.05), transparent 60%);
  border-radius:0 8px 8px 0;
}
.callout p{margin-bottom:0;font-size:15px;color:#d7dde6}
.callout .tag{
  display:block;font-family:var(--ff-mono);font-size:10px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--amber);margin-bottom:6px;
}

.def-list{
  display:grid;grid-template-columns:200px 1fr;gap:14px 24px;
  margin:18px 0 24px;padding:20px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.def-list dt{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cyan);padding-top:3px;
}
.def-list dd{color:#c7cfda;font-size:15px;line-height:1.6}
@media (max-width:640px){.def-list{grid-template-columns:1fr;gap:6px}}

.contact-card{
  border:1px solid var(--line-strong);border-radius:14px;
  padding:28px;margin-top:24px;background:rgba(12,17,25,.5);
}
.contact-card h3{margin-top:0}
.contact-card p{margin-bottom:8px;font-size:15px}
.contact-card a{color:var(--cyan);transition:color .2s}
.contact-card a:hover{color:var(--text)}

.divider-rule{
  height:1px;background:linear-gradient(90deg,transparent,var(--line-strong),transparent);
  margin:48px 0;
}

/* ————— Footer (matched to home) ————— */
footer{border-top:1px solid var(--line);padding:56px 0 64px;color:var(--dim)}
.foot{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
}
.foot .motto{color:var(--muted)}
.foot-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-links a{color:var(--muted);transition:color .2s}
.foot-links a:hover{color:var(--cyan)}
.foot-links a.current{color:var(--cyan)}

/* Reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}
