/* ============================================================
   CrisisShieldAI — Dashboard layout
   ============================================================ */
.dash-body{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* Sidebar */
.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:1.4rem 1rem;background:rgba(8,11,20,.72);backdrop-filter:blur(18px);border-right:1px solid var(--stroke);z-index:50;transition:transform .35s var(--ease)}
.side-brand{padding:.3rem .5rem 1.4rem;font-size:1.1rem}
.side-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}
.side-link{display:flex;align-items:center;gap:.75rem;padding:.7rem .8rem;border-radius:11px;color:var(--txt-dim);font-weight:550;font-size:.92rem;cursor:pointer;transition:.2s}
.side-link svg{opacity:.85;flex:0 0 18px}
.side-link:hover{background:rgba(255,255,255,.05);color:var(--txt)}
.side-link.active{background:linear-gradient(100deg,rgba(47,125,255,.22),rgba(123,92,255,.16));color:#fff;border:1px solid var(--stroke-strong)}
.side-link.active svg{opacity:1}
.side-foot{border-top:1px solid var(--stroke);padding-top:1rem;margin-top:1rem}
.side-user{display:flex;align-items:center;gap:.65rem}
.side-user b{display:block;font-size:.88rem}
.side-user span{font-size:.76rem;color:var(--txt-mute)}
.avatar{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:var(--grad-2);font-weight:700;font-size:.82rem;color:#fff;flex:0 0 36px}

/* Main */
.dash-main{display:flex;flex-direction:column;min-width:0}
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:1rem;padding:.9rem 1.6rem;background:rgba(6,9,16,.8);backdrop-filter:blur(16px);border-bottom:1px solid var(--stroke)}
.side-toggle{display:none;background:none;border:0;color:var(--txt);cursor:pointer}
.search{display:flex;align-items:center;gap:.55rem;flex:1;max-width:420px;padding:.55rem .9rem;border-radius:11px;background:rgba(255,255,255,.04);border:1px solid var(--stroke);color:var(--txt-mute)}
.search input{flex:1;background:none;border:0;color:var(--txt);font-family:inherit;font-size:.9rem;outline:none}
.search input::placeholder{color:var(--txt-mute)}
.top-right{margin-left:auto;display:flex;align-items:center;gap:1rem}
.live-pill{display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--txt-dim);padding:.4rem .75rem;border-radius:99px;border:1px solid var(--stroke);background:rgba(61,220,135,.05)}
.live-pill b{font-family:'JetBrains Mono',monospace;color:var(--txt)}
.icon-btn{position:relative;background:none;border:0;color:var(--txt-dim);cursor:pointer;padding:.3rem;transition:.2s}
.icon-btn:hover{color:var(--txt)}
.icon-btn .badge{position:absolute;top:-3px;right:-4px;font-size:.62rem;font-weight:700;font-style:normal;background:var(--red);color:#fff;border-radius:99px;padding:.05rem .3rem}
.demo-pill{font-size:.66rem;font-weight:700;letter-spacing:.12em;color:var(--amber);background:rgba(255,184,77,.12);border:1px solid rgba(255,184,77,.35);padding:.32rem .55rem;border-radius:6px;font-family:'JetBrains Mono',monospace}

.dash-content{padding:1.8rem 1.6rem 3rem}
.sample-banner{display:flex;align-items:center;gap:.7rem;margin-bottom:1.4rem;padding:.75rem 1.05rem;border-radius:12px;font-size:.86rem;line-height:1.4;color:var(--txt-dim);background:linear-gradient(100deg,rgba(255,184,77,.1),rgba(255,184,77,.04));border:1px solid rgba(255,184,77,.28)}
.sample-banner svg{color:var(--amber);flex-shrink:0}
.sample-banner b{color:var(--txt)}
@media (max-width:540px){.demo-pill{display:none}}
.view{display:none;animation:fadeUp .5s var(--ease)}
.view.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.view-head{margin-bottom:1.5rem}
.view-head h1{font-size:1.7rem;font-weight:800;letter-spacing:-.02em}
.view-head p{color:var(--txt-dim);font-size:.95rem;margin-top:.2rem}

/* KPI row */
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:1.2rem}
.kpi-card{display:flex;align-items:center;gap:.9rem;padding:1.1rem 1.2rem}
.kpi-ico{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;font-size:1.25rem;background:rgba(255,255,255,.05)}
.ic-blue{background:rgba(77,163,255,.14)}.ic-amber{background:rgba(255,184,77,.14)}
.ic-red{background:rgba(255,94,108,.14)}.ic-violet{background:rgba(123,92,255,.14)}
.kpi-card span{font-size:.76rem;color:var(--txt-mute);text-transform:uppercase;letter-spacing:.05em}
.kpi-card b{font-size:1.7rem;font-weight:800;letter-spacing:-.02em}
.kpi-card.risk .gauge{width:44px;height:44px;border-radius:50%;background:conic-gradient(var(--amber) 0deg,var(--amber) 0deg,rgba(255,255,255,.08) 0deg);position:relative;display:grid;place-items:center;transition:background 1.2s var(--ease)}
.kpi-card.risk .gauge::after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--panel-solid)}

