/* v3 — light gray conversion-first UI + paywall/report */
:root{
  --bg:#f4f6f8;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --shadow: 0 10px 30px rgba(15, 23, 42, .08);
  --shadow2: 0 2px 10px rgba(15, 23, 42, .06);
  --accent:#2563eb;
  --accent2:#7c3aed;
  --danger:#dc2626;
  --radius:16px;
  --radius2:12px;
  --font: system-ui, -apple-system, Segoe UI, Roboto, Arial;
}

*{ box-sizing:border-box; }
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:
    radial-gradient(1000px 450px at 10% 0%, rgba(37, 99, 235, .12), transparent 55%),
    radial-gradient(1000px 450px at 90% 10%, rgba(124, 58, 237, .10), transparent 55%),
    var(--bg);
}
.wrap{ max-width: 1050px; margin: 0 auto; padding: 26px 16px 70px; }
.hidden{ display:none; }
.securitybadges img{
  width:20% !important;
}

.topbar{ display:flex; justify-content:space-between; align-items:center; gap:12px; }
.brand{ display:flex; align-items:center; gap:10px; font-weight:900; letter-spacing:.2px; }
.logoDot{ width:14px; height:14px; border-radius:999px; background: linear-gradient(135deg, var(--accent), var(--accent2)); box-shadow: 0 6px 18px rgba(37,99,235,.25); }
.brandName{ font-size:15px; }
.trustRow{ display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
.pill{ font-size:12px; color:#0b1220; padding:6px 10px; border-radius:999px; background: rgba(255,255,255,.75); border:1px solid var(--line); box-shadow: var(--shadow2); }

.hero{ padding: 8px 0 10px; }
.heroGrid{ display:grid; grid-template-columns: 1.2fr .8fr; gap: 18px; margin-top: 16px; }
.heroCopy h1{ margin: 10px 0 10px; font-size: 42px; line-height: 1.08; letter-spacing: -.7px; }
.sub{ margin:0 0 14px; color:var(--muted); font-size:16px; }

.card{ margin-top: 18px; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; box-shadow: var(--shadow); }

.ctaCard{ background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px; box-shadow: var(--shadow); }
.label{ display:block; font-size:12px; color:var(--muted); margin-bottom:8px; }
.cta{ display:flex; gap:10px; }
#url{ flex:1; padding: 14px 14px; border-radius: var(--radius2); border: 1px solid var(--line); background: #fbfdff; color: var(--text); font-size: 15px; outline:none; }
#url:focus{ border-color: rgba(37,99,235,.45); box-shadow: 0 0 0 4px rgba(37,99,235,.12); }

button{ padding: 14px 16px; border-radius: var(--radius2); border: 0; color: white; font-weight: 900; cursor: pointer; background: linear-gradient(135deg, var(--accent), var(--accent2)); box-shadow: 0 10px 25px rgba(37,99,235,.25); transition: transform .08s ease, filter .15s ease, box-shadow .15s ease; white-space:nowrap; }
button:hover{ filter: brightness(1.03); }
button:active{ transform: translateY(1px); }
button:disabled{ opacity: .55; cursor:not-allowed; box-shadow:none; }
button.ghost{ border:1px solid var(--line); box-shadow: var(--shadow2); }
a.ghostLink{ display:inline-block; padding: 12px 14px; border-radius: var(--radius2); border:1px solid var(--line); background:#fff; color:#111; text-decoration:none; font-weight:900; box-shadow: var(--shadow2); }

.micro{ margin-top: 10px; font-size: 12px; color: var(--muted); }
.socialProof{ margin-top: 14px; }
.proofLine{ display:flex; align-items:center; gap:8px; font-size: 13px; }
.spark{ width:10px; height:10px; border-radius:999px; background: rgba(22,163,74,.18); border: 2px solid rgba(22,163,74,.5); }
.error{ color: var(--danger); margin-top: 10px; font-size: 13px; }

.heroPanel .panelCard{ background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; box-shadow: var(--shadow); }
.panelTitle{ font-weight: 950; margin-bottom: 8px; }
.panelList{ margin: 0; padding-left: 18px; color: var(--muted); font-size: 13px; }
.panelList li{ margin: 8px 0; }
.panelFooter{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 14px; }
.stat{ padding: 10px; border: 1px solid var(--line); border-radius: 14px; background: #fbfdff; }
.statNum{ font-weight: 950; font-size: 18px; }
.statLbl{ color: var(--muted); font-size: 12px; margin-top: 2px; }

.cardHead{ display:flex; justify-content:space-between; align-items:flex-start; gap: 12px; }
h2{ margin:0; font-size: 18px; letter-spacing: -.2px; }
h3{ margin: 0; }
.small{ font-size: 13px; }
.tiny{ font-size: 12px; }
.muted{ color: var(--muted); }

.stepsRow{ display:flex; align-items:center; gap: 10px; margin: 14px 0 10px; }
.stepBubble{ width: 30px; height: 30px; border-radius: 999px; display:flex; align-items:center; justify-content:center; font-weight: 900; font-size: 13px; background: #f1f5f9; border: 1px solid var(--line); }
.stepBubble.on{ background: rgba(37,99,235,.12); border-color: rgba(37,99,235,.35); color: #1d4ed8; }
.stepLine{ flex:1; height: 2px; background: #e5e7eb; border-radius: 999px; }

.bar{ height:10px; background:#eef2f7; border-radius:999px; overflow:hidden; border: 1px solid #e5e7eb; }
#barFill{ height:10px; width: 10%; border-radius:999px; background: linear-gradient(90deg, var(--accent), var(--accent2)); }

.resultHead{ display:flex; justify-content:space-between; align-items:flex-start; gap: 12px; flex-wrap:wrap; }
.shareBox{ min-width: 260px; }
#shareLink{ width: 100%; padding: 10px 12px; border-radius: 12px; border: 1px solid var(--line); background: #fbfdff; }
.money{ font-size: 44px; font-weight: 950; margin: 12px 0 8px; letter-spacing: -1px; }
.sectionTitle{ margin: 18px 0 10px; }

.inputsCard{ margin: 14px 0 6px; padding: 14px; border-radius: var(--radius); border: 1px solid var(--line); background: #fbfdff; }
.inputsHead{ display:flex; align-items:flex-start; justify-content:space-between; gap: 10px; flex-wrap:wrap; margin-bottom: 10px; }
.inputsTitle{ font-weight: 950; }
.grid3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.inp label{ display:block; font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.inp input{ width: 100%; padding: 12px; border-radius: 12px; border: 1px solid var(--line); background: #fff; outline:none; }
.inp input:focus{ border-color: rgba(37,99,235,.45); box-shadow: 0 0 0 4px rgba(37,99,235,.12); }

.leak{ padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: #fbfdff; margin: 10px 0; }
.leak .t{ font-weight: 950; display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.leak .e{ color: var(--muted); font-size: 13px; margin-top: 6px; }
.badge{ display:inline-block; padding: 4px 10px; border-radius: 999px; font-size: 12px; border: 1px solid var(--line); background: rgba(37,99,235,.08); color: #1d4ed8; }

.paywall{ margin-top: 14px; }
.paywallTop{ display:flex; justify-content:space-between; gap: 12px; align-items:flex-start; flex-wrap:wrap; }
.lockTitle{ font-weight: 950; margin-bottom: 6px; }
.badge2{ display:inline-block; padding: 6px 10px; border-radius: 999px; border: 1px solid var(--line); background: rgba(124,58,237,.08); color: #5b21b6; font-weight:900; font-size: 12px; }

.planGrid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 12px; }
.plan{ position:relative; padding: 14px; border-radius: var(--radius); border: 1px solid var(--line); background:#fff; box-shadow: var(--shadow2); }
.plan.featured{ border-color: rgba(37,99,235,.35); box-shadow: 0 14px 34px rgba(37,99,235,.16); }
.ribbon{ position:absolute; top: 10px; right: 10px; background: linear-gradient(135deg, var(--accent), var(--accent2)); color:#fff; font-size: 11px; font-weight:900; padding: 6px 10px; border-radius: 999px; }
.planName{ font-weight: 950; }
.planPrice{ font-size: 34px; font-weight: 950; margin-top: 8px; letter-spacing: -1px; }
.planDesc{ margin-top: 6px; }
.planList{ margin: 10px 0 0; padding-left: 18px; color: var(--muted); font-size: 13px; }
.planList li{ margin: 8px 0; }
.planBtn{ width: 100%; margin-top: 12px; }

.payBox{ margin-top: 14px; padding: 14px; border-radius: var(--radius); border: 1px dashed rgba(37,99,235,.35); background: radial-gradient(600px 260px at 20% 0%, rgba(37,99,235,.10), transparent 60%), #fbfdff; }

.reportActions{ display:flex; gap: 10px; flex-wrap:wrap; margin: 12px 0 16px; }

.footer{ padding: 18px 16px; text-align:center; }

@media (max-width: 980px){
  .heroGrid{ grid-template-columns: 1fr; }
  .shareBox{ min-width: 100%; }
  .grid3{ grid-template-columns: 1fr; }
  .planGrid{ grid-template-columns: 1fr; }
  .heroCopy h1{ font-size: 36px; }
}


/* Checkout summary */
.checkoutSummary{
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  margin-bottom:14px;
  background:linear-gradient(180deg,#ffffff,#fbfdff);
}
.summaryHead{ font-weight:950; margin-bottom:8px; }
.summaryRow{ display:flex; justify-content:space-between; margin:6px 0; font-size:14px; }
.sumLabel{ color:var(--muted); }
.sumValue{ font-weight:700; text-align:right; }
.summaryRow.total{
  border-top:1px solid var(--line);
  margin-top:10px; padding-top:10px;
  font-size:18px; font-weight:900;
}
.summaryTrust{ margin-top:10px; font-size:12px; color:var(--muted); }


/* Email gate */
.emailGate{
  margin: 12px 0 14px;
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: #fff;
  box-shadow: var(--shadow2);
}
#buyerEmail{
  flex:1;
  padding: 14px 14px;
  border-radius: var(--radius2);
  border: 1px solid var(--line);
  background: #fbfdff;
  color: var(--text);
  font-size: 15px;
  outline:none;
}
#buyerEmail:focus{ border-color: rgba(37,99,235,.45); box-shadow: 0 0 0 4px rgba(37,99,235,.12); }


/* Model warning */
.warn{
  margin-top:10px;
  padding:12px 12px;
  border-radius: var(--radius);
  border: 1px solid rgba(245,158,11,.35);
  background: linear-gradient(180deg, #fff7ed, #fffbeb);
  color:#7c2d12;
  font-weight:800;
}
