:root{
  --bg:#0f1419; --panel:#1a2230; --panel2:#232d3d; --bd:#2d3a4d;
  --tx:#e6edf3; --dim:#9aa7b8; --pri:#2f81f7; --grn:#2ea043; --red:#e5484d; --yel:#e3b341;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Segoe UI",system-ui,sans-serif;background:var(--bg);color:var(--tx)}
.hidden{display:none!important}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-box{background:var(--panel);border:1px solid var(--bd);border-radius:16px;padding:36px;
  width:360px;display:flex;flex-direction:column;gap:14px}
.brand-lg{font-size:26px;font-weight:800;color:var(--pri);text-align:center}
.brand-sub{text-align:center;color:var(--dim);margin-top:-8px;margin-bottom:8px}
.login-box input{height:46px;background:var(--bg);border:1px solid var(--bd);border-radius:10px;
  color:var(--tx);padding:0 14px;font-size:15px}
.hint{text-align:center;color:var(--dim);font-size:12px}
.err{color:var(--red);font-size:13px;min-height:16px;text-align:center}

/* Buttons */
.btn{border:none;border-radius:10px;padding:0 18px;height:44px;font-size:15px;font-weight:600;
  color:#fff;background:var(--panel2);cursor:pointer;transition:.15s}
.btn-primary{background:var(--pri)}.btn-primary:hover{background:#4a93ff}
.btn-ghost{background:transparent;border:1px solid var(--bd)}
.btn-sm{height:38px;font-size:14px;padding:0 14px}

/* App layout */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--panel);border-right:1px solid var(--bd);display:flex;flex-direction:column;padding:20px 14px}
.brand{font-size:20px;font-weight:800;color:var(--pri);padding:6px 10px 20px}
nav{display:flex;flex-direction:column;gap:6px;flex:1}
.nav-item{text-align:left;background:none;border:none;color:var(--dim);font-size:15px;font-weight:600;
  padding:12px 14px;border-radius:10px;cursor:pointer}
.nav-item:hover{background:var(--panel2);color:var(--tx)}
.nav-item.active{background:var(--pri);color:#fff}
.side-foot{border-top:1px solid var(--bd);padding-top:14px;display:flex;flex-direction:column;gap:8px}
.who{color:var(--dim);font-size:13px;padding:0 6px;word-break:break-all}

.content{padding:28px 32px;overflow:auto}
.tab{display:none}.tab.active{display:block}
h1{font-size:24px;margin-bottom:20px}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.card{background:var(--panel);border:1px solid var(--bd);border-radius:14px;padding:22px}
.card .num{font-size:40px;font-weight:800}
.card .lbl{color:var(--dim);margin-top:4px}
.card.ok .num{color:var(--grn)}.card.warn .num{color:var(--yel)}.card.pri .num{color:var(--pri)}

/* Table */
.search{height:42px;background:var(--panel);border:1px solid var(--bd);border-radius:10px;color:var(--tx);
  padding:0 14px;font-size:15px;width:320px;max-width:100%;margin-bottom:16px}
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.toolbar label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--dim)}
.toolbar input{height:40px;background:var(--panel);border:1px solid var(--bd);border-radius:8px;color:var(--tx);padding:0 12px}
.table-wrap{background:var(--panel);border:1px solid var(--bd);border-radius:14px;overflow:auto}
table{width:100%;border-collapse:collapse;font-size:14px;min-width:520px}
th,td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--bd)}
th{color:var(--dim);font-size:12px;text-transform:uppercase;letter-spacing:.4px;background:var(--panel2)}
tr:last-child td{border-bottom:none}
.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--panel2)}
.avatar-ph{width:40px;height:40px;border-radius:50%;background:var(--panel2);display:flex;
  align-items:center;justify-content:center;color:var(--dim);font-weight:700}
