/* ============================================================
   WhaleClues · Legal page styles (Terms / Privacy / Cookies /
   Disclaimer / Refund). Self-contained: tokens + nav + footer +
   long-form prose. Each legal page links ONLY this file.
   Tokens mirror DESIGN.md / index.html (Carbon Lab).
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&family=Sora:wght@300;400;600;700&family=Space+Grotesk:wght@500;600;700&display=swap');

:root{
  --bg:#0a0e14; --bg-edge:#101a29; --panel:#111826; --panel-2:#1a2333;
  --line:#283648; --ink:#f5f7fb; --text-2:#b6c2d2; --muted:#7f8ca3;
  --accent:#4da3ff; --accent-2:#6bb4ff; --gold:#f0bc42; --brand-gold:#C9A84C;
  --glow:rgba(77,163,255,.30);
  --font-ui:'Sora',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --font-display:'Space Grotesk','Sora',system-ui,sans-serif;
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-ui);
  background:
    radial-gradient(1100px 560px at 82% -8%, rgba(107,180,255,.10), transparent 60%),
    radial-gradient(900px 520px at -6% 8%, rgba(77,163,255,.07), transparent 55%),
    var(--bg);
  color:var(--ink);line-height:1.6;font-weight:300;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:48px 48px;opacity:.10;
  mask-image:radial-gradient(circle at 50% 0%, #000 0%, transparent 70%);
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}

/* ---- brand logo mark (shared with index/nav/footer) ---- */
.wc-logo{display:inline-flex;align-items:center;gap:11px;}
.wc-logo .mark{flex:none;}
.wc-logo .word{font-family:var(--font-display);font-weight:700;letter-spacing:.1em;font-size:15px;color:var(--accent);}
.wc-logo .word b{font-weight:700;color:var(--brand-gold);}
.wc-logo .sub{display:block;font-family:var(--font-mono);font-weight:400;font-size:8.5px;letter-spacing:.18em;color:var(--muted);margin-top:2px;}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-ui);font-weight:600;font-size:14.5px;border-radius:10px;padding:11px 20px;cursor:pointer;border:1px solid transparent;transition:.2s;}
.btn-primary{background:var(--accent);color:#06101e;border-color:var(--accent);box-shadow:0 10px 30px -12px var(--glow);}
.btn-primary:hover{background:var(--accent-2);box-shadow:0 14px 34px -10px var(--glow);transform:translateY(-1px);}

/* ---- top nav (mirrors index.html) ---- */
nav.top{position:sticky;top:0;z-index:120;backdrop-filter:blur(12px);background:rgba(10,14,20,.72);border-bottom:1px solid rgba(40,54,72,.55);}
nav.top .row{max-width:var(--maxw);margin:0 auto;padding:7px 28px;display:flex;align-items:center;gap:30px;}
nav.top .wc-logo{gap:11px;}
nav.top .wc-logo .mark{height:41px;width:auto;}
nav.top .wc-logo .word{font-size:21px;}
nav.top .wc-logo .sub{font-size:11.7px;margin-top:1px;}
nav.top .links{display:flex;gap:26px;margin-left:14px;}
nav.top .links a{font-size:13.5px;color:var(--text-2);transition:.2s;}
nav.top .links a:hover{color:var(--ink);}
nav.top .right{margin-left:auto;display:flex;align-items:center;gap:14px;}
nav.top .right .signin{font-size:13.5px;color:var(--text-2);}
nav.top .right .signin:hover{color:var(--ink);}
@media(max-width:860px){nav.top .links{display:none;}}

/* ============================================================
   Legal long-form layout
   ============================================================ */
.legal-wrap{position:relative;z-index:1;max-width:860px;margin:0 auto;padding:0 28px 40px;}

.legal-head{padding:54px 0 28px;border-bottom:1px solid var(--line);margin-bottom:34px;}
.legal-back{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:24px;transition:.2s;}
.legal-back:hover{color:var(--accent);}
.legal-head h1{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,5vw,46px);letter-spacing:-.02em;line-height:1.05;margin:0 0 14px;}
.legal-updated{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--muted);}
.legal-intro{margin-top:18px;font-size:16px;line-height:1.75;color:var(--text-2);font-weight:300;}
.legal-intro b{color:var(--ink);font-weight:600;}

