:root{
  --teal:#00414B; --teal2:#0a5563; --orange:#F8981D; --ink:#243038;
  --grey:#5b6770; --light:#eef3f4; --line:#d4dee0; --bg:#f4f7f8;
  --green:#1E7E34; --amber:#B8860B; --red:#C0392B; --white:#fff;
}
*{box-sizing:border-box}
body{margin:0;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);font-size:14px}
a{color:var(--teal2)}
.hidden{display:none!important}

/* ---- login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#00414B,#0a5563)}
.login-card{background:#fff;border-radius:14px;padding:34px 32px;width:360px;box-shadow:0 18px 50px rgba(0,0,0,.25)}
.login-card img{height:34px;margin-bottom:6px}
.login-card h1{font-size:17px;margin:6px 0 2px;color:var(--teal)}
.login-card p.sub{color:var(--grey);margin:0 0 20px;font-size:12.5px}
.login-card label{display:block;font-size:12px;color:var(--grey);margin:12px 0 4px}
.login-card input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px}
.login-card button{width:100%;margin-top:20px;padding:11px;border:0;border-radius:8px;background:var(--teal);color:#fff;font-weight:600;font-size:14px;cursor:pointer}
.login-card button:hover{background:var(--teal2)}
.err{color:var(--red);font-size:12.5px;margin-top:12px;min-height:16px}

/* ---- header ---- */
header{background:var(--teal);color:#fff;display:flex;align-items:center;padding:0 18px;height:54px;gap:16px}
header img{height:26px}
header .title{font-weight:600;font-size:15px;letter-spacing:.3px}
header .title small{font-weight:400;opacity:.8;font-size:11.5px;display:block;margin-top:-2px}
header .spacer{flex:1}
header .quota{font-size:12px;background:rgba(255,255,255,.12);padding:5px 10px;border-radius:20px}
header .quota b{color:var(--orange)}
header .who{font-size:12.5px;opacity:.95}
header .logout{color:#fff;text-decoration:none;font-size:12.5px;border:1px solid rgba(255,255,255,.4);padding:4px 10px;border-radius:6px}
header .logout:hover{background:rgba(255,255,255,.12)}

/* ---- tabs ---- */
.tabs{display:flex;gap:2px;background:#fff;border-bottom:1px solid var(--line);padding:0 14px}
.tabs button{border:0;background:none;padding:13px 16px;font-size:13.5px;color:var(--grey);cursor:pointer;border-bottom:3px solid transparent}
.tabs button.active{color:var(--teal);border-bottom-color:var(--orange);font-weight:600}
main{padding:18px 22px;max-width:1280px;margin:0 auto}
h2.sec{font-size:16px;color:var(--teal);margin:4px 0 4px}
p.hint{color:var(--grey);font-size:12.5px;margin:0 0 14px}

/* ---- table ---- */
table.cmp{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden}
table.cmp th{background:var(--teal);color:#fff;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;padding:9px 8px;text-align:left;border-bottom:2px solid var(--orange)}
table.cmp td{padding:8px;border-bottom:1px solid var(--light);font-size:13px}
table.cmp tr:hover td{background:#f8fbfb}
table.cmp tr.group-sep td{background:var(--light);font-weight:600;color:var(--teal);font-size:11.5px;text-transform:uppercase}
.proto-h1{color:var(--amber);font-weight:700}
.proto-h2{color:var(--green);font-weight:700}
.bold{font-weight:700}
.muted{color:var(--grey)}
.linkish{color:var(--teal2);cursor:pointer;text-decoration:underline}
.right{text-align:right}.center{text-align:center}

/* ---- buttons ---- */
.btn{border:0;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer}
.btn.primary{background:var(--teal);color:#fff}.btn.primary:hover{background:var(--teal2)}
.btn.orange{background:var(--orange);color:#3a2700}.btn.orange:hover{filter:brightness(.96)}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.toolbar{display:flex;gap:10px;align-items:center;margin:12px 0}

/* ---- cards / kpis ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:14px 0}
.kpi{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.kpi .lab{font-size:11px;color:var(--grey);text-transform:uppercase;letter-spacing:.4px}
.kpi .val{font-size:22px;font-weight:700;color:var(--teal);margin-top:3px}
.kpi .val.warn{color:var(--amber)} .kpi .val.bad{color:var(--red)} .kpi .val.good{color:var(--green)}
.kpi .sub{font-size:11.5px;color:var(--grey);margin-top:2px}
.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px;margin:14px 0}
.card h3{margin:0 0 10px;font-size:14px;color:var(--teal)}
.verdict{background:#eaf1f2;border-left:4px solid var(--orange);padding:10px 14px;border-radius:6px;font-size:13px;margin:10px 0}

/* decomposition bar */
.decomp{display:flex;height:26px;border-radius:6px;overflow:hidden;border:1px solid var(--line);margin:8px 0}
.decomp span{display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;white-space:nowrap;overflow:hidden}
.seg-server{background:var(--teal)} .seg-net{background:var(--orange);color:#3a2700} .seg-dl{background:#7aa0a8}

/* ai */
.ai-box{background:#0f2a30;color:#e7eef0;border-radius:10px;padding:16px 18px;font-size:13px;line-height:1.5;white-space:pre-wrap;margin-top:12px;min-height:40px}
.ai-box.empty{background:#fff;color:var(--grey);border:1px dashed var(--line)}
.spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:sp .8s linear infinite;vertical-align:-2px;margin-right:6px}
@keyframes sp{to{transform:rotate(360deg)}}
textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:10px;font-family:inherit;font-size:13px;resize:vertical}
.slow-list{font-family:Consolas,monospace;font-size:12px}
.slow-list div{padding:3px 0;border-bottom:1px solid var(--light)}
.drop{border:2px dashed var(--line);border-radius:10px;padding:26px;text-align:center;color:var(--grey);background:#fff;cursor:pointer}
.drop.hover{border-color:var(--orange);background:#fffaf0}
.pager{display:flex;gap:5px;align-items:center;margin:12px 0;flex-wrap:wrap}
.pager .pg{border:1px solid var(--line);background:#fff;border-radius:6px;padding:5px 11px;cursor:pointer;font-size:12.5px;color:var(--ink)}
.pager .pg:hover{background:var(--light)}
.pager .pg.on{background:var(--teal);color:#fff;border-color:var(--teal);font-weight:600}
.pager .pg:disabled{opacity:.4;cursor:not-allowed}
.foot{color:var(--grey);font-size:11px;margin-top:18px;text-align:center}
