
:root{
  --bg:#0A0B10;--bg-soft:#0E1018;--panel:#12141E;--panel-2:#171A26;
  --line:rgba(255,255,255,.07);--line-2:rgba(255,255,255,.12);
  --ink:#F2F4FA;--ink-soft:#A6AEC2;--ink-faint:#6B7388;--ink-bold:#FFFFFF;--ink-italic:#C4B5FD;--accent-rgb:91,140,255;
  --accent:#5B8CFF;--accent-2:#7C5CFF;--mint:#3DE0B0;
  --crit:#FF5470;--high:#FF9F45;--med:#FFD43B;--low:#3DE0B0;--amber:#FF9F45;
  --c-cve:#FF5470;--c-tech:#3DE0B0;--c-actor:#A98BFF;--c-tool:#5B8CFF;--c-family:#FF7AB0;--c-comp:#7CE0A0;--c-product:#FFB454;
  --radius:18px;--radius-s:12px;--shadow:0 24px 60px -28px rgba(0,0,0,.85);
  --f-display:"IBM Plex Sans",system-ui,sans-serif;--f-sans:"IBM Plex Sans",system-ui,sans-serif;--f-mono:"IBM Plex Mono","SF Mono",ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--f-sans);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.5}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(900px 700px at 50% -10%,rgba(91,140,255,.11),transparent 65%)}
::selection{background:rgba(91,140,255,.32)}
strong,b{color:var(--ink-bold);font-weight:600}
em,i{color:var(--ink-italic);font-style:italic}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
a{color:inherit;text-decoration:none}
.app{position:relative;z-index:2}

/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;padding:14px 30px;
  background:linear-gradient(180deg,rgba(10,11,16,.88),rgba(10,11,16,.5));backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.logo{display:flex;align-items:center;gap:12px;cursor:pointer}
.logo svg{width:24px;height:24px}
.logo .wm{font-family:var(--f-display);font-weight:600;font-size:21px;letter-spacing:.2px}
.logo .wm .sh{color:var(--accent);font-family:var(--f-mono);font-size:15px}
.logo .tag{font-size:9.5px;letter-spacing:2.5px;color:var(--ink-faint);text-transform:uppercase;margin-top:-2px}
.nav .grow{flex:1}
.backbtn{display:flex;align-items:center;gap:7px;font-family:var(--f-mono);font-size:12.5px;color:var(--ink-soft);
  background:var(--panel);border:1px solid var(--line-2);padding:8px 13px;border-radius:10px;cursor:pointer;transition:.18s}
.backbtn:hover{color:var(--ink);border-color:var(--accent)}
.backbtn.on{display:flex}
.loc{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:12px;color:var(--ink-soft);font-variant-ligatures:none;
  padding:7px 13px;border:1px solid var(--line-2);border-radius:30px;background:var(--panel)}
.loc .dot{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 8px var(--mint)}
.loc b{color:var(--ink);font-weight:500}
.navsearch{position:relative;width:min(340px,30vw)}
.navsearch input{width:100%;background:var(--panel);border:1px solid var(--line-2);color:var(--ink);font-family:var(--f-sans);
  font-size:14px;padding:10px 14px 10px 38px;border-radius:11px;outline:none;transition:.25s}
.navsearch input:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(91,140,255,.14)}
.navsearch .mag{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ink-faint)}

/* views */
.view{display:none}.view.on{display:block;animation:fade .4s cubic-bezier(.2,.7,.3,1)}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* home */
.hero{max-width:1000px;margin:0 auto;padding:64px 30px 24px;text-align:center}
.eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:3px;color:var(--accent);text-transform:uppercase}
.hero h1{font-family:var(--f-display);font-weight:600;font-size:clamp(36px,6vw,70px);line-height:1.02;letter-spacing:-1.2px;margin-top:18px}
.hero h1 .it{font-style:italic;background:linear-gradient(110deg,var(--accent),var(--mint));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero .sub{color:var(--ink-soft);font-size:17px;max-width:600px;margin:20px auto 0;line-height:1.65}
.search-xl{max-width:660px;margin:36px auto 0;position:relative}
.search-xl .box{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line-2);border-radius:18px;padding:16px 18px;transition:.3s;box-shadow:var(--shadow)}
.search-xl .box:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgba(91,140,255,.13),var(--shadow)}
.search-xl input{flex:1;background:none;border:none;outline:none;color:var(--ink);font-family:var(--f-sans);font-size:17px}
.search-xl input::placeholder{color:var(--ink-faint)}
.search-xl .btn{font-family:var(--f-sans);font-weight:600;font-size:14px;color:#0A0B10;background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;padding:11px 20px;border-radius:12px;cursor:pointer;transition:.2s}
.search-xl .btn:hover{transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(91,140,255,.7)}
/* persistent feedback BELOW the search bar (replaces the transient toast) */
.feedback{margin-top:14px;min-height:22px;text-align:left}
.feedback .msg{font-family:var(--f-mono);font-size:13px;color:var(--ink-soft);padding:4px 2px}
.feedback .msg b{color:var(--accent)}
.suglist{display:flex;flex-direction:column;gap:6px;margin-top:6px;background:var(--panel);border:1px solid var(--line-2);border-radius:12px;overflow:hidden}
.sug{display:flex;align-items:center;gap:11px;padding:11px 15px;cursor:pointer;transition:.15s;border-bottom:1px solid var(--line)}
.sug:last-child{border-bottom:none}.sug:hover{background:var(--panel-2)}
.sug .tg{font-family:var(--f-mono);font-size:10px;padding:3px 8px;border-radius:6px;border:1px solid var(--line-2);color:var(--ink-faint);text-transform:uppercase}
.sug .nm{font-size:14px}.sug .nm b{color:var(--accent)}
.sug .meta{margin-left:auto;font-family:var(--f-mono);font-size:11px;color:var(--ink-faint)}
.examples{margin-top:16px;font-family:var(--f-mono);font-size:12.5px;color:var(--ink-faint)}
.examples b{color:var(--ink-soft);cursor:pointer;padding:2px 4px;border-radius:5px}.examples b:hover{color:var(--accent);background:rgba(91,140,255,.1)}
.chips{display:flex;flex-wrap:wrap;gap:11px;justify-content:center;max-width:780px;margin:28px auto 0}
.echip{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:500;padding:11px 17px;border-radius:13px;border:1px solid var(--line-2);background:var(--panel);color:var(--ink-soft);cursor:pointer;transition:.22s}
.echip:hover{color:var(--ink);transform:translateY(-3px);border-color:var(--cc);box-shadow:0 14px 30px -16px var(--cc)}
.echip .d{width:9px;height:9px;border-radius:3px;background:var(--cc)}
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;max-width:1080px;margin:54px auto 0;padding:0 30px}
.scard{background:linear-gradient(165deg,var(--panel),var(--bg-soft));border:1px solid var(--line);border-radius:var(--radius);padding:22px 20px;position:relative;overflow:hidden}
.scard::after{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.6}
.scard .n{font-family:var(--f-display);font-weight:600;font-size:33px;letter-spacing:-.5px}
.scard .l{font-family:var(--f-mono);font-size:11px;color:var(--ink-faint);letter-spacing:1px;text-transform:uppercase;margin-top:6px}

