:root{
  --bg:#f7f7f8; --panel:#ffffff; --text:#0b0b0c; --muted:#6b7280;
  --line:#e5e7eb; --accent:#111111; --accent-2:#2563eb; --ok:#10b981; --warn:#f59e0b; --danger:#ef4444;
  --radius:12px; --shadow:0 1px 2px rgba(0,0,0,.06), 0 8px 20px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg)}
.app-header{
  display:flex;align-items:center;gap:16px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--panel);position:sticky;top:0;z-index:50;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.searchbar{flex:1;display:flex;gap:8px}
.searchbar input{flex:1;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff}
.header-actions{display:flex;gap:8px;align-items:center}
button,.button{
  background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 14px;cursor:pointer;font-weight:600;box-shadow:var(--shadow)
}
button.secondary,.button.secondary{background:#fff;color:var(--text);border:1px solid var(--line)}
button.ghost{background:transparent;color:var(--muted);border:1px dashed var(--line)}
button.icon{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;padding:0}
button:hover,.button:hover{opacity:.92}
.dot{width:9px;height:9px;background:var(--danger);border-radius:999px;display:inline-block;position:absolute;margin-left:18px;margin-top:-6px}
.tabs{display:flex;gap:6px;padding:10px 18px;background:var(--bg);position:sticky;top:62px;z-index:45;border-bottom:1px solid var(--line)}
.tab{background:#fff;color:var(--text);border:1px solid var(--line);padding:8px 12px;border-radius:999px}
.tab.active{background:var(--text);color:#fff;border-color:var(--text)}
main{padding:18px}
.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.panel-header h1{margin:0;font-size:20px}
.context{color:var(--muted);display:flex;gap:12px;align-items:center}
.grid{display:grid;gap:12px}
.grid.two{grid-template-columns:1fr 1fr}
.grid.three{grid-template-columns:1fr 1fr 1fr}
.grid.compact{gap:8px}
@media(max-width:1000px){.grid.two{grid-template-columns:1fr}.grid.three{grid-template-columns:1fr 1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.card-title{font-weight:600;margin-bottom:10px}
.kpis .kpi{padding:14px}
.kpi-label{color:var(--muted);font-size:12px}
.kpi-value{font-size:22px;font-weight:700;margin-top:4px}
.kpi-trend{font-size:12px;color:var(--muted)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:10px}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table thead th{position:sticky;top:0;background:#fafafa;color:var(--muted);text-align:left;font-weight:600;padding:10px;border-bottom:1px solid var(--line);cursor:pointer}
.table tbody td{padding:10px;border-bottom:1px solid var(--line);white-space:nowrap}
.table tbody tr:hover{background:#fafafa}
.input{padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff;width:100%}
.report{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;background:#fff}
.right{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}
.muted{color:var(--muted)}
.muted.small{font-size:12px}
.mono{font-variant-numeric:tabular-nums}
.value{font-weight:700}
.badge{display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:6px}
.badge.ok{background:var(--ok)}
.badge.warn{background:var(--warn)}
.badge.danger{background:var(--danger)}
.progress-grid{display:grid;grid-template-columns:1fr;gap:8px}
.progress-item{display:flex;align-items:center;gap:10px}
.progress-bar{flex:1;height:10px;background:#f1f5f9;border-radius:999px;position:relative}
.progress-bar > span{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--accent-2),#60a5fa);border-radius:999px}
.timeline{display:grid;gap:10px}
.timeline-row{display:grid;grid-template-columns:180px repeat(6,1fr);gap:6px;align-items:center}
.timeline-row .label{font-weight:600}
.timeline-cell{height:12px;background:#f3f4f6;border-radius:6px;position:relative}
.timeline-cell.done{background:linear-gradient(90deg,var(--ok),#34d399)}
.timeline-cell.partial{background:linear-gradient(90deg,var(--warn),#fbbf24)}
.ai-list{margin:0;padding-left:18px}
.ai-list li{margin-bottom:6px}
.notif-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.notif{display:flex;gap:10px;align-items:flex-start;border:1px solid var(--line);background:#fff;padding:10px;border-radius:10px}
.notif .tag{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.notif .title{font-weight:600}
.notif .time{color:var(--muted);font-size:12px}
.tab-panel{display:none}
.tab-panel.active{display:block}
#notifDot.hidden{display:none}