:root{
  --bg:#0f1115; --card:#1a1d24; --fg:#e6e8ec; --muted:#8a8f99; --line:#2a2f3a;
  --accent:#6ee7b7; --bad:#ef4444; --warn:#f59e0b;
  --indigo:#8b9efb; --red:#f87171; --yellow:#facc15; --blue:#60a5fa; --green:#34d399; --purple:#c084fc;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:14px;line-height:1.5}
a{color:inherit;text-decoration:none}
a:hover{opacity:.8}
code{font-family:'SF Mono','Monaco','Consolas',monospace;background:#222;padding:1px 4px;border-radius:3px;font-size:12px}
pre{background:#111;padding:12px;border-radius:6px;overflow:auto;font-size:12px;max-height:500px}

/* Sidebar (desktop fixed, mobile drawer) */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:220px;background:#0a0c10;border-right:1px solid var(--line);display:flex;flex-direction:column;z-index:20;transition:transform .25s}
.sidebar-logo{padding:20px 18px 14px;border-bottom:1px solid var(--line)}
.sidebar-logo a{font-weight:700;font-size:16px;color:var(--fg)}
.sidebar-sub{color:var(--muted);font-size:11px;margin-top:2px}
.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;font-size:14px;border-left:3px solid transparent;transition:.12s}
.nav-item:hover{background:#141720;border-left-color:var(--muted)}
.nav-item.active{background:#141720;border-left-color:currentColor;font-weight:600}
.nav-icon{font-size:18px;width:22px;text-align:center;line-height:1}
.sidebar-user{padding:14px 18px;border-top:1px solid var(--line)}
.logout-link{display:inline-block;margin-top:4px;font-size:12px;color:var(--muted)}
.logout-link:hover{color:var(--fg)}
.burger{display:none;position:fixed;top:12px;left:12px;z-index:30;background:var(--card);color:var(--fg);border:1px solid var(--line);border-radius:8px;width:40px;height:40px;font-size:20px;cursor:pointer}
.backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:15}
.backdrop.show{display:block}

.main-content{margin-left:220px;min-height:100vh;display:flex;flex-direction:column}
.main-content > *:not(footer){max-width:1200px;width:100%;margin-left:auto;margin-right:auto;padding:0 24px;box-sizing:border-box}
.main-content > :first-child{margin-top:24px}
.main-content footer{margin-top:auto;padding:20px 24px}

@media (max-width:900px){
  .sidebar{transform:translateX(-100%);width:260px}
  .sidebar.open{transform:translateX(0)}
  .burger{display:block}
  .main-content{margin-left:0}
  .main-content > :first-child{margin-top:64px}
  .main-content > *:not(footer){padding:0 14px}
  .hero{grid-template-columns:repeat(2,1fr)}
  .tiles{grid-template-columns:1fr}
  .ssl-row{grid-template-columns:100px 1fr 44px;font-size:12px}
  .section{padding:14px 16px}
}
.section{background:var(--card);padding:18px 22px;border-radius:10px;margin-bottom:18px;border:1px solid var(--line)}
.section h2{margin:0 0 14px 0;font-size:16px;font-weight:600}

.grid{display:grid;gap:14px}
.cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.two-col{grid-template-columns:1fr 1fr}
@media (max-width:700px){.two-col{grid-template-columns:1fr}}

.card{display:block;padding:14px 16px;background:#141720;border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:.15s}
.card:hover{border-color:var(--accent);transform:translateY(-1px)}
.card.bad{border-color:var(--bad)}
.card.ok{}
.card-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.card-head h3{margin:0;font-size:15px}
.card .role{color:var(--muted);font-size:12px;margin:2px 0 10px}
.card .meta{margin:0;padding:0;list-style:none;font-size:12px;color:var(--muted)}
.card .meta li{padding:2px 0}

.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot-ok{background:var(--accent);box-shadow:0 0 6px var(--accent)}
.dot-bad{background:var(--bad);box-shadow:0 0 6px var(--bad)}

.color-indigo{color:var(--indigo)} .color-red{color:var(--red)} .color-yellow{color:var(--yellow)}
.color-blue{color:var(--blue)} .color-green{color:var(--green)} .color-purple{color:var(--purple)}

.table{width:100%;border-collapse:collapse;font-size:13px}
.table th,.table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--line)}
.table th{color:var(--muted);font-weight:500;font-size:12px}
.table tr.critical{color:var(--bad)}
.table tr.warning{color:var(--warn)}

.stub{padding:20px;background:#0b0d12;border:1px dashed var(--line);border-radius:6px;color:var(--muted);text-align:center;font-size:13px}
.handoff{white-space:pre-wrap;word-wrap:break-word}
.muted{color:var(--muted)}
.hint{color:var(--muted);font-size:12px;margin-top:18px}
.mono{font-family:'SF Mono',monospace;font-size:12px}

footer{text-align:center;color:var(--muted);font-size:12px;padding:20px;border-top:1px solid var(--line);margin-top:30px}
footer a{color:var(--muted);margin:0 4px}

/* Hero tiles — big-number KPI row */
.hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}
.hero-tile{padding:18px 20px;border-radius:12px;border:1px solid var(--line);background:linear-gradient(135deg,#181b24 0%,#12151c 100%);position:relative;overflow:hidden}
.hero-tile::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--muted)}
.hero-tile.tile-ok::before{background:var(--accent)}
.hero-tile.tile-warn::before{background:var(--warn)}
.hero-tile.tile-bad::before{background:var(--bad)}
.hero-num{font-size:34px;font-weight:700;line-height:1.1;letter-spacing:-1px}
.hero-den{font-size:18px;color:var(--muted);font-weight:500;margin-left:2px}
.hero-label{font-size:12px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}

/* Agent tiles — compact, icon-led */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.tile{display:flex;align-items:center;gap:12px;padding:14px;background:#141720;border:1px solid var(--line);border-radius:10px;transition:.15s;cursor:pointer}
.tile:hover{border-color:currentColor;transform:translateY(-2px)}
.tile.tile-alert{border-color:var(--bad)}
.tile-icon{font-size:32px;line-height:1;flex-shrink:0}
.tile-body{min-width:0;flex:1}
.tile-title{font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px;color:var(--fg)}
.tile-sub{font-size:11px;color:var(--muted);margin:2px 0 6px}
.tile-stats{display:flex;gap:10px;font-size:11px;color:var(--muted)}
.tile-stats span{white-space:nowrap}

/* SSL horizontal bars */
.ssl-bars{display:flex;flex-direction:column;gap:8px}
.ssl-row{display:grid;grid-template-columns:160px 1fr 56px;align-items:center;gap:12px;font-size:13px}
.ssl-domain{color:var(--fg);font-family:'SF Mono',monospace;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ssl-bar-wrap{height:8px;background:#0b0d12;border-radius:4px;overflow:hidden;border:1px solid var(--line)}
.ssl-bar{height:100%;transition:width .3s;border-radius:4px}
.ssl-ok .ssl-bar{background:linear-gradient(90deg,var(--green),var(--accent))}
.ssl-warn .ssl-bar{background:linear-gradient(90deg,var(--warn),var(--yellow))}
.ssl-bad .ssl-bar{background:linear-gradient(90deg,var(--bad),var(--red))}
.ssl-days{text-align:right;font-weight:600;font-family:'SF Mono',monospace;font-size:12px}
.ssl-ok .ssl-days{color:var(--accent)}
.ssl-warn .ssl-days{color:var(--warn)}
.ssl-bad .ssl-days{color:var(--bad)}

/* Big stat tiles (backup, cron) */
.big-stat{padding:12px 0;margin-bottom:8px}
.big-stat .big-num{font-size:38px;font-weight:700;letter-spacing:-1px;line-height:1}
.big-stat .big-num small{font-size:18px;color:var(--muted);font-weight:500;margin-left:2px}
.big-stat .big-sub{display:block;font-size:11px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}
.stat-ok .big-num{color:var(--accent)}
.stat-bad .big-num{color:var(--bad)}

/* KGB badges */
.kgb-badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.badge{padding:14px 16px;border-radius:8px;background:#141720;border:1px solid var(--line);border-left:3px solid var(--muted)}
.badge b{display:block;font-size:13px;margin-bottom:4px}
.badge span{display:block;font-size:13px;color:var(--fg)}
.badge small{display:block;font-size:11px;color:var(--muted);margin-top:4px;font-family:'SF Mono',monospace}
.badge-ok{border-left-color:var(--accent)}
.badge-warn{border-left-color:var(--warn)}
.badge-muted{border-left-color:var(--muted);opacity:.7}

.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{max-width:420px;padding:40px;background:var(--card);border-radius:12px;border:1px solid var(--line);text-align:center}
.login-card h1{margin:0 0 4px;font-size:28px}
.login-card .subtitle{color:var(--muted);margin:0 0 24px}
.login-card .hint{font-size:12px;margin-top:20px}
.btn-primary{background:linear-gradient(135deg,#229ED9 0%,#1a7cb8 100%);color:#fff;border:none;padding:14px 28px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:.15s;width:100%}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(34,158,217,.3)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

.back-link{color:var(--accent);font-size:13px;padding:4px 10px;border:1px solid var(--line);border-radius:6px;background:#141720;white-space:nowrap}
.back-link:hover{border-color:var(--accent)}
.file-links li{padding:3px 0}
.file-links a{color:var(--accent);border-bottom:1px dotted var(--accent)}
.file-links a:hover{opacity:.8}

.file-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.file-path{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.view-toggle{display:flex;gap:4px;background:#0b0d12;border-radius:6px;padding:3px;border:1px solid var(--line)}
.toggle-btn{background:none;border:none;color:var(--muted);padding:5px 10px;font-size:12px;cursor:pointer;border-radius:4px;transition:.12s}
.toggle-btn.active{background:var(--card);color:var(--fg)}
.toggle-btn:hover:not(.active){color:var(--fg)}

/* Markdown body */
.markdown-body{font-size:14px;line-height:1.6;color:var(--fg)}
.markdown-body h1{font-size:22px;margin:24px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.markdown-body h2{font-size:18px;margin:22px 0 10px;color:var(--accent)}
.markdown-body h3{font-size:16px;margin:18px 0 8px}
.markdown-body h4{font-size:14px;margin:14px 0 6px;color:var(--muted)}
.markdown-body p{margin:8px 0}
.markdown-body ul,.markdown-body ol{margin:8px 0;padding-left:24px}
.markdown-body li{margin:3px 0}
.markdown-body code{background:#0b0d12;border:1px solid var(--line);padding:1px 5px;border-radius:3px;font-size:12.5px;color:var(--indigo)}
.markdown-body pre{background:#0b0d12;border:1px solid var(--line);padding:14px;border-radius:6px;overflow-x:auto;margin:10px 0}
.markdown-body pre code{background:none;border:none;padding:0;color:var(--fg)}
.markdown-body blockquote{border-left:3px solid var(--muted);padding:4px 0 4px 14px;margin:10px 0;color:var(--muted)}
.markdown-body a{color:var(--accent);border-bottom:1px dotted var(--accent)}
.markdown-body strong{color:var(--fg);font-weight:600}
.markdown-body em{color:var(--indigo)}
.markdown-body hr{border:none;border-top:1px solid var(--line);margin:20px 0}
.markdown-body table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}
.markdown-body th,.markdown-body td{padding:8px 12px;border:1px solid var(--line);text-align:left}
.markdown-body th{background:#0b0d12;font-weight:600}
.markdown-body input[type=checkbox]{margin-right:6px}

/* Chat */
.chat-section{display:flex;flex-direction:column;min-height:70vh}
.chat-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.chat-icon{font-size:32px;line-height:1}
.chat-status{margin-left:auto;font-size:12px;color:var(--muted);padding:4px 10px;background:#0b0d12;border-radius:6px;border:1px solid var(--line)}
.chat-log{flex:1;overflow-y:auto;min-height:360px;max-height:60vh;padding:8px 4px;display:flex;flex-direction:column;gap:10px;background:#0b0d12;border-radius:8px;border:1px solid var(--line);padding:14px}
.msg{max-width:80%;padding:10px 14px;border-radius:10px;font-size:13.5px;line-height:1.45}
.msg-out{align-self:flex-end;background:linear-gradient(135deg,#1f3a5f,#173052);border:1px solid #2a4e80}
.msg-in{align-self:flex-start;background:#141720;border:1px solid var(--line)}
.msg-meta{display:flex;gap:10px;font-size:11px;color:var(--muted);margin-bottom:4px;justify-content:space-between}
.msg-text{white-space:pre-wrap;word-wrap:break-word}
.msg-pending{align-self:flex-end;max-width:80%;padding:8px 12px;border-radius:10px;font-size:12px;color:var(--muted);background:rgba(31,58,95,.25);border:1px dashed #2a4e80;display:flex;align-items:center;gap:8px}
.msg-pending .dot{width:8px;height:8px;border-radius:50%;background:#5ba4ff;animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(.9)}50%{opacity:1;transform:scale(1.15)}}
.msg-failed{opacity:.7;background:linear-gradient(135deg,#5f1f1f,#521717);border-color:#803a2a}
.badge-err{color:#ff7a7a;font-weight:600}

/* --- STRIKE widget --- */
.badge-fresh{font-size:11px;padding:3px 10px;background:rgba(87,219,118,.14);color:#7ed991;border:1px solid rgba(87,219,118,.35);border-radius:999px;font-weight:500}
.badge-stale{font-size:11px;padding:3px 10px;background:rgba(255,193,70,.14);color:#ffc146;border:1px solid rgba(255,193,70,.35);border-radius:999px;font-weight:500}
.alert-banner{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:linear-gradient(135deg,rgba(220,38,38,.18),rgba(185,28,28,.12));border:1px solid rgba(239,68,68,.5);border-left:4px solid #ef4444;border-radius:8px;margin:14px 0;font-size:14px;line-height:1.5}
.alert-banner .alert-icon{font-size:20px;line-height:1}
.client-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:16px 0}
.client-card{padding:14px;background:#0b0d12;border:1px solid var(--line);border-radius:10px;border-left:4px solid var(--line);transition:transform .15s}
.client-card:hover{transform:translateY(-2px)}
.client-red{border-left-color:#ef4444;background:linear-gradient(135deg,rgba(220,38,38,.08),#0b0d12 60%)}
.client-yellow{border-left-color:#facc15;background:linear-gradient(135deg,rgba(234,179,8,.08),#0b0d12 60%)}
.client-green{border-left-color:#22c55e;background:linear-gradient(135deg,rgba(34,197,94,.08),#0b0d12 60%)}
.client-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:4px}
.client-name{font-weight:600;font-size:15px}
.cpa-val{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;color:#e5e7eb}
.client-red .cpa-val{color:#ff7a7a}
.client-yellow .cpa-val{color:#ffc146}
.client-green .cpa-val{color:#7ed991}
.client-goal{font-size:11px;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.3px}
.client-status{font-size:12.5px;line-height:1.45}
.actions-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:18px}
.actions-block{padding:12px 14px;background:#0b0d12;border-radius:8px;border:1px solid var(--line)}
.actions-block h4{margin:0 0 8px;font-size:13px;font-weight:600}
.actions-block ul{margin:0;padding-left:20px}
.actions-block li{font-size:12.5px;line-height:1.5;margin-bottom:6px}
.actions-red{border-left:3px solid #ef4444}
.actions-yellow{border-left:3px solid #facc15}
.actions-green{border-left:3px solid #22c55e}
@media (max-width:900px){
  .client-grid{grid-template-columns:1fr}
  .actions-wrap{grid-template-columns:1fr}
}
.chat-form{display:flex;gap:10px;margin-top:14px;align-items:stretch}
.chat-form textarea{flex:1;background:#0b0d12;color:var(--fg);border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px;resize:vertical;min-height:46px}
.chat-form textarea:focus{outline:none;border-color:var(--accent)}
.chat-form .btn-primary{width:auto;padding:10px 20px;align-self:stretch}
@media (max-width:900px){
  .chat-form{flex-direction:column}
  .chat-form .btn-primary{width:100%}
  .msg{max-width:92%}
}

/* KORT widget — VPS/docker */
.vps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin-top:10px}
.vps-card{padding:12px 14px;background:#0b0d12;border:1px solid var(--line);border-left:4px solid var(--line);border-radius:10px}
.vps-up{border-left-color:#22c55e;background:linear-gradient(135deg,rgba(34,197,94,.06),#0b0d12 60%)}
.vps-down{border-left-color:#ef4444;background:linear-gradient(135deg,rgba(220,38,38,.10),#0b0d12 60%)}
.vps-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.vps-name{font-weight:700;font-size:14px;letter-spacing:.3px}
.vps-lat{margin-left:auto;font-size:11px;color:var(--muted)}
.vps-ip{font-size:12px;color:var(--muted);margin-bottom:4px}
.vps-role{font-size:12px;color:#c3ccd6}
.vps-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-green{background:#22c55e;box-shadow:0 0 6px rgba(34,197,94,.6);animation:pulse 2.2s ease-in-out infinite}
.dot-red{background:#ef4444;box-shadow:0 0 6px rgba(239,68,68,.6)}
.docker-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;margin-top:8px}
.docker-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#0b0d12;border:1px solid var(--line);border-radius:8px;font-size:13px}
.dk-up{border-left:3px solid #22c55e}
.dk-down{border-left:3px solid #ef4444;background:linear-gradient(135deg,rgba(220,38,38,.08),#0b0d12 60%)}
.docker-item .muted{margin-left:auto;font-size:11px}
@media (max-width:900px){.vps-grid,.docker-grid{grid-template-columns:1fr}}

/* KEKS widget — контент-конвейер */
.kx-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;margin-top:10px}
.kx-card{padding:14px;background:#0b0d12;border:1px solid var(--line);border-radius:10px;border-left:4px solid #d85d8a}
.kx-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.kx-value{font-size:18px;font-weight:700;color:#f2c6d7;margin-bottom:4px}
.kx-value.muted{color:var(--muted);font-weight:400}
.kx-sub{font-size:12px;color:#a0aab4}
.schedule-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.schedule-pill{padding:8px 14px;background:#0b0d12;border:1px solid var(--line);border-radius:999px;font-size:13px;color:#c3ccd6}
.schedule-pill.sp-active{background:linear-gradient(135deg,rgba(216,93,138,.16),#0b0d12 80%);border-color:#d85d8a;color:#f2c6d7;font-weight:600}
.todo-list{margin-top:6px;padding-left:22px}
.todo-list li{margin:4px 0;font-size:13px;color:#c3ccd6}
.todo-done li{color:var(--muted);text-decoration:line-through}
@media (max-width:900px){.kx-grid{grid-template-columns:1fr}}

/* VITAL widget — стройка */
.vital-theme{padding:10px 14px;background:linear-gradient(135deg,rgba(234,158,73,.12),#0b0d12 70%);border-left:4px solid #ea9e49;border-radius:8px;font-size:14px;margin-top:6px;color:#e8d5b8}
.fin-bar-wrap{margin-top:8px;margin-bottom:14px}
.fin-bar{position:relative;background:#0b0d12;border:1px solid var(--line);border-radius:999px;height:30px;overflow:hidden}
.fin-bar-fill{position:absolute;inset:0;width:0;background:linear-gradient(90deg,#ea9e49,#c77d2b);border-radius:999px;transition:width .4s ease}
.fin-bar-label{position:relative;z-index:1;text-align:center;line-height:30px;font-size:13px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6)}
.fin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:6px}
.fin-card{padding:14px;background:#0b0d12;border:1px solid var(--line);border-radius:10px;border-left:4px solid var(--line)}
.fin-green{border-left-color:#22c55e;background:linear-gradient(135deg,rgba(34,197,94,.07),#0b0d12 60%)}
.fin-yellow{border-left-color:#facc15;background:linear-gradient(135deg,rgba(234,204,21,.08),#0b0d12 60%)}
.fin-red{border-left-color:#ef4444;background:linear-gradient(135deg,rgba(220,38,38,.09),#0b0d12 60%)}
.stage-grid{display:flex;flex-direction:column;gap:4px;margin-top:8px}
.stage-row{display:grid;grid-template-columns:32px 1fr auto 140px;gap:10px;align-items:center;padding:8px 12px;background:#0b0d12;border:1px solid var(--line);border-radius:8px;font-size:13px}
.stage-done{border-left:3px solid #22c55e}
.stage-pending{border-left:3px solid #facc15;opacity:.9}
.stage-num{font-weight:700;color:var(--muted);text-align:center}
.stage-name{color:#e8e8e8}
.stage-status{font-size:12px;color:#c3ccd6;white-space:nowrap}
.stage-left{font-size:12px;font-family:ui-monospace,monospace;color:#ea9e49;text-align:right}
.stage-left .muted{color:var(--muted)}
.stage-paid-past{color:#6b7280;text-decoration:line-through;text-decoration-color:#4a4f5a;text-decoration-thickness:1.5px;font-size:11px}

/* Keks sentiment */
.sent-summary{display:grid;grid-template-columns:160px 1fr;gap:16px;margin-top:8px;padding:12px;background:rgba(15,15,20,.5);border:1px solid var(--line);border-radius:8px}
.sent-summary-total{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:10px;background:rgba(34,197,94,.07);border:1px solid rgba(34,197,94,.25);border-radius:8px}
.sent-big{font-size:34px;font-weight:700;color:#4ade80;line-height:1}
.sent-big-label{font-size:12px;color:#c3ccd6}
.sent-small-label{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace;margin-top:4px;text-align:center}
.sent-channels{display:flex;flex-direction:column;gap:10px}
.sent-ch-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.sent-ch-name{font-size:13px;color:#e8e8e8;font-weight:500}
.sent-ch-count{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace}
.sent-bar{display:flex;height:10px;border-radius:4px;overflow:hidden;background:rgba(15,15,20,.8);border:1px solid var(--line)}
.sent-bar-pos{background:#22c55e}
.sent-bar-neu{background:#6b7280}
.sent-bar-neg{background:#ef4444}
.sent-ch-nums{display:flex;gap:10px;margin-top:4px;font-size:11px;font-family:ui-monospace,monospace}
.sent-ch-nums .pos{color:#22c55e}
.sent-ch-nums .neu{color:#9ca3af}
.sent-ch-nums .neg{color:#ef4444}
.sent-ch-nums.muted{color:var(--muted)}
.sent-chart{display:flex;gap:3px;align-items:flex-end;margin-top:12px;padding:8px;background:rgba(15,15,20,.4);border:1px solid var(--line);border-radius:6px;height:62px}
.sent-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:2px;min-width:12px}
.sent-chart-bars{display:flex;flex-direction:column;justify-content:flex-end;align-items:stretch;width:100%;gap:1px;min-height:1px}
.sent-chart-pos{background:#22c55e;width:100%;border-radius:2px 2px 0 0}
.sent-chart-neg{background:#ef4444;width:100%;border-radius:2px 2px 0 0}
.sent-chart-day{font-size:9px;color:var(--muted);font-family:ui-monospace,monospace}
@media (max-width:700px){.sent-summary{grid-template-columns:1fr}}

/* Morning digest */
.digest-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-top:8px}
.digest-block{padding:12px;background:rgba(15,15,20,.5);border:1px solid var(--line);border-radius:8px}
.digest-wide{grid-column:1/-1}
.digest-title{font-size:13px;font-weight:600;color:#e8e8e8;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.digest-row{display:grid;grid-template-columns:48px 1fr auto;gap:8px;align-items:center;padding:4px 0;font-size:13px}
.digest-sym{color:#c3ccd6;font-family:ui-monospace,monospace;font-weight:600}
.digest-val{color:#e8e8e8;font-family:ui-monospace,monospace}
.digest-delta{font-size:11px;font-family:ui-monospace,monospace;color:var(--muted)}
.digest-delta.up{color:#22c55e}
.digest-delta.down{color:#ef4444}
.digest-todos{list-style:none;padding:0;margin:4px 0 0;font-size:12px}
.digest-todos li{padding:4px 0;border-bottom:1px dashed var(--line);color:#d6dde3;line-height:1.4}
.digest-todos li:last-child{border-bottom:none}
.digest-who{color:#f59e0b;font-family:ui-monospace,monospace;font-size:11px;margin-right:4px}
.ai-risk{font-size:12px;padding:3px 10px;border-radius:999px;font-weight:600;font-family:ui-monospace,monospace}
.ai-risk-green{background:rgba(34,197,94,.14);color:#22c55e;border:1px solid rgba(34,197,94,.4)}
.ai-risk-yellow{background:rgba(234,179,8,.14);color:#eab308;border:1px solid rgba(234,179,8,.4)}
.ai-risk-red{background:rgba(239,68,68,.14);color:#ef4444;border:1px solid rgba(239,68,68,.4)}
.ai-src{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace}
.ai-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-top:8px}
.ai-tile{padding:10px 12px;background:rgba(15,15,20,.5);border:1px solid var(--line);border-radius:8px;display:flex;flex-direction:column;gap:6px}
.ai-tile-up{border-color:rgba(34,197,94,.3)}
.ai-tile-degraded{border-color:rgba(234,179,8,.4)}
.ai-tile-down{border-color:rgba(239,68,68,.45);background:rgba(239,68,68,.06)}
.ai-tile-head{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#e8e8e8}
.ai-tile-name{color:#e8e8e8}
.ai-tile-stats{display:flex;justify-content:space-between;font-family:ui-monospace,monospace;font-size:11px;color:var(--muted)}
.ai-footer{margin-top:10px;font-size:11px;color:var(--muted);font-style:italic}
.ai-probe{margin-top:12px}
.ai-probe:first-of-type{margin-top:6px}
.ai-probe-head{display:flex;align-items:center;gap:10px;font-size:12px;margin-bottom:6px}
.ai-probe-badge{padding:2px 8px;border-radius:4px;font-family:ui-monospace,monospace;font-weight:700;font-size:11px}
.ai-loc-RF{background:rgba(239,68,68,.12);color:#ff8585;border:1px solid rgba(239,68,68,.35)}
.ai-loc-DE{background:rgba(59,130,246,.12);color:#7bafff;border:1px solid rgba(59,130,246,.35)}
.ai-probe-src{color:#c3ccd6;font-size:12px}
.ai-probe-score{margin-left:auto;font-family:ui-monospace,monospace;font-size:12px;color:var(--muted)}
.ai-reg{margin-top:14px;padding-top:12px;border-top:1px dashed var(--line)}
.ai-reg-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;font-weight:600;color:#e8e8e8}
.ai-reg-stats{color:var(--muted);font-family:ui-monospace,monospace;font-size:11px;font-weight:400}
.ai-reg-list{margin-top:8px}
.ai-reg-list-title{font-size:11px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.ai-reg-item{display:flex;gap:8px;padding:5px 8px;font-size:12px;text-decoration:none;color:#d6dde3;border-left:2px solid rgba(234,179,8,.4);margin-bottom:3px;background:rgba(15,15,20,.35);border-radius:0 4px 4px 0;transition:background .15s}
.ai-reg-item:hover{background:rgba(15,15,20,.6);color:#fff}
.ai-reg-item-high{border-left-color:rgba(239,68,68,.6)}
.ai-reg-feed{color:var(--muted);font-family:ui-monospace,monospace;font-size:11px;flex-shrink:0;min-width:140px}
.ai-reg-title{flex:1}
.ai-reg-empty{font-size:12px;color:var(--muted);font-style:italic;padding:8px 0}
.digest-gmail-count{font-size:20px;font-weight:700;color:#4ade80;margin-bottom:4px}

/* Router card */
.router-card{margin-top:8px;padding:12px;background:rgba(15,15,20,.5);border:1px solid var(--line);border-left:3px solid #6b7280;border-radius:8px}
.router-ok{border-left-color:#22c55e;background:rgba(34,197,94,.05)}
.router-stale{border-left-color:#f59e0b;background:rgba(245,158,11,.05)}
.router-down{border-left-color:#ef4444;background:rgba(239,68,68,.07)}
.router-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.router-label{font-weight:600;color:#e8e8e8}
.router-hs{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace;margin-left:auto}
.router-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:6px 16px;font-size:12px;color:#c3ccd6}
.router-grid .mono{font-family:ui-monospace,monospace;color:#e8e8e8}
.dot-yellow{background:#f59e0b}

/* Kort todos */
.kort-todos{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.kort-todo{font-size:13px;line-height:1.35;padding:6px 10px;background:rgba(15,15,20,.5);border:1px solid var(--line);border-left:3px solid #6b7280;border-radius:6px;color:#d6dde3}
.kort-prio-red{border-left-color:#ef4444;background:rgba(239,68,68,.07)}
.kort-prio-yellow{border-left-color:#f59e0b;background:rgba(245,158,11,.07)}
.kort-prio-green{border-left-color:#22c55e;background:rgba(34,197,94,.05)}
.kort-prio-wait{border-left-color:#6366f1;background:rgba(99,102,241,.05);opacity:.85}
.kort-prio-gray{border-left-color:#6b7280}

@media (max-width:900px){
  .fin-grid{grid-template-columns:1fr}
  .stage-row{grid-template-columns:28px 1fr;row-gap:2px}
  .stage-status,.stage-left{grid-column:2;text-align:left}
}

/* KGB widget — security */
.kgb-rules{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.kgb-rule-pill{font-size:11px;padding:3px 8px;background:rgba(15,15,20,.6);border:1px solid var(--line);border-radius:999px;color:#c3ccd6;font-family:ui-monospace,monospace}
.kgb-rule-pill b{color:#ff7a7a}

/* ═══ Block 6 — Overview redesign ═══ */
.hero-compact{margin-top:16px}
.hero-compact .hero-tile{min-height:80px;padding:12px 18px}
.hero-compact .hero-num{font-size:32px}
.hero-compact .hero-label{font-size:12px}

.hot-list{display:flex;flex-direction:column;gap:6px}
.hot-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;border:1px solid var(--line);background:rgba(15,15,20,.5);border-left:3px solid #6b7280;font-size:13px;line-height:1.3}
.hot-row.hot-bad{border-left-color:#ef4444;background:rgba(239,68,68,.08);color:#fbb}
.hot-row.hot-warn{border-left-color:#f59e0b;background:rgba(245,158,11,.06);color:#fde3a8}
.hot-icon{font-size:16px}
.hot-text{flex:1;color:#e8e8e8}

.today-grid{display:flex;flex-direction:column;gap:6px}
.today-row{display:grid;grid-template-columns:28px 80px 1fr;align-items:center;gap:10px;padding:8px 12px;background:rgba(15,15,20,.4);border:1px solid var(--line);border-radius:8px;font-size:13px}
.today-icon{font-size:16px;text-align:center}
.today-who{font-weight:600;color:#c3ccd6}
.today-metric{color:#e8e8e8;line-height:1.35}
.today-metric small{color:var(--muted);font-size:11px;margin-left:4px}

.tile-headline{font-size:11px;color:var(--muted);line-height:1.35;margin-top:4px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

.infra-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.infra-card{background:rgba(15,15,20,.4);border:1px solid var(--line);border-radius:10px;padding:14px}
.infra-card .infra-title{font-weight:600;font-size:14px;color:#e8e8e8;margin-bottom:10px}
.infra-card .big-stat{margin:4px 0}
.infra-card .big-num{font-size:26px}
.infra-card .ssl-bars{gap:4px;display:flex;flex-direction:column}
.infra-card .ssl-row{font-size:11px}
.infra-card .ssl-domain{font-size:11px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.infra-card .kgb-badges{flex-direction:column;gap:6px;display:flex}
.infra-card .badge{padding:6px 10px;font-size:11px}

.tile-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.15);display:block}
.tile-icon img.tile-avatar{display:block}

.nav-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover;display:inline-block;vertical-align:middle;border:1px solid rgba(255,255,255,.12)}
.nav-icon img.nav-avatar{display:inline-block}
