/* Perimeter — continuous vulnerability + attack-surface management.
   Brand: "radar at night." Near-black base, electric lime sweep, alert magenta.
   Space Grotesk display, Inter body, JetBrains Mono for findings/CVE/IPs.
   Plain CSS, no build step. */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  --bg: #0A0E14;          /* near-black radar base */
  --bg-2: #0e131c;        /* panel */
  --bg-3: #131a26;        /* raised card */
  --lime: #9EF01A;        /* electric lime — the sweep / signal */
  --lime-d: #7bc014;
  --magenta: #FF3D81;     /* alert magenta — KEV / overdue */
  --cyan: #22D3EE;        /* deep cyan accent */
  --slate: #94A3B8;       /* neutral */
  --text: #E6EDF3;        /* off-white */
  --border: #1e2735;
  --border-2: #2a3548;
  --good: #34d399;
  --warn: #fbbf24;
  --bad: #FF3D81;
  --maxw: 1200px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  line-height: 1.6; -webkit-font-smoothing: antialiased;
}
h1, h2, h3, .brand { font-family: "Space Grotesk", system-ui, sans-serif; line-height: 1.15; font-weight: 600; letter-spacing: -0.01em; }
h1 { font-size: clamp(2.1rem, 5vw, 3.4rem); }
a { color: var(--lime); text-decoration: none; font-weight: 600; }
a:hover { text-decoration: underline; }
.mono { font-family: "JetBrains Mono", ui-monospace, monospace; }
.muted { color: var(--slate); }
.small { font-size: .85rem; }
.good { color: var(--good); } .warn { color: var(--warn); } .bad { color: var(--bad); }
code { background: var(--bg-3); padding: .1rem .35rem; border-radius: 4px; font-family: "JetBrains Mono", monospace; font-size: .88em; color: var(--lime); }

