:root{
  --bg:#0c0f17; --bg2:#111623; --card:#151b2b; --card2:#1a2235;
  --line:#243047; --line2:#2e3c58;
  --txt:#e7ecf6; --muted:#8a98b5; --muted2:#6b7a99;
  --acc:#4f8cff; --acc2:#6ba4ff; --ok:#2fbf71; --warn:#f3b13b; --fail:#ef5a5a;
  --rad:14px; --rad-s:9px;
  --font:'Segoe UI',Roboto,system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:radial-gradient(1200px 600px at 80% -10%,#16203a 0,var(--bg) 55%);
  color:var(--txt);font-family:var(--font);font-size:14px;line-height:1.5;min-height:100vh}

/* Topbar */
.topbar{display:flex;align-items:center;gap:24px;padding:14px 24px;
  background:rgba(13,17,27,.8);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;flex-wrap:wrap}
.brand{display:flex;flex-direction:column;gap:3px}
.brand-title{font-weight:800;font-size:19px;letter-spacing:.16em;line-height:1}
.brand-title b{color:var(--warn);font-weight:800}
.brand-sub{font-family:ui-monospace,'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.34em;
  color:var(--muted2);text-transform:uppercase}
.spacer{flex:1}
.top-chip{font-family:ui-monospace,monospace;font-size:11px;color:var(--muted);padding:6px 12px;
  border:1px solid var(--line);border-radius:8px;background:var(--card);margin-left:18px}
.top-chip[hidden]{display:none}
.top-chip b{color:var(--ok)}
.top-stats{display:flex;gap:10px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:6px 14px;text-align:center;min-width:62px}
.stat span{display:block;font-size:18px;font-weight:700;color:var(--acc2)}
.stat label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.top-nav{display:flex;gap:6px}
.nav-btn{background:transparent;border:1px solid var(--line);color:var(--muted);
  padding:8px 16px;border-radius:9px;cursor:pointer;font-size:13px;font-weight:600}
.nav-btn.active{background:var(--acc);color:#fff;border-color:var(--acc)}

main{max-width:none;margin:0;padding:20px 26px}
.view{display:none}.view.active{display:block}

/* Dropzone */
.dropzone{max-width:600px;margin:44px auto;border:1.5px dashed var(--line2);border-radius:18px;
  background:linear-gradient(180deg,var(--card2),var(--card));
  padding:52px 40px;text-align:center;transition:.2s;cursor:pointer;
  box-shadow:0 18px 50px rgba(0,0,0,.35)}
.dropzone.drag{border-color:var(--acc);background:#16203a;transform:translateY(-2px)}
.dropzone .dz-icon{filter:drop-shadow(0 4px 14px rgba(79,140,255,.4))}
.dz-icon{font-size:46px;color:var(--acc2);margin-bottom:10px}
.dz-title{font-size:18px;font-weight:600}
.dz-sub{color:var(--muted);margin:6px 0 18px}
.dz-progress{display:flex;flex-direction:column;align-items:center;gap:10px}
/* hidden atributini display:flex/grid ustidan to'g'ri ishlatish (specifik) */
.dz-progress[hidden],.dz-inner[hidden],.logo-compare[hidden],.result-head[hidden],.results-main[hidden],.boot-spot[hidden]{display:none}
.spinner{width:38px;height:38px;border:4px solid var(--line2);border-top-color:var(--acc);
  border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Buttons */
.btn{border:1px solid var(--line2);background:var(--card2);color:var(--txt);
  padding:10px 18px;border-radius:var(--rad-s);cursor:pointer;font-size:13px;font-weight:600;
  transition:.15s}
.btn:hover{border-color:var(--acc)}
.btn.primary{background:linear-gradient(135deg,var(--acc),var(--acc2));border:none;color:#fff;
  box-shadow:0 4px 14px rgba(0,0,0,.32)}
.btn.primary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.btn.ghost{background:transparent}
.btn.sm{padding:6px 12px;font-size:12px}
.btn.big{padding:13px 24px;font-size:15px}
.btn.danger{background:transparent;border-color:rgba(239,90,90,.5);color:var(--fail)}
.btn.danger:hover{background:rgba(239,90,90,.12);border-color:var(--fail)}

/* Cards & layout */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);
  padding:18px 20px;margin-bottom:16px}
.card h3{margin:0 0 14px;font-size:15px;font-weight:700}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:880px){.grid-2{grid-template-columns:1fr}}
.muted{color:var(--muted)}.small{font-size:12px}

/* Result head */
.result-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.rh-title{font-size:22px;font-weight:800}
.rh-sub{color:var(--muted);margin-top:3px}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.badge{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;
  border:1px solid var(--line2);background:var(--card2)}
.badge.ok{color:var(--ok);border-color:rgba(47,191,113,.4);background:rgba(47,191,113,.1)}
.badge.warn{color:var(--warn);border-color:rgba(243,177,59,.4);background:rgba(243,177,59,.1)}
.badge.acc{color:var(--acc2);border-color:rgba(79,140,255,.4);background:rgba(79,140,255,.12)}

/* Tabs */
.tabs{display:flex;gap:4px;margin:4px 0 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tab{background:transparent;border:none;color:var(--muted);padding:11px 18px;cursor:pointer;
  font-size:13px;font-weight:600;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab.active{color:var(--txt);border-bottom-color:var(--acc)}
.tabpane{display:none}.tabpane.active{display:block;animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* Key-value tables */
table.kv{width:100%;border-collapse:collapse}
table.kv td{padding:7px 4px;border-bottom:1px solid var(--line);vertical-align:top}
table.kv td:first-child{color:var(--muted);width:42%;font-size:13px}
table.kv td:last-child{font-weight:600;word-break:break-word}

/* Region map */
.regionmap{display:flex;height:46px;border-radius:9px;overflow:hidden;border:1px solid var(--line2)}
.region-seg{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;
  color:#fff;position:relative;cursor:default;min-width:2px;overflow:hidden;white-space:nowrap}
.region-seg.r-Descriptor{background:#7c5cff}
.region-seg.r-ME{background:#e0794a}
.region-seg.r-BIOS{background:linear-gradient(90deg,#3a7bd5,#4f8cff)}
.region-seg.r-GbE{background:#2fbf71}
.region-seg.r-PDR{background:#9aa0aa}
.region-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px}
.leg{display:flex;gap:7px;align-items:center;font-size:12px}
.leg i{width:13px;height:13px;border-radius:3px;display:inline-block}
.leg .desc{color:var(--muted)}

/* Diagnostics */
.diag-mini,.diag-full{display:flex;flex-direction:column;gap:9px}
.diag-row{display:flex;gap:12px;padding:11px 14px;border-radius:10px;background:var(--card2);
  border:1px solid var(--line);align-items:flex-start}
.diag-row .dot{width:11px;height:11px;border-radius:50%;margin-top:5px;flex:0 0 auto}
.dot.ok{background:var(--ok)}.dot.warn{background:var(--warn)}.dot.fail{background:var(--fail)}
.dot.info{background:var(--acc2)}
.diag-row .dr-label{font-weight:700}
.diag-row .dr-detail{color:var(--txt);font-size:13px}
.diag-row .dr-explain{color:var(--muted);font-size:12px;margin-top:3px}

/* ---- Edit layout ---- */
.edit-layout{display:grid;grid-template-columns:1fr 460px;gap:18px;align-items:start}
@media(max-width:1080px){.edit-layout{grid-template-columns:1fr}}
.hint-bar{background:rgba(79,140,255,.1);border:1px solid rgba(79,140,255,.3);
  padding:11px 14px;border-radius:10px;font-size:13px;margin-bottom:14px}
.field{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;margin-bottom:12px;transition:.15s}
.field.focused{border-color:var(--acc);box-shadow:0 0 0 3px rgba(79,140,255,.15)}
.field.changed{border-color:var(--warn)}
.field-top{display:flex;justify-content:space-between;align-items:center;gap:10px}
.field-label{font-weight:700;font-size:13.5px}
.field-type{font-size:11px;color:var(--muted);background:var(--card2);padding:2px 8px;
  border-radius:6px;border:1px solid var(--line)}
.field input{width:100%;margin-top:9px;background:var(--bg2);border:1px solid var(--line2);
  color:var(--txt);padding:10px 12px;border-radius:8px;font-size:14px;font-family:inherit}
.field input:focus{outline:none;border-color:var(--acc)}
.field-explain{color:var(--muted);font-size:12.5px;margin-top:9px;line-height:1.5}
.field-where{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}
.where-chip{font-size:11px;color:var(--acc2);background:rgba(79,140,255,.1);
  border:1px solid rgba(79,140,255,.25);padding:3px 9px;border-radius:14px;cursor:default}
.changed-mark{font-size:11px;color:var(--warn);font-weight:700;display:none}
.field.changed .changed-mark{display:inline}
.edit-actions{display:flex;gap:10px;margin-top:8px}
#editResult{margin-top:14px}

/* ---- Mockups ---- */
.mockups{position:sticky;top:84px}
.mockup-tabs{display:flex;gap:5px;margin-bottom:10px}
.mk-tab{flex:1;background:var(--card2);border:1px solid var(--line);color:var(--muted);
  padding:8px 6px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600}
.mk-tab.active{background:var(--acc);color:#fff;border-color:var(--acc)}
.mk-pane{display:none}.mk-pane.active{display:block}
.screen{border-radius:10px;overflow:hidden;border:1px solid var(--line2);aspect-ratio:4/3;
  position:relative}
.mk-caption{color:var(--muted);font-size:12px;margin-top:8px;text-align:center}

/* POST screen */
.post-screen{background:#000;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:14px;padding:20px;font-family:'Consolas',monospace}
.post-logo{max-width:62%;max-height:42%;object-fit:contain}
.post-board{color:#fff;font-size:17px;font-weight:700;letter-spacing:.5px;text-align:center}
.post-meta{color:#b9c0cc;font-size:12px}
.post-help{position:absolute;bottom:14px;left:0;right:0;text-align:center;color:#8a98b5;
  font-size:11px}
.post-help b{color:#dfe5ee}

/* SETUP screen (AMI Aptio look) */
.setup-screen{background:#0a1a4f;color:#cdd6ff;font-family:'Consolas',monospace;
  display:flex;flex-direction:column;font-size:12px}
.setup-top{background:#cdd6ff;color:#0a1a4f;text-align:center;font-weight:700;padding:3px}
.setup-menu{display:flex;gap:0;background:#16277a;border-bottom:1px solid #2c3f9e}
.setup-menu span{padding:5px 9px;font-size:11px}
.setup-menu span.active{background:#cdd6ff;color:#0a1a4f;font-weight:700}
.setup-body{flex:1;padding:12px 16px;display:flex;flex-direction:column;gap:5px}
.setup-row{display:flex;justify-content:space-between;gap:10px}
.setup-row .sk{color:#9fb0ff}
.setup-row .sv{color:#fff;font-weight:600}
.setup-row.hl .sv{background:#fff;color:#0a1a4f;padding:0 4px}
.setup-foot{border-top:1px solid #2c3f9e;padding:4px 8px;font-size:10px;color:#9fb0ff}

/* Windows screen */
.win-screen{background:#f0f0f0;display:flex;flex-direction:column}
.win-titlebar{background:linear-gradient(#fdfdfd,#e8e8e8);color:#222;padding:7px 12px;
  font-size:12px;font-weight:600;border-bottom:1px solid #ccc;display:flex;align-items:center;gap:8px}
.win-dots{display:flex;gap:4px;margin-left:auto}
.win-dots i{width:11px;height:11px;border-radius:50%;background:#ccc;display:block}
.win-body{flex:1;overflow:auto;padding:4px 0;background:#fff}
.win-row{display:grid;grid-template-columns:46% 54%;padding:5px 12px;font-size:11.5px;
  border-bottom:1px solid #eee;color:#222}
.win-row:nth-child(odd){background:#f7f9fc}
.win-row .wk{color:#555}
.win-row .wv{font-weight:600;color:#0a3a8a}
.mk-flash{animation:flash 1.1s ease}
@keyframes flash{0%{background:#fff7d6}40%{background:#ffe98a}100%{}}
.setup-row.mk-flash{animation:flashb 1.1s ease}
@keyframes flashb{0%{background:#33489e}40%{background:#5570d8}100%{}}

/* Logo tab */
.bootlogo-box{background:#000;border-radius:10px;padding:18px;text-align:center;
  border:1px solid var(--line2);min-height:120px;display:grid;place-items:center}
.bootlogo-box img{max-width:100%;max-height:200px}
.logo-replace{margin-top:14px}
.logo-compare{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.logo-compare .lc{background:#000;border-radius:8px;padding:12px;text-align:center}
.logo-compare .lc img{max-width:100%;max-height:120px}
.logo-compare .lc label{display:block;color:var(--muted);font-size:11px;margin-top:6px}
.img-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;
  max-height:420px;overflow:auto}
.img-thumb{background:#0a0d15;border:1px solid var(--line);border-radius:8px;padding:6px;
  text-align:center}
.img-thumb img{max-width:100%;max-height:64px;object-fit:contain}
.img-thumb label{display:block;font-size:9.5px;color:var(--muted);margin-top:4px}
.img-thumb.boot{border-color:var(--acc);box-shadow:0 0 0 2px rgba(79,140,255,.2)}

/* FV / SMBIOS */
.smbios-list{display:flex;flex-direction:column;gap:6px;max-height:430px;overflow:auto}
.smb-item{background:var(--card2);border:1px solid var(--line);border-radius:8px;padding:8px 11px}
.smb-item .st{font-weight:700;font-size:12px;color:var(--acc2)}
.smb-item .ss{color:var(--muted);font-size:11.5px;margin-top:2px;word-break:break-word}

/* History */
.history-table{width:100%;border-collapse:collapse;font-size:13px}
.history-table th{text-align:left;padding:10px 8px;color:var(--muted);font-size:11px;
  text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--line2)}
.history-table td{padding:11px 8px;border-bottom:1px solid var(--line)}
.history-table tr:hover td{background:var(--card2)}
.st-pill{padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700}
.st-analyzed{background:rgba(79,140,255,.13);color:var(--acc2)}
.st-modified{background:rgba(243,177,59,.13);color:var(--warn)}
.st-verified{background:rgba(47,191,113,.13);color:var(--ok)}

/* result success box */
.result-box{padding:14px 16px;border-radius:11px;margin-top:6px}
.result-box.ok{background:rgba(47,191,113,.1);border:1px solid rgba(47,191,113,.35)}
.result-box.err{background:rgba(239,90,90,.1);border:1px solid rgba(239,90,90,.35)}
.result-box h4{margin:0 0 8px}
.verify-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px;font-size:12.5px;margin:10px 0}
.verify-grid .vk{color:var(--muted)}
.dl-row{display:flex;gap:10px;align-items:center;margin-top:12px;flex-wrap:wrap}

/* Session ended screen */
.session-ended[hidden]{display:none}
.session-ended{display:flex;justify-content:center;padding:40px 16px}
.se-card{background:var(--card);border:1px solid var(--line2);border-radius:18px;
  padding:42px 48px;text-align:center;max-width:480px}
.se-icon{width:64px;height:64px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center;
  font-size:30px;color:#fff;background:linear-gradient(135deg,var(--ok),#1f9e5a);
  box-shadow:0 8px 24px rgba(47,191,113,.4)}
.se-title{font-size:22px;font-weight:800;margin-bottom:8px}
.se-sub{color:var(--muted);font-size:13px;margin-bottom:22px;line-height:1.6}

/* Gallery thumb replace */
.img-thumb{position:relative;cursor:pointer;transition:.15s}
.img-thumb:not(.locked):hover{border-color:var(--acc);transform:translateY(-2px)}
.img-thumb.locked{opacity:.6;cursor:not-allowed}
.img-thumb .thumb-img{position:relative;min-height:48px;display:grid;place-items:center}
.thumb-replace{position:absolute;inset:0;border:none;background:rgba(8,12,22,.78);
  color:#fff;font-size:11px;font-weight:700;opacity:0;cursor:pointer;border-radius:8px;
  transition:.15s;display:grid;place-items:center}
.img-thumb:not(.locked):hover .thumb-replace{opacity:1}
.img-thumb.changed{border-color:var(--warn);box-shadow:0 0 0 2px rgba(243,177,59,.3)}
.thumb-badge{position:absolute;top:4px;right:4px;background:var(--warn);color:#1a1206;
  font-size:8.5px;font-weight:800;padding:2px 6px;border-radius:10px}

/* Verify panel */
.verify-panel{margin-top:16px}
.verify-panel h4{margin:0 0 4px;font-size:15px}
.vmode{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:14px;padding-bottom:14px;
  border-bottom:1px solid var(--line)}
.vmode label{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;cursor:pointer}
.vmode input{accent-color:var(--acc);width:15px;height:15px}
.vchecks{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
@media(max-width:760px){.vchecks{grid-template-columns:1fr}}
.vchecks.locked .vcheck{opacity:.85}
.vchecks.locked .vcheck input{pointer-events:none}
.vcheck{display:grid;grid-template-columns:18px 1fr;gap:4px 9px;align-items:start;
  background:var(--card2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;cursor:pointer}
.vcheck input{margin-top:2px;accent-color:var(--acc);width:16px;height:16px;grid-row:span 2}
.vc-label{font-weight:700;font-size:12.5px}
.vc-explain{font-size:11px;color:var(--muted);line-height:1.45}

/* Verify report */
.verify-summary{font-size:14px;font-weight:700;margin:14px 0 10px}
.vr-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.vr-row{display:flex;gap:11px;padding:11px 14px;border-radius:10px;background:var(--card2);
  border:1px solid var(--line);align-items:flex-start}
.vr-row.vr-fail{border-color:rgba(239,90,90,.45);background:rgba(239,90,90,.07)}
.vr-row.vr-warn{border-color:rgba(243,177,59,.4);background:rgba(243,177,59,.06)}
.vr-dot{width:11px;height:11px;border-radius:50%;margin-top:5px;flex:0 0 auto}
.vr-dot.pass{background:var(--ok)}.vr-dot.warn{background:var(--warn)}.vr-dot.fail{background:var(--fail)}
.vr-body{flex:1;min-width:0}
.vr-top{display:flex;align-items:center;gap:9px}
.vr-pill{font-size:10px;font-weight:800;padding:2px 8px;border-radius:10px;letter-spacing:.5px}
.vr-pill.pass{background:rgba(47,191,113,.15);color:var(--ok)}
.vr-pill.warn{background:rgba(243,177,59,.15);color:var(--warn)}
.vr-pill.fail{background:rgba(239,90,90,.15);color:var(--fail)}
.vr-detail{font-size:12.5px;margin-top:3px;word-break:break-word}
.vr-explain{margin-top:2px}
.vc-extra{margin-top:7px;padding:8px 10px;background:var(--bg2);border:1px solid var(--line);
  border-radius:7px;font-size:11.5px;font-family:monospace;color:var(--muted);
  word-break:break-word;line-height:1.6}

/* Completion banner */
.complete-banner{text-align:center;padding:26px 22px}
.complete-banner .cb-icon{font-size:40px;margin-bottom:6px}
.complete-banner h3{margin:0 0 8px;font-size:20px}
.complete-banner .dl-row{justify-content:center;margin-top:18px}
.next-steps{text-align:left;background:var(--bg2);border:1px solid var(--line);border-radius:11px;
  padding:14px 18px;margin-top:18px;font-size:12.5px;line-height:1.7}
.next-steps ol{margin:8px 0 0;padding-left:20px}
.next-steps code{background:var(--card2);padding:1px 6px;border-radius:5px;font-size:11px}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);
  background:var(--card2);border:1px solid var(--line2);padding:13px 22px;border-radius:11px;
  font-size:13px;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.5);transition:.3s;z-index:100;
  max-width:90vw}
.toast.show{transform:translateX(-50%) translateY(0)}

/* =====================================================================
   v11 — flash map, gallereya filtrlari, SMBIOS muharrir, prepare modal
   ===================================================================== */

/* Topbar: prepare tugma + badge */
.top-actions{display:flex;align-items:center;gap:12px}
.prepare-btn{position:relative;white-space:nowrap}
.prepare-btn[hidden]{display:none}
.chg-badge{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;
  margin-left:6px;border-radius:11px;background:rgba(255,255,255,.22);color:#fff;
  font-size:11px;font-weight:800;vertical-align:middle}
.prepare-btn:not(:disabled){animation:prePulse 2.2s ease-in-out infinite}
@keyframes prePulse{0%,100%{box-shadow:0 4px 14px rgba(79,140,255,.35)}
  50%{box-shadow:0 4px 22px rgba(79,140,255,.7)}}

/* Results layout: chap rail + o'ng kontent (doimiy) */
.results-layout,.analyze-layout{display:flex;gap:18px;align-items:flex-start;margin-top:16px}
.flash-rail{width:262px;flex:none;position:sticky;top:84px}
.flash-rail h3{margin:0 0 12px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted2);font-weight:700}
.results-main,.analyze-main{flex:1;min-width:0}
.analyze-layout[hidden]{display:none}
@media(max-width:980px){.results-layout,.analyze-layout{flex-direction:column}
  .flash-rail{width:100%;position:static}.flashmap{height:140px!important}}
/* bo'sh holat placeholderi */
.fm-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;text-align:center;color:var(--muted2);font-size:11.5px;line-height:1.5;padding:18px;
  pointer-events:none;z-index:2}
.fm-empty .fme-ic{font-size:30px;opacity:.55}
.flashmap.has-data .fm-empty{display:none}

/* Flash map (vertikal 16MB, matritsa skani) */
.flashmap{position:relative;height:580px;margin-left:50px;border-radius:10px;
  background:linear-gradient(180deg,#0b101c,#0e1426);border:1px solid var(--line);overflow:hidden;
  box-shadow:inset 0 0 40px rgba(0,0,0,.5)}
.flashmap.has-data::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(79,140,255,.06) 1px,transparent 1px);background-size:100% 18px;opacity:.5}
.fm-region{position:absolute;left:0;right:0;display:flex;align-items:center;padding-left:9px;
  font-size:10px;font-family:monospace;letter-spacing:.04em;color:rgba(255,255,255,.85);
  overflow:hidden;border-bottom:1px solid rgba(0,0,0,.4);transition:filter .15s;cursor:default}
.fm-region:hover{filter:brightness(1.25)}
.fm-region.r-Descriptor{background:linear-gradient(90deg,#3a4763,#28324c)}
.fm-region.r-ME{background:linear-gradient(90deg,#7a5a2a,#523c1b)}
.fm-region.r-BIOS{background:linear-gradient(90deg,#1e4a3f,#163a31)}
.fm-region.r-GbE{background:linear-gradient(90deg,#3a2a5e,#2a1f47)}
.fm-region.r-PDR{background:linear-gradient(90deg,#5a2a3a,#43202c)}
.fm-tick{position:absolute;left:-50px;width:44px;text-align:right;font-family:monospace;
  font-size:9px;color:var(--muted2);transform:translateY(-50%)}
.fm-tick::after{content:"";position:absolute;right:-6px;top:50%;width:5px;height:1px;background:var(--line2)}
.fm-fv{position:absolute;left:2px;width:5px;height:4px;background:rgba(107,164,255,.7);border-radius:1px}
.fm-mk{position:absolute;left:0;right:0;height:2px;background:var(--acc);box-shadow:0 0 7px var(--acc);
  transition:.2s;cursor:default;z-index:3}
.fm-mk.logo{background:#a87cf0;box-shadow:0 0 8px #a87cf0}
.fm-mk.smbios{background:var(--warn);box-shadow:0 0 8px var(--warn)}
.fm-mk.fit{background:var(--fail);box-shadow:0 0 8px var(--fail)}
.fm-mk .fm-lbl{position:absolute;left:7px;top:-7px;font-family:monospace;font-size:8.5px;
  background:#0b101c;padding:1px 5px;border-radius:3px;white-space:nowrap;border:1px solid var(--line)}
.fm-mk.logo .fm-lbl{color:#bb9bf5}.fm-mk.smbios .fm-lbl{color:var(--warn)}.fm-mk.fit .fm-lbl{color:var(--fail)}
.fm-mk.hot{height:5px;filter:brightness(1.7);box-shadow:0 0 16px currentColor;z-index:4}
.fm-scan{position:absolute;left:0;right:0;height:40px;pointer-events:none;opacity:0;z-index:5;
  background:linear-gradient(180deg,transparent,rgba(79,140,255,.28),rgba(47,191,113,.18),transparent)}
.flashmap.scanning .fm-scan{animation:fmSweep 1.1s ease-in-out infinite}
/* tablar yuklanmagunча o'chiq (lekin ko'rinadi — workbench tayyor ko'rinishi) */
.tabs.tabs-disabled{opacity:.5;pointer-events:none}
@keyframes fmSweep{0%{top:-40px;opacity:1}100%{top:580px;opacity:1}}
.fm-legend{margin-top:10px;display:flex;flex-direction:column;gap:5px;font-size:11px;color:var(--muted)}
.fm-legend .lg{display:flex;align-items:center;gap:7px}
.fm-legend .lg i{width:12px;height:4px;border-radius:2px;flex:none}

/* Rasm filtrlari + gallereya */
.img-filters{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.img-filt{font-size:12px;cursor:pointer;padding:6px 13px;border-radius:18px;
  border:1px solid var(--line);background:var(--bg2);color:var(--muted);font-weight:600}
.img-filt:hover{border-color:var(--line2);color:var(--txt)}
.img-filt.on{background:var(--acc);border-color:var(--acc);color:#fff}
.gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:13px}
.gitem{background:var(--bg2);border:1px solid var(--line);border-radius:11px;overflow:hidden;
  display:flex;flex-direction:column}
.gitem.edited{border-color:var(--ok);box-shadow:0 0 0 1px var(--ok)}
.gitem.boot{border-color:var(--warn)}
.gthumb{height:122px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;
  background:repeating-conic-gradient(#192133 0% 25%,#141b2a 0% 50%) 50%/18px 18px}
.gthumb img{max-width:100%;max-height:100%}
.gthumb .gbadge{position:absolute;top:6px;right:6px;font-size:9px;font-weight:800;padding:2px 6px;
  border-radius:5px;background:var(--ok);color:#04231a}
.gthumb .gstar{position:absolute;top:6px;left:6px;font-size:12px}
.gmeta{padding:9px 11px}
.gmeta .grole{font-weight:700;font-size:12.5px}
.gmeta .gspec{font-family:monospace;color:var(--muted2);font-size:10px;margin-top:2px}
.gmeta .gacts{display:flex;gap:6px;margin-top:9px}
.gmeta .gacts .btn{flex:1;text-align:center;padding:6px;font-size:11px}

/* SMBIOS to'liq muharrir */
.smbios-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.smbios-toolbar input[type=search]{flex:1;min-width:180px;background:var(--bg2);border:1px solid var(--line);
  color:var(--txt);padding:9px 13px;border-radius:9px;font-size:13px}
.smbios-toolbar .chk{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted);cursor:pointer;white-space:nowrap}
.smb-struct{background:var(--bg2);border:1px solid var(--line);border-radius:11px;overflow:hidden;margin-bottom:11px}
.smb-struct>summary{cursor:pointer;list-style:none;padding:12px 15px;display:flex;align-items:center;gap:11px;font-weight:700}
.smb-struct>summary::-webkit-details-marker{display:none}
.smb-struct>summary .tnum{font-family:monospace;font-size:10px;color:#0b101c;background:var(--muted);
  padding:2px 7px;border-radius:5px;font-weight:800}
.smb-struct.key>summary .tnum{background:var(--acc2)}
.smb-struct>summary .cnt{margin-left:auto;font-family:monospace;font-size:10px;color:var(--muted2);font-weight:500}
.smb-fields{padding:5px 15px 15px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:11px}
.smb-field{display:grid;grid-template-columns:220px 1fr;gap:13px;align-items:start}
@media(max-width:560px){.smb-field{grid-template-columns:1fr}}
.smb-field>label{font-size:12.5px;color:var(--muted);padding-top:8px}
.smb-field .sidx{font-family:monospace;font-size:9px;color:var(--muted2);margin-left:4px}
.smb-field .q{display:inline-grid;place-items:center;width:15px;height:15px;border:1px solid var(--line2);
  border-radius:50%;font-size:9px;color:var(--muted);margin-left:5px;cursor:help}
.smb-field .inwrap{display:flex;flex-direction:column;gap:5px}
.smb-field input{font-family:monospace;font-size:13px;background:var(--card2);border:1px solid var(--line2);
  color:var(--txt);padding:8px 11px;border-radius:8px;width:100%}
.smb-field input:focus{outline:none;border-color:var(--acc)}
.smb-field input.changed{border-color:var(--ok);background:rgba(47,191,113,.08)}
.smb-field.ro input{color:var(--muted2);background:transparent;cursor:not-allowed}
.smb-field .fhelp{font-size:11px;color:var(--muted2);line-height:1.5}

/* Modal — prepare/eksport bosqichi */
.modal-wrap{position:fixed;inset:0;background:rgba(5,8,14,.74);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}
.modal-box{background:var(--card);border:1px solid var(--line2);border-radius:16px;width:min(720px,96vw);
  max-height:92vh;overflow:auto;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.modal-head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:var(--card);z-index:2}
.modal-head h3{margin:0;font-size:17px}
.modal-head .mclose{margin-left:auto;background:transparent;border:none;color:var(--muted);font-size:22px;cursor:pointer;line-height:1}
.modal-body{padding:20px 22px}
.steps{display:flex;gap:8px;margin-bottom:20px}
.step{flex:1;text-align:center;font-size:11.5px;color:var(--muted2);padding:8px 4px;border-radius:9px;
  border:1px solid var(--line);background:var(--bg2);font-weight:600}
.step.active{color:#fff;border-color:var(--acc);background:rgba(79,140,255,.16)}
.step.done{color:var(--ok);border-color:rgba(47,191,113,.4)}
.step b{display:block;font-size:15px;margin-bottom:2px}
.chg-list{display:flex;flex-direction:column;gap:8px;margin:6px 0 16px}
.chg-item{display:flex;gap:12px;align-items:center;background:var(--bg2);border:1px solid var(--line);
  border-radius:10px;padding:10px 13px}
.chg-item .ci-ico{width:34px;height:34px;border-radius:8px;flex:none;display:grid;place-items:center;
  background:var(--card2);font-size:16px;overflow:hidden}
.chg-item .ci-ico img{width:100%;height:100%;object-fit:cover}
.chg-item .ci-main{min-width:0}
.chg-item .ci-t{font-weight:600;font-size:13px}
.chg-item .ci-d{font-size:11.5px;color:var(--muted);font-family:monospace;word-break:break-word}
.chg-item .ci-d b{color:var(--ok)}
.chg-item .ci-d s{color:var(--muted2)}
.modal-actions{display:flex;gap:10px;align-items:center;padding:16px 22px;border-top:1px solid var(--line);
  position:sticky;bottom:0;background:var(--card)}
.modal-actions .sp{flex:1}
.vmodes{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px;font-size:12.5px}
.vmodes label{display:flex;align-items:center;gap:6px;cursor:pointer}
.sect-h{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted2);
  font-weight:700;margin:4px 0 10px;display:flex;align-items:center;gap:10px}
.sect-h::after{content:"";flex:1;height:1px;background:var(--line)}
.note{color:var(--muted)}
.btn.big{padding:13px 22px;font-size:14px}

/* Rasmlar bo'limi boyitish — toolbar, spotlight, dublikat, lightbox */
.img-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.img-toolbar input[type=search]{flex:1;min-width:180px;background:var(--bg2);border:1px solid var(--line);
  color:var(--txt);padding:9px 13px;border-radius:9px;font-size:13px}
.img-toolbar select{background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  padding:9px 11px;border-radius:9px;font-size:13px;cursor:pointer}
.img-toolbar .sp{flex:1}
#imgEditedInfo b{color:var(--ok)}

/* Boot logo spotlight */
.boot-spot[hidden]{display:none}
.boot-spot{display:flex;gap:20px;align-items:center;flex-wrap:wrap;
  border-color:rgba(243,177,59,.4);background:linear-gradient(180deg,rgba(243,177,59,.06),var(--card))}
.bs-preview{width:280px;max-width:100%;aspect-ratio:580/194;border-radius:10px;flex:none;
  background:repeating-conic-gradient(#192133 0% 25%,#141b2a 0% 50%) 50%/18px 18px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--line)}
.bs-preview img{max-width:100%;max-height:100%}
.bs-info{flex:1;min-width:220px}
.bs-info h3{margin:0 0 4px;display:flex;align-items:center;gap:9px}
.bs-info .bs-spec{font-family:monospace;color:var(--muted2);font-size:11px;margin:2px 0 12px}
.bs-actions{display:flex;gap:9px;flex-wrap:wrap}
.bs-compare{display:flex;gap:14px;margin-top:14px;flex-wrap:wrap}
.bs-compare .lc{text-align:center}
.bs-compare .lc img{max-width:200px;max-height:80px;border:1px solid var(--line);border-radius:7px;background:#000}
.bs-compare .lc label{display:block;font-size:11px;color:var(--muted);margin-top:4px}

/* dublikat badge gallereyada */
.gthumb .gdup{position:absolute;bottom:6px;right:6px;font-size:9px;font-weight:800;padding:2px 6px;
  border-radius:5px;background:rgba(79,140,255,.85);color:#fff}
.gitem .gthumb{cursor:zoom-in}

/* Lightbox — rasm detali */
.lb-grid{display:grid;grid-template-columns:1fr 240px;gap:20px}
@media(max-width:620px){.lb-grid{grid-template-columns:1fr}}
.lb-big{min-height:240px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  overflow:hidden;background:repeating-conic-gradient(#192133 0% 25%,#141b2a 0% 50%) 50%/22px 22px;border:1px solid var(--line)}
.lb-big img{max-width:100%;max-height:60vh}
.lb-meta{display:flex;flex-direction:column;gap:9px}
.lb-meta .lbm{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;
  border-bottom:1px dashed var(--line);padding-bottom:6px}
.lb-meta .lbm .lk{color:var(--muted)}
.lb-meta .lbm .lv{font-family:monospace;color:var(--txt);text-align:right;word-break:break-all}
.lb-meta .btn{width:100%;text-align:center;margin-top:4px}
.lb-cmp{display:flex;gap:12px;margin-top:8px}
.lb-cmp .lc{flex:1;text-align:center}
.lb-cmp .lc img{max-width:100%;max-height:120px;border:1px solid var(--line);border-radius:7px;background:#000}
.lb-cmp .lc label{display:block;font-size:10.5px;color:var(--muted);margin-top:3px}
.toast.ok{border-color:var(--ok)}.toast.err{border-color:var(--fail)}

/* v2 brand tag */
.ver-tag{font-family:ui-monospace,monospace;font-size:9px;font-weight:800;letter-spacing:.08em;
  color:#1a1205;background:var(--warn);padding:2px 7px;border-radius:5px;margin-left:10px;vertical-align:4px}

/* ===== v2 PRO — Xavfsizlik / Modullar / Mikrokod ===== */
.sec-verdict{display:flex;gap:14px;align-items:flex-start;border-radius:14px;padding:16px 18px;margin-bottom:10px;border:1px solid var(--line)}
.sec-verdict.safe{background:rgba(47,191,113,.08);border-color:rgba(47,191,113,.45)}
.sec-verdict.unsafe{background:rgba(243,177,59,.09);border-color:rgba(243,177,59,.5)}
.sec-verdict .vic{font-size:30px;line-height:1}
.sec-verdict .vt{font-weight:700;font-size:15px;margin-bottom:3px}
.sec-verdict .vd{color:var(--muted);font-size:13px;line-height:1.55}
.sec-items{display:flex;flex-direction:column;gap:9px}
.sec-row{display:flex;gap:13px;align-items:flex-start;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:12px 15px}
.sec-row .sdot{width:9px;height:9px;border-radius:50%;margin-top:6px;flex:none}
.sec-row .sdot.ok{background:var(--ok)}.sec-row .sdot.warn{background:var(--warn)}.sec-row .sdot.err{background:var(--fail)}.sec-row .sdot.info{background:var(--acc2)}
.sec-row .smain{flex:1;min-width:0}
.sec-row .sl{font-weight:600}
.sec-row .sv{font-family:ui-monospace,monospace;color:var(--acc2);margin-left:8px;font-size:12.5px}
.sec-row .sd{color:var(--muted);font-size:12.5px;margin-top:3px}
.data-table{width:100%;border-collapse:collapse;font-size:12.5px}
.data-table th{text-align:left;color:var(--muted2);font-weight:700;font-size:10px;letter-spacing:.09em;text-transform:uppercase;padding:9px 14px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--card);z-index:1}
.data-table td{padding:8px 14px;border-bottom:1px solid var(--line);font-family:ui-monospace,monospace;vertical-align:top}
.data-table tr:hover td{background:var(--bg2)}
.data-table .name{font-family:var(--font);font-weight:600}
.data-table .dl{color:var(--acc2);cursor:pointer;text-decoration:none;font-weight:700}
.data-table .kind-pill{font-family:var(--font);font-size:10px;padding:1px 7px;border-radius:5px;background:var(--card2);border:1px solid var(--line);color:var(--muted)}

/* ===== v2 PRO — Hex ko'ruvchi / Diff ===== */
.hex-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.hex-toolbar input,.hex-toolbar select{background:var(--bg2);border:1px solid var(--line);color:var(--txt);padding:7px 10px;border-radius:7px;font-size:12px;font-family:ui-monospace,monospace}
.hex-toolbar #hexGoto{width:130px}.hex-toolbar #hexSearch{width:160px}
.hex-pos{margin-bottom:6px;font-family:ui-monospace,monospace}
.hex-view{background:#0a0e16;border:1px solid var(--line);border-radius:10px;padding:12px 14px;overflow:auto;max-height:60vh;font-family:ui-monospace,monospace;font-size:12px;line-height:1.55;color:#cdd6e6;white-space:pre}
.hex-view .o{color:var(--muted2)}
.hex-view .a{color:var(--acc2)}
.hex-results{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}
.hex-results .hr{font-family:ui-monospace,monospace;font-size:11px;padding:3px 9px;border-radius:6px;background:var(--bg2);border:1px solid var(--line);cursor:pointer;color:var(--acc2)}
.hex-results .hr:hover{border-color:var(--acc)}
.diff-grid{display:flex;flex-direction:column;gap:9px}
.diff-row{display:flex;gap:12px;background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:11px 14px;font-size:13px;align-items:flex-start;flex-wrap:wrap}
.diff-row .dk{color:var(--muted);min-width:170px;font-weight:600}
.diff-row .dv{flex:1;min-width:200px}
.diff-chip{font-size:11px;padding:1px 8px;border-radius:5px;margin:0 5px 4px 0;display:inline-block;font-family:ui-monospace,monospace}
.diff-chip.add{background:rgba(47,191,113,.15);color:var(--ok)}
.diff-chip.rem{background:rgba(239,90,90,.15);color:var(--fail)}
.diff-chip.chg{background:rgba(243,177,59,.15);color:var(--warn)}
.diff-chip.same{background:var(--card2);color:var(--muted)}

/* ===== v2 PRO — Setup / IFR (AMIBCP-lite) ===== */
.setup-fs{background:var(--bg2);border:1px solid var(--line);border-radius:11px;overflow:hidden;margin-bottom:10px}
.setup-fs>summary{cursor:pointer;list-style:none;padding:11px 15px;font-weight:700;display:flex;align-items:center;gap:10px}
.setup-fs>summary::-webkit-details-marker{display:none}
.setup-fs>summary .cnt{margin-left:auto;font-family:ui-monospace,monospace;font-size:10px;color:var(--muted2);font-weight:500}
.setup-form{padding:2px 15px 12px;border-top:1px solid var(--line)}
.setup-form>.fh{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--acc2);font-weight:700;margin:11px 0 5px}
.setup-q{display:flex;gap:10px;align-items:baseline;padding:5px 0;border-bottom:1px solid var(--line);font-size:12.5px;flex-wrap:wrap}
.setup-q:last-child{border-bottom:none}
.setup-q .qt{font-size:9px;padding:1px 6px;border-radius:4px;background:var(--card2);border:1px solid var(--line);color:var(--muted);font-family:ui-monospace,monospace}
.setup-q .qn{font-weight:600;flex:1;min-width:170px}
.setup-q .qd{font-family:ui-monospace,monospace;color:var(--ok)}
.setup-q .qo{color:var(--muted2);font-size:11px;width:100%}
.setup-q .qf{font-size:9px;padding:1px 6px;border-radius:4px;font-family:ui-monospace,monospace}
.setup-q .qf.hid{background:rgba(243,177,59,.15);color:var(--warn)}
.setup-q .qf.lock{background:rgba(239,90,90,.15);color:var(--fail)}

/* ===== v2 PRO — Profillar / Partiya ===== */
.prof-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.prof-card{background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:14px 16px}
.prof-card .pn{font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.prof-card .pmeta{font-size:11.5px;color:var(--muted);margin-top:6px;line-height:1.6}
.prof-card .pmeta code{background:var(--card2);padding:1px 6px;border-radius:4px;font-size:11px}
.prof-card .pacts{display:flex;gap:7px;margin-top:11px}
.prof-badge{font-size:9px;font-weight:800;padding:1px 7px;border-radius:5px;background:rgba(243,177,59,.16);color:var(--warn)}
.batch-form{display:flex;gap:14px;align-items:center;flex-wrap:wrap;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:14px 16px}
.batch-form label{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted)}
.batch-form select,.batch-form input[type=number]{background:var(--card2);border:1px solid var(--line2);color:var(--txt);padding:7px 10px;border-radius:7px;font-size:13px}
.batch-table{width:100%;border-collapse:collapse;font-size:12.5px;margin-top:6px}
.batch-table th{text-align:left;color:var(--muted2);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:8px 12px;border-bottom:1px solid var(--line)}
.batch-table td{padding:8px 12px;border-bottom:1px solid var(--line);font-family:ui-monospace,monospace}
.batch-table .ok{color:var(--ok)}.batch-table .bad{color:var(--fail)}
.batch-sum{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin:6px 0 12px}

/* ===== v2 PRO — Tema variantlari (Phase UX) ===== */
body.theme-amber{--acc:#f4a53a;--acc2:#ffc46b}
body.theme-teal{--acc:#2fbf9f;--acc2:#5fd9bd}
.theme-btn{font-size:15px;line-height:1;padding:9px 12px}
/* Yo'riqnoma modal */
.guide h4{margin:16px 0 6px;font-size:14px;color:var(--acc2)}
.guide ol,.guide ul{margin:6px 0;padding-left:20px;line-height:1.7;font-size:13px}
.guide li{margin:3px 0}
.guide .warn-box{background:rgba(243,177,59,.1);border:1px solid rgba(243,177,59,.4);border-radius:9px;padding:11px 14px;margin:12px 0;font-size:12.5px;line-height:1.6}
.guide code{background:var(--card2);padding:1px 6px;border-radius:5px;font-size:12px}
.modal-box.wide{width:min(680px,96vw)}
.modal-body.scroll{max-height:70vh;overflow:auto}