/* Cards / grid */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.2rem}
.card{padding:1.3rem}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.card-h h3{font-size:1.02rem;font-weight:700}
.card-link{font-size:.82rem;color:var(--blue);font-weight:600;cursor:pointer}
.legend{display:flex;align-items:center;gap:.5rem;font-size:.76rem;color:var(--txt-dim)}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin:0 .2rem 0 .6rem}
.lc-blue{background:var(--blue)}.lc-violet{background:var(--violet)}
canvas{max-width:100%}

/* Donut */
.donut-wrap{display:flex;align-items:center;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.donut-legend{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.donut-legend li{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--txt-dim)}
.donut-legend i{width:11px;height:11px;border-radius:3px}
.donut-legend b{margin-left:auto;color:var(--txt);font-family:'JetBrains Mono',monospace;padding-left:.8rem}

/* Feed list */
.feed-list{display:flex;flex-direction:column;gap:.6rem}
.fl-item{display:flex;align-items:flex-start;gap:.8rem;padding:.75rem .85rem;border-radius:11px;background:rgba(255,255,255,.03);border:1px solid var(--stroke);transition:.2s}
.fl-item:hover{border-color:var(--stroke-strong);background:rgba(255,255,255,.05)}
.sev-chip{font-size:.66rem;font-weight:700;padding:.2rem .5rem;border-radius:6px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex:0 0 auto;margin-top:.1rem}
.sev-crit{color:var(--red);background:rgba(255,94,108,.14)}
.sev-high{color:var(--amber);background:rgba(255,184,77,.14)}
.sev-med{color:var(--blue);background:rgba(77,163,255,.14)}
.sev-low{color:var(--green);background:rgba(61,220,135,.14)}
.fl-body{flex:1;min-width:0}
.fl-body b{font-size:.9rem;font-weight:650}
.fl-body p{font-size:.8rem;color:var(--txt-dim);margin-top:.1rem}
.fl-meta{font-size:.72rem;color:var(--txt-mute);font-family:'JetBrains Mono',monospace;margin-top:.3rem;display:flex;gap:.8rem;flex-wrap:wrap}
.fl-meta .mitre{color:var(--violet)}

/* Threat grid */
.threat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}
.threat-card{padding:1.2rem}
.tc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}
.tc-top h3{font-size:1.02rem;font-weight:700}
.threat-card p{font-size:.85rem;color:var(--txt-dim);margin:.4rem 0 .8rem}
.tc-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.tc-tags span{font-size:.72rem;padding:.25rem .55rem;border-radius:7px;background:rgba(255,255,255,.04);border:1px solid var(--stroke);color:var(--txt-dim);font-family:'JetBrains Mono',monospace}
.tc-tags .mitre{color:var(--violet);border-color:rgba(123,92,255,.3)}

/* Tables */
.table-card{padding:0;overflow:hidden}
.data-table{width:100%;border-collapse:collapse;font-size:.88rem}
.data-table thead th{text-align:left;padding:.95rem 1.2rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--txt-mute);border-bottom:1px solid var(--stroke);background:rgba(255,255,255,.02)}
.data-table tbody td{padding:.85rem 1.2rem;border-bottom:1px solid var(--stroke);color:var(--txt-dim)}
.data-table tbody tr{transition:.18s}
.data-table tbody tr:hover{background:rgba(255,255,255,.03)}
.data-table tbody tr:last-child td{border-bottom:0}
.mono{font-family:'JetBrains Mono',monospace;color:var(--txt)}
.cvss{font-family:'JetBrains Mono',monospace;font-weight:700;padding:.15rem .5rem;border-radius:6px}
.cvss.c-crit{color:var(--red);background:rgba(255,94,108,.14)}
.cvss.c-high{color:var(--amber);background:rgba(255,184,77,.14)}
.cvss.c-med{color:var(--blue);background:rgba(77,163,255,.14)}
.patch-yes{color:var(--green);font-weight:600}
.patch-no{color:var(--red);font-weight:600}
.pill-status{font-size:.74rem;font-weight:600;padding:.2rem .55rem;border-radius:7px}
.st-ok{color:var(--green);background:rgba(61,220,135,.12)}
.st-warn{color:var(--amber);background:rgba(255,184,77,.12)}
.st-risk{color:var(--red);background:rgba(255,94,108,.12)}

