/* ================================================================
   CyberPrivacy — Dark Premium Edition
   Aesthetic: editorial dark · Space Grotesk + Syne + JetBrains Mono
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap');

/* ── TOKENS ── */
:root {
  /* Dark surfaces */
  --surface-0:   #080c12;
  --surface-1:   #0d1117;
  --surface-2:   #111820;
  --surface-3:   #161e28;
  --surface-4:   #1c2534;

  /* Borders */
  --border-1:    rgba(255,255,255,.06);
  --border-2:    rgba(255,255,255,.10);
  --border-3:    rgba(255,255,255,.16);

  /* Text */
  --text-1:      #f0f4ff;
  --text-2:      #8b97b0;
  --text-3:      #4d5a72;

  /* Brand accent — electric indigo / steel blue palette */
  --accent:      #4e8ef7;
  --accent-glow: rgba(78,142,247,.18);
  --accent-dim:  rgba(78,142,247,.12);
  --accent-mid:  #6ea8ff;
  --accent-hover:#5a97ff;

  /* Semantic */
  --red:         #f85149;
  --red-dim:     rgba(248,81,73,.12);
  --amber:       #e3a008;
  --amber-dim:   rgba(227,160,8,.12);
  --green:       #3fb950;
  --green-dim:   rgba(63,185,80,.12);
  --teal:        #39d0d8;
  --teal-dim:    rgba(57,208,216,.12);

  /* Shadows */
  --shadow-sm:   0 1px 4px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.04);
  --shadow:      0 4px 24px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.05);
  --shadow-lg:   0 16px 60px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.06);
  --glow-blue:   0 0 40px rgba(78,142,247,.15);

  /* Fonts — Apple system stack */
  --font-disp:   -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", Arial, sans-serif;
  --font-body:   -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Arial, sans-serif;
  --font-mono:   'JetBrains Mono', ui-monospace, "SF Mono", "Cascadia Code", "Courier New", monospace;

  /* Layout */
  --radius-sm:   6px;
  --radius:      10px;
  --radius-lg:   16px;
  --radius-xl:   22px;
  --ease:        cubic-bezier(.4,0,.2,1);
  --t:           .2s;
  --max-w:       1120px;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  background: var(--surface-0);
  color: var(--text-1);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--surface-1); }
::-webkit-scrollbar-thumb { background: var(--surface-4); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--border-3); }

/* ── NAVBAR ── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 900;
  height: 56px;
  display: flex; align-items: center;
  padding: 0 clamp(1.25rem, 4vw, 2.5rem);
  background: rgba(8,12,18,.82);
  backdrop-filter: saturate(160%) blur(24px);
  -webkit-backdrop-filter: saturate(160%) blur(24px);
  border-bottom: 1px solid var(--border-1);
  transition: border-color var(--t), box-shadow var(--t);
}
.navbar.scrolled {
  border-bottom-color: var(--border-2);
  box-shadow: 0 1px 0 var(--border-1), var(--shadow-sm);
}

.nav-inner {
  width: 100%; max-width: var(--max-w); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
}

.nav-logo {
  display: flex; align-items: center; gap: .6rem;
  text-decoration: none;
}
.nav-logo-mark {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}
.nav-logo-mark img {
  width: 100%; height: 100%; object-fit: contain;
}
.nav-logo-mark .fallback {
  color: var(--accent); font-size: 14px;
}
.nav-logo-name {
  font-family: var(--font-disp);
  font-size: .9rem; font-weight: 700;
  color: var(--text-1); letter-spacing: -.02em;
}
.nav-logo-name .logo-cyber { color: var(--text-1); }
.nav-logo-name .logo-privacy { color: var(--accent-mid); }

.nav-menu {
  display: flex; align-items: center; gap: .05rem;
  list-style: none;
}
.nav-menu a {
  text-decoration: none;
  color: var(--text-2);
  font-family: var(--font-body);
  font-size: .8125rem; font-weight: 500;
  padding: .35rem .8rem;
  border-radius: var(--radius-sm);
  transition: color var(--t), background var(--t);
  letter-spacing: -.01em;
}
.nav-menu a:hover { color: var(--text-1); background: var(--border-1); }
.nav-menu a.active { color: var(--text-1); font-weight: 600; }

.nav-cta-btn {
  background: var(--accent) !important;
  color: #fff !important;
  border-radius: 980px !important;
  padding: .35rem 1.1rem !important;
  font-weight: 600 !important;
  letter-spacing: -.01em !important;
  transition: background var(--t), box-shadow var(--t) !important;
}
.nav-cta-btn:hover {
  background: var(--accent-hover) !important;
  box-shadow: 0 0 20px rgba(78,142,247,.35) !important;
}

.hamburger {
  display: none;
  flex-direction: column; gap: 4.5px;
  cursor: pointer; background: none; border: none; padding: 4px;
}
.hamburger span {
  display: block; width: 20px; height: 1.5px;
  background: var(--text-2); border-radius: 2px; transition: var(--t);
}

/* ── LAYOUT ── */
.page-wrap { padding-top: 56px; }

