/* ═══════════════ hero (shared 2-col pattern — same as /vps/, /dedicated/ etc.) ═══════════════ */
.vhero{position:relative;padding:48px 0 40px;overflow:hidden}
.vhero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(700px 400px at 85% -10%,rgba(34,211,238,.07),transparent 60%),
  radial-gradient(560px 320px at 10% 30%,rgba(16,185,129,.055),transparent 55%);
  pointer-events:none;z-index:0}
.vhero::after{content:"";position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:44px 44px;mask-image:radial-gradient(ellipse at 60% 40%,#000 15%,transparent 70%);
  pointer-events:none;z-index:0}
.vhero-wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.3fr 340px;gap:56px;align-items:center}

.crumb{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-3);margin-bottom:14px;font-weight:500;letter-spacing:.2px;flex-wrap:wrap}
.crumb a{color:var(--text-3);transition:.15s}
.crumb a:hover{color:var(--accent)}
.crumb i{font-size:13px;color:var(--text-3)}
.crumb [aria-current]{color:#67e8f9;font-weight:600}

.vhero h1{font-size:40px;font-weight:800;line-height:1.1;letter-spacing:-1.2px;margin:0 0 14px;color:var(--text)}
.vhero-sub{font-size:15.5px;color:var(--text-2);line-height:1.65;max-width:560px;margin:0 0 22px}
.vhero-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:11.5px;font-weight:500}
.vhero-meta span{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:100px;
  background:rgba(255,255,255,.025);border:1px solid var(--border);color:var(--text-2)}
.vhero-meta span i{font-size:13px;color:#67e8f9}
.vhero-meta strong{color:#f1f5f9;font-weight:700;margin-left:2px}

.vhero-visual{position:relative;width:100%;max-width:340px;aspect-ratio:1/1;margin:0 auto}
.vhero-visual img{position:relative;z-index:2;width:100%;height:auto;border-radius:18px;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.55)) drop-shadow(0 0 30px rgba(34,211,238,.1));
  animation:vhfloat 7s ease-in-out infinite}
@keyframes vhfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.vhero-visual::before{content:"";position:absolute;inset:-8%;z-index:1;pointer-events:none;
  background:radial-gradient(50% 50% at 50% 50%,rgba(34,211,238,.14),transparent 70%);filter:blur(10px)}

/* ═══════════════ Legal 2-column layout: sidebar TOC + content ═══════════════ */
.legal-section{padding:40px 0 80px}
.legal-wrap{display:grid;grid-template-columns:260px 1fr;gap:64px;align-items:start}

.legal-toc{position:sticky;top:76px;padding:22px 24px;border:1px solid var(--border);border-radius:14px;
  background:linear-gradient(180deg,rgba(19,26,43,.85),rgba(11,15,25,.94));
  max-height:calc(100dvh - 96px);overflow-y:auto;overscroll-behavior:contain}
