/* SafeAI Scan — styles */
:root {
  --navy:#0f172a; --navy-2:#1e293b; --blue:#2563eb; --blue-d:#1d4ed8;
  --green:#16a34a; --amber:#d97706; --red:#dc2626; --grey:#64748b;
  --bg:#f8fafc; --card:#ffffff; --line:#e2e8f0; --text:#0f172a;
  --radius:14px; --shadow:0 10px 30px rgba(15,23,42,.08);
}
* { box-sizing:border-box; margin:0; padding:0; }
body {
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--text); line-height:1.5; -webkit-font-smoothing:antialiased;
}
.wrap { max-width:1040px; margin:0 auto; padding:0 24px; }
small { font-size:.6em; vertical-align:super; opacity:.7; }

/* Topbar */
.topbar { background:var(--navy); color:#fff; padding:14px 0; }
.topbar .wrap { display:flex; align-items:center; gap:16px; justify-content:space-between; }
.logo { display:inline-flex; align-items:center; gap:9px; font-weight:800; font-size:1.15rem; letter-spacing:-.02em; }
.logo-mark { flex:0 0 auto; filter:drop-shadow(0 2px 6px rgba(37,99,235,.45)); }
.logo-text { line-height:1; }
.tagline { color:#94a3b8; font-size:.85rem; }

/* Screens */
.screen { display:none; padding:48px 0 64px; min-height:60vh; }
.screen.active { display:block; animation:fade .4s ease; }
@keyframes fade { from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none} }

/* Buttons */
.btn-primary {
  background:var(--blue); color:#fff; border:0; padding:15px 26px; font-size:1.02rem;
  font-weight:700; border-radius:10px; cursor:pointer; transition:.15s; box-shadow:0 6px 18px rgba(37,99,235,.3);
}
.btn-primary:hover { background:var(--blue-d); transform:translateY(-1px); }
.btn-primary:disabled { opacity:.6; cursor:default; transform:none; }
.btn-ghost {
  background:#fff; color:var(--navy); border:1.5px solid var(--line); padding:13px 20px;
  font-weight:600; border-radius:10px; cursor:pointer; transition:.15s;
}
.btn-ghost:hover { border-color:var(--blue); color:var(--blue); }
.btn-text { background:none; border:0; color:var(--grey); font-size:.95rem; cursor:pointer; padding:8px; margin-top:18px; }
.btn-text:hover { color:var(--blue); }

/* ---------- Hero ---------- */
#landing { background:
  radial-gradient(60% 50% at 85% 0%, rgba(56,189,248,.10), transparent 70%),
  radial-gradient(50% 40% at 0% 10%, rgba(37,99,235,.08), transparent 70%); }