.badge{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.badge.on{background:rgba(46,160,67,.2);color:#5fd97a}
.badge.off{background:rgba(229,72,77,.2);color:#ff8488}
.tok{font-family:Consolas,monospace;font-size:12px;color:#ffd479;word-break:break-all}
.in{color:var(--grn);font-weight:600}.out{color:var(--yel);font-weight:600}
.new-token{background:rgba(46,160,67,.12);border:1px solid var(--grn);border-radius:10px;padding:12px 16px;margin-bottom:16px}
.empty{padding:28px;text-align:center;color:var(--dim)}

/* Dashboard — Health hero */
.hero{display:grid;grid-template-columns:220px 1fr;gap:24px;background:var(--panel);border:1px solid var(--bd);
  border-radius:16px;padding:22px 24px;margin-bottom:16px}
.hero-gauge{position:relative;width:200px;height:160px}
.hero-center{position:absolute;inset:0;top:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.hs-num{font-size:46px;font-weight:800;line-height:1}
.hs-lbl{color:var(--dim);font-size:13px;margin-top:2px}
.hero-info{display:flex;flex-direction:column;justify-content:center}
.hero-title{font-size:18px;font-weight:700;display:flex;align-items:center;gap:12px}
.hero-sub{color:var(--dim);font-size:13px;margin:4px 0 14px}
.hdelta{font-size:15px;font-weight:700;padding:2px 10px;border-radius:20px}
.hdelta.up{background:rgba(46,160,67,.18);color:#5fd97a}
.hdelta.down{background:rgba(229,72,77,.18);color:#ff8488}
.hdelta.flat{background:var(--panel2);color:var(--dim)}
.subbars{display:flex;flex-direction:column;gap:9px;margin-bottom:14px}
.subbar{display:grid;grid-template-columns:110px 1fr 40px;align-items:center;gap:10px;font-size:13px;color:var(--dim)}
.subbar .track{height:8px;background:var(--panel2);border-radius:4px;overflow:hidden}
.subbar .fill{height:100%;border-radius:4px}
.spark-wrap{height:46px}

.dash-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}

/* Flight-risk watchlist */
.flight-list{display:flex;flex-direction:column;gap:8px}
.frow{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:var(--panel2);
  border-radius:10px;padding:10px 12px;border-left:4px solid var(--bd)}
.frow.high{border-left-color:var(--red)}.frow.watch{border-left-color:var(--yel)}
.frow .fn{font-weight:600}
.frow .fd{font-size:12px;color:var(--dim)}
.frow .fscore{font-size:22px;font-weight:800;text-align:right}
.frow.high .fscore{color:#ff8488}.frow.watch .fscore{color:var(--yel)}
.pill{display:inline-block;font-size:11px;padding:1px 7px;border-radius:10px;background:rgba(229,72,77,.2);color:#ff8488;margin-left:6px}
.empty-good{color:#5fd97a;padding:16px;text-align:center}

/* Insight feed */
.insight-feed{display:flex;flex-direction:column;gap:8px}
.ins{display:grid;grid-template-columns:14px 1fr;gap:10px;align-items:start;background:var(--panel2);
  border-radius:10px;padding:11px 13px;font-size:14px;line-height:1.4}
.ins .idot{width:10px;height:10px;border-radius:50%;margin-top:5px}
.ins.good .idot{background:var(--grn)}.ins.warning .idot{background:var(--yel)}.ins.critical .idot{background:var(--red)}
.lv{font-size:13px;font-weight:700;padding:2px 10px;border-radius:20px}
.lv.worse{background:rgba(229,72,77,.18);color:#ff8488}
.lv.better{background:rgba(46,160,67,.18);color:#5fd97a}
.lv.stable{background:var(--panel2);color:var(--dim)}

/* Heatmap */
.heatmap-wrap{overflow-x:auto}
.hm{display:grid;gap:2px;min-width:600px}
.hm-row{display:grid;grid-template-columns:150px 1fr;gap:8px;align-items:center}
.hm-name{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hm-cells{display:flex;gap:2px}
.hm-cell{flex:1;height:15px;border-radius:2px;min-width:5px}
.c0{background:#131a24}.c1{background:#2ea043}.c2{background:#e3b341}.c3{background:#2f81f7}.c4{background:#5b6472}.c5{background:#e5484d}
.hc{display:inline-block;width:10px;height:10px;border-radius:2px;margin:0 4px 0 10px;vertical-align:middle}
.hc.g{background:#2ea043}.hc.a{background:#e3b341}.hc.b{background:#2f81f7}.hc.r{background:#e5484d}.hc.gr{background:#5b6472}

@media(max-width:820px){.hero{grid-template-columns:1fr}.dash-2{grid-template-columns:1fr}.hero-gauge{margin:0 auto}}

/* Modal (xodim tahrir) */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;
  justify-content:center;z-index:50;padding:16px}
.modal-box{background:var(--panel);border:1px solid var(--bd);border-radius:16px;width:760px;max-width:100%;
  max-height:92vh;overflow:auto}
.em-analytics{padding:0 22px 20px}
.ea-title{font-size:14px;font-weight:700;color:var(--dim);margin:6px 0 12px;border-top:1px solid var(--bd);padding-top:16px}
.em-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px;margin-bottom:14px}
.ekpi{background:var(--panel2);border-radius:10px;padding:11px 12px;text-align:center}
.ekpi .v{font-size:22px;font-weight:800}
.ekpi .k{font-size:11px;color:var(--dim);margin-top:2px}
.em-charts{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.em-chart{background:var(--panel2);border-radius:10px;padding:12px}
.ec-title{font-size:12px;color:var(--dim);margin-bottom:6px}
.em-chart canvas{max-height:150px}
@media(max-width:600px){.em-charts{grid-template-columns:1fr}}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--bd)}
.modal-head h2{font-size:19px}
.x{background:none;border:none;color:var(--dim);font-size:26px;cursor:pointer;line-height:1}
.modal-body{padding:22px;display:grid;grid-template-columns:150px 1fr;gap:22px}
.em-photo-col{display:flex;flex-direction:column;align-items:center;gap:10px}
.em-photo{width:120px;height:120px;border-radius:16px;background:var(--panel2);overflow:hidden;
  display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:44px;font-weight:700}
.em-photo img{width:100%;height:100%;object-fit:cover}
.em-vecs{font-size:12px;color:var(--dim)}
.em-fields{display:flex;flex-direction:column;gap:12px}
.em-fields label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--dim)}
.em-fields input{height:42px;background:var(--bg);border:1px solid var(--bd);border-radius:9px;color:var(--tx);padding:0 12px;font-size:15px}
.em-check{flex-direction:row!important;align-items:center;gap:8px!important;color:var(--tx)!important}
.em-check input{width:20px;height:20px;height:auto}
.modal-foot{display:flex;justify-content:flex-end;align-items:center;gap:16px;padding:16px 22px;border-top:1px solid var(--bd)}
.em-status{color:var(--grn);font-size:14px}
tr.clickable{cursor:pointer}tr.clickable:hover{background:var(--panel2)}
@media(max-width:520px){.modal-body{grid-template-columns:1fr}}

/* Hisobotlar / charts */
.rep-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.range{display:flex;gap:6px}
.range button{background:var(--panel2);border:1px solid var(--bd);color:var(--dim);height:36px;padding:0 14px;
  border-radius:8px;cursor:pointer;font-weight:600}
.range button.active{background:var(--pri);color:#fff;border-color:var(--pri)}
.chart-box{background:var(--panel);border:1px solid var(--bd);border-radius:14px;padding:18px 20px;margin-top:16px}
.chart-title{color:var(--dim);font-size:14px;font-weight:600;margin-bottom:12px;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.chart-title .lg{font-size:12px;font-weight:500}
.dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin:0 5px 0 10px;vertical-align:middle}
.dot.g{background:var(--grn)}.dot.y{background:var(--yel)}.dot.b{background:var(--pri)}
.chart{width:100%;height:auto;display:block}
.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.chart rect{transition:opacity .1s}.chart rect:hover{opacity:.8}
.bar-mini{height:8px;background:var(--panel2);border-radius:4px;overflow:hidden;min-width:80px}
.bar-mini > i{display:block;height:100%;background:var(--pri);border-radius:4px}
.axlbl{fill:var(--dim);font-size:11px}

/* Hisobot-karta */
.rc-head{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:16px}
.rc-gpa{width:80px;height:80px;border-radius:50%;display:flex;flex-direction:column;align-items:center;
  justify-content:center;font-weight:800;flex-shrink:0;border:3px solid}
.rc-gpa .lt{font-size:30px;line-height:1}.rc-gpa .g{font-size:11px;color:var(--dim)}
.rc-headline{font-size:15px;line-height:1.5}
.rc-subs{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}
.rc-sub{background:var(--panel2);border-radius:10px;padding:14px;text-align:center}
.rc-sub .gr{font-size:32px;font-weight:800;line-height:1}
.rc-sub .nm{font-size:12px;color:var(--dim);margin-top:4px}
.rc-sub .dl{font-size:12px;margin-top:2px}

/* Izoh (tushuntirish) tizimi */
.info-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;
  background:var(--panel2);border:1px solid var(--bd);color:var(--dim);font-size:11px;font-weight:700;
  cursor:pointer;margin-left:8px;flex-shrink:0;user-select:none}
.info-btn:hover{background:var(--pri);color:#fff;border-color:var(--pri)}
.explain{background:rgba(47,129,247,.08);border-left:3px solid var(--pri);border-radius:6px;
  padding:10px 13px;margin:8px 0 4px;font-size:13px;line-height:1.5;color:#c7d2de}
.explain.hidden{display:none}

/* Settings + forecast */
.set-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.set-field label{font-size:13px;color:var(--dim)}
.set-field input{height:44px;background:var(--bg);border:1px solid var(--bd);border-radius:9px;color:var(--tx);padding:0 14px;font-size:15px}
.hc-big{font-size:52px;font-weight:800;text-align:center;line-height:1}
.hc-band{text-align:center;color:var(--dim);margin:6px 0 4px}
.hc-range{text-align:center;font-size:14px}
.shift-table{width:100%;border-collapse:collapse;font-size:14px}
.shift-table th,.shift-table td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--bd)}
.shift-table th{color:var(--dim);font-size:12px;text-transform:uppercase}
.drift-badge{font-size:12px;font-weight:700;padding:2px 9px;border-radius:20px;background:var(--panel2)}
.mono{font-family:Consolas,monospace}

/* Coverage heatmap */
.cov-wrap{overflow-x:auto}
.cov{display:inline-grid;gap:2px}
.cov-lbl{font-size:11px;color:var(--dim);display:flex;align-items:center;justify-content:flex-end;padding-right:6px;white-space:nowrap}
.cov-hd{font-size:10px;color:var(--dim);text-align:center}
.cov-cell{width:26px;height:22px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:9px;color:#dfe7ef;text-shadow:0 1px 1px rgba(0,0,0,.5)}

/* Xato banneri */
.err-banner{position:fixed;top:0;left:0;right:0;z-index:100;background:#e5484d;color:#fff;
  text-align:center;padding:10px 16px;font-size:14px;font-weight:600;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.err-banner.hidden{display:none}
/* Yuklanmoqda */
.loading{opacity:.5;pointer-events:none}

/* Deep list items */
.dp-list{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow:auto}
.dp-item{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;background:var(--panel2);
  border-radius:8px;padding:8px 11px;font-size:13px}
.dp-item .dn{font-weight:600}
.dp-item .ds{font-size:12px;color:var(--dim)}
.dp-item .dv{font-size:18px;font-weight:800}
.unit{font-size:10px;color:var(--dim);font-weight:400;margin-left:3px}
.medal{font-size:15px;margin-right:4px}
.gini-num{font-size:15px;font-weight:800}
.hygiene-big{font-size:38px;font-weight:800;text-align:center;padding:8px}

@media(max-width:900px){.chart-row{grid-template-columns:1fr}}
@media(max-width:640px){
  .app{grid-template-columns:1fr}
  .sidebar{flex-direction:row;flex-wrap:wrap;align-items:center}
  nav{flex-direction:row;flex-wrap:wrap;flex:1 0 100%;order:3}
  .brand{padding:6px 10px}
  .content{padding:18px 14px}
}