.container {
  width: 100%; max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 clamp(1.25rem, 4vw, 2.5rem);
}

/* ── HERO ── */
.hero {
  padding: 8rem 0 6rem;
  background: var(--surface-0);
  position: relative; overflow: hidden;
}
.hero-bg-shape {
  position: absolute; top: -15%; right: -8%;
  width: 700px; height: 700px;
  background: radial-gradient(ellipse at center,
    rgba(78,142,247,.07) 0%, transparent 60%);
  pointer-events: none;
}
.hero-bg-shape-2 {
  position: absolute; bottom: -10%; left: -5%;
  width: 500px; height: 500px;
  background: radial-gradient(ellipse at center,
    rgba(57,208,216,.05) 0%, transparent 60%);
  pointer-events: none;
}
/* Subtle grid texture */
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: .68rem; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 1.5rem;
  display: flex; align-items: center; gap: .6rem;
  animation: fadeUp .5s var(--ease) both;
  opacity: .9;
}
.hero-eyebrow::before {
  content: '';
  display: block; width: 28px; height: 1px;
  background: var(--accent);
}

.hero h1 {
  font-family: var(--font-disp);
  font-size: clamp(3.2rem, 7.5vw, 6.5rem);
  font-weight: 700; line-height: 1.0;
  letter-spacing: -.03em;
  color: var(--text-1);
  margin-bottom: 1.75rem;
  animation: fadeUp .5s .08s var(--ease) both;
}
.hero h1 em {
  font-style: normal;
  background: linear-gradient(135deg, var(--accent) 0%, var(--teal) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-sub {
  max-width: 520px;
  color: var(--text-2);
  font-size: 1.05rem; line-height: 1.8;
  margin-bottom: 2.75rem;
  animation: fadeUp .5s .16s var(--ease) both;
  font-weight: 400;
}
.hero-actions {
  display: flex; gap: .85rem; flex-wrap: wrap;
  animation: fadeUp .5s .22s var(--ease) both;
}

@keyframes fadeUp {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .75rem 1.75rem;
  border-radius: 980px;
  font-family: var(--font-body); font-weight: 600;
  font-size: .9rem; text-decoration: none; cursor: pointer;
  border: none; transition: all var(--t) var(--ease);
  letter-spacing: -.01em; white-space: nowrap;
}
.btn-primary {
  background: var(--accent); color: #fff;
  box-shadow: 0 0 0 1px rgba(78,142,247,.3);
}
.btn-primary:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 24px rgba(78,142,247,.35), 0 0 0 1px rgba(78,142,247,.4);
}
.btn-secondary {
  background: var(--surface-3); color: var(--text-1);
  border: 1px solid var(--border-2);
}
.btn-secondary:hover {
  background: var(--surface-4);
  border-color: var(--border-3);
  transform: translateY(-1px);
}

/* ── DIVIDER ── */
.divider {
  border: none; border-top: 1px solid var(--border-1);
  margin: 0 clamp(1.25rem,4vw,2.5rem);
}

/* ── SECTION ── */
.section {
  padding: 5.5rem 0;
}
.section-alt { background: var(--surface-1); }

.section-label {
  font-family: var(--font-mono);
  font-size: .67rem; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: .65rem;
  display: block; opacity: .85;
}
.section-title {
  font-family: var(--font-disp);
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 700; letter-spacing: -.03em;
  line-height: 1.05; color: var(--text-1);
  margin-bottom: .85rem;
}
.section-title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--accent) 0%, var(--teal) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-desc {
  color: var(--text-2); max-width: 560px;
  font-size: .9375rem; line-height: 1.8;
  margin-bottom: 3rem;
}

