/* Privacy Compliance Checker — interactive quiz. Trust-blue brand (sister to Privacy Law Templates). */
*,*::before,*::after{ box-sizing:border-box; }
:root{
  --ink:#0e1a2b; --muted:#566173; --line:#e3e8f0; --paper:#ffffff; --wash:#f5f8fc;
  --primary:#1d4ed8; --primary-deep:#1e3a8a; --primary-press:#1b3aa8; --ok:#0f9d6b; --warn:#d97706; --bad:#dc2626;
  --soft:#eaf1fe; --lt:#c6d6f5; --ring:rgba(29,78,216,.22); --radius:14px;
  --head:"Spectral",Georgia,serif; --body:"Inter",-apple-system,"Segoe UI",Roboto,Arial,sans-serif; --mono:"IBM Plex Mono",ui-monospace,Menlo,monospace;
}
html{ -webkit-text-size-adjust:100%; }
body{ margin:0; background:linear-gradient(180deg,#0e1a2b 0%,#16294a 100%); color:var(--ink); font-family:var(--body); line-height:1.6; font-size:17px; -webkit-font-smoothing:antialiased; min-height:100vh; }
.wrap{ max-width:720px; margin:0 auto; padding:0 22px; }
a{ color:var(--primary); text-decoration:none; } a:hover{ text-decoration:underline; }
h1,h2,h3{ font-family:var(--head); line-height:1.14; letter-spacing:-.015em; margin:0; font-weight:700; }
.eyebrow{ font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:#9db8ec; }

header.site{ padding:26px 0; }
.brand{ display:flex; align-items:center; gap:9px; font-family:var(--head); font-weight:700; font-size:1.08rem; color:#fff; }
.brand svg{ width:21px; height:24px; }

main{ padding:18px 0 70px; }
.card{ background:#fff; border-radius:20px; padding:40px 38px; box-shadow:0 30px 70px -28px rgba(0,0,0,.5); }

/* intro */
.intro .eyebrow{ color:var(--primary); }
.intro h1{ font-size:clamp(1.9rem,4.5vw,2.7rem); color:var(--ink); margin:14px 0 14px; }
.intro p.lead{ font-size:1.12rem; color:var(--muted); margin:0 0 26px; }
.intro .meta{ display:flex; gap:18px; flex-wrap:wrap; font-size:.9rem; color:var(--muted); margin-bottom:28px; }
.intro .meta span{ display:flex; gap:7px; align-items:center; }
.intro .meta .ok{ color:var(--ok); }

.btn{ display:inline-block; border:0; cursor:pointer; font-family:var(--body); font-size:1.05rem; font-weight:600; padding:16px 30px; border-radius:11px; background:var(--primary); color:#fff; transition:background .15s,transform .02s; }
.btn:hover{ background:var(--primary-press); text-decoration:none; }
.btn:active{ transform:translateY(1px); }
.btn[disabled]{ opacity:.6; cursor:default; }
.btn,.opt{ touch-action:manipulation; -webkit-tap-highlight-color:transparent; }
.btn.full{ width:100%; }
.btn.ghost{ background:#fff; color:var(--primary-deep); border:1.5px solid var(--line); }

/* progress */
.progress{ height:6px; background:var(--soft); border-radius:99px; overflow:hidden; margin-bottom:6px; }
.progress > i{ display:block; height:100%; width:100%; background:var(--primary); transform:scaleX(0); transform-origin:left; transition:transform .3s ease; }
.qcount{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:22px; }

/* question */
.q h2{ font-size:1.5rem; color:var(--ink); margin-bottom:8px; }
.q .hint{ color:var(--muted); font-size:.98rem; margin:0 0 26px; }
.opts{ display:grid; gap:12px; }
.opt{ display:flex; align-items:center; gap:14px; width:100%; text-align:left; background:#fff; border:1.5px solid var(--line); border-radius:12px; padding:16px 18px; font-size:1.05rem; font-weight:500; color:var(--ink); cursor:pointer; transition:border-color .12s, background .12s; font-family:var(--body); }
.opt:hover{ border-color:var(--primary); background:var(--soft); }
.opt .k{ flex:0 0 auto; width:26px; height:26px; border-radius:7px; background:var(--wash); color:var(--muted); display:grid; place-items:center; font-family:var(--mono); font-size:.8rem; }
.opt[data-v="yes"] .k{ background:rgba(15,157,107,.12); color:var(--ok); }
.opt[data-v="no"] .k{ background:rgba(220,38,38,.1); color:var(--bad); }
.back{ background:none; border:0; color:var(--muted); font-size:.92rem; cursor:pointer; margin-top:22px; font-family:var(--body); }
.back:hover{ color:var(--ink); }

/* result */
.result .scorebar{ display:flex; align-items:baseline; gap:14px; margin:6px 0 4px; }
.result .scorebar .pct{ font-family:var(--head); font-weight:700; font-size:3.2rem; line-height:1; }
.result .tier{ display:inline-block; font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; padding:6px 12px; border-radius:99px; }
.tier.good{ background:rgba(15,157,107,.12); color:var(--ok); }
.tier.mid{ background:rgba(217,119,6,.12); color:var(--warn); }
.tier.bad{ background:rgba(220,38,38,.1); color:var(--bad); }
.result .verdict{ color:var(--muted); margin:14px 0 22px; }
.gaps{ list-style:none; padding:0; margin:0 0 26px; }
.gaps li{ display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--line); font-size:1rem; }
.gaps li .mk{ flex:0 0 auto; width:22px; height:22px; border-radius:50%; display:grid; place-items:center; font-size:.8rem; font-weight:700; }
.gaps li.miss .mk{ background:rgba(220,38,38,.1); color:var(--bad); }
.gaps li.ok .mk{ background:rgba(15,157,107,.12); color:var(--ok); }
.gaps li .lbl b{ font-weight:600; }
.gaps li .lbl small{ display:block; color:var(--muted); font-size:.86rem; }

.capture{ background:var(--wash); border:1px solid var(--line); border-radius:14px; padding:24px; margin-top:8px; }
.capture h3{ font-size:1.2rem; color:var(--ink); margin-bottom:6px; }
.capture p{ color:var(--muted); font-size:.96rem; margin:0 0 16px; }
form.signup{ display:flex; gap:10px; flex-wrap:wrap; }
form.signup input[type=email]{ flex:1 1 220px; min-width:0; padding:14px 16px; font-size:1rem; border:1.5px solid var(--line); border-radius:10px; background:#fff; color:var(--ink); outline:none; }
form.signup input[type=email]:focus{ border-color:var(--primary); box-shadow:0 0 0 4px var(--ring); }
form.signup .btn{ flex:0 0 auto; }
.micro{ font-size:.8rem; color:var(--muted); margin-top:12px; }
.upsell{ text-align:center; margin-top:22px; font-size:.96rem; color:var(--muted); }
.disclaimer{ color:var(--muted); font-size:.8rem; text-align:center; margin-top:26px; }
.disclaimer a{ color:var(--primary); text-decoration:underline; }
.result .scorebar .pct{ font-variant-numeric:tabular-nums; }

/* Keyboard focus visibility */
:focus-visible{ outline:2px solid var(--primary); outline-offset:2px; border-radius:4px; }

[hidden]{ display:none !important; }
@media (prefers-reduced-motion: reduce){ *{ scroll-behavior:auto !important; } }
@media (max-width:480px){ .card{ padding:30px 22px; } form.signup .btn{ flex:1 1 100%; } }
