/* TemplateHub — shared styles for legal & contact pages */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --primary:#6c47ff; --primary-d:#4e2fcf; --accent:#ff5c87;
  --bg:#0b0b0f; --bg2:#12121a; --bg3:#1a1a28; --border:rgba(255,255,255,.08);
  --text:#e8e8f0; --muted:#888899; --white:#fff; --green:#34d399;
}
html { scroll-behavior: smooth; }
body { font-family:'Inter',sans-serif; background:var(--bg); color:var(--text); line-height:1.7; overflow-x:hidden; }
a { color:var(--primary); text-decoration:none; }
a:hover { text-decoration:underline; }
.container { max-width:840px; margin:0 auto; padding:0 24px; }

/* top bar */
.topbar { border-bottom:1px solid var(--border); position:sticky; top:0; background:rgba(11,11,15,.85); backdrop-filter:blur(14px); z-index:50; }
.topbar-inner { height:64px; display:flex; align-items:center; justify-content:space-between; max-width:1180px; margin:0 auto; padding:0 24px; }
.logo { display:flex; align-items:center; gap:9px; font-weight:800; font-size:1.15rem; letter-spacing:-.02em; color:var(--text); }
.logo:hover { text-decoration:none; }
.logo .dot { width:10px; height:10px; border-radius:50%; background:var(--primary); box-shadow:0 0 14px var(--primary); }
.logo b { color:var(--primary); font-weight:800; }
.topnav { display:flex; gap:22px; font-size:.88rem; }
.topnav a { color:var(--muted); } .topnav a:hover { color:var(--text); text-decoration:none; }

/* hero */
.legal-hero { padding:64px 0 28px; border-bottom:1px solid var(--border); }
.badge { display:inline-flex; align-items:center; gap:6px; background:rgba(108,71,255,.15); border:1px solid rgba(108,71,255,.3); color:#a78bff; border-radius:50px; padding:4px 14px; font-size:.74rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; }
.legal-hero h1 { font-size:2.6rem; font-weight:800; letter-spacing:-.03em; color:var(--white); margin:18px 0 10px; line-height:1.1; }
.legal-hero .updated { color:var(--muted); font-size:.86rem; }

/* body */
.legal-body { padding:44px 0 80px; }
.legal-body h2 { font-size:1.3rem; font-weight:700; color:var(--white); margin:38px 0 12px; scroll-margin-top:80px; }
.legal-body h2:first-child { margin-top:0; }
.legal-body h3 { font-size:1.02rem; font-weight:700; color:var(--white); margin:22px 0 8px; }
.legal-body p, .legal-body li { color:var(--text); font-size:.96rem; }
.legal-body p { margin-bottom:14px; }
.legal-body ul { margin:0 0 16px 4px; padding-left:22px; }
.legal-body li { margin-bottom:8px; }
.legal-body strong { color:var(--white); }
.legal-body .lead { font-size:1.05rem; color:var(--muted); }

/* TOC */
.toc { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:20px 24px; margin-bottom:34px; }
.toc h4 { font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); margin-bottom:12px; font-weight:700; }
.toc ul { columns:2; column-gap:30px; list-style:none; padding:0; margin:0; }
.toc li { margin-bottom:7px; break-inside:avoid; }
.toc a { font-size:.88rem; color:var(--text); }

/* callout */
.callout { background:rgba(108,71,255,.09); border:1px solid rgba(108,71,255,.26); border-radius:12px; padding:16px 18px; margin:18px 0; font-size:.9rem; color:#c5b6ff; display:flex; gap:11px; }
.callout.warn { background:rgba(255,92,135,.08); border-color:rgba(255,92,135,.28); color:#ffb3c6; }

/* license tier table */
.tier-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:20px 0 8px; }
.tier { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:20px; }
.tier.hl { border-color:var(--primary); }
.tier h4 { font-size:1rem; color:var(--white); margin-bottom:4px; }
.tier .who { font-size:.78rem; color:var(--muted); margin-bottom:14px; }
.tier ul { list-style:none; padding:0; margin:0; }
.tier li { font-size:.84rem; margin-bottom:8px; display:flex; gap:8px; align-items:flex-start; color:var(--text); }
.tier li.yes::before { content:'✓'; color:var(--green); font-weight:700; flex-shrink:0; }
.tier li.no::before { content:'✗'; color:var(--muted); font-weight:700; flex-shrink:0; }
.tier li.no { color:var(--muted); }

/* contact form */
.contact-grid { display:grid; grid-template-columns:1.3fr 1fr; gap:36px; align-items:start; }
.cform { background:var(--bg2); border:1px solid var(--border); border-radius:18px; padding:28px; }
.field { display:flex; flex-direction:column; gap:7px; margin-bottom:16px; }
.field label { font-size:.84rem; font-weight:600; color:var(--text); }
.field input, .field select, .field textarea { background:var(--bg); border:1px solid var(--border); border-radius:10px; color:var(--text); font-family:inherit; font-size:.94rem; padding:12px 14px; outline:none; transition:border-color .18s; width:100%; }
.field input:focus, .field select:focus, .field textarea:focus { border-color:var(--primary); }
.field textarea { resize:vertical; min-height:120px; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 24px; border-radius:11px; font-weight:700; font-size:.95rem; cursor:pointer; border:none; font-family:inherit; transition:all .2s; }
.btn-primary { background:var(--primary); color:#fff; box-shadow:0 4px 20px rgba(108,71,255,.4); width:100%; }
.btn-primary:hover { background:var(--primary-d); text-decoration:none; }
.cside .card { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:20px 22px; margin-bottom:14px; }
.cside .card h4 { color:var(--white); font-size:.96rem; margin-bottom:6px; }
.cside .card p { color:var(--muted); font-size:.86rem; margin:0; }
.cside .card a { font-size:.88rem; }
.form-note { text-align:center; font-size:.82rem; color:var(--muted); margin-top:14px; }

/* footer */
.legal-footer { border-top:1px solid var(--border); padding:30px 0; }
.legal-footer .container { display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; }
.legal-footer p { color:var(--muted); font-size:.84rem; }
.legal-footer .links { display:flex; gap:18px; }
.legal-footer .links a { color:var(--muted); font-size:.84rem; }
.legal-footer .links a:hover { color:var(--text); text-decoration:none; }

@media (max-width:720px) {
  .legal-hero h1 { font-size:2rem; }
  .toc ul { columns:1; }
  .tier-grid { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .topnav { display:none; }
}