/* ---- Nav ---- */
.nav { position: sticky; top: 0; z-index: 30; background: rgba(10,14,20,.85); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.nav-inner { max-width: var(--maxw); margin: 0 auto; padding: .7rem 1.2rem; display: flex; align-items: center; gap: .3rem 1.3rem; flex-wrap: wrap; }
.brand { display: flex; align-items: center; gap: .55rem; font-weight: 700; font-size: 1.3rem; color: var(--text); margin-right: auto; }
.brand .mark { width: 30px; height: 30px; flex: none; }
.nav a { color: var(--slate); font-size: .92rem; font-weight: 500; }
.nav a:hover { color: var(--lime); text-decoration: none; }
.nav a[aria-current] { color: var(--lime); }

/* ---- Buttons ---- */
.btn { display: inline-block; cursor: pointer; font: inherit; font-weight: 600; border-radius: 8px;
  background: var(--bg-3); color: var(--text); border: 1px solid var(--border-2); padding: .55rem 1.15rem; transition: .14s; }
.btn:hover { border-color: var(--lime); color: var(--lime); text-decoration: none; }
.btn.primary { background: var(--lime); color: #06200a; border-color: var(--lime); }
.btn.primary:hover { background: var(--lime-d); color: #06200a; }
.btn.ghost { background: transparent; }
.btn.sm, .btn.mini { padding: .3rem .7rem; font-size: .82rem; }
.btn.mini { border-radius: 6px; }

/* ---- Layout ---- */
.wrap { max-width: 1000px; margin: 0 auto; padding: 2rem 1.2rem 5rem; }
.wrap-app { max-width: var(--maxw); margin: 0 auto; padding: 1.4rem 1.2rem 5rem; }
.wrap-app h1 { font-size: 1.8rem; margin: 0 0 .3rem; }
.row { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; margin: .5rem 0; }
.callout { background: var(--bg-2); border: 1px solid var(--border); border-left: 3px solid var(--lime); border-radius: 8px; padding: .9rem 1.1rem; margin: 1rem 0; }
.callout.good { border-left-color: var(--good); }
.hidden { display: none; }

/* ---- Radar hero (marketing + app header motif) ---- */
.radar { position: relative; width: 240px; height: 240px; flex: none; }
.radar .ring { position: absolute; inset: 0; border: 1px solid var(--border-2); border-radius: 50%; }
.radar .ring.r2 { inset: 18%; } .radar .ring.r3 { inset: 36%; } .radar .ring.r4 { inset: 54%; }
.radar .cross, .radar .cross2 { position: absolute; background: var(--border-2); }
.radar .cross { left: 50%; top: 0; width: 1px; height: 100%; }
.radar .cross2 { top: 50%; left: 0; height: 1px; width: 100%; }
.radar .sweep { position: absolute; inset: 0; border-radius: 50%;
  background: conic-gradient(from 0deg, rgba(158,240,26,.45), rgba(158,240,26,0) 60deg, transparent 360deg);
  animation: spin 4s linear infinite; }
.radar .blip { position: absolute; width: 9px; height: 9px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 10px var(--lime); animation: pulse 2.4s ease-out infinite; }
.radar .blip.alert { background: var(--magenta); box-shadow: 0 0 10px var(--magenta); }
.radar .b1 { left: 64%; top: 30%; } .radar .b2 { left: 32%; top: 58%; animation-delay: .6s; }
.radar .b3 { left: 70%; top: 66%; animation-delay: 1.1s; } .radar .b4 { left: 44%; top: 24%; animation-delay: 1.7s; }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulse { 0% { transform: scale(.6); opacity: 1; } 70% { transform: scale(1.5); opacity: .25; } 100% { transform: scale(.6); opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .radar .sweep { animation: none; } .radar .blip { animation: none; } }

/* ---- App: tabs ---- */
.tabs { display: flex; gap: .3rem; border-bottom: 1px solid var(--border); margin: 0 0 1.4rem; flex-wrap: wrap; }
.tab { background: none; border: none; color: var(--slate); font: inherit; font-weight: 600; padding: .6rem .9rem; cursor: pointer; border-bottom: 2px solid transparent; }
.tab:hover { color: var(--text); }
.tab.active { color: var(--lime); border-bottom-color: var(--lime); }

/* ---- Stat cards ---- */
.grid-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: .8rem; margin-bottom: 1.6rem; }
.statcard { background: var(--bg-2); border: 1px solid var(--border); border-radius: 10px; padding: 1rem 1.1rem; }
.statval { font-family: "Space Grotesk", sans-serif; font-size: 2rem; font-weight: 700; color: var(--lime); }
.statval.bad { color: var(--magenta); } .statval.warn { color: var(--warn); } .statval.good { color: var(--good); }
.statlabel { color: var(--slate); font-size: .82rem; text-transform: uppercase; letter-spacing: .04em; }

/* ---- Filter bar ---- */
.filterbar { display: flex; gap: .6rem; flex-wrap: wrap; align-items: center; margin-bottom: 1rem; }
.filterbar input[type=search], .filterbar select { background: var(--bg-3); color: var(--text); border: 1px solid var(--border-2); border-radius: 8px; padding: .45rem .7rem; font: inherit; }
.filterbar input[type=search] { min-width: 240px; flex: 1; }
.chk { color: var(--slate); display: flex; align-items: center; gap: .35rem; font-size: .9rem; }

/* ---- Finding cards ---- */
.finding { background: var(--bg-2); border: 1px solid var(--border); border-radius: 10px; margin-bottom: .7rem; overflow: hidden; }
.finding.kev { border-left: 3px solid var(--magenta); }
.f-head { display: flex; gap: 1rem; padding: .85rem 1rem; align-items: flex-start; }
.f-risk { font-family: "Space Grotesk", sans-serif; font-weight: 700; font-size: 1.5rem; color: var(--lime); min-width: 2.4rem; text-align: center; line-height: 1; }
.f-main { flex: 1; min-width: 0; }
.f-title { font-weight: 600; font-size: 1.02rem; }
.f-meta { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; margin: .3rem 0; font-size: .85rem; }
.f-asset { font-size: .85rem; color: var(--slate); margin-top: .15rem; }
.f-status { text-align: right; }
.sla { font-size: .78rem; color: var(--slate); margin-top: .3rem; }
.sla.bad { color: var(--magenta); font-weight: 600; }
.f-body { padding: 0 1rem 1rem; border-top: 1px solid var(--border); }
.f-body p { margin: .6rem 0; }
.f-body .suppress { background: var(--bg-3); border-radius: 8px; padding: .6rem .8rem; }

/* ---- Chips ---- */
.chip { display: inline-block; padding: .12rem .5rem; border-radius: 999px; font-size: .76rem; font-weight: 600; border: 1px solid var(--border-2); background: var(--bg-3); color: var(--slate); white-space: nowrap; }
.chip.tiny { font-size: .68rem; padding: .05rem .4rem; }
.chip.sev-critical { background: rgba(255,61,129,.16); color: var(--magenta); border-color: rgba(255,61,129,.4); }
.chip.sev-high { background: rgba(251,191,36,.14); color: var(--warn); border-color: rgba(251,191,36,.35); }
.chip.sev-medium { background: rgba(34,211,238,.12); color: var(--cyan); border-color: rgba(34,211,238,.3); }
.chip.sev-low { background: var(--bg-3); color: var(--slate); }
.chip.kevchip, .chip.crown { background: var(--magenta); color: #fff; border-color: var(--magenta); }
.chip.new { background: rgba(158,240,26,.15); color: var(--lime); border-color: rgba(158,240,26,.4); }
.chip.ext { background: rgba(255,61,129,.1); color: var(--magenta); border-color: rgba(255,61,129,.3); }
.chip.int { background: rgba(34,211,238,.1); color: var(--cyan); border-color: rgba(34,211,238,.3); }
.chip.ctl { background: rgba(158,240,26,.08); color: var(--lime); border-color: rgba(158,240,26,.3); margin: .15rem .15rem 0 0; }
.chip.st-open { color: var(--magenta); } .chip.st-in_progress { color: var(--warn); }
.chip.st-fixed { color: var(--good); border-color: rgba(52,211,153,.4); } .chip.st-accepted_risk { color: var(--slate); }
.chip.conf { background: rgba(52,211,153,.12); color: var(--good); border-color: rgba(52,211,153,.4); }

/* ---- Report block ---- */
.report { background: var(--bg-2); border: 1px solid var(--border); border-radius: 12px; padding: 1.4rem 1.6rem; margin-top: 1.4rem; }
.report-head { border-bottom: 1px solid var(--border); padding-bottom: 1rem; margin-bottom: 1rem; }
.report h4 { margin: 1.4rem 0 .5rem; color: var(--lime); font-family: "Space Grotesk", sans-serif; }
@media print {
  .nav, .tabs, .filterbar, .f-actions, #print-report, .foot { display: none !important; }
  body { background: #fff; color: #000; }
  .report { border: none; background: #fff; }
  .report h4, .statval { color: #000; }
}

/* ---- Controls block ---- */
.controls { margin: .8rem 0; }
.controls-h { font-size: .82rem; color: var(--slate); margin-bottom: .3rem; }
.control-chips { display: flex; flex-wrap: wrap; }

/* ---- Actions row ---- */
.f-actions { display: flex; gap: .6rem; flex-wrap: wrap; align-items: flex-end; margin-top: .8rem; }
.minilab, .aiform label { display: flex; flex-direction: column; font-size: .72rem; color: var(--slate); gap: .2rem; }
.mini { background: var(--bg-3); color: var(--text); border: 1px solid var(--border-2); border-radius: 6px; padding: .35rem .5rem; font: inherit; font-size: .85rem; }
.ai-out { background: var(--bg-3); border: 1px solid var(--border-2); border-left: 3px solid var(--cyan); border-radius: 8px; padding: .8rem 1rem; margin-top: .8rem; font-size: .92rem; }
.ai-label { font-size: .7rem; text-transform: uppercase; letter-spacing: .05em; color: var(--cyan); margin-bottom: .4rem; }

/* ---- Tables ---- */
.tbl { width: 100%; border-collapse: collapse; margin: .5rem 0 1.6rem; font-size: .9rem; }
.tbl th { text-align: left; color: var(--slate); font-weight: 600; font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; border-bottom: 1px solid var(--border-2); padding: .5rem .6rem; }
.tbl td { padding: .55rem .6rem; border-bottom: 1px solid var(--border); }
.tbl tr:hover td { background: var(--bg-2); }

/* ---- AI form ---- */
.aiform { display: grid; gap: .8rem; max-width: 460px; }
.aiform input { background: var(--bg-3); color: var(--text); border: 1px solid var(--border-2); border-radius: 6px; padding: .5rem .6rem; font: inherit; }
.integr { display: flex; background: var(--bg-2); border: 1px solid var(--border); border-radius: 10px; padding: .9rem 1.1rem; margin-bottom: .7rem; }

/* ---- Toast ---- */
.toast { position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%); background: var(--bg-3); color: var(--text); border: 1px solid var(--lime); border-radius: 8px; padding: .7rem 1.1rem; z-index: 100; box-shadow: 0 6px 24px rgba(0,0,0,.5); font-size: .9rem; }

/* ---- Marketing-specific ---- */
.hero { display: flex; gap: 3rem; align-items: center; flex-wrap: wrap; padding: 3rem 0 2rem; }
.hero-copy { flex: 1; min-width: 300px; }
.tagline { color: var(--lime); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; font-size: .85rem; }
.lead { font-size: 1.15rem; color: var(--slate); max-width: 40ch; }
.section { padding: 2.5rem 0; border-top: 1px solid var(--border); }
.cards3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; }
.fcard { background: var(--bg-2); border: 1px solid var(--border); border-radius: 12px; padding: 1.3rem; }
.fcard h3 { margin: 0 0 .5rem; color: var(--lime); }
.pricetable { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.pcard { background: var(--bg-2); border: 1px solid var(--border); border-radius: 12px; padding: 1.4rem; }
.pcard.feat { border-color: var(--lime); box-shadow: 0 0 0 1px var(--lime) inset; }
.pcard .price { font-family: "Space Grotesk", sans-serif; font-size: 2rem; font-weight: 700; color: var(--lime); }
.pcard ul { padding-left: 1.1rem; color: var(--slate); font-size: .92rem; }
.foot { border-top: 1px solid var(--border); margin-top: 3rem; padding: 2rem 1.2rem; color: var(--slate); font-size: .9rem; }
.foot a { color: var(--slate); }
.foot a:hover { color: var(--lime); }
.cmp { width: 100%; border-collapse: collapse; }
.cmp th, .cmp td { padding: .6rem .7rem; border-bottom: 1px solid var(--border); text-align: left; font-size: .9rem; }
.cmp .yes { color: var(--lime); } .cmp .no { color: var(--magenta); }
