:root {
  --bg: #08111f;
  --panel: #0f1b31;
  --panel-2: #12233f;
  --text: #ebf0f8;
  --muted: #9eb0cc;
  --line: rgba(255,255,255,.08);
  --accent: #5aa8ff;
  --accent-2: #8b5cf6;
  --success: #35d399;
  --warning: #f59e0b;
  --danger: #fb7185;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, sans-serif;
  background: linear-gradient(180deg, #07101d 0%, #0a1425 100%);
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
.container { width: min(1120px, calc(100% - 2rem)); margin: 0 auto; }
.narrow { max-width: 760px; }
.hero, .subhero { padding: 1.25rem 0 4rem; background: radial-gradient(circle at top right, rgba(90,168,255,.18), transparent 30%), radial-gradient(circle at top left, rgba(139,92,246,.12), transparent 25%); }
.subhero { padding-bottom: 2.5rem; }
.nav { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding: .75rem 0 2rem; }
.topbar { display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; margin-bottom: 2rem; }
.brand { font-weight: 800; letter-spacing: -.03em; font-size: 1.15rem; }
.nav-links { display:flex; gap:1rem; flex-wrap:wrap; color: var(--muted); }
.nav-links a:hover, .footer-links a:hover, .backlink:hover { color: var(--text); }
.backlink { color: var(--muted); }
.hero-grid { display:grid; grid-template-columns: 1.15fr .85fr; gap:2rem; align-items:center; }
.eyebrow { display:inline-block; margin-bottom:1rem; font-size:.82rem; text-transform:uppercase; letter-spacing:.12em; color: #9dc3ff; font-weight:700; }
h1 { font-size: clamp(2.2rem, 5vw, 4.5rem); line-height: 1.02; margin: 0 0 1rem; letter-spacing: -.04em; }
h2 { font-size: clamp(1.7rem, 3vw, 2.7rem); line-height: 1.08; margin: 0; letter-spacing: -.03em; }
h3 { margin: 0 0 .7rem; font-size: 1.12rem; }
p { color: var(--muted); line-height: 1.7; }
.lead { font-size: 1.08rem; max-width: 62ch; }
.microcopy { font-size: .95rem; margin-top: .9rem; }
.cta-row, .cta-stack, .inline-cta { display:flex; gap:.9rem; flex-wrap:wrap; }
.cta-row { margin: 1.5rem 0 .4rem; }
.cta-stack { flex-direction: column; }
.inline-cta { margin-top: 1rem; }
.btn { display:inline-flex; align-items:center; justify-content:center; padding:.9rem 1.2rem; border-radius: 14px; font-weight:700; }
.btn-primary { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color:white; }
.btn-secondary { border:1px solid var(--line); background: rgba(255,255,255,.02); }
.full { width: 100%; }
.panel, .card, .proof-chip, .stat-card { background: rgba(15,27,49,.75); border: 1px solid var(--line); border-radius: 22px; box-shadow: 0 10px 35px rgba(0,0,0,.18); }
.notice { margin-bottom: 1rem; }
.notice-info { border-color: rgba(90,168,255,.35); }
.notice-success { border-color: rgba(53,211,153,.35); }
.notice-error { border-color: rgba(251,113,133,.35); }
.hero-card { padding: 1rem; }
.panel-header { display:flex; align-items:center; gap:.45rem; margin-bottom:1rem; }
.panel-title { margin-left: .4rem; color: var(--muted); font-size: .92rem; }
.dot { width:10px; height:10px; border-radius:50%; display:inline-block; }
.red { background: var(--danger); } .yellow { background: var(--warning); } .green { background: var(--success); }
.finding { display:flex; justify-content:space-between; gap:1rem; align-items:center; padding: .95rem 1rem; border-radius: 16px; margin-top: .8rem; }
.finding strong { display:block; margin-bottom:.25rem; }
.finding p { margin:0; font-size:.92rem; }
.finding span { font-weight:800; font-size:1.35rem; }
.finding.high { background: rgba(251,113,133,.12); }
.finding.medium { background: rgba(245,158,11,.11); }
.finding.low { background: rgba(53,211,153,.11); }
.section { padding: 5.5rem 0; }
.section-inline { padding: 1rem 0 0; }
.pt-0 { padding-top: 0; }
.section-dark { background: rgba(255,255,255,.02); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.section-accent { background: linear-gradient(180deg, rgba(90,168,255,.08), rgba(139,92,246,.08)); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.section-heading { margin-bottom: 2rem; max-width: 760px; }
.section-heading.slim { margin-bottom: 1rem; }
.grid { display:grid; gap:1.1rem; }
.grid.three { grid-template-columns: repeat(3, 1fr); }
.grid.two { grid-template-columns: repeat(2, 1fr); }
.card { padding: 1.35rem; }
.steps { display:grid; grid-template-columns: repeat(3, 1fr); gap:1.1rem; }
.step-number { display:inline-flex; width:38px; height:38px; align-items:center; justify-content:center; border-radius: 50%; background: rgba(90,168,255,.14); color: #bbd5ff; font-weight:800; margin-bottom: .8rem; }
ul { margin: 0; padding-left: 1.1rem; color: var(--muted); }
li { margin: .45rem 0; }
.quick-proof { display:flex; gap:.8rem; flex-wrap:wrap; padding-bottom: 2rem; }
.proof-chip { padding: .8rem 1rem; border-radius: 999px; color: #c7d7ef; font-size: .95rem; }
.pricing-wrap { display:grid; grid-template-columns: 1.2fr .8fr; gap:1.2rem; align-items:center; }
.price-card { max-width: 380px; justify-self:end; }
.price { font-size: 3rem; margin: 0 0 1rem; color: var(--text); font-weight: 800; }
.price span { font-size: 1rem; color: var(--muted); font-weight: 600; }
.link-card:hover { border-color: rgba(90,168,255,.4); transform: translateY(-2px); transition: .2s ease; }
.footer { padding: 2rem 0 3rem; }
.footer-wrap { display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; border-top:1px solid var(--line); padding-top: 1.3rem; }
.footer-links { display:flex; gap:1rem; flex-wrap:wrap; color: var(--muted); }
.stat-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:1rem; }
.stat-card { padding: 1.2rem; display:flex; flex-direction:column; gap:.35rem; }
.stat-card strong { font-size: 2rem; }
.stat-card span { color: var(--muted); }
.demo-table { overflow:auto; }
table { width:100%; border-collapse: collapse; }
th, td { text-align:left; padding: 1rem; border-bottom:1px solid var(--line); vertical-align: top; }
th { color: #9dc3ff; font-size: .9rem; }
.badge { display:inline-flex; align-items:center; justify-content:center; min-width: 56px; padding: .35rem .6rem; border-radius: 999px; font-size: .85rem; font-weight: 700; }
.badge-danger { background: rgba(251,113,133,.16); color: #ffc1cb; }
.badge-warning { background: rgba(245,158,11,.16); color: #ffd18a; }
.badge-ok { background: rgba(53,211,153,.16); color: #baf5df; }
.badge-new { background: rgba(90,168,255,.16); color: #b8d8ff; }
.badge-seen { background: rgba(255,255,255,.08); color: #d6deed; }
.badge-up { background: rgba(139,92,246,.18); color: #dcc8ff; }
.badge-current { background: rgba(53,211,153,.12); color: #c4f5e2; }
.cta-panel { display:grid; grid-template-columns: 1.2fr .8fr; gap:1rem; align-items:center; }
.form-card { max-width: 560px; }
.mock-form { display: grid; gap: .85rem; margin-top: 1rem; }
.mock-form label { display: grid; gap: .45rem; color: var(--muted); font-size: .95rem; }
.mock-form input, .mock-form select {
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: .85rem .95rem;
}
.auth-card { max-width: 680px; }
.app-grid { align-items: start; }

@media (max-width: 920px) {
  .hero-grid, .pricing-wrap, .grid.three, .grid.two, .steps, .stat-grid, .cta-panel { grid-template-columns: 1fr; }
  .price-card { justify-self:start; max-width:none; }
}
@media (max-width: 640px) {
  .nav { align-items:flex-start; flex-direction:column; }
  .section { padding: 4.2rem 0; }
  h1 { font-size: 2.4rem; }
  th, td { padding: .8rem .65rem; font-size: .92rem; }
}