.hero { display:grid; grid-template-columns:1.4fr 1fr; gap:48px; align-items:center; }
.pill {
  display:inline-block; background:#dbeafe; color:var(--blue-d); font-size:.8rem; font-weight:600;
  padding:6px 14px; border-radius:999px; margin-bottom:18px;
}
.hero h1 { font-size:2.8rem; line-height:1.1; letter-spacing:-.03em; margin-bottom:18px; }
.hl { color:var(--blue); }
.lead { font-size:1.12rem; color:#475569; margin-bottom:26px; max-width:36ch; }
.micro { font-size:.82rem; color:var(--grey); margin-top:14px; }

.trust-badges { display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.trust-badge {
  display:inline-flex; align-items:center; gap:6px; font-size:.8rem; font-weight:600; color:#334155;
  background:#fff; border:1px solid var(--line); padding:7px 13px; border-radius:99px; box-shadow:0 1px 2px rgba(15,23,42,.04);
}

.hero-card {
  background:var(--navy); color:#fff; border-radius:var(--radius); padding:30px; box-shadow:var(--shadow);
}
.card-title { color:#fff; font-size:1.18rem; font-weight:700; margin-bottom:14px; }
.card-list { list-style:none; padding:0; margin:0 0 16px; }
.card-list li { color:#e2e8f0; font-size:1.02rem; padding:12px 0 12px 30px; position:relative; border-bottom:1px solid #334155; }
.card-list li:last-child { border-bottom:0; }
.card-list li::before { content:"✓"; position:absolute; left:0; color:#38bdf8; font-weight:800; }
.card-foot { color:#94a3b8; font-size:.9rem; text-align:center; margin-top:4px; }

.counter { text-align:center; padding-bottom:18px; border-bottom:1px solid #334155; }
.counter .big { font-size:3.4rem; font-weight:800; line-height:1; color:#fff; }
.counter-label { color:#94a3b8; font-size:.9rem; margin-top:6px; }
.counter-split { padding:18px 0; text-align:center; }
.stat { font-size:2rem; font-weight:800; color:#f87171; }
.counter-split small { color:#cbd5e1; }
.counter-foot { text-align:center; color:#60a5fa; font-weight:600; margin-top:4px; }

.facts { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
.fact { background:var(--card); border:1px solid var(--line); border-radius:12px; padding:20px; }
.fact strong { display:block; font-size:1.7rem; color:var(--navy); letter-spacing:-.02em; }
.fact span { font-size:.85rem; color:var(--grey); }

/* ---------- How it works ---------- */
.section-h { text-align:center; font-size:1.6rem; letter-spacing:-.02em; margin:60px 0 28px; }
.steps-row { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.step { background:var(--card); border:1px solid var(--line); border-radius:12px; padding:24px; }
.step-num { display:grid; place-items:center; width:34px; height:34px; border-radius:9px; background:var(--blue); color:#fff; font-weight:800; margin-bottom:12px; }
.step h3 { font-size:1.1rem; margin-bottom:6px; }
.step p { color:var(--grey); font-size:.92rem; }

/* ---------- Expertise / AI risks (dark band) ---------- */
.expertise {
  margin-top:60px;
  padding:54px 0 10px;
  background:
    radial-gradient(55% 60% at 100% 0%, rgba(56,189,248,.10), transparent 70%),
    radial-gradient(45% 55% at 0% 100%, rgba(37,99,235,.10), transparent 70%),
    #0b1220;
}
.expertise .section-h { color:#fff; margin-top:0; margin-bottom:14px; }
.section-sub { text-align:center; color:#94a3b8; max-width:64ch; margin:0 auto 32px; font-size:.98rem; line-height:1.6; }
.risk-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; padding-bottom:54px; }
.risk-card {
  background:rgba(255,255,255,.04); border:1px solid rgba(148,163,184,.18);
  border-radius:14px; padding:24px; transition:transform .18s, border-color .18s, background .18s;
}
.risk-card:hover { transform:translateY(-3px); border-color:rgba(56,189,248,.55); background:rgba(255,255,255,.06); }
.risk-ico { display:grid; place-items:center; width:44px; height:44px; border-radius:11px; background:rgba(56,189,248,.14); font-size:1.35rem; margin-bottom:14px; }
.risk-card h3 { color:#fff; font-size:1.12rem; margin-bottom:8px; }
.risk-card p { color:#cbd5e1; font-size:.92rem; line-height:1.55; }

/* ---------- Built by ---------- */
.built-by { text-align:center; color:var(--grey); font-size:.9rem; margin:46px auto 0; max-width:60ch; }
.built-by strong { color:var(--navy); }

/* ---------- Form privacy line ---------- */
.form-privacy { font-size:.84rem; color:var(--green); font-weight:600; margin:-8px 0 4px; }

/* ---------- Quiz ---------- */
.quiz-wrap { max-width:680px; margin:0 auto; }
.progress-track { height:8px; background:var(--line); border-radius:99px; overflow:hidden; }
.progress-bar { height:100%; width:0; background:var(--blue); border-radius:99px; transition:width .3s ease; }
.progress-row { display:flex; justify-content:space-between; margin-top:10px; font-size:.85rem; color:var(--grey); }
.pillar-tag { background:#eff6ff; color:var(--blue-d); padding:3px 12px; border-radius:99px; font-weight:600; }

.question-card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:34px; margin-top:26px; box-shadow:var(--shadow); }
.q-text { font-size:1.5rem; letter-spacing:-.02em; margin-bottom:12px; }
.q-help { color:var(--grey); margin-bottom:24px; font-size:.98rem; }
.options { display:flex; flex-direction:column; gap:12px; }
.option {
  display:flex; align-items:center; gap:14px; text-align:left; width:100%;
  background:#fff; border:1.5px solid var(--line); border-radius:12px; padding:16px 18px;
  font-size:1.02rem; cursor:pointer; transition:.13s; color:var(--text);
}
.option:hover { border-color:var(--blue); background:#f8faff; }
.option.selected { border-color:var(--blue); background:#eff6ff; box-shadow:0 0 0 3px rgba(37,99,235,.12); }
.opt-radio { width:20px; height:20px; border-radius:50%; border:2px solid var(--line); flex:0 0 auto; transition:.13s; }
.option.selected .opt-radio { border-color:var(--blue); background:radial-gradient(var(--blue) 42%, #fff 46%); }

/* ---------- Gate ---------- */
.gate-wrap { max-width:540px; margin:0 auto; text-align:center; }
.gate-score-box { background:var(--navy); color:#fff; border-radius:var(--radius); padding:26px; margin-bottom:30px; }
.gate-label { color:#94a3b8; font-size:.9rem; }
.gate-score { font-size:4rem; font-weight:800; line-height:1; }
.gate-grade { color:#cbd5e1; font-weight:600; }
.gate-wrap h2 { font-size:1.7rem; letter-spacing:-.02em; margin-bottom:8px; }
.gate-form { display:flex; flex-direction:column; gap:12px; margin-top:24px; text-align:left; }
.gate-form input, .gate-form select {
  padding:14px 16px; border:1.5px solid var(--line); border-radius:10px; font-size:1rem; font-family:inherit;
}
.gate-form input:focus, .gate-form select:focus { outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(37,99,235,.12); }
.gate-form .btn-primary { margin-top:6px; }
.gate-form .micro { text-align:center; }

/* ---------- Dashboard ---------- */
.dash-head { display:grid; grid-template-columns:auto 1fr; gap:34px; align-items:center; background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:34px; box-shadow:var(--shadow); }
.ring { width:150px; height:150px; border-radius:50%; display:grid; place-items:center; }
.ring-inner { width:118px; height:118px; background:#fff; border-radius:50%; display:grid; place-items:center; text-align:center; }
.dash-score { font-size:2.8rem; font-weight:800; line-height:1; }
.dash-grade { color:var(--grey); font-weight:600; font-size:.9rem; }
.band-chip { display:inline-block; color:#fff; font-weight:700; font-size:.8rem; padding:4px 14px; border-radius:99px; margin-bottom:8px; }
.dash-head-copy h2 { font-size:1.6rem; letter-spacing:-.02em; }
.dash-head-copy p { color:var(--grey); margin:6px 0 18px; }
.dash-actions { display:flex; gap:12px; flex-wrap:wrap; }
.email-status { margin-top:12px; font-size:.88rem; font-weight:600; color:var(--green); }

.section-title { margin:42px 0 16px; font-size:1.3rem; letter-spacing:-.02em; }
.pillars { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.pillar { background:var(--card); border:1px solid var(--line); border-left-width:4px; border-radius:12px; padding:16px 18px; }
.pillar.green { border-left-color:var(--green); } .pillar.amber { border-left-color:var(--amber); }
.pillar.red { border-left-color:var(--red); } .pillar.na { border-left-color:var(--grey); }
.pillar-head { display:flex; align-items:center; gap:10px; }
.pillar-head strong { flex:1; font-size:1rem; }
.dot { width:11px; height:11px; border-radius:50%; flex:0 0 auto; }
.pillar-score { font-weight:800; font-size:1.15rem; }
.pillar-ai6 { color:var(--grey); font-size:.8rem; margin:4px 0 10px; }
.pillar-bar { height:7px; background:var(--line); border-radius:99px; overflow:hidden; }
.pillar-bar i { display:block; height:100%; border-radius:99px; transition:width .5s ease; }

.risks { display:flex; flex-direction:column; gap:16px; }
.risk { display:grid; grid-template-columns:auto 1fr; gap:18px; background:var(--card); border:1px solid var(--line); border-radius:12px; padding:22px; }
.risk-num { width:34px; height:34px; border-radius:9px; color:#fff; font-weight:800; display:grid; place-items:center; }
.risk h4 { font-size:1.1rem; }
.risk-meta { color:var(--grey); font-size:.85rem; margin:3px 0 10px; }
.risk ul { padding-left:18px; color:#334155; }
.risk li { margin-bottom:5px; }
.all-clear { background:#f0fdf4; border:1px solid #bbf7d0; color:#166534; padding:20px; border-radius:12px; font-weight:600; }

.upsell { background:linear-gradient(135deg,var(--navy),var(--navy-2)); color:#fff; border-radius:var(--radius); padding:32px; margin-top:42px; }
.upsell h3 { font-size:1.4rem; margin-bottom:10px; }
.upsell p { color:#cbd5e1; margin-bottom:20px; }
.upsell .btn-primary { display:inline-block; text-decoration:none; }

/* ---------- Footer ---------- */
.footer { background:var(--navy); color:#94a3b8; padding:30px 0; font-size:.85rem; margin-top:40px; }
.footer a { color:#93c5fd; }
.disclaimer { margin-top:8px; opacity:.7; }

/* ---------- Responsive ---------- */
@media (max-width:820px) {
  .hero { grid-template-columns:1fr; gap:30px; }
  .hero h1 { font-size:2.1rem; }
  .facts { grid-template-columns:repeat(2,1fr); }
  .steps-row, .risk-grid { grid-template-columns:1fr; }
  .pillars { grid-template-columns:1fr; }
  .dash-head { grid-template-columns:1fr; text-align:center; justify-items:center; }
  .dash-actions { justify-content:center; }
}
