/* ─── TTP Atlas v2 – clean professional dark design ─── */
:root{
  --bg:#f0f5f7;--bg2:#f7fbfb;--bg3:#e9f1f5;
  --card:rgba(255,255,255,.95);--card2:rgba(255,255,255,.92);--glass:rgba(20,44,85,.05);
  --border:rgba(22,62,87,.16);--border2:rgba(22,62,87,.1);
  --text:#11253b;--muted:#607894;--soft:#284664;
  --blue:#1d87c8;--indigo:#2f7bc0;--cyan:#0f9f96;--green:#1aa97b;
  --amber:#bc7a25;--rose:#cf586e;--violet:#7067c4;
  --shadow:0 14px 40px rgba(20,50,90,.14),0 2px 10px rgba(20,50,90,.08);
  --shadow-sm:0 6px 20px rgba(20,50,90,.12);
  --radius:16px;--radius-sm:10px;--radius-xs:6px;
  --font:"IBM Plex Sans","Segoe UI Variable",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-mono:"JetBrains Mono","Fira Code","Consolas",monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%;font-family:var(--font);font-size:15px;line-height:1.6;color:var(--text);background:radial-gradient(1200px 600px at -10% -5%, #dbeefe 0%, transparent 60%),radial-gradient(900px 500px at 110% 5%, #d9f8ef 0%, transparent 56%),var(--bg)}
body{position:relative;overflow-x:hidden}
body::before{content:'';position:fixed;inset:-10% -10% auto -10%;height:340px;background:linear-gradient(135deg,rgba(29,135,200,.12),rgba(15,159,150,.08));filter:blur(20px);pointer-events:none;z-index:0}
body::after{content:'';position:fixed;inset:auto -10% -18% -10%;height:360px;background:radial-gradient(ellipse at center,rgba(112,103,196,.12),transparent 66%);pointer-events:none;z-index:0}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit;font-size:inherit}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.22)}

/* layout */
.shell{display:grid;grid-template-columns:255px minmax(0,1fr);min-height:100vh;position:relative;z-index:1}