/* shared briefing */
.wrap{max-width:1280px;margin:0 auto;padding:26px 30px 100px}
.crumb{display:flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:12.5px;color:var(--ink-faint);margin-bottom:20px;flex-wrap:wrap}
.crumb a{color:var(--accent);cursor:pointer}.crumb .s{opacity:.5}
.head{display:flex;gap:22px;flex-wrap:wrap;background:linear-gradient(155deg,var(--panel),var(--bg-soft));border:1px solid var(--line);border-radius:var(--radius);padding:30px;position:relative;overflow:hidden}
.head::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;background:radial-gradient(circle,var(--ac,var(--accent)),transparent 64%);opacity:.12;filter:blur(8px)}
.kind{align-self:flex-start;font-family:var(--f-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:6px 13px;border-radius:9px;border:1px solid var(--ac,var(--accent));color:var(--ac,var(--accent));background:rgba(255,255,255,.02);white-space:nowrap}
.head .main{flex:1;min-width:280px}
.head h2{font-family:var(--f-display);font-weight:600;font-size:clamp(26px,3.2vw,38px);line-height:1.1;letter-spacing:-.6px}
.head .sid{font-family:var(--f-mono);font-size:13px;color:var(--ink-soft);margin-top:10px;line-height:1.7}
.head .summary{color:var(--ink);font-size:16px;line-height:1.7;margin-top:18px;max-width:820px;
  padding:14px 18px;background:rgba(91,140,255,.06);border-left:3px solid var(--ac,var(--accent));border-radius:0 10px 10px 0}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.badge{font-family:var(--f-mono);font-size:12px;padding:7px 13px;border-radius:9px;border:1px solid var(--line-2);background:var(--panel-2);display:flex;align-items:center;gap:8px}
.badge .dt{width:8px;height:8px;border-radius:50%}
.badge.crit{border-color:rgba(255,84,112,.45);color:var(--crit)}.badge.crit .dt{background:var(--crit);box-shadow:0 0 9px var(--crit)}
.badge.high{border-color:rgba(255,159,69,.4);color:var(--high)}.badge.high .dt{background:var(--high)}
.badge.kev{border-color:rgba(255,84,112,.55);color:var(--crit);font-weight:600}
.badge.mint{color:var(--mint)}.badge.mint .dt{background:var(--mint)}
.cols{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;margin-top:20px;align-items:start}
@media(max-width:920px){.cols{grid-template-columns:1fr}}
.stack{display:flex;flex-direction:column;gap:20px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel .ph{display:flex;align-items:center;gap:11px;padding:16px 20px;border-bottom:1px solid var(--line)}
.panel .ph .pi{color:var(--ac,var(--accent));font-size:15px}
.panel .ph h3{font-family:var(--f-sans);font-weight:600;font-size:13.5px;letter-spacing:.4px}
.panel .ph .ct{margin-left:auto;font-family:var(--f-mono);font-size:11px;color:var(--ink-faint);background:var(--panel-2);padding:4px 11px;border-radius:30px;border:1px solid var(--line)}
.panel .pb{padding:18px 20px}
/* prose with hierarchy (fixes word-vomit) */
.prose p{color:var(--ink-soft);font-size:14.5px;line-height:1.75;margin-bottom:14px}
.prose p:last-child{margin-bottom:0}
.prose p strong{color:#C9D4FF;font-weight:600}
/* proper ordered list (fixes the CISA one-line problem) */
.reqlist{margin:10px 0 0;padding:0;list-style:none;counter-reset:r}
.reqlist li{counter-increment:r;position:relative;padding:11px 0 11px 38px;border-bottom:1px solid var(--line);color:var(--ink-soft);font-size:14px;line-height:1.6}
.reqlist li:last-child{border-bottom:none}
.reqlist li::before{content:counter(r);position:absolute;left:0;top:10px;width:24px;height:24px;border-radius:7px;
  background:rgba(91,140,255,.12);border:1px solid var(--accent);color:var(--accent);font-family:var(--f-mono);font-size:12px;display:grid;place-items:center}
.line{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line)}
.line:last-child{border-bottom:none}
.tg{font-family:var(--f-mono);font-size:10.5px;padding:3px 8px;border-radius:6px;border:1px solid var(--line-2);color:var(--ink-faint);white-space:nowrap}
.tg.crit{color:var(--crit);border-color:rgba(255,84,112,.4)}.tg.actor{color:var(--c-actor);border-color:rgba(169,139,255,.4)}
.click{cursor:pointer;transition:.15s;font-size:14px;color:var(--accent)}.click:hover{color:var(--accent);opacity:.8}
a.click:not(.pill){text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(91,140,255,.4)}
a.click:not(.pill):hover{text-decoration-color:var(--accent);opacity:1}
/* pill.click overrides click's accent color - pills have their own color scheme */
.pill.click{color:var(--ink-soft)}
.line .rt{margin-left:auto;font-family:var(--f-mono);font-size:11px;color:var(--ink-faint);white-space:nowrap}
.pills{display:flex;flex-wrap:wrap;gap:8px}
.pill{font-family:var(--f-mono);font-size:12px;padding:6px 12px;border-radius:9px;background:var(--panel-2);border:1px solid var(--line-2);color:var(--ink-soft);transition:.18s}
.pill.click:hover{color:var(--ink);border-color:var(--ac,var(--accent));background:var(--bg-soft)}
/* asbtn - action button used in audit/assess exports */
.asbtn{font-family:var(--f-mono);font-size:13px;padding:9px 18px;border-radius:9px;border:1px solid var(--accent);background:rgba(91,140,255,.08);color:var(--accent);cursor:pointer;transition:.15s;text-decoration:none;display:inline-block}
.asbtn:hover{background:rgba(91,140,255,.16);color:var(--accent)}
.kvs{display:grid;grid-template-columns:auto 1fr;gap:10px 18px;font-size:14px}
.kvs .k{font-family:var(--f-mono);font-size:11px;color:var(--ink-faint);letter-spacing:.5px;text-transform:uppercase;padding-top:3px}
.kvs .v{color:var(--ink);line-height:1.55}

/* results list */
.rhead{font-family:var(--f-display);font-weight:600;font-size:26px;letter-spacing:-.4px;margin-bottom:6px}
.rsub{color:var(--ink-faint);font-family:var(--f-mono);font-size:13px;margin-bottom:22px}
.rcard{display:flex;align-items:center;gap:16px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 20px;margin-bottom:12px;cursor:pointer;transition:.18s}
.rcard:hover{border-color:var(--accent);transform:translateX(3px)}
.rcard .rk{font-family:var(--f-mono);font-size:10.5px;padding:4px 9px;border-radius:7px;border:1px solid var(--rc,var(--line-2));color:var(--rc,var(--ink-faint));text-transform:uppercase;white-space:nowrap}
.rcard .rmain{flex:1;min-width:0}
.rcard .rt2{font-family:var(--f-mono);font-size:14px}
.rcard .rd{color:var(--ink-faint);font-size:13px;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rcard .rsev{font-family:var(--f-mono);font-size:12px;white-space:nowrap}
.rsev.crit{color:var(--crit)}.rsev.high{color:var(--high)}.rsev.med{color:var(--med)}

/* graph */
.gpanel{margin-top:20px;position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:600px;background:radial-gradient(ellipse 70% 60% at 50% 45%,var(--panel),var(--bg) 92%)}
.gpanel .gl{position:absolute;top:16px;left:18px;z-index:3;font-family:var(--f-mono);font-size:11px;letter-spacing:1.5px;color:var(--ink-faint);text-transform:uppercase}
.gpanel .gh{position:absolute;bottom:14px;left:18px;z-index:3;font-family:var(--f-mono);font-size:11px;color:var(--ink-faint)}
.glegend{position:absolute;top:14px;right:16px;z-index:3;display:flex;flex-direction:column;gap:6px}
.glegend span{font-family:var(--f-mono);font-size:10.5px;color:var(--ink-soft);display:flex;align-items:center;gap:7px}
.glegend i{width:9px;height:9px;border-radius:50%}
svg.graph{width:100%;height:100%;display:block;cursor:grab}svg.graph:active{cursor:grabbing}
.edge{stroke:var(--line-2);stroke-width:1.2;fill:none}
.edge.hot{stroke:url(#flow);stroke-width:1.9;stroke-dasharray:5 6;animation:dash 1.1s linear infinite}
@keyframes dash{to{stroke-dashoffset:-22}}
.gnode text{font-family:var(--f-mono);font-size:10px;fill:var(--ink-soft);text-anchor:middle;pointer-events:none}
.gnode.focus text{fill:var(--ink);font-size:11px;font-weight:600}
.gnode circle.core{transition:filter .25s}.gnode:hover circle.core{filter:brightness(1.45)}
.foot{max-width:1280px;margin:0 auto;padding:32px 30px 60px;border-top:1px solid var(--line);font-family:var(--f-mono);font-size:11px;color:var(--ink-faint);line-height:1.85}
.foot b{color:var(--ink-soft)}


.rk-cve{--rc:var(--c-cve)}.rk-actor{--rc:var(--c-actor)}.rk-tool{--rc:var(--c-tool)}.rk-technique{--rc:var(--c-tech)}.rk-family{--rc:var(--c-family)}.rk-product{--rc:var(--c-product)}.rk{color:var(--rc,var(--ink-faint));border-color:var(--rc,var(--line-2))}
.pb .lead{color:var(--ink-soft);font-size:13px;line-height:1.6;margin-bottom:12px}
.v.mono{font-family:var(--f-mono);font-size:12px}
.fw{display:flex;align-items:center;gap:12px;padding:9px 0;font-family:var(--f-mono);font-size:13px}.fw .nm{color:var(--c-comp);min-width:120px;font-weight:600}.fw .vl{color:var(--ink-soft)}
.ck{font-family:var(--f-mono)}
a.logo{text-decoration:none}.logo .wm,.logo .tag{display:block}
a.echip{text-decoration:none}

/* ===== finalized logo: crosshair mark + split-hairline wordmark ===== */
:root{--f-geo:"IBM Plex Sans",sans-serif}
a.logo{text-decoration:none;display:inline-flex;align-items:center;gap:11px}
.mark{width:24px;height:24px;flex:0 0 auto;fill:none;stroke:var(--accent);stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;
  transition:transform .4s cubic-bezier(.16,1,.3,1)}
.mark circle{fill:var(--accent);stroke:none}
a.logo:hover .mark{transform:rotate(45deg)}
.brand{display:inline-flex;align-items:center;font-family:var(--f-geo);letter-spacing:-.03em;white-space:nowrap;line-height:1;font-size:22px}
.brand .threat{font-weight:300;color:#7C879B}
.brand .bar{width:1px;height:.74em;background:rgba(255,255,255,.18);margin:0 .34em}
.brand .engine{font-weight:600;color:var(--accent)}
.brand .sh{font-family:var(--f-mono);font-weight:500;color:var(--mint);margin-left:.3em;font-size:.62em;align-self:flex-end;transform:translateY(-.16em)}

/* full description block under the summary lead */
.fulldesc{margin-top:16px;padding-top:4px}
.fulldesc p{color:var(--ink-soft);font-size:14.5px;line-height:1.75;margin-bottom:13px}
.fulldesc p:last-child{margin-bottom:0}

/* references list (CVE page) */
.reflist .refrow{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px dashed var(--line);flex-wrap:wrap}
.reflist .refrow:last-child{border-bottom:none}
.reflink{font-family:var(--f-mono);font-size:12px;color:var(--accent);word-break:break-all;flex:1;min-width:0}
.reflink:hover{text-decoration:underline}
.reftag{font-family:var(--f-mono);font-size:9.5px;text-transform:uppercase;color:var(--ink-faint);border:1px solid var(--line-2);border-radius:5px;padding:2px 6px;white-space:nowrap}
.line a.click[target]{word-break:break-word}

/* expandable sections (compact by default, expand-all to read) */
.expandable{margin-top:8px;border-top:1px solid var(--line)}
.expandable summary{cursor:pointer;padding:10px 0 8px;font-family:var(--f-mono);font-size:12px;color:var(--accent);list-style:none;user-select:none}
.expandable summary::before{content:"+ ";color:var(--accent);font-weight:600}
.expandable[open] summary::before{content:"- "}
.expandable[open] summary{margin-bottom:4px}

/* fullscreen graph */
.gpanel{position:relative}
.gfs{position:absolute;top:14px;right:170px;z-index:4;background:var(--panel-2);border:1px solid var(--line-2);color:var(--ink-soft);
  width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:18px;line-height:1;transition:.18s;font-family:var(--f-mono)}
.gfs:hover{color:var(--ink);border-color:var(--accent)}
.gpanel.full{position:fixed !important;inset:0;z-index:9999;height:100vh;width:100vw;border-radius:0;background:var(--bg)}
.gpanel.full .gfs::before{content:"\00d7";font-size:22px}
.gpanel.full .gfs{font-size:0}

/* ============================================================
   Discovery pages - visual polish (features, stats, list pages)
   ============================================================ */

/* --- /features: clean rows with name+description on left, count on right --- */
.featlist{display:flex;flex-direction:column}
.featrow{display:flex;align-items:flex-start;gap:20px;padding:14px 0;border-bottom:1px dashed var(--line)}
.featrow:last-child{border-bottom:none}
.featrow .fl{flex:1;min-width:0}
.featrow .fn{font-size:14.5px;color:var(--ink);font-weight:500}
.featrow .fn a{color:var(--accent)}.featrow .fn a:hover{text-decoration:underline}
.featrow .fd{color:var(--ink-faint);font-size:12.5px;margin-top:4px;line-height:1.55}
.featrow .fv{font-family:var(--f-mono);font-size:18px;font-weight:600;color:var(--ink-soft);white-space:nowrap;padding-top:3px}
.featrow .fv.method{font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:1px}

/* --- /stats: dashboard-style 3-column responsive grid --- */
.statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:24px}
.scard2{position:relative;background:linear-gradient(165deg,var(--panel),var(--bg-soft));border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px 20px;overflow:hidden;transition:.18s}
.scard2:hover{transform:translateY(-2px);border-color:var(--cc,var(--accent));box-shadow:0 18px 36px -20px var(--cc,var(--accent))}
.scard2::after{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,transparent,var(--cc,var(--accent)),transparent);opacity:.55}
.scard2 .n{font-family:var(--f-display);font-weight:600;font-size:30px;letter-spacing:-.4px;color:var(--cc,var(--ink));line-height:1.05}
.scard2 .l{font-family:var(--f-mono);font-size:10.5px;color:var(--ink-faint);letter-spacing:1.2px;text-transform:uppercase;margin-top:9px}
.scard2 .h{color:var(--ink-soft);font-size:12.5px;line-height:1.55;margin-top:8px}
.scard2 a.l{color:var(--accent)}

/* --- /sigma, /yara, etc: vertical rule cards with hierarchy --- */
.rulelist{display:flex;flex-direction:column;gap:0}
.rulerow{padding:14px 0;border-bottom:1px dashed var(--line);display:flex;flex-direction:column;gap:5px}
.rulerow:last-child{border-bottom:none}
.rulerow .top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rulerow .ti{font-size:14px;color:var(--ink);flex:1;min-width:0}
.rulerow .dd{color:var(--ink-faint);font-size:12.5px;line-height:1.5;margin-top:2px}
.rulerow .meta{display:flex;gap:11px;color:var(--ink-faint);font-family:var(--f-mono);font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;margin-top:4px;flex-wrap:wrap}
.rulerow .meta b{color:var(--ink-soft);font-weight:500}

/* --- Stat strip (used on home page right under search) --- */
.statstrip{display:grid;grid-template-columns:repeat(auto-fit,minmax(115px,1fr));gap:14px;max-width:980px;margin:36px auto 0;padding:0 30px}
.stsl{text-align:center}
.stsl .n{font-family:var(--f-display);font-weight:600;font-size:22px;color:var(--ink);letter-spacing:-.3px}
.stsl .l{font-family:var(--f-mono);font-size:9.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:1.1px;margin-top:5px}

/* --- chip groups on home (organize 13 chips into rows) --- */
.chipgrp{max-width:920px;margin:32px auto 0;padding:0 30px}
.chipgrp .gl{font-family:var(--f-mono);font-size:10.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:1.4px;margin-bottom:10px;text-align:center}
.chipgrp + .chipgrp{margin-top:18px}

/* --- filter pill row improvement --- */
.filterbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:18px}
.filterbar .lab{font-family:var(--f-mono);font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:1px}

/* --- /brief: rank pill + cleaner cve card layout --- */
.briefcard{margin-top:14px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.briefcard .bch{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.briefcard .bch .rank{font-family:var(--f-mono);font-size:11px;color:var(--accent);background:rgba(91,140,255,.1);border:1px solid var(--accent);width:28px;height:28px;display:grid;place-items:center;border-radius:7px;font-weight:600}
.briefcard .bch h3{font-family:var(--f-mono);font-size:15px;color:var(--ink);font-weight:600;margin:0}
.briefcard .bch h3 a{color:inherit}.briefcard .bch h3 a:hover{color:var(--accent)}
.briefcard .bcb{padding:16px 20px 18px}
.briefcard .bcb .lead{color:var(--ink-soft);font-size:14px;line-height:1.65;margin:0 0 12px}
.briefcard .bcb .info{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}
.briefcard .bcb .info span{font-family:var(--f-mono);font-size:11px;color:var(--ink-soft);background:var(--panel-2);padding:5px 10px;border-radius:6px;border:1px solid var(--line-2)}
.briefcard .bcb .info span b{color:var(--ink);font-weight:600}

/* ============================================================
   Discovery pages - search box, pagination, rule content blocks
   ============================================================ */

/* Search box for list pages */
.psearch{display:flex;align-items:center;gap:0;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:0;overflow:hidden;max-width:540px;margin-top:18px}
.psearch input{flex:1;background:none;border:none;color:var(--ink);font-family:var(--f-sans);font-size:14px;padding:11px 16px;outline:none}
.psearch input::placeholder{color:var(--ink-faint)}
.psearch button{background:var(--accent);color:#fff;border:none;padding:11px 22px;font-family:var(--f-mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-weight:600;transition:.18s}
.psearch button:hover{background:#7aa7ff}

/* Pagination bar */
.pgr{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 0 4px;font-family:var(--f-mono);font-size:12px;color:var(--ink-faint);flex-wrap:wrap}
.pgr .info{}
.pgr .info b{color:var(--ink-soft)}
.pgr .nav-pg{display:flex;gap:8px}
.pgr a, .pgr span.curp{padding:7px 13px;border-radius:7px;border:1px solid var(--line);font-family:var(--f-mono);font-size:11px;color:var(--ink-soft);background:var(--panel-2);cursor:pointer;text-decoration:none}
.pgr a:hover{border-color:var(--accent);color:var(--accent)}
.pgr .curp{background:var(--accent);color:#fff;border-color:var(--accent)}
.pgr .disabled{opacity:.35;pointer-events:none}

/* Rule content collapsible (Sigma YAML, YARA pattern) */
.rulecontent{margin-top:10px;background:#0a0e16;border:1px solid var(--line-2);border-radius:8px;overflow:hidden}
.rulecontent summary{cursor:pointer;padding:10px 14px;font-family:var(--f-mono);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:1px;background:var(--panel-2);user-select:none}
.rulecontent summary:hover{color:#7aa7ff}
.rulecontent pre{margin:0;padding:14px 16px;font-family:var(--f-mono);font-size:11.5px;color:var(--ink-soft);overflow-x:auto;line-height:1.55;white-space:pre-wrap;word-break:break-word}
.rulecontent[open] summary{border-bottom:1px solid var(--line)}

/* No-results state */
.empty{padding:60px 20px;text-align:center;color:var(--ink-faint);font-family:var(--f-mono);font-size:13px}
.empty b{display:block;color:var(--ink-soft);font-size:16px;margin-bottom:8px;font-family:var(--f-sans);font-weight:500}

/* ============================================================
   READABLE TYPOGRAPHY - magazine-grade prose
   ============================================================ */

/* Hard reset on prose blocks - make them readable like an article */
.prose{
  font-family: var(--f-sans);
  font-size: 15.5px;
  line-height: 1.72;
  color: var(--ink-soft);
  max-width: 72ch;
  letter-spacing: 0.005em;
}
.prose p{
  margin: 0 0 1.05em;
}
.prose p:last-child{margin-bottom:0}
.prose p:first-child{
  /* Lead paragraph treatment */
  font-size: 16.5px;
  color: var(--ink);
}
.prose b, .prose strong{color:var(--ink);font-weight:600}

/* Read more toggle pattern.
   .fulldesc starts collapsed; clicking .rm-toggle reveals.
   Uses <details> for accessibility - no JS needed. */
.fulldesc{
  margin-top: 14px;
  padding: 0;
}
.fulldesc[open] > summary{
  color: var(--ink-faint);
  margin-bottom: 14px;
}
.fulldesc > summary{
  cursor: pointer;
  display: inline-block;
  padding: 7px 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: 0.6px;
  color: var(--accent);
  text-transform: uppercase;
  user-select: none;
  transition: 0.18s;
  list-style: none;
}
.fulldesc > summary::-webkit-details-marker{display:none}
.fulldesc > summary:hover{
  border-color: var(--accent);
  background: rgba(122,167,255,0.06);
}
.fulldesc > summary:after{content:" \2193"; opacity:0.6}
.fulldesc[open] > summary:after{content:" \2191"}

/* Drill-down pill row on entity pages */
.drilldown{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}
.dpill{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--ink-soft);
  font-family: var(--f-mono);
  font-size: 12px;
  text-decoration: none;
  transition: 0.18s;
  cursor: pointer;
}
.dpill b{
  color: var(--ink);
  font-weight: 500;
  font-family: var(--f-sans);
  font-size: 13.5px;
}
.dpill .ct{
  background: rgba(122,167,255,0.12);
  color: var(--accent);
  padding: 2px 8px;
  border-radius: 10px;
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 600;
}
.dpill .ar{color:var(--accent);font-family:var(--f-sans)}
a.dpill:hover{
  border-color: var(--accent);
  transform: translateY(-1px);
  background: rgba(122,167,255,0.04);
  text-decoration: none;
}
.dpill.disabled{
  opacity: 0.42;
  cursor: not-allowed;
  pointer-events: auto; /* keep so tooltip still works on hover */
}
.dpill.disabled .ct{
  background: transparent;
  color: var(--ink-faint);
  border: 1px solid var(--line-2);
}
.dpill.disabled:hover{
  border-color: var(--line);
  transform: none;
  background: var(--panel-2);
}

/* Improve actor/tool/CVE description quality */
.summary{
  font-family: var(--f-sans);
  font-size: 15px;
  line-height: 1.65;
  color: var(--ink-soft);
  border-left: 3px solid var(--accent);
  background: rgba(122,167,255,0.04);
  padding: 12px 16px;
  border-radius: 0 8px 8px 0;
  margin: 14px 0;
  max-width: 72ch;
}
.summary b{color:var(--ink)}

/* ============================================================
   CVSS visual breakdown panel
   ============================================================ */
.cvss-block{
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px 18px;
  margin: 0 0 16px;
}
.cvss-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 14px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--line-2);
}
.cvss-score .num{
  font-family: var(--f-serif);
  font-size: 34px;
  font-weight: 600;
  color: var(--crit);
  line-height: 1;
}
.cvss-score .lbl{
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-top: 6px;
}
.cvss-link{
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.6px;
  color: var(--accent);
  text-decoration: none;
  padding: 7px 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  transition: 0.18s;
}
.cvss-link:hover{
  border-color: var(--accent);
  background: rgba(122,167,255,0.05);
}
.cvss-metrics{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
.cvss-metric{
  display: grid;
  grid-template-columns: 145px 1fr;
  align-items: center;
  gap: 14px;
}
.cvss-metric .mn{
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.7px;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.cvss-metric .mopts{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.cvss-metric .mopt{
  padding: 5px 10px;
  border: 1px solid var(--line);
  border-radius: 5px;
  background: transparent;
  color: var(--ink-faint);
  font-family: var(--f-mono);
  font-size: 11px;
  cursor: default;
  transition: 0.18s;
  opacity: 0.55;
}
.cvss-metric .mopt:hover{
  opacity: 1;
  border-color: var(--line-3);
}
.cvss-metric .mopt.sel{
  opacity: 1;
  border-color: var(--crit);
  background: rgba(255,107,107,0.08);
  color: var(--crit);
  font-weight: 600;
}

/* ============================================================
   External pivot links - "look this up elsewhere" shelf
   ============================================================ */
.pivot{
  margin-top: 14px;
  padding: 12px 14px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 8px;
}
.pivot .pivot-h{
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 9px;
}
.pivot .pivot-row{
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.pivot a.xl{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border: 1px solid rgba(91,140,255,.35);
  border-radius: 6px;
  background: rgba(91,140,255,.05);
  color: var(--accent);
  font-family: var(--f-mono);
  font-size: 11.5px;
  text-decoration: none;
  transition: 0.15s;
}
.pivot a.xl:hover{
  border-color: var(--accent);
  color: var(--ink);
  background: rgba(91,140,255,.12);
}

.pivot a.xl .xn{ color: var(--ink-faint); font-size: 10px; }

/* ============================================================
   Pivot links as SECOND-CLASS - visually subordinate to our own data.
   First-class = our content (panels above). Second-class = these links.
   ============================================================ */

/* Bottom-of-page external-lookup footer: muted, clearly secondary. */
.pivot-foot{
  margin-top: 28px;
  background: transparent;
  border: 1px dashed var(--line-2);
  opacity: 0.78;
}
.pivot-foot:hover{ opacity: 1; }
.pivot-foot .pivot-h{
  color: var(--ink-faint);
  opacity: 0.8;
}

/* Inline per-IOC pivots: collapsed by default so they never crowd our data.
   The <details> keeps them one click away rather than always-on. */
details.iocpivot{ margin-top: 7px; }
details.iocpivot > summary{
  cursor: pointer;
  list-style: none;
  display: inline-block;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--ink-faint);
  opacity: 0.7;
  user-select: none;
}
details.iocpivot > summary::-webkit-details-marker{ display: none; }
details.iocpivot > summary:hover{ opacity: 1; color: var(--accent); }
details.iocpivot > summary::after{ content: " ↓"; }
details.iocpivot[open] > summary::after{ content: " ↑"; }
details.iocpivot > summary::before{ content: "external lookups"; }
details.iocpivot .pivot-row{ margin-top: 8px; }

/* ============================================================
   Atomic Red Team tests + CAR analytics + Falco rule rows
   ============================================================ */
.atomic{
  border: 1px solid var(--line-2);
  border-radius: 8px;
  padding: 11px 13px;
  margin-bottom: 11px;
  background: var(--panel-2);
}
.atomic-head{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.atomic-name{ color: var(--ink); font-weight: 500; font-size: 13.5px; }
.atomic-plat{
  font-family: var(--f-mono);
  font-size: 10.5px;
  color: var(--ink-faint);
}
.atomic-cmd{
  margin-top: 9px;
  padding: 10px 12px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: var(--f-mono);
  font-size: 12px;
  line-height: 1.55;
  color: var(--ink-soft);
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-word;
}
.carrow{
  padding: 10px 0;
  border-bottom: 1px solid var(--line-2);
}
.carrow:last-child{ border-bottom: none; }
.line2{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}
.line2 b{ color: var(--ink); font-weight: 500; }

/* ============================================================
   SSVC triage block (CVE scoring panel)
   ============================================================ */
.ssvc{
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
}
.ssvc-h{
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 10px;
}
.ssvc-grid{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.ssvc-cell{
  flex: 1 1 28%;
  min-width: 90px;
  border: 1px solid var(--line-2);
  border-radius: 6px;
  padding: 8px 10px;
}
.ssvc-cell .sk{
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 3px;
}
.ssvc-cell .sv{
  font-family: var(--f-sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  text-transform: capitalize;
}
.ssvc-cell .sv.sv-hot{ color: var(--crit); }
.ssvc-note{
  margin-top: 10px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--ink-faint);
}

/* ============================================================
   CWE relationship groups (weakness tree)
   ============================================================ */
.cwe-rel{ margin-bottom: 14px; }
.cwe-rel:last-child{ margin-bottom: 0; }
.cwe-rel-h{
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 6px;
}

/* result badges for rule-type search hits (sigma/yara) */
.rk-sigma{--rc:var(--c-comp)}
.rk-yara{--rc:var(--c-comp)}

/* ============================================================
   Compliance: control -> technique -> detection-coverage view
   ============================================================ */
.ctrl-tech{
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line-2);
}
.ctrl-tech-h{
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 7px;
}
/* a pill marked as "covered" (we have detection) or active framework tab */
.pill-covered{
  border-color: var(--mint) !important;
  color: var(--mint) !important;
  background: rgba(80,200,160,0.06) !important;
}

/* ============================================================
   Compliance report: stat blocks, coverage bar, control rows
   ============================================================ */
.repstat{
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 14px;
}
.repstat .rs{
  flex: 1 1 130px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  padding: 14px;
  text-align: center;
}
.repstat .rsn{ font-size: 30px; font-weight: 700; color: var(--ink); line-height: 1; }
.repstat .rsn.hot{ color: var(--crit); }
.repstat .rsl{
  margin-top: 6px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.covbar{
  height: 10px;
  border-radius: 6px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  overflow: hidden;
}
.covbar-fill{
  height: 100%;
  background: linear-gradient(90deg, var(--mint), var(--accent));
  border-radius: 6px;
}
.repctrl{
  padding: 11px 0;
  border-bottom: 1px solid var(--line-2);
}
.repctrl:last-child{ border-bottom: none; }

/* C-1 audit answer (/compliance/audit) */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;padding:7px 10px;color:var(--ink-soft);border-bottom:1px solid var(--panel-2);font-weight:600}
.tbl td{padding:7px 10px;border-bottom:1px solid var(--panel-2)}
.tbl tr:last-child td{border-bottom:none}
.cov{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}
.cov-hi{background:rgba(61,224,176,.16);color:var(--mint)}
.cov-mid{background:rgba(255,212,59,.16);color:var(--med)}
.cov-lo{background:rgba(255,84,112,.16);color:var(--crit)}
.cov-na{background:var(--panel-2);color:var(--ink-faint)}
.auditrow{padding:11px 0;border-bottom:1px solid var(--panel-2)}
.auditrow:last-child{border-bottom:none}
.actrl{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.actrlid{color:var(--c-comp);font-weight:700}
.actrltitle{color:var(--ink);flex:1;min-width:180px}
.actechs{margin-top:7px;display:flex;flex-wrap:wrap;gap:6px}
.techchip{display:inline-block;padding:2px 8px;border-radius:6px;font-size:12px;font-family:ui-monospace,monospace;text-decoration:none;border:1px solid transparent}
.tc-ok{background:rgba(61,224,176,.14);color:var(--mint);border-color:rgba(61,224,176,.3)}
.tc-ok:hover{background:rgba(61,224,176,.24)}
.tc-gap{background:rgba(255,84,112,.12);color:var(--crit);border-color:rgba(255,84,112,.28)}
.tc-gap:hover{background:rgba(255,84,112,.22)}
/* audit: hide unmapped enhancements by default (toggle reveals them) */
.auditrow.enh-unmapped{display:none}
.auditnote{background:var(--panel-2);border:1px solid rgba(124,224,160,.2);border-radius:8px;padding:10px 12px;margin-bottom:12px;font-size:13px;color:var(--ink-soft);line-height:1.5}
.audittoggle{display:block;margin-top:8px;color:var(--c-comp);cursor:pointer;font-size:12px}
.audittoggle input{margin-right:6px;vertical-align:middle}

/* features page - "what you can do" task cards (harmonised with the design system) */
.taskintro{margin-top:30px;margin-bottom:6px}
.taskintro h3{font-size:21px;font-weight:600;color:var(--ink);margin:0 0 6px;letter-spacing:-.01em}
.taskintro p{color:var(--ink-soft);font-size:14px;margin:0;line-height:1.6;max-width:760px}
.live-key{color:var(--mint);font-weight:600}
.roadmap-key{color:var(--ink-faint);font-weight:600}
.taskpanel .lead{color:var(--ink-soft);font-size:13.5px;line-height:1.6;margin-bottom:16px;max-width:760px}
.tasklist{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.taskcard{display:flex;flex-direction:column;background:linear-gradient(165deg,var(--panel),var(--bg-soft));border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;text-decoration:none;color:inherit;transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease}
.taskcard:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.28)}
.tasktop{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:7px}
.taskname{font-weight:600;color:var(--ink);font-size:15px;line-height:1.3;letter-spacing:-.01em}
.taskdesc{color:var(--ink-soft);font-size:13px;line-height:1.6;flex:1}
.taskex{margin-top:12px;font-size:12.5px;color:var(--accent);font-weight:500}
.taskex span{font-family:var(--f-mono);background:rgba(91,140,255,.12);padding:2px 7px;border-radius:6px;font-weight:400}
.taskbadge{flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:20px;white-space:nowrap;position:relative;top:-1px}
.taskbadge.live{background:rgba(61,224,176,.15);color:var(--mint)}
.taskbadge.roadmap{background:rgba(255,255,255,.04);color:var(--ink-faint);border:1px solid var(--line)}
.taskcard.roadmap{background:rgba(255,255,255,.015);border-style:dashed;cursor:default}
.taskcard.roadmap:hover{border-color:var(--line);transform:none;box-shadow:none}
.taskcard.roadmap .taskname{color:var(--ink-soft)}
.taskex.muted{color:var(--ink-faint);font-weight:400}
.taskex.muted::before{content:"Planned: ";font-weight:500}
@media(max-width:600px){.tasklist{grid-template-columns:1fr}}
.taskkind{color:var(--ink-faint);font-style:normal;font-size:11px;background:rgba(255,255,255,.04);padding:1px 6px;border-radius:5px;margin-left:4px}
/* CVE triage verdict banner */
.triage{margin:14px 0 4px;padding:12px 16px;border-radius:var(--radius-s);border:1px solid var(--line-2);background:var(--panel-2)}
.triage-verdict{display:flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:14px;font-weight:600;letter-spacing:.02em}
.triage-dot{width:10px;height:10px;border-radius:50%;flex:none}
.triage-why{margin:9px 0 0;padding:0 0 0 19px;display:flex;flex-direction:column;gap:3px}
.triage-why li{font-size:12.5px;color:var(--ink-soft);line-height:1.45}
.triage-act-now{border-color:rgba(255,84,112,.5);background:rgba(255,84,112,.08)}
.triage-act-now .triage-verdict{color:var(--crit)} .triage-act-now .triage-dot{background:var(--crit)}
.triage-schedule{border-color:rgba(255,159,69,.5);background:rgba(255,159,69,.08)}
.triage-schedule .triage-verdict{color:var(--high)} .triage-schedule .triage-dot{background:var(--high)}
.triage-monitor{border-color:rgba(61,224,176,.4);background:rgba(61,224,176,.06)}
.triage-monitor .triage-verdict{color:var(--mint)} .triage-monitor .triage-dot{background:var(--mint)}
/* Adversary emulation plan steps */
.emu-step{border-left:2px solid var(--line-2);padding:8px 0 8px 14px;margin:10px 0}
.emu-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.emu-ord{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:50%;background:var(--panel-2);border:1px solid var(--line-2);font-family:var(--f-mono);font-size:11px;color:var(--ink-soft)}
.emu-plat{font-family:var(--f-mono);font-size:10px;color:var(--ink-faint);margin-left:auto}
.emu-ability{font-size:12.5px;color:var(--ink-soft);margin:5px 0 0}
.emu-cmd{margin:7px 0 0;padding:9px 12px;background:var(--bg);border:1px solid var(--line);border-radius:8px;overflow-x:auto}
.emu-cmd code{font-family:var(--f-mono);font-size:11.5px;color:var(--mint);white-space:pre}
/* Detection coverage matrix (technique page) */
.covgrid{display:flex;flex-direction:column;gap:2px;margin-top:4px}
.covrow{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:var(--panel-2)}
.covrow .cov-dot{width:8px;height:8px;border-radius:50%;flex:none}
.covrow .cov-name{font-size:13px;color:var(--ink)}
.covrow .cov-ct{margin-left:auto;font-family:var(--f-mono);font-size:12px}
.cov-has .cov-dot{background:var(--mint)}
.cov-has .cov-name{color:var(--ink)}
.cov-gap{background:transparent;border:1px dashed var(--line-2)}
.cov-gap .cov-dot{background:var(--ink-faint);opacity:.5}
.cov-gap .cov-name{color:var(--ink-faint)}
.cov-none{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.05em;font-size:10px}
/* Detection blind-spot bars (actor page) */
.cvbar-row{margin:10px 0}
.cvbar-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}
.cvbar-name{font-size:12.5px;color:var(--ink-soft)}
.cvbar-num{font-family:var(--f-mono);font-size:11px;color:var(--ink-faint)}
.cvbar-track{height:7px;border-radius:4px;background:var(--panel-2);overflow:hidden}
.cvbar-fill{height:100%;border-radius:4px;transition:width .3s}
.cv-low{background:var(--crit)}
.cv-mid{background:var(--high)}
.cv-high{background:var(--mint)}
/* Watchlist pin button (entity heads) + remove button (watchlist page) */
.wlpin{position:absolute;top:18px;right:18px;z-index:5;font-family:var(--f-mono);font-size:12px;padding:6px 12px;border-radius:9px;border:1px solid var(--line-2);background:var(--panel-2);color:var(--ink-soft);cursor:pointer;transition:.15s}
.wlpin:hover{border-color:var(--c-actor);color:var(--ink)}
.wlpin.on{border-color:var(--c-actor);color:var(--c-actor);background:rgba(169,139,255,.10)}
.wlrm{margin-left:auto;width:22px;height:22px;border-radius:6px;border:1px solid var(--line-2);background:transparent;color:var(--ink-faint);cursor:pointer;font-size:14px;line-height:1;flex:none;transition:.15s}
.wlrm:hover{border-color:var(--crit);color:var(--crit)}

/* structured-desc: readable rendering of MITRE mitigation/CAR descriptions
   (intro paragraph, labelled sub-headers, bullet lists) instead of a text dump. */
.dd.struct{font-size:12.5px;line-height:1.66}
.dd.struct .sd-p{margin:0 0 11px;color:var(--ink-faint,#c7ccd6)}
.dd.struct .sd-h{margin:16px 0 7px;font-weight:600;color:#9FB6F0;font-size:12.5px;letter-spacing:.2px}
.dd.struct .sd-ul{margin:0 0 11px;padding-left:18px;list-style:disc}
.dd.struct .sd-ul li{margin:6px 0;color:var(--ink-faint,#c7ccd6);line-height:1.6}
.dd.struct .sd-ul li::marker{color:var(--c-comp,#7CE0A0)}

/* product CVE filter bar */
.cvefilter{display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;margin-top:18px;
  padding:14px 16px;border:1px solid var(--line-2,#22252e);border-radius:12px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0));
  font-family:var(--f-mono,'Spline Sans Mono',monospace);font-size:12px}
.cvefilter label{display:inline-flex;align-items:center;gap:8px;color:var(--ink-faint,#6B7388);
  font-size:10.5px;letter-spacing:1.2px;text-transform:uppercase}
.cvefilter select,.cvefilter input[type=date]{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  background:var(--bg,#0a0b10);color:var(--ink,#F2F4FA);
  border:1px solid var(--line-2,#2a2e38);border-radius:8px;padding:7px 11px;
  font-family:var(--f-mono,'Spline Sans Mono',monospace);font-size:12.5px;letter-spacing:.2px;
  cursor:pointer;transition:border-color .15s,box-shadow .15s}
.cvefilter select{padding-right:30px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 3.5l3 3 3-3' fill='none' stroke='%236B7388' stroke-width='1.3' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 11px center}
.cvefilter select:hover,.cvefilter input[type=date]:hover{border-color:var(--c-product,#FFB454)}
.cvefilter select:focus,.cvefilter input[type=date]:focus{outline:none;
  border-color:var(--c-product,#FFB454);box-shadow:0 0 0 3px rgba(255,180,84,.12)}
.cvefilter input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer;opacity:.7}
.cf-reset{background:transparent;color:var(--ink-faint,#6B7388);border:1px solid var(--line-2,#2a2e38);
  border-radius:8px;padding:7px 14px;cursor:pointer;font-family:inherit;font-size:11px;
  letter-spacing:.6px;text-transform:uppercase;transition:color .15s,border-color .15s}
.cf-reset:hover{color:var(--ink,#F2F4FA);border-color:var(--c-product,#FFB454)}
.cf-count{margin-left:auto;color:var(--ink-soft,#A6AEC2);font-size:11.5px;letter-spacing:.3px}
.rmeta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.rcvss{font-family:var(--f-mono,'Spline Sans Mono',monospace);font-size:12px;font-weight:600;
  color:var(--ink-soft,#A6AEC2);min-width:30px;text-align:right}

/* CVE description: single quote box that expands in place (no duplicate block) */
.summary .desc-body p{margin:0 0 10px}
.summary .desc-body p:last-child{margin-bottom:0}
.desc-clamp{position:relative}
.desc-clamp .desc-body{max-height:7.4em;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,#000 60%,transparent);
  mask-image:linear-gradient(180deg,#000 60%,transparent)}
.desc-clamp.open .desc-body{max-height:none;
  -webkit-mask-image:none;mask-image:none}
.desc-toggle{margin-top:12px;background:rgba(91,140,255,.10);border:1px solid var(--accent,#5B8CFF);
  color:#AfC2FF;border-radius:8px;padding:8px 16px;cursor:pointer;
  font-family:var(--f-sans);font-size:12px;font-weight:500;letter-spacing:.2px;transition:background .15s,color .15s}
.desc-toggle:hover{background:rgba(91,140,255,.20);color:#fff}

/* CVE metadata: Published / CVSS Vector - labelled rows with a code-chip vector */
.metarow{display:flex;align-items:baseline;gap:12px;padding:9px 0;border-top:1px solid var(--line,#1a1d24)}
.metarow:first-of-type{border-top:none}
.metarow.vec{flex-direction:column;gap:7px}
.metak{flex:0 0 auto;min-width:120px;color:var(--ink-faint,#6B7388);font-family:var(--f-mono,'Spline Sans Mono',monospace);
  font-size:10px;letter-spacing:1.3px;text-transform:uppercase}
.metav{color:var(--ink,#F2F4FA);font-size:13.5px}
.vecchip{display:block;width:100%;box-sizing:border-box;background:var(--bg,#0a0b10);
  border:1px solid var(--line-2,#2a2e38);border-left:2px solid var(--c-cve,#FF5470);border-radius:8px;
  padding:9px 12px;font-family:var(--f-mono,'Spline Sans Mono',monospace);font-size:11.5px;
  letter-spacing:.3px;color:var(--ink-soft,#A6AEC2);word-break:break-all;line-height:1.5}

/* FIX: graph panel + external-lookup footer render OUTSIDE .wrap, so without
   this they spill edge-to-edge while the cards stay inset. Constrain them to the
   same content width (.wrap content box) so everything lines up. */
.gpanel,.pivot-foot{max-width:1220px;margin-left:auto;margin-right:auto}
.gpanel.full{max-width:none}            /* keep fullscreen graph truly full-screen */
.pivot-foot{padding:16px 18px}          /* a touch more breathing room */

/* Sponsor / operational prose: readable paragraph spacing inside the kv cell */
.sponsorbody p{margin:0 0 9px;line-height:1.6}
.sponsorbody p:last-child{margin-bottom:0}

/* Copy button for detection-rule bodies (Sigma/YARA) */
.rulecontent{position:relative}
.copybtn{margin-top:8px;background:transparent;border:1px solid var(--line-2,#2a2e38);
  color:var(--ink-soft,#A6AEC2);border-radius:7px;padding:5px 12px;cursor:pointer;
  font-family:var(--f-mono,'Spline Sans Mono',monospace);font-size:10.5px;letter-spacing:.6px;
  text-transform:uppercase;transition:color .15s,border-color .15s}
.copybtn:hover{color:var(--ink,#F2F4FA);border-color:var(--accent,#5B8CFF)}

/* Inline `code` chips inside curated/MITRE prose (rendered by richText) */
.sd-p code,.sd-ul li code,.desc-body code,.dd.struct code,.prose code,.summary code{
  font-family:var(--f-mono,'Spline Sans Mono',monospace);font-size:.9em;color:var(--mint,#7CE0A0);
  background:rgba(124,224,160,.09);border:1px solid rgba(124,224,160,.18);
  border-radius:4px;padding:1px 5px}
/* Bold inside curated prose visible against the faint body text */
.sd-p strong,.sd-ul li strong,.desc-body strong,.dd.struct strong,.summary strong{color:#C9D4FF;font-weight:600}
/* A little more air between the description paragraphs */
.summary .desc-body p{margin:0 0 11px;line-height:1.62}

/* vendor advisory shown without a human page (CSAF/JSON-only source) */
.advid{color:var(--ink-soft,#A6AEC2);font-family:var(--f-mono,monospace);font-size:12.5px}

/* ══════════════════════════════════════════════════════════════
   LIGHT THEME - Porcelain + Admiral Blue
   ══════════════════════════════════════════════════════════════ */
:root[data-theme="light"] {
  --bg:          #F8F9FC;
  --bg-soft:     #EEF2F8;
  --panel:       #FFFFFF;
  --panel-2:     #F2F5FB;
  --line:        rgba(10,25,80,.08);
  --line-2:      rgba(10,25,80,.15);
  --ink:         #0C1428;
  --ink-bold:    #050E1F;
  --ink-italic:  #1A40B0;
  --ink-soft:    #3A507A;
  --ink-faint:   #7888A8;
  --accent:      #1A40B0;
  --accent-2:    #102E8A;
  --accent-rgb:  26,64,176;
  --mint:        #1A7038;
  --crit:        #C02820;
  --high:        #8A4818;
  --med:         #5A6018;
  --low:         #1A6030;
  --c-cve:       #C02820;
  --c-tech:      #1A7038;
  --c-actor:     #1A40B0;
  --c-tool:      #7018C0;
  --c-family:    #901860;
  --c-comp:      #1A7878;
  --c-product:   #784810;
  --shadow:      0 8px 32px -8px rgba(10,25,80,.18);
}
/* remove gradient blobs in light mode */
:root[data-theme="light"] body::before { display:none; }

/* ══════════════════════════════════════════════════════════════
   EMERALD THEME - Dark + Forest Green
   ══════════════════════════════════════════════════════════════ */
:root[data-theme="emerald"] {
  --bg:          #0C110E;
  --bg-soft:     #111A14;
  --panel:       #172019;
  --panel-2:     #1D2820;
  --line:        rgba(210,240,220,.07);
  --line-2:      rgba(210,240,220,.13);
  --ink:         #DFF0E4;
  --ink-bold:    #F4FFF7;
  --ink-italic:  #6EE89A;
  --ink-soft:    #7EA888;
  --ink-faint:   #4A6855;
  --accent:      #2AB860;
  --accent-2:    #1E8A48;
  --accent-rgb:  42,184,96;
  --mint:        #2AB860;
  --crit:        #E04030;
  --high:        #C08030;
  --med:         #889030;
  --low:         #2AB860;
  --c-cve:       #E04030;
  --c-tech:      #2AB860;
  --c-actor:     #40A0E0;
  --c-tool:      #9058D0;
  --c-family:    #C04088;
  --c-comp:      #28C0A8;
  --c-product:   #B09828;
}

/* ── Theme toggle button ──────────────────────────────────────── */

/* bold/italic in prose contexts */
.prose strong,.prose b,.summary strong,.summary b,
.sd-p strong,.sd-ul li strong,.desc-body strong{color:var(--ink-bold);font-weight:600}
.prose em,.prose i,.summary em,.summary i,
.sd-p em,.sd-ul li em,.desc-body em{color:var(--ink-italic)}

/* a.xl standalone - works without .pivot parent (e.g. inside iocpivot) */
a.xl{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;
  border:1px solid var(--line-2);border-radius:var(--radius);color:var(--accent);
  font-family:var(--f-mono);font-size:11px;text-decoration:none;transition:.13s;
  margin:0 4px 4px 0}
a.xl:hover{border-color:var(--accent);background:rgba(var(--accent-rgb,91,140,255),.08)}
a.xl .xn{color:var(--ink-faint);font-size:9px}