/* prose */
.legal-body{font-size:15px;line-height:1.78;color:var(--text-2);font-weight:300;}
.legal-body h2{font-family:var(--font-display);font-weight:600;font-size:clamp(20px,2.4vw,26px);letter-spacing:-.01em;line-height:1.2;color:var(--ink);margin:42px 0 14px;padding-top:8px;}
.legal-body h3{font-family:var(--font-ui);font-weight:600;font-size:16.5px;color:var(--ink);margin:26px 0 10px;}
.legal-body p{margin:0 0 16px;}
.legal-body b,.legal-body strong{color:var(--ink);font-weight:600;}
.legal-body a{color:var(--accent);transition:.2s;border-bottom:1px solid rgba(77,163,255,.3);}
.legal-body a:hover{color:var(--accent-2);border-bottom-color:var(--accent-2);}
.legal-body ul{margin:0 0 18px;padding-left:22px;}
.legal-body li{margin:0 0 9px;}
.legal-body li::marker{color:var(--muted);}
.legal-body hr{border:0;height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);margin:32px 0;}

/* upper-case caps blocks (warranty/liability) read as quieter */
.legal-body .caps{font-size:13px;letter-spacing:.01em;color:var(--muted);background:rgba(18,26,40,.5);border:1px solid var(--line);border-radius:12px;padding:16px 18px;}

/* callout (EU/UK, key consumer rights, immediate-access) */
.legal-callout{border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;background:rgba(18,26,40,.5);padding:16px 20px;margin:0 0 18px;}
.legal-callout.gold{border-left-color:var(--gold);background:rgba(224,179,65,.06);border-color:rgba(224,179,65,.28);}
.legal-callout p:last-child{margin-bottom:0;}

/* tables (cookie list, plan comparison) */
.legal-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:14px;margin:0 0 20px;background:linear-gradient(180deg,var(--panel),var(--panel-2));}
.legal-table{width:100%;min-width:560px;border-collapse:separate;border-spacing:0;font-size:13.5px;}
.legal-table th,.legal-table td{padding:12px 15px;text-align:left;vertical-align:top;border-right:1px solid var(--line);border-bottom:1px solid var(--line);}
.legal-table th:last-child,.legal-table td:last-child{border-right:0;}
.legal-table tbody tr:last-child td{border-bottom:0;}
.legal-table thead th{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(17,24,38,.55);}
.legal-table td{color:var(--text-2);}
.legal-table td b{color:var(--ink);}
.legal-table-note{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--muted);margin:-8px 0 22px;}

/* contact / footer-of-doc block */
.legal-contact{border:1px solid var(--line);border-radius:14px;background:rgba(18,26,40,.5);padding:20px 22px;margin:30px 0 0;}
.legal-contact h2{margin-top:0;}
.legal-contact a{color:var(--accent);}

/* related policies strip */
.legal-related{margin:40px 0 0;padding-top:26px;border-top:1px solid var(--line);}
.legal-related h4{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
.legal-related .links{display:flex;flex-wrap:wrap;gap:10px;}
.legal-related .links a{font-size:13px;color:var(--text-2);border:1px solid var(--line);border-radius:999px;padding:7px 14px;background:rgba(18,26,40,.5);transition:.2s;}
.legal-related .links a:hover{color:var(--accent);border-color:var(--accent);}
.legal-related .links a[aria-current="page"]{color:var(--accent);border-color:var(--accent);background:rgba(77,163,255,.08);}

/* ---- footer (mirrors index.html, adds Legal column) ---- */
footer{position:relative;z-index:1;border-top:1px solid var(--line);margin-top:80px;padding:44px 0 0;}
footer .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
footer .grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:40px;}
footer .cols{display:flex;gap:56px;flex-wrap:wrap;}
footer .col h4{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
footer .col a{display:block;font-size:13.5px;color:var(--text-2);margin-bottom:9px;transition:.2s;}
footer .col a:hover{color:var(--ink);}