/* sidebar */
.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;padding:14px 10px;display:flex;flex-direction:column;gap:2px;background:linear-gradient(180deg,rgba(247,251,251,.96),rgba(236,245,248,.93));border-right:1px solid var(--border)}
.nav-icon{width:14px;height:14px;flex:0 0 14px}
.sidebar-brand{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:8px 8px 16px}
.sidebar-brand-main{display:flex;align-items:center;gap:10px}
.brand-logo{width:90px;height:90px;flex:0 0 90px;border-radius:16px;background:#fff url('/static/izo6.png') center/cover no-repeat;box-shadow:0 0 0 1px rgba(255,255,255,.08)}
.brand-text h1{margin:0;font-size:14.5px;font-weight:700;color:var(--text);line-height:1.2}
.brand-text p{margin:0;font-size:11px;color:var(--muted);line-height:1.3}
.brand-cyberevidence{font-family:"Montserrat","Poppins","Segoe UI",sans-serif;font-weight:800;letter-spacing:.12em;font-size:13px;line-height:1;text-transform:uppercase;white-space:nowrap;padding-left:2px}
.cyber-word{color:#0b4db7}
.evidence-word{color:#0f9f96}
.nav-section{margin-top:8px}
.nav-section-label{padding:0 10px 4px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.navbtn{width:100%;display:flex;align-items:center;gap:9px;border:none;background:transparent;color:var(--muted);text-align:left;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:background .14s,color .14s;position:relative}
.navbtn:hover{background:var(--glass);color:var(--text)}
.navbtn.active{background:rgba(33,118,255,.12);color:#114ca8;font-weight:700}
.navbtn.active::before{content:'';position:absolute;left:0;top:22%;bottom:22%;width:2.5px;border-radius:2px;background:var(--blue)}
.navbtn .cnt{margin-left:auto;font-size:10.5px;color:var(--muted)}
.nav-divider{height:1px;background:var(--border);margin:6px 4px}

/* topbar */
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;padding:9px 22px;background:rgba(247,251,251,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);min-height:50px}
.topbar-title{font-size:14.5px;font-weight:600;color:var(--text);flex:1}
.topbar-actions{display:flex;align-items:center;gap:7px}
.role-badge{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:999px}
.role-admin{background:rgba(164,111,223,.18);color:#d4b0f8;border:1px solid rgba(164,111,223,.3)}
.role-operator{background:rgba(79,142,240,.16);color:#a8d0ff;border:1px solid rgba(79,142,240,.28)}
.role-user{background:rgba(52,201,140,.14);color:#9fedd1;border:1px solid rgba(52,201,140,.24)}

/* content */
.main-content{padding:22px 26px 64px;overflow:auto}
.section{display:none;animation:fadeIn .2s ease}
.section.active{display:block}
@keyframes fadeIn{from{opacity:.35;transform:translateY(5px)}to{opacity:1;transform:none}}

/* hero */
.page-hero{padding:24px 24px;border-radius:var(--radius);margin-bottom:18px;background:linear-gradient(120deg,rgba(255,255,255,.98),rgba(234,246,246,.9));border:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;right:-80px;top:-80px;width:220px;height:220px;background:radial-gradient(circle at center,rgba(29,135,200,.18),transparent 70%)}
.page-hero::after{content:'';position:absolute;left:-90px;bottom:-100px;width:260px;height:260px;background:radial-gradient(circle at center,rgba(15,159,150,.16),transparent 72%)}
.eyebrow{display:flex;align-items:center;gap:7px;margin-bottom:8px}
.dot-accent{width:7px;height:7px;border-radius:50%;background:var(--blue);flex:0 0 7px}
.eyebrow-text{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--blue)}
.page-hero h2{margin:0 0 8px;font-size:26px;font-weight:750;letter-spacing:-.022em;line-height:1.12}
.page-hero p{margin:0;color:var(--soft);font-size:14px;max-width:800px}

/* cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.card:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(20,50,90,.12);border-color:rgba(29,135,200,.26)}
.card.pad{padding:18px 20px}
.card h3{margin:0 0 6px;font-size:16.5px;font-weight:700}
.card h4{margin:0 0 6px;font-size:13px;font-weight:600;color:var(--soft)}
.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.card-header p{margin:5px 0 0;color:var(--muted);font-size:13px;line-height:1.5}

.grid{display:grid;gap:14px}
.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin:14px 0}

/* kpi */
.kpi{padding:15px 18px}
.kpi-val{font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:5px}
.kpi-label{font-size:12px;color:var(--muted);line-height:1.4}

/* tags */
.tagrow{display:flex;gap:5px;flex-wrap:wrap;margin-top:9px}
.tag{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--glass);color:var(--soft);border:1px solid var(--border);white-space:nowrap}
.tag.blue{background:rgba(33,118,255,.12);color:#184d9c;border-color:rgba(33,118,255,.28)}
.tag.indigo{background:rgba(99,88,220,.12);color:#4a3fa4;border-color:rgba(99,88,220,.25)}
.tag.cyan{background:rgba(13,155,176,.12);color:#0a6977;border-color:rgba(13,155,176,.28)}
.tag.green{background:rgba(18,184,134,.12);color:#0d7f5d;border-color:rgba(18,184,134,.28)}
.tag.amber{background:rgba(198,123,26,.12);color:#8b5711;border-color:rgba(198,123,26,.27)}
.tag.rose{background:rgba(209,73,111,.11);color:#8d2f4a;border-color:rgba(209,73,111,.23)}
.tag.violet{background:rgba(122,85,192,.11);color:#573a90;border-color:rgba(122,85,192,.24)}
.tag.clickable{cursor:pointer}
.tag.clickable:hover{opacity:.82;filter:brightness(1.15)}

.badge-status{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:999px;white-space:nowrap}
.badge-ok{background:rgba(52,201,140,.14);color:#a0f0ca;border:1px solid rgba(52,201,140,.22)}
.badge-warn{background:rgba(232,166,61,.14);color:#f5d89a;border:1px solid rgba(232,166,61,.24)}
.badge-crit{background:rgba(224,90,122,.14);color:#f5b4c8;border:1px solid rgba(224,90,122,.25)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--glass);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .14s,border-color .14s}
.btn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);color:var(--text)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn.primary{background:rgba(33,118,255,.16);border-color:rgba(33,118,255,.3);color:#1556b7}
.btn.primary:hover{background:rgba(33,118,255,.24)}
.btn.sm{padding:5px 9px;font-size:12px;border-radius:var(--radius-xs)}
.btn.ghost{background:transparent;border-color:transparent}
.btn.ghost:hover{background:var(--glass)}
.btn.danger{background:rgba(224,90,122,.11);border-color:rgba(224,90,122,.3);color:#f5aabf}
.btn.danger:hover{background:rgba(224,90,122,.2)}
.full-w{width:100%;justify-content:center}

/* inputs */
.filterbar{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.input,.select{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);outline:none;font-size:13.5px}
.input:focus,.select:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(79,142,240,.16)}
.input{flex:1 1 200px;min-width:150px}
.select{max-width:240px}
input::placeholder{color:var(--muted)}

/* accordion */
.accordion{display:grid;gap:7px}
.acc-item{border:1px solid var(--border);border-radius:var(--radius);background:var(--card2);overflow:hidden;box-shadow:0 2px 8px rgba(20,50,90,.06)}
.acc-head{width:100%;border:none;background:none;color:inherit;padding:13px 16px;cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.acc-head strong{display:block;font-size:14px;font-weight:700;margin-bottom:3px;color:var(--text)}
.acc-meta{color:var(--muted);font-size:12px;line-height:1.5}
.acc-chevron{font-size:17px;color:var(--muted);flex:0 0 auto;transition:transform .18s;line-height:1;margin-top:2px}
.acc-item.open .acc-chevron{transform:rotate(90deg);color:var(--blue)}
.acc-body{display:none;padding:0 16px 16px}
.acc-item.open .acc-body{display:block}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.field-block h4{margin:0 0 3px;font-size:11.5px;font-weight:700;color:var(--cyan);text-transform:uppercase;letter-spacing:.06em}
.field-block p{margin:0;color:var(--soft);font-size:13px;line-height:1.62;white-space:pre-wrap;word-break:break-word}

/* tables */
.table-wrap{overflow:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:12.5px}
table.data-table{margin:15px 0;border:1px solid var(--border);border-radius:var(--radius-sm)}
th,td{padding:9px 12px;border-bottom:1px solid var(--border2);text-align:left;vertical-align:top}
th{position:sticky;top:0;background:rgba(243,247,255,.98);color:var(--cyan);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;z-index:1;font-weight:700}
tr:hover td{background:rgba(255,255,255,.025)}
.link-cell{color:var(--blue);cursor:pointer}
.link-cell:hover{text-decoration:underline}

/* evidence */
.ev-card{padding:13px 15px;border:1px solid var(--border);border-radius:var(--radius-sm);background:linear-gradient(180deg,rgba(255,255,255,.75),rgba(237,247,250,.62));margin-bottom:9px}
.ev-title{font-weight:700;font-size:14px;color:var(--text);margin-bottom:3px}
.ev-orig{font-size:11.5px;color:var(--muted);margin-bottom:6px;font-style:italic;cursor:pointer;display:inline-block}
.ev-orig:hover{color:var(--soft)}
.ev-meta{font-size:11.5px;color:var(--muted);margin-bottom:7px}
.ev-snip{font-size:13px;color:var(--soft);line-height:1.65;border-left:2px solid rgba(79,142,240,.38);padding-left:11px;white-space:pre-wrap}
.ev-snip.ko{border-left-color:rgba(164,111,223,.45)}
.ev-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}

/* kill-chain */
.killchain-wrap{overflow-x:auto;padding:10px 0;margin-bottom:18px}
.killchain{display:flex;align-items:center;min-width:max-content;padding:0 4px}
.kc-node{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;transition:transform .16s;padding:0 3px}
.kc-node:hover{transform:translateY(-3px)}
.kc-box{padding:8px 12px;border-radius:10px;font-size:11.5px;font-weight:700;text-align:center;border:1.5px solid transparent;min-width:88px;max-width:120px;position:relative;transition:border-color .16s,box-shadow .16s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kc-box.active{border-color:rgba(255,255,255,.55)!important;box-shadow:0 0 0 3px rgba(255,255,255,.1)}
.kc-num{font-size:10px;font-weight:800;opacity:.65;display:block;margin-bottom:2px}
.kc-label{font-size:11px;display:block;overflow:hidden;text-overflow:ellipsis;max-width:108px}
.kc-arrow{font-size:16px;color:var(--muted);padding:0 3px;flex:0 0 auto;align-self:center;margin-top:-14px}
.kc-count{font-size:10px;color:var(--muted)}

/* incidents */
.wb-chain{width:100%}
.incident-workbench{display:grid;grid-template-columns:1fr;gap:12px;align-items:start}
.incident-col{display:grid;gap:12px;align-content:start;padding-right:2px}
.wb-card{margin:0}
.inc-cards-scroll{max-height:340px;overflow:auto;padding-right:4px}
.incident-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px}
.incident-cards.compact{grid-template-columns:1fr}
.inc-card{cursor:pointer;padding:13px 15px;border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(236,245,249,.8));transition:.18s}
.inc-card:hover{border-color:rgba(29,135,200,.45);background:rgba(29,135,200,.08)}
.inc-card.active{border-color:var(--blue);background:rgba(79,142,240,.1)}
.inc-card h4{margin:0 0 5px;font-size:14.5px;font-weight:700}
.inc-card p{margin:0;color:var(--muted);font-size:12.5px;line-height:1.5}
.path-chips{display:flex;gap:4px;flex-wrap:wrap;margin-top:9px}
.path-chip{padding:3px 7px;border-radius:999px;background:var(--glass);font-size:10px;color:var(--soft);border:1px solid var(--border2)}

.narrative-notes{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.narrative-notes .block p{font-size:12.5px;line-height:1.55}

.attack-lane-grid{display:grid;grid-template-columns:repeat(7,minmax(175px,1fr));gap:8px;align-items:start;overflow:auto;padding-bottom:4px}
.attack-lane{border:1px solid var(--border2);border-radius:12px;background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(235,245,249,.58));padding:8px;min-height:120px;position:relative}
.attack-lane::after{content:'';position:absolute;left:8px;right:8px;bottom:8px;height:3px;border-radius:999px;background:linear-gradient(90deg,rgba(29,135,200,.45),rgba(15,159,150,.45));opacity:.45}
.attack-lane-head{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:800;color:var(--blue);margin-bottom:7px;line-height:1.3}
.attack-lane-num{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:20px;border-radius:999px;background:rgba(33,118,255,.12);border:1px solid rgba(33,118,255,.2);font-size:10px}
.attack-lane-body{display:grid;gap:6px}
.attack-lane-note{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.attack-step-btn{width:100%;display:flex;justify-content:space-between;align-items:flex-start;gap:6px;border:1px solid var(--border);border-radius:10px;padding:6px 7px;background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(233,244,249,.62));cursor:pointer;color:var(--text);text-align:left;transition:all .18s ease}
.attack-step-btn:hover{transform:translateY(-1px);border-color:rgba(29,135,200,.45)}
.attack-step-btn.active{box-shadow:inset 0 0 0 2px rgba(33,118,255,.32)}
.attack-step-title{font-size:12px;line-height:1.25;word-break:break-word}
.attack-step-stats{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.attack-step-ttp{font-size:11px;color:var(--muted);font-weight:700;white-space:nowrap}
.attack-step-pct{display:inline-flex;align-items:center;justify-content:center;min-width:42px;padding:2px 7px;border-radius:999px;border:1px solid rgba(33,118,255,.25);background:rgba(33,118,255,.12);color:#1f57aa;font-size:11px;font-weight:800;white-space:nowrap}

/* product tabs */
.product-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:13px}
.prod-tab{padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;transition:.14s}
.prod-tab:hover{background:var(--glass);color:var(--text)}
.prod-tab.active{background:rgba(79,142,240,.14);border-color:var(--blue);color:#a8d0ff}

.detect-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.detect-card{padding:13px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(236,247,249,.64))}
.detect-card h4{margin:0 0 6px;font-size:13px;font-weight:700;color:var(--text)}
.detect-card p{margin:0 0 7px;color:var(--soft);font-size:12.5px;line-height:1.52}
.feature-list{display:grid;gap:5px;margin-top:7px}
.feat-chip{padding:6px 9px;border-radius:var(--radius-xs);background:rgba(33,118,255,.06);border:1px solid rgba(33,118,255,.16);font-size:11px;color:#3f5d8a;line-height:1.4}
.feat-chip strong{color:#1f58ad;display:block;margin-bottom:2px}

/* progress */
.progress{height:7px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden}
.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--blue) 0%,var(--indigo) 70%);border-radius:999px}

/* heatmap */
.heatmap{display:grid;gap:7px;overflow:auto}
.heat-row{display:grid;grid-template-columns:130px repeat(16,minmax(34px,1fr)) 66px;gap:4px;align-items:center;min-width:940px}
.hm-head{padding:6px 4px;border-radius:var(--radius-xs);text-align:center;font-size:10px;font-weight:700;color:var(--cyan);background:rgba(255,255,255,.03);border:1px solid var(--border2)}
.hm-label{font-weight:700;font-size:11.5px;color:var(--text);padding:3px}
.hm-cell{padding:6px 3px;border-radius:var(--radius-xs);text-align:center;font-size:11px;border:1px solid rgba(255,255,255,.04);font-weight:700;color:#1d3d5f}

/* modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(22,41,76,.35);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;padding:36px 14px;z-index:50;overflow-y:auto}
.modal-backdrop.open{display:flex}
.modal{width:min(800px,96vw);border:1px solid var(--border);border-radius:18px;background:var(--bg2);box-shadow:0 24px 80px rgba(0,0,0,.6)}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--border)}
.modal-head h3{margin:0;font-size:16.5px;font-weight:700}
.modal-body{padding:17px 20px;max-height:70vh;overflow-y:auto}
.modal-foot{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:11px 20px;border-top:1px solid var(--border)}
.modal-x{border:none;background:rgba(255,255,255,.07);color:var(--text);width:28px;height:28px;border-radius:var(--radius-xs);cursor:pointer;font-size:15px;display:grid;place-items:center}
.modal-x:hover{background:rgba(255,255,255,.12)}
.modal-error{color:#f5b4c8;font-size:13px;margin-right:auto}

/* edit fields */
.edit-field{margin-bottom:13px}
.edit-field label{display:block;font-size:11px;font-weight:700;color:var(--cyan);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em}
.edit-field textarea,.edit-field input,.edit-field select{width:100%;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);outline:none;font-size:13.5px;font-family:inherit;resize:vertical}
.edit-field textarea:focus,.edit-field input:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(79,142,240,.14)}
.edit-field .hint{font-size:10.5px;color:var(--muted);margin-top:4px}

/* detail blocks */
.detail-section{margin-top:16px}
.detail-section-title{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:9px;display:flex;align-items:center;gap:7px}
.detail-section-title::after{content:'';flex:1;height:1px;background:var(--border)}
.block{padding:12px 14px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--glass)}
.block h4{margin:0 0 5px;font-size:12px;font-weight:700;color:var(--cyan)}
.block p{margin:0;color:var(--soft);font-size:13.5px;line-height:1.68;white-space:pre-wrap;word-break:break-word}
.block-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.block-span-2{grid-column:1 / -1}

/* cross-links */
.xlink{display:inline-flex;align-items:center;gap:4px;cursor:pointer;padding:2px 7px;border-radius:var(--radius-xs);font-size:11px;font-weight:700;background:rgba(33,118,255,.1);border:1px solid rgba(33,118,255,.22);color:#1c56af}
.xlink:hover{background:rgba(79,142,240,.2);text-decoration:none}

.mini-toggle-list{display:grid;gap:6px}
.mini-toggle{width:100%;display:flex;justify-content:space-between;align-items:flex-start;gap:8px;padding:7px 8px;border:1px solid var(--border);border-radius:8px;background:rgba(255,255,255,.55);color:var(--soft);font-size:12px;cursor:pointer;text-align:left}
.mini-toggle span:last-child{font-weight:700;font-size:11px;white-space:nowrap}
.mini-toggle.on{border-color:rgba(18,184,134,.35);background:rgba(18,184,134,.09);color:#14563f}

/* toast */
.toast{position:fixed;bottom:18px;right:18px;padding:11px 17px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg2);color:var(--text);box-shadow:var(--shadow);z-index:60;opacity:0;transform:translateY(10px);transition:.24s;font-size:13.5px}
.toast.show{opacity:1;transform:none}
.toast.ok-t{border-color:rgba(52,201,140,.4)}
.toast.err-t{border-color:rgba(224,90,122,.4)}

/* login */
.login-page{display:grid;place-items:center;min-height:100vh;padding:20px}
.login-card{width:min(410px,100%);padding:26px;border:1px solid var(--border);border-radius:18px;background:var(--card);box-shadow:var(--shadow)}
.login-brand{margin-bottom:18px}
.login-brand-main{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.field-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:5px}
.field-wrap{margin-bottom:12px}
.form-error{color:#f5aabf;font-size:13px;min-height:17px;margin-top:7px}
.login-footer{margin-top:13px;color:var(--muted);font-size:12px;line-height:1.5}

/* misc */
.empty{padding:26px;text-align:center;color:var(--muted);font-size:14px}
.loader{padding:28px;text-align:center;color:var(--muted)}
.small{font-size:13px}.muted{color:var(--muted)}.nowrap{white-space:nowrap}
.mono{font-family:var(--font-mono)}.edit-badge{font-size:11px;color:var(--muted)}
.item-actions{display:flex;gap:6px;align-items:center;margin-top:12px}
hr{border:none;border-top:1px solid var(--border);margin:14px 0}
.cov-label{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-bottom:4px}

/* responsive */
@media(max-width:1100px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;display:block;padding:10px;overflow-y:visible}
  .sidebar-brand{padding:6px 8px 6px}
  .sidebar-brand-main{align-items:center}
  .nav-section{margin-top:6px;display:flex;flex-wrap:wrap;gap:6px}
  .nav-section-label{width:100%;padding:2px 6px}
  .navbtn{width:auto}
  .main-content{padding:14px}
  .incident-workbench{grid-template-columns:1fr}
  .incident-col{max-height:none;overflow:visible;padding-right:0}
  .inc-cards-scroll{max-height:none}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:1fr 1fr}
  .detect-grid,.cols-2,.incident-cards,.block-grid,.field-grid{grid-template-columns:1fr}
  .narrative-notes{grid-template-columns:1fr}
  .attack-lane-grid{grid-template-columns:repeat(3,minmax(175px,1fr))}
  .page-hero h2{font-size:21px}
}
@media(max-width:640px){
  .kpi-grid,.cols-3{grid-template-columns:1fr}
  .attack-lane-grid{grid-template-columns:repeat(2,minmax(165px,1fr))}
  .main-content{padding:10px}
  .topbar{padding:7px 12px}
}
