/* Shared styling for Pruvio legal and data-rights pages. Same visual system as
   privacy.html and terms.html. Loaded same-origin (CSP style-src 'self'). */
:root {
  --bg:#0A0D14; --text:#E5E7EB; --muted:#9CA3AF; --heading:#F3F4F6;
  --link:#60A5FA; --link-hover:#93C5FD; --brand:#3B82F6;
  --border:rgba(255,255,255,0.10); --surface:rgba(255,255,255,0.04);
  --pill-bg:rgba(96,165,250,0.14); --pill-text:#93C5FD;
  --header-bg:rgba(10,13,20,0.85); --table-head:rgba(255,255,255,0.05);
  --field-bg:rgba(255,255,255,0.04);
}
:root[data-theme="light"] {
  --bg:#FFFFFF; --text:#1a1a1a; --muted:#6B7280; --heading:#0f172a;
  --link:#3B82F6; --link-hover:#2563EB; --brand:#3B82F6;
  --border:#E5E7EB; --surface:#F9FAFB;
  --pill-bg:#EFF6FF; --pill-text:#2563EB;
  --header-bg:rgba(255,255,255,0.88); --table-head:#F3F4F6;
  --field-bg:#FFFFFF;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  font-style:normal; line-height:1.65; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  overflow-wrap:break-word; word-wrap:break-word;
}
a { color:var(--link); text-decoration:none; }
a:hover { color:var(--link-hover); text-decoration:underline; }