/* Asset tabs */
.asset-tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.atab{padding:.5rem .9rem;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid var(--stroke);color:var(--txt-dim);font-weight:600;font-size:.85rem;cursor:pointer;transition:.2s}
.atab b{color:var(--txt);margin-left:.3rem;font-family:'JetBrains Mono',monospace}
.atab:hover{border-color:var(--stroke-strong)}
.atab.active{background:linear-gradient(100deg,rgba(47,125,255,.2),rgba(123,92,255,.16));color:#fff;border-color:var(--stroke-strong)}

/* Incidents */
.incident-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1rem}
.incident-card{padding:1.3rem;border-left:3px solid var(--red)}
.incident-card.sev-high-b{border-left-color:var(--amber)}
.incident-card.sev-med-b{border-left-color:var(--blue)}
.ic-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}
.ic-type{font-size:1.1rem;font-weight:750}
.incident-card .impact{font-size:.85rem;color:var(--txt-dim);margin:.5rem 0}
.ic-actions{margin-top:.9rem}
.ic-actions h4{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-mute);margin-bottom:.5rem}
.ic-actions ul{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.ic-actions li{position:relative;padding-left:1.4rem;font-size:.84rem;color:var(--txt-dim)}
.ic-actions li::before{content:"→";position:absolute;left:0;color:var(--blue);font-weight:700}
.ic-foot{display:flex;gap:.5rem;margin-top:1rem}

/* Chat */
.chat-card{display:flex;flex-direction:column;height:min(64vh,620px);padding:0;overflow:hidden}
.chat-log{flex:1;overflow-y:auto;padding:1.3rem;display:flex;flex-direction:column;gap:1rem}
.msg-row{display:flex;gap:.7rem;max-width:88%}
.msg-row.user{align-self:flex-end;flex-direction:row-reverse}
.msg-ava{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-size:.9rem;flex:0 0 32px}
.msg-ava.ai{background:var(--grad-2)}
.msg-ava.me{background:rgba(255,255,255,.08)}
.bubble{padding:.8rem 1rem;border-radius:14px;font-size:.9rem;line-height:1.6}
.msg-row.ai .bubble{background:rgba(255,255,255,.04);border:1px solid var(--stroke);border-top-left-radius:4px}
.msg-row.user .bubble{background:linear-gradient(120deg,rgba(47,125,255,.28),rgba(123,92,255,.24));border-top-right-radius:4px}
.bubble h5{font-size:.82rem;color:var(--blue);margin:.6rem 0 .2rem;text-transform:uppercase;letter-spacing:.05em}
.bubble h5:first-child{margin-top:0}
.bubble p{margin:0}
.typing{display:inline-flex;gap:4px;padding:.3rem 0}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--txt-mute);animation:blink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}
.chat-suggest{display:flex;gap:.5rem;padding:0 1.3rem .8rem;flex-wrap:wrap}
.chat-suggest button{font-size:.8rem;padding:.45rem .75rem;border-radius:9px;background:rgba(255,255,255,.04);border:1px solid var(--stroke);color:var(--txt-dim);cursor:pointer;transition:.2s}
.chat-suggest button:hover{border-color:var(--blue);color:var(--txt)}
.chat-input{display:flex;gap:.6rem;padding:1rem 1.3rem;border-top:1px solid var(--stroke)}
.chat-input input{flex:1;padding:.75rem 1rem;border-radius:11px;background:rgba(255,255,255,.04);border:1px solid var(--stroke);color:var(--txt);font-family:inherit;font-size:.92rem;outline:none}
.chat-input input:focus{border-color:var(--blue)}

/* Reports */
.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1rem}
.report-card{padding:1.5rem}
.rc-ico{font-size:1.8rem}
.report-card h3{font-size:1.15rem;font-weight:750;margin:.6rem 0 .3rem}
.report-card p{font-size:.88rem;color:var(--txt-dim);margin-bottom:1.1rem}
.rc-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.report-toast{position:fixed;bottom:1.5rem;right:1.5rem;padding:.9rem 1.2rem;border-radius:12px;background:var(--panel-solid);border:1px solid var(--stroke-strong);font-size:.88rem;box-shadow:var(--shadow);opacity:0;transform:translateY(20px);transition:.4s var(--ease);pointer-events:none;z-index:80}
.report-toast.show{opacity:1;transform:none}

/* Responsive */
@media (max-width:1100px){.kpi-row{grid-template-columns:repeat(3,1fr)}}
@media (max-width:880px){
  .dash-body{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;left:0;width:248px;transform:translateX(-100%)}
  .sidebar.open{transform:none;box-shadow:var(--shadow)}
  .side-toggle{display:block}
  .grid-2{grid-template-columns:1fr}
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  .search{max-width:none}
}
@media (max-width:540px){.kpi-row{grid-template-columns:1fr}.live-pill{display:none}}
