/* AlphaSecure — shared dark observatory theme */
:root{
  --bg:#06080f; --bg2:#0a0f1c; --panel:#0d1424; --panel2:#111a2e; --line:#16263f;
  --ink:#dbe6ff; --muted:#7d97c0; --dim:#5b7da6;
  --cyan:#22d3ee; --green:#2ad17e; --amber:#ff8a3b; --red:#ff3b5c; --yellow:#ffd23b; --violet:#a78bfa;
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(1200px 700px at 80% -10%,#0e1730 0,var(--bg) 55%);color:var(--ink);
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--cyan);text-decoration:none}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace}
.wrap{max-width:1240px;margin:0 auto;padding:22px}
.row{display:flex;gap:16px;flex-wrap:wrap}
.grid{display:grid;gap:16px}
.card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:14px;padding:18px}
.card h3{margin:0 0 12px;font-size:13px;letter-spacing:.18em;color:var(--dim);text-transform:uppercase;font-weight:700}
.kpi{font-size:30px;font-weight:800;line-height:1}
.kpi small{display:block;font-size:11px;letter-spacing:.2em;color:var(--dim);margin-top:8px;text-transform:uppercase}
.tag{display:inline-block;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.05em}
.tag.crit{background:#ff3b5c22;color:var(--red);border:1px solid #ff3b5c55}
.tag.high{background:#ff8a3b22;color:var(--amber);border:1px solid #ff8a3b55}
.tag.med{background:#ffd23b1f;color:var(--yellow);border:1px solid #ffd23b44}
.tag.low{background:#22d3ee1f;color:var(--cyan);border:1px solid #22d3ee44}
.tag.ok{background:#2ad17e1f;color:var(--green);border:1px solid #2ad17e44}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--dim);font-weight:600;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--line)}
td{padding:9px 10px;border-bottom:1px solid #102036;color:var(--ink)}
tr:hover td{background:#0c1525}
input,select,textarea{background:#0a1322;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:10px 12px;font:inherit;width:100%}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--cyan)}
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 5px}
.btn{display:inline-block;cursor:pointer;background:var(--cyan);color:#04121a;font-weight:800;border:none;border-radius:9px;padding:11px 18px;letter-spacing:.04em}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.danger{background:var(--red);color:#fff}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#06080fcc;backdrop-filter:blur(8px);z-index:10}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.04em}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--cyan);box-shadow:0 0 14px var(--cyan)}
.sub{font-size:11px;letter-spacing:.3em;color:var(--dim);text-transform:uppercase}
.muted{color:var(--muted)}.dim{color:var(--dim)}
.spark{display:flex;gap:3px;align-items:flex-end;height:54px}
.spark i{flex:1;background:linear-gradient(180deg,var(--cyan),#155e75);border-radius:2px 2px 0 0;min-height:2px}
.pill{padding:2px 8px;border:1px solid var(--line);border-radius:20px;font-size:11px;color:var(--muted)}
.live{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--green)}
.live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.codebox{background:#04101c;border:1px solid var(--line);border-radius:10px;padding:14px;font-family:ui-monospace,monospace;font-size:13px;color:#9fe7ff;overflow:auto;white-space:pre-wrap;word-break:break-all}
.flash{padding:12px 14px;border-radius:10px;margin:10px 0;font-size:13px}
.flash.err{background:#ff3b5c1a;border:1px solid #ff3b5c55;color:#ffb3c0}
.flash.ok{background:#2ad17e1a;border:1px solid #2ad17e55;color:#9ff0c4}

/* ── Mobile / small-screen responsiveness (global; covers Pentagon + app pages) ──
   Topbars wrap instead of overflowing, wide tables scroll horizontally inside
   their own area instead of pushing the page sideways, and the common grid
   layouts collapse to a single column. */
@media (max-width: 760px) {
  .topbar { flex-wrap: wrap; gap: 10px; padding: 12px 16px; }
  .topbar > div { flex-wrap: wrap; }
  .wrap { padding-left: 16px; padding-right: 16px; }
  /* Action clusters / button rows never run off the edge */
  .links, .cta, .actions { flex-wrap: wrap; }
  .btn { white-space: nowrap; }
  /* Wide data tables scroll on their own instead of widening the page */
  table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; }
  /* Common multi-column grids → single column on phones */
  .pillars, .feat, .plans, .steps, .stats, .grid2, .kpis, .formgrid, .setrow { grid-template-columns: 1fr !important; }
  /* Centred modals fit the viewport */
  .modal { width: min(94vw, 460px) !important; }
}

/* ── Predictive Threat Intelligence (assets/intel.js) ──────────────────────── */
.ai-card{margin-top:16px}
.ai-card h3{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.ai-meta{font-size:9.5px;letter-spacing:.12em;color:var(--dim);text-transform:none;font-weight:600}
.ai-top{display:grid;grid-template-columns:1fr 1.1fr;gap:18px;align-items:center}
.ai-gauge-num{font-size:46px;font-weight:800;line-height:1}
.ai-gauge-num span{font-size:16px;color:var(--dim);font-weight:600}
.ai-gauge-band{font-size:11px;letter-spacing:.16em;font-weight:800;margin:4px 0 10px}
.ai-trend{margin-left:6px;font-size:10px;letter-spacing:.06em}
.ai-bar{position:relative;height:9px;border-radius:6px;background:#0a1322;border:1px solid var(--line);overflow:visible}
.ai-bar i{display:block;height:100%;border-radius:6px;transition:width .6s}
.ai-bar u{position:absolute;top:-3px;width:3px;height:15px;border-radius:2px;background:#fff;transform:translateX(-50%);box-shadow:0 0 6px #fff8}
.ai-head{margin-top:11px;font-size:12.5px;color:var(--muted);line-height:1.4}
.ai-fc-wrap{min-width:0}
.ai-fc-t{font-size:10px;letter-spacing:.1em;color:var(--dim);text-transform:uppercase;margin-bottom:6px}
.ai-fc{width:100%;height:90px;display:block}
.ai-fc-legend{display:flex;gap:14px;font-size:10px;color:var(--muted);margin-top:5px}
.ai-fc-legend i{display:inline-block;width:9px;height:3px;border-radius:2px;margin-right:4px;vertical-align:middle}
.ai-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:14px}
.ai-stat{background:#0a1322;border:1px solid var(--line);border-radius:10px;padding:9px 11px}
.ai-stat b{display:block;font-size:17px;font-weight:800}
.ai-stat span{font-size:9.5px;letter-spacing:.08em;color:var(--dim);text-transform:uppercase}
.ai-next{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:13px;padding-top:12px;border-top:1px solid var(--line)}
.ai-next-k{font-size:10px;letter-spacing:.12em;color:var(--dim);text-transform:uppercase}
.ai-chip{background:#0a1322;border:1px solid var(--line);border-radius:20px;padding:4px 11px;font-size:12px;color:var(--ink)}
.ai-chip b{color:var(--cyan)}
.ai-scns{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.ai-scn{background:#0a1322;border:1px solid var(--line);border-radius:12px;padding:13px}
.ai-scn-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.ai-scn-top b{font-size:13.5px}
.ai-scn-p{font-size:15px;font-weight:800}
.ai-scn-bar{height:6px;border-radius:4px;background:#06101e;border:1px solid var(--line);margin:8px 0;overflow:hidden}
.ai-scn-bar i{display:block;height:100%}
.ai-scn-narr{font-size:11.5px;color:var(--muted);line-height:1.45;margin:0 0 9px}
.ai-scn-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;font-size:10.5px;color:var(--dim);margin-bottom:10px}
.ai-scn-grid b{color:var(--ink);font-size:13px;margin-left:4px}
.ai-scn-grid u{color:var(--dim);text-decoration:none;margin-left:5px;font-size:9.5px}
.ai-play div,.ai-rec-b div{font-size:11px;color:var(--muted);line-height:1.45;padding:7px 9px;border-radius:8px;background:#06101e;margin-top:6px}
.ai-play div span,.ai-rec-b div span{display:block;font-size:8.5px;letter-spacing:.14em;color:var(--cyan);font-weight:800;margin-bottom:3px}
.ai-play div.off span,.ai-rec-b div.off span{color:var(--red)}
.ai-tbl{width:100%}
.ai-tbl td{vertical-align:middle}
.ai-kind{display:block;font-size:9.5px;color:var(--dim);text-decoration:none}
.ai-rr{height:7px;border-radius:4px;background:#06101e;border:1px solid var(--line);overflow:hidden;min-width:60px}
.ai-rr i{display:block;height:100%}
.ai-act a{font-size:11px;white-space:nowrap}
.ai-rec{border-left:3px solid var(--green);padding:2px 0 2px 12px;margin-bottom:12px}
.ai-rec-h{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.ai-rec-h .dim{font-size:10.5px}
.ai-rec-b{display:grid;grid-template-columns:1fr 1fr;gap:9px}
@media(max-width:760px){.ai-top{grid-template-columns:1fr}.ai-stats{grid-template-columns:repeat(2,1fr)}.ai-rec-b{grid-template-columns:1fr}}