/* ── GRID ── */
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.25rem; }
@media(max-width:900px){ .grid-3{grid-template-columns:repeat(2,1fr);} }
@media(max-width:640px){ .grid-3,.grid-2{grid-template-columns:1fr;} }

/* ── CARD ── */
.card {
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  padding: 1.85rem;
  transition: box-shadow var(--t), transform var(--t), border-color var(--t);
}
.card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-3px);
  border-color: var(--border-2);
}
.card-icon {
  width: 44px; height: 44px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
  margin-bottom: 1.1rem;
  flex-shrink: 0;
}
.card-icon.blue   { background: var(--accent-dim);  }
.card-icon.red    { background: var(--red-dim);     }
.card-icon.green  { background: var(--green-dim);   }
.card-icon.amber  { background: var(--amber-dim);   }
.card-icon.teal   { background: var(--teal-dim);    }
.card-icon.gray   { background: var(--surface-4);   }

.card-title {
  font-family: var(--font-body);
  font-size: 1rem; font-weight: 700;
  color: var(--text-1); letter-spacing: -.02em;
  margin-bottom: .45rem;
}
.card-desc {
  color: var(--text-2); font-size: .875rem; line-height: 1.7;
}

/* ── THREAT CARDS ── */
.threat-card {
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  padding: 1.85rem;
  transition: box-shadow var(--t), transform var(--t), border-color var(--t);
  display: flex; flex-direction: column; gap: .9rem;
}
.threat-card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-3px);
  border-color: var(--border-2);
}
.threat-card-top {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 1rem;
}
.threat-rank {
  font-family: var(--font-disp); font-size: 2.75rem;
  font-weight: 800; line-height: 1; color: var(--surface-4);
  letter-spacing: -.04em; flex-shrink: 0;
}
.threat-badge-wrap { display: flex; flex-direction: column; align-items: flex-end; gap: .3rem; }
.threat-title {
  font-family: var(--font-body);
  font-size: 1.0625rem; font-weight: 700;
  color: var(--text-1); letter-spacing: -.02em;
}
.threat-subtitle {
  font-size: .79rem; color: var(--text-3);
  font-family: var(--font-mono);
}
.threat-desc {
  color: var(--text-2); font-size: .875rem; line-height: 1.75;
}
.threat-stats {
  display: flex; gap: 1.5rem; flex-wrap: wrap;
  padding-top: .85rem; border-top: 1px solid var(--border-1);
}
.threat-stat-item { display: flex; flex-direction: column; gap: .1rem; }
.threat-stat-value {
  font-family: var(--font-disp); font-size: 1.6rem;
  font-weight: 800; letter-spacing: -.03em; line-height: 1;
}
.threat-stat-value.red    { color: var(--red); }
.threat-stat-value.amber  { color: var(--amber); }
.threat-stat-value.blue   { color: var(--accent); }
.threat-stat-label {
  font-size: .7rem; color: var(--text-3); font-family: var(--font-mono);
}

/* ── BADGE ── */
.badge {
  display: inline-flex; align-items: center; gap: .25rem;
  padding: .2rem .65rem;
  border-radius: 980px;
  font-family: var(--font-mono); font-size: .65rem;
  letter-spacing: .5px; font-weight: 500;
  text-transform: uppercase; white-space: nowrap;
}
.badge-blue   { background: var(--accent-dim);  color: var(--accent-mid); border: 1px solid rgba(78,142,247,.2); }
.badge-red    { background: var(--red-dim);     color: #f98983;            border: 1px solid rgba(248,81,73,.2); }
.badge-green  { background: var(--green-dim);   color: var(--green);       border: 1px solid rgba(63,185,80,.2); }
.badge-amber  { background: var(--amber-dim);   color: var(--amber);       border: 1px solid rgba(227,160,8,.2); }
.badge-teal   { background: var(--teal-dim);    color: var(--teal);        border: 1px solid rgba(57,208,216,.2); }
.badge-gray   { background: var(--surface-4);   color: var(--text-2);      border: 1px solid var(--border-1); }

/* ── TOOL CARD ── */
.tool-card {
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  padding: 1.85rem;
  display: flex; flex-direction: column; gap: .75rem;
  transition: box-shadow var(--t), transform var(--t), border-color var(--t);
  position: relative; overflow: hidden;
}
.tool-card::after {
  content: '';
  position: absolute; top:0; left:0; right:0; height:2px;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  background: linear-gradient(90deg, var(--accent), var(--teal));
  opacity: 0; transition: opacity var(--t);
}
.tool-card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-3px);
  border-color: var(--border-2);
}
.tool-card:hover::after { opacity: 1; }