.legal-header-nav { position:sticky; top:0; z-index:100; display:flex; align-items:center; justify-content:space-between; height:60px; padding:0 calc(clamp(16px,4vw,40px) + env(safe-area-inset-right)) 0 calc(clamp(16px,4vw,40px) + env(safe-area-inset-left)); background:var(--header-bg); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--border); }
.legal-logo { font-size:20px; font-weight:700; color:var(--brand); letter-spacing:-0.02em; }
.legal-logo:hover { text-decoration:none; }
.legal-nav-links { display:flex; align-items:center; gap:6px; }
.legal-nav-links a { color:var(--muted); font-size:14px; padding:8px 12px; border-radius:6px; font-weight:500; }
.legal-nav-links a:hover { color:var(--text); text-decoration:none; }
.legal-cta { background:var(--brand); color:#fff !important; padding:8px 18px !important; border-radius:6px; font-weight:600; }
.legal-cta:hover { background:#2563EB; text-decoration:none !important; }
@media (max-width:640px) { .legal-nav-links a:not(.legal-cta) { display:none; } }

.legal-wrap { max-width:760px; margin:0 auto; padding:clamp(32px,5vw,60px) calc(clamp(16px,4vw,32px) + env(safe-area-inset-right)) 0 calc(clamp(16px,4vw,32px) + env(safe-area-inset-left)); }
.legal-content { padding-bottom:72px; }
.legal-title { font-size:clamp(32px,5vw,46px); font-weight:700; letter-spacing:-0.02em; line-height:1.15; color:var(--heading); }
.legal-sub { font-size:18px; color:var(--muted); margin-top:12px; line-height:1.5; }
.legal-dates { display:flex; flex-wrap:wrap; gap:10px; margin:22px 0 4px; }
.legal-pill { display:inline-block; background:var(--pill-bg); color:var(--pill-text); font-size:13px; font-weight:600; padding:5px 12px; border-radius:999px; }
.legal-content h2 { font-size:clamp(21px,3vw,26px); font-weight:600; letter-spacing:-0.01em; color:var(--heading); margin-top:44px; scroll-margin-top:88px; }
.legal-content h2:first-of-type { margin-top:36px; }
.legal-content h3 { font-size:18px; font-weight:600; color:var(--heading); margin-top:26px; }
.legal-content p { margin-top:14px; font-size:16.5px; }
.legal-content ul, .legal-content ol.body-list { margin:14px 0 0 22px; font-size:16.5px; }
.legal-content li { margin-top:8px; }
.legal-content strong { font-weight:600; color:var(--heading); }
.lead { font-size:17.5px; }
.callout { margin-top:16px; border:1px solid var(--border); border-left:3px solid var(--brand); background:var(--surface); border-radius:10px; padding:14px 18px; font-size:15.5px; }

.legal-pagefoot { border-top:1px solid var(--border); padding:28px calc(clamp(16px,4vw,32px) + env(safe-area-inset-right)) calc(40px + env(safe-area-inset-bottom)) calc(clamp(16px,4vw,32px) + env(safe-area-inset-left)); margin-top:24px; }
.legal-pagefoot .inner { max-width:1080px; margin:0 auto; }
.legal-pagefoot .foot-links { display:flex; flex-wrap:wrap; gap:10px 20px; align-items:center; justify-content:center; }
.legal-pagefoot .foot-links a, .legal-pagefoot .foot-links button { font-size:13px; color:var(--muted); background:none; border:none; cursor:pointer; font-family:inherit; padding:2px 0; }
.legal-pagefoot .foot-links a:hover, .legal-pagefoot .foot-links button:hover { color:var(--link); text-decoration:underline; }
.legal-pagefoot .foot-meta { text-align:center; font-size:12.5px; color:var(--muted); margin-top:16px; }
.legal-pagefoot button:focus-visible, .legal-pagefoot a:focus-visible { outline:2px solid var(--brand); outline-offset:3px; border-radius:3px; }

/* Form controls for the data-rights pages */
.form-card { margin-top:26px; border:1px solid var(--border); border-radius:14px; background:var(--surface); padding:24px; }
.form-row { margin-top:18px; }
.form-row:first-child { margin-top:0; }
.form-row label { display:block; font-size:14px; font-weight:600; color:var(--heading); margin-bottom:7px; }
.form-row input, .form-row select, .form-row textarea {
  width:100%; font-family:inherit; font-size:15px; color:var(--text); background:var(--field-bg);
  border:1px solid var(--border); border-radius:10px; padding:11px 13px; line-height:1.4;
}
.form-row textarea { min-height:120px; resize:vertical; }
.form-row input:focus, .form-row select:focus, .form-row textarea:focus { outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(59,130,246,0.25); }
.form-submit { margin-top:22px; }
.btn-primary { appearance:none; background:var(--brand); color:#fff; border:1px solid var(--brand); font-size:15px; font-weight:600; padding:12px 24px; border-radius:10px; cursor:pointer; font-family:inherit; }
.btn-primary:hover { background:#2563EB; border-color:#2563EB; }
.btn-primary:disabled { opacity:.6; cursor:not-allowed; }
.btn-primary:focus-visible { outline:3px solid rgba(59,130,246,0.5); outline-offset:2px; }
.form-note { font-size:13px; color:var(--muted); margin-top:14px; }
.form-status { margin-top:16px; font-size:14.5px; border-radius:10px; padding:12px 14px; display:none; }
.form-status.show { display:block; }
.form-status.ok { background:rgba(34,197,94,0.12); border:1px solid rgba(34,197,94,0.4); color:#86EFAC; }
.form-status.err { background:rgba(239,68,68,0.12); border:1px solid rgba(239,68,68,0.4); color:#FCA5A5; }
:root[data-theme="light"] .form-status.ok { color:#15803D; }
:root[data-theme="light"] .form-status.err { color:#B91C1C; }
.confirm-card { margin-top:26px; border:1px solid rgba(34,197,94,0.4); background:rgba(34,197,94,0.10); border-radius:14px; padding:24px; }
.confirm-card h2 { margin-top:0; }

@media print {
  .legal-header-nav, .legal-cta { display:none !important; }
  body { background:#fff !important; color:#000 !important; }
  a { color:#000 !important; text-decoration:none !important; }
}