.legal-toc-title{font-size:10.5px;color:#64748b;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:14px;padding-bottom:12px;border-bottom:1px dashed rgba(148,163,184,.18)}
.legal-toc ol{list-style:none;counter-reset:t;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.legal-toc ol li{counter-increment:t}
.legal-toc ol li a{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:8px;
  font-size:12.5px;font-weight:500;color:#94a3b8;line-height:1.45;transition:.15s}
.legal-toc ol li a::before{content:counter(t,decimal-leading-zero);font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;color:#64748b;flex-shrink:0;margin-top:2px}
.legal-toc ol li a:hover{background:rgba(34,211,238,.06);color:#f1f5f9}
.legal-toc ol li a:hover::before{color:#67e8f9}
.legal-toc ol li a.active{background:rgba(34,211,238,.1);color:#67e8f9;border:1px solid rgba(34,211,238,.18)}

/* ═══════════════ Long-form content typography ═══════════════ */
.legal-content{max-width:820px;min-width:0}
.legal-content > section{padding:24px 0;border-bottom:1px dashed rgba(148,163,184,.12);scroll-margin-top:80px}
.legal-content > section:last-child{border-bottom:none}
.legal-content > section > h2{display:flex;align-items:baseline;gap:14px;font-size:22px;font-weight:800;letter-spacing:-.5px;color:#f5f9ff;margin:0 0 18px;line-height:1.25}
.legal-content > section > h2::before{content:counter(ls,decimal-leading-zero);counter-increment:ls;font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;color:#67e8f9;background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.2);padding:4px 9px;border-radius:6px;line-height:1.2;align-self:center;flex-shrink:0}
.legal-content{counter-reset:ls}
.legal-content h3{font-size:15.5px;font-weight:700;color:#f1f5f9;letter-spacing:-.2px;margin:22px 0 10px;line-height:1.3}
.legal-content p{font-size:14.5px;color:#cbd5e1;line-height:1.75;margin:0 0 14px}
.legal-content p strong{color:#f5f9ff;font-weight:700}
.legal-content p em{color:#e2e8f0;font-style:italic}
.legal-content ul,.legal-content ol{margin:8px 0 16px;padding-left:22px}
.legal-content ul li,.legal-content ol li{font-size:14px;color:#cbd5e1;line-height:1.7;margin:5px 0}
.legal-content ul li strong,.legal-content ol li strong{color:#f1f5f9;font-weight:700}
.legal-content a{color:#67e8f9;text-decoration:underline;text-decoration-color:rgba(34,211,238,.3);text-underline-offset:2px;transition:.15s}
.legal-content a:hover{text-decoration-color:#67e8f9;color:#a5f3fc}
.legal-content code{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:#67e8f9;background:rgba(34,211,238,.07);border:1px solid rgba(34,211,238,.16);padding:1px 6px;border-radius:4px}

/* Table styling inside legal content */
.legal-table{width:100%;border-collapse:collapse;margin:18px 0;font-size:13px;
  border:1px solid var(--border);border-radius:10px;overflow:hidden;
  background:rgba(19,26,43,.5)}
.legal-table thead th{background:rgba(255,255,255,.025);color:#f1f5f9;font-weight:700;font-size:11.5px;letter-spacing:.6px;text-transform:uppercase;padding:11px 14px;text-align:left;border-bottom:1px solid var(--border-hover)}
.legal-table tbody th{font-weight:700;color:#f1f5f9;padding:11px 14px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.015);text-align:left;vertical-align:top;white-space:nowrap}
.legal-table td{color:#cbd5e1;padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:top;line-height:1.55}
.legal-table tr:last-child th,.legal-table tr:last-child td{border-bottom:none}
.legal-table code{font-size:11.5px}

/* Inline CTA row (PGP download etc.) */
.legal-cta{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 12px}

/* ═══════════════ Footer meta card (version / last updated) ═══════════════ */
.legal-foot{margin-top:24px;padding:18px 22px;border:1px solid var(--border);border-radius:12px;
  background:linear-gradient(180deg,rgba(19,26,43,.6),rgba(11,15,25,.8));
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--text-3)}
.legal-foot i{color:#67e8f9;font-size:15px}
.legal-foot strong{color:#f1f5f9;font-weight:700;font-family:'JetBrains Mono',monospace;font-size:11.5px}

/* ═══════════════ Responsive ═══════════════ */
@media (max-width:1024px){
  .vhero{padding:40px 0 32px}
  .vhero-wrap{grid-template-columns:1fr;gap:32px}
  .vhero-visual{max-width:260px;order:-1}
  .legal-wrap{grid-template-columns:1fr;gap:22px}
  .legal-toc{position:static;max-height:none}
  .vhero h1{font-size:clamp(28px,4.6vw,34px);letter-spacing:-1px}
  .legal-content{max-width:100%}
}
@media (max-width:720px){
  .vhero{padding:28px 0 24px}
  .vhero h1{font-size:clamp(24px,6.2vw,30px);letter-spacing:-.7px;margin-bottom:10px}
  .vhero-sub{font-size:14.5px;margin-bottom:16px}
  .vhero-meta{gap:6px;font-size:11px}
  .vhero-meta span{padding:4px 10px}
  .vhero-visual{max-width:200px}
  .crumb{font-size:11px;margin-bottom:10px}
  .legal-section{padding:28px 0 56px}
  /* TOC collapsible on mobile via native <details>-style pattern */
  .legal-toc{padding:14px 16px;border-radius:12px}
  .legal-toc-title{font-size:10px;margin-bottom:10px;padding-bottom:8px}
  .legal-toc ol{display:grid;grid-template-columns:1fr 1fr;gap:2px}
  .legal-toc ol li a{padding:8px 10px;font-size:12px}
  /* Legal content */
  .legal-content > section{padding:18px 0}
  .legal-content > section > h2{font-size:17px;gap:10px;margin-bottom:14px}
  .legal-content > section > h2::before{font-size:11px;padding:3px 7px}
  .legal-content h3{font-size:14.5px;margin:18px 0 8px}
  .legal-content p{font-size:14px;line-height:1.7;margin-bottom:12px}
  .legal-content ul,.legal-content ol{padding-left:20px}
  .legal-content ul li,.legal-content ol li{font-size:13.5px}
  /* Tables scroll instead of wrap */
  .legal-table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .legal-foot{padding:14px 16px;font-size:11.5px;gap:10px}
}
@media (max-width:480px){
  .legal-toc ol{grid-template-columns:1fr}
}