.tool-card.avoid {
  border-color: rgba(248,81,73,.15);
}
.tool-card.avoid::after {
  background: linear-gradient(90deg, var(--red), var(--amber));
}

.tool-icon { font-size: 1.75rem; line-height: 1; }
.tool-icon img {
  width: 36px; height: 36px;
  border-radius: 8px;
  object-fit: contain;
  display: block;
}
.tool-name {
  font-size: 1.0625rem; font-weight: 700;
  color: var(--text-1); letter-spacing: -.02em;
}
.tool-desc { font-size: .875rem; color: var(--text-2); flex:1; line-height: 1.7; }
.tool-meta { display: flex; gap: .4rem; flex-wrap: wrap; }

.tool-pros { margin-top: .25rem; }
.tool-pro-item {
  font-family: var(--font-mono); font-size: .77rem;
  color: var(--text-2); padding: .2rem 0;
  padding-left: 1.1rem; position: relative;
}
.tool-pro-item::before {
  content: '+'; position:absolute; left:0;
  color: var(--green); font-weight:700;
}
.tool-pro-item.minus::before { content: '−'; color: var(--red); }

.tool-link {
  display: inline-flex; align-items: center; gap: .3rem;
  text-decoration: none; color: var(--accent);
  font-family: var(--font-mono); font-size: .78rem;
  transition: color var(--t); margin-top: .25rem;
}
.tool-link:hover { color: var(--accent-mid); text-decoration: underline; }

/* ── ACCORDION ── */
.acc-stack { display: flex; flex-direction: column; gap: .6rem; }

.acc-item {
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--t), box-shadow var(--t);
}
.acc-item.open {
  border-color: var(--border-2);
  box-shadow: var(--shadow-sm);
}

.acc-btn {
  width:100%; background:none; border:none; cursor:pointer;
  padding: 1.25rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  text-align:left;
  transition: background var(--t);
}
.acc-btn:hover { background: var(--surface-3); }

.acc-btn-left {
  display:flex; align-items:center; gap:.9rem;
}
.acc-ico {
  width:38px; height:38px;
  background: var(--surface-3); border: 1px solid var(--border-1);
  border-radius: 9px;
  display:flex; align-items:center; justify-content:center;
  font-size: 1rem; flex-shrink:0;
  overflow: hidden;
  transition: background var(--t), border-color var(--t);
}
.acc-ico img {
  width: 100%; height: 100%;
  object-fit: contain;
}
.acc-item.open .acc-ico { background: var(--accent-dim); border-color: rgba(78,142,247,.2); }

.acc-label {
  font-size: .9375rem; font-weight: 600;
  color: var(--text-1); letter-spacing: -.01em;
}

.acc-chevron {
  width: 26px; height: 26px;
  border: 1px solid var(--border-1); border-radius: 6px;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-3); font-size:.65rem; flex-shrink:0;
  transition: transform .28s var(--ease), background var(--t), color var(--t);
}
.acc-item.open .acc-chevron {
  transform: rotate(180deg);
  background: var(--accent); color:#fff; border-color:var(--accent);
}

.acc-body {
  max-height:0; overflow:hidden;
  transition: max-height .38s var(--ease);
}
.acc-item.open .acc-body { max-height: 4000px; }

.acc-content {
  padding: 0 1.5rem 1.5rem;
  border-top: 1px solid var(--border-1);
  padding-top: 1.25rem;
  color: var(--text-2);
  font-size: .9rem; line-height: 1.85;
}
.acc-content h4 {
  font-family: var(--font-mono);
  font-size: .67rem; letter-spacing: 2px;
  text-transform: uppercase; color: var(--accent);
  margin: 1.4rem 0 .6rem; opacity: .85;
}
.acc-content h4:first-child { margin-top: 0; }
.acc-content p  { margin-bottom: .8rem; }
.acc-content ul { padding-left: 1.25rem; margin-bottom: .9rem; }
.acc-content li { margin-bottom: .4rem; }
.acc-content strong { color: var(--text-1); font-weight: 600; }
.acc-content a  { color: var(--accent); }

.callout {
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  margin: 1.1rem 0;
  font-size: .875rem; line-height: 1.75;
  display: flex; gap: .75rem;
}
.callout-icon { flex-shrink: 0; margin-top: .05rem; }
.callout.info  { background: var(--accent-dim);  border:1px solid rgba(78,142,247,.2); }
.callout.warn  { background: var(--red-dim);     border:1px solid rgba(248,81,73,.2); }
.callout.tip   { background: var(--green-dim);   border:1px solid rgba(63,185,80,.2); }
.callout.note  { background: var(--amber-dim);   border:1px solid rgba(227,160,8,.2); }

.code-block {
  background: var(--surface-1); color: #c9d1d9;
  border: 1px solid var(--border-1);
  border-radius: var(--radius); padding: 1rem 1.25rem;
  font-family: var(--font-mono); font-size: .8rem;
  line-height: 1.75; margin: 1rem 0; overflow-x: auto;
}
.code-block .c-dim   { color: #4d5a72; }
.code-block .c-green { color: #3fb950; }
.code-block .c-blue  { color: #6ea8ff; }
.code-block .c-amber { color: #e3a008; }

/* ── COMPARISON TABLE ── */
.compare-table {
  width: 100%; border-collapse: collapse;
  margin: 1rem 0; font-size: .85rem;
}
.compare-table th {
  background: var(--surface-3);
  padding: .65rem 1rem;
  font-family: var(--font-mono); font-size: .67rem;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text-2); border-bottom: 1px solid var(--border-1);
  text-align: left;
}
.compare-table td {
  padding: .65rem 1rem;
  border-bottom: 1px solid var(--border-1);
  color: var(--text-2); vertical-align: middle;
}
.compare-table tr:last-child td { border-bottom: none; }
.compare-table td:first-child { font-weight: 600; color: var(--text-1); }
.ct-yes  { color: var(--green);  font-weight:700; }
.ct-no   { color: var(--red);    font-weight:700; }
.ct-part { color: var(--amber);  font-weight:700; }

/* ── TERMINAL ── */
.terminal {
  background: var(--surface-1); border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  overflow: hidden; font-family: var(--font-mono); font-size: .82rem;
}
.terminal-bar {
  background: var(--surface-2); padding: .7rem 1rem;
  display: flex; align-items: center; gap: .45rem;
  border-bottom: 1px solid var(--border-1);
}
.t-dot { width:10px;height:10px;border-radius:50%; }
.t-r{background:#ff5f57;} .t-y{background:#febc2e;} .t-g{background:#28c840;}
.t-file { margin-left:.5rem; font-size:.72rem; color:var(--text-3); }
.terminal-body { padding:1.2rem 1.4rem; line-height:1.9; color:#c9d1d9; }
.td { color:var(--text-3); } .tb{ color:#6ea8ff; } .tg{ color:#3fb950; }
.tr{ color:#f85149; } .ty{ color:#e3a008; } .tw{ color:#f0f4ff; }

/* ── PAGE HEADER ── */
.page-hero {
  padding: 7rem 0 5rem;
  background: var(--surface-0);
  border-bottom: 1px solid var(--border-1);
  position: relative; overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.015) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.page-hero-label {
  font-family: var(--font-mono); font-size: .68rem;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--accent); margin-bottom: .85rem;
  display: flex; align-items: center; gap: .5rem; opacity: .85;
}
.page-hero-label::before {
  content: ''; display: block;
  width: 20px; height: 1px; background: var(--accent);
}
.page-hero h1 {
  font-family: var(--font-disp);
  font-size: clamp(2.5rem, 5vw, 4.25rem);
  font-weight: 700; letter-spacing: -.03em; line-height: 1.02;
  color: var(--text-1); margin-bottom: .85rem;
}
.page-hero p {
  color: var(--text-2); font-size: .9375rem;
  max-width: 560px; line-height: 1.75;
  font-family: var(--font-mono);
}

/* ── LEGAL ── */
.legal-body {
  max-width: 740px;
}
.legal-body h2 {
  font-family: var(--font-disp);
  font-size: 1.5rem; font-weight: 700;
  letter-spacing: -.03em; color: var(--text-1);
  margin: 2.5rem 0 .75rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--border-1);
}
.legal-body h2:first-of-type { margin-top: 0; }
.legal-body p  { color:var(--text-2); font-size:.9rem; margin-bottom:.9rem; line-height:1.85; }
.legal-body ul { color:var(--text-2); padding-left:1.25rem; margin-bottom:.9rem; font-size:.9rem; }
.legal-body li { margin-bottom:.4rem; line-height:1.75; }
.legal-body strong { color:var(--text-1); font-weight:600; }
.legal-body a  { color:var(--accent); }

.legal-toc {
  background: var(--surface-2); border: 1px solid var(--border-1);
  border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 3rem;
}
.legal-toc-title {
  font-family: var(--font-mono); font-size: .67rem; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 1rem;
}
.legal-toc a {
  display: block; font-size: .875rem; color: var(--text-2);
  text-decoration: none; padding: .4rem 0;
  border-bottom: 1px solid var(--border-1);
  transition: color var(--t);
}
.legal-toc a:hover { color: var(--accent); }
.legal-toc a:last-child { border-bottom: none; }

/* ── FOOTER ── */
footer {
  background: var(--surface-1);
  border-top: 1px solid var(--border-1);
  padding: 4.5rem 0 2.5rem; margin-top: 0;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem; padding-bottom: 3rem;
  border-bottom: 1px solid var(--border-1);
  margin-bottom: 2rem;
}
.footer-brand-desc {
  color: var(--text-2); font-size: .85rem;
  line-height: 1.75; margin-top: .85rem;
}

.footer-col-title {
  font-family: var(--font-mono); font-size: .67rem;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 1rem;
}
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: .55rem; }
.footer-col a {
  text-decoration: none; color: var(--text-2);
  font-size: .875rem; transition: color var(--t);
}
.footer-col a:hover { color: var(--text-1); }

.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: .75rem;
}
.footer-copy { font-size: .78rem; color: var(--text-3); font-family: var(--font-mono); }
.footer-made { font-size: .78rem; color: var(--text-3); }

/* ── CATEGORY HEADER ── */
.cat-header {
  margin-bottom: 2rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--border-1);
}
.cat-header h2 {
  font-family: var(--font-disp);
  font-size: 1.75rem; font-weight: 700;
  letter-spacing: -.03em; color: var(--text-1);
  margin-bottom: .3rem;
}
.cat-header p { font-size: .875rem; color: var(--text-2); }

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media(max-width:700px){
  .nav-menu {
    display: none; position: fixed;
    top:56px; left:0; right:0;
    background: rgba(8,12,18,.97);
    backdrop-filter: blur(24px);
    flex-direction: column; padding:1.5rem;
    gap:.25rem; border-bottom: 1px solid var(--border-1);
  }
  .nav-menu.open { display: flex; }
  .nav-menu a { padding: .65rem 1rem; width:100%; border-radius:var(--radius-sm); }
  .hamburger { display: flex; }
  .footer-grid { grid-template-columns:1fr; gap:2rem; }
  .hero h1 { font-size: 2.9rem; }
  .compare-table { font-size: .78rem; }
  .compare-table th, .compare-table td { padding: .5rem .65rem; }
}
@media(max-width:480px){
  .hero { padding: 6rem 0 4.5rem; }
  .section { padding: 3.5rem 0; }
  .grid-3, .grid-2 { gap: .75rem; }
  .code-block { font-size: .72rem; padding: .85rem 1rem; }
  .compare-table { font-size: .72rem; }
  .compare-table th, .compare-table td { padding: .4rem .5rem; }
  .acc-content { padding: 0 1rem 1rem; padding-top: 1rem; }
}

/* ── MODAL RESPONSIVE ── */
@media(max-width:700px){
  .modal-overlay { padding: 1rem .75rem; align-items: flex-start; }
  .modal { padding: 1.75rem 1.25rem; border-radius: var(--radius-lg); }
  .modal-title { font-size: 1.3rem; padding-right: 2.5rem; }
  .modal-body table { font-size: .78rem; }
  .modal-body table th, .modal-body table td { padding: .5rem .65rem; }
}
@media(max-width:480px){
  .modal-overlay { padding: .5rem; }
  .modal { padding: 1.25rem 1rem; }
  .modal-title { font-size: 1.15rem; }
  .modal-body { font-size: .85rem; }
  .modal-body table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .modal-body table th, .modal-body table td { padding: .4rem .5rem; font-size: .72rem; }
  .modal-body .code-block { font-size: .68rem; padding: .75rem .85rem; }
}

/* ── GUIDE CARD RESPONSIVE ── */
@media(max-width:750px){
  .guide-card { aspect-ratio: auto; min-height: 160px; }
}
@media(max-width:480px){
  .guide-card { aspect-ratio: auto; min-height: auto; padding: 1.15rem; }
}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion: reduce){
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}
