/* ===== OMNISYNX DEFENCE — enterprise console theme ===== */
:root{
  --bg:#070b12; --bg2:#0b1220; --panel:rgba(16,24,38,.72); --panel2:rgba(22,32,50,.6);
  --stroke:rgba(120,160,220,.14); --stroke2:rgba(120,160,220,.28);
  --ink:#e7eefc; --ink2:#8aa0c4; --ink3:#5b6f92;
  --cyan:#38e1ff; --cyan2:#12b6da; --amber:#ffb648; --grn:#54e6a4; --red:#ff5d6c; --violet:#9b8cff;
  --glow:0 0 0 1px rgba(56,225,255,.25), 0 8px 30px rgba(0,0,0,.5);
  --mono:"JetBrains Mono",ui-monospace,monospace; --sans:"Inter",system-ui,sans-serif; --disp:"Sora","Inter",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;overflow:hidden}
body{font-family:var(--sans);color:var(--ink);background:
  radial-gradient(1200px 700px at 78% -10%,rgba(56,225,255,.10),transparent 60%),
  radial-gradient(900px 600px at 12% 110%,rgba(155,140,255,.10),transparent 55%),
  linear-gradient(180deg,#060a11,#0a0f1a);}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.35;
  background-image:linear-gradient(rgba(120,160,220,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(120,160,220,.05) 1px,transparent 1px);
  background-size:44px 44px;mask:radial-gradient(circle at 60% 30%,#000,transparent 85%)}
.hidden{display:none!important}

.app{position:relative;z-index:1;height:100vh;display:grid;grid-template-rows:66px 1fr;grid-template-columns:428px 1fr;
  grid-template-areas:"top top" "panel theatre";gap:0}

/* ===== topbar ===== */
.topbar{grid-area:top;display:flex;align-items:center;justify-content:space-between;padding:0 20px;
  border-bottom:1px solid var(--stroke);background:linear-gradient(180deg,rgba(12,19,32,.9),rgba(9,14,24,.72));backdrop-filter:blur(14px)}
.brand{display:flex;align-items:center;gap:13px}
.logo svg{width:34px;height:34px;filter:drop-shadow(0 0 10px rgba(56,225,255,.5))}
.logo .hex{fill:none;stroke:var(--cyan);stroke-width:1.4;opacity:.9}
.logo .hexi{fill:rgba(56,225,255,.10);stroke:var(--cyan2);stroke-width:1.2}
.logo .dot{fill:var(--cyan)}
.wordmark .name{font-family:var(--disp);font-weight:800;letter-spacing:2px;font-size:19px;line-height:1}
.wordmark .name span{color:var(--cyan)}
.wordmark .tag{font-size:11px;letter-spacing:2.5px;color:var(--ink3);text-transform:uppercase;margin-top:4px}
.topmeta{display:flex;align-items:center;gap:22px}
.stat{display:flex;flex-direction:column;gap:3px}
.stat label{font-size:9.5px;letter-spacing:1.6px;color:var(--ink3)}
.stat b{font-family:var(--mono);font-size:13px;color:var(--ink);font-weight:600}
.pill{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;letter-spacing:1.5px;color:var(--grn);
  border:1px solid rgba(84,230,164,.3);border-radius:20px;padding:6px 13px;background:rgba(84,230,164,.07)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--grn);box-shadow:0 0 8px var(--grn);animation:pulse 1.8s infinite}
.pill.busy{color:var(--amber);border-color:rgba(255,182,72,.35);background:rgba(255,182,72,.08)}
.pill.busy .dot{background:var(--amber);box-shadow:0 0 8px var(--amber)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.clock{font-family:var(--mono);font-size:14.5px;color:var(--cyan);letter-spacing:1px;min-width:88px;text-align:right}

/* ===== panel ===== */
.panel{grid-area:panel;overflow:hidden;padding:12px;display:flex;flex-direction:column;gap:10px;min-height:0;
  border-right:1px solid var(--stroke);background:linear-gradient(180deg,rgba(9,14,24,.5),rgba(8,12,20,.2))}
.panel::-webkit-scrollbar{width:9px}.panel::-webkit-scrollbar-thumb{background:var(--stroke2);border-radius:6px}
.card{flex:0 0 auto;background:var(--panel);border:1px solid var(--stroke);border-radius:14px;padding:12px 13px;backdrop-filter:blur(12px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03),0 6px 20px rgba(0,0,0,.35)}
/* job-queue fills the remaining panel height & scrolls internally (fully visible, no double-scroll) */
.card.grow{flex:1 1 0;min-height:200px;display:flex;flex-direction:column}
.ttl{font-family:var(--mono);font-size:12.5px;letter-spacing:2px;color:var(--ink2);text-transform:uppercase;
  display:flex;align-items:center;gap:9px;margin-bottom:13px}
.ttl .ix{font-weight:700;color:var(--cyan);background:rgba(56,225,255,.1);border:1px solid rgba(56,225,255,.25);
  border-radius:6px;padding:2px 7px;font-size:11px}
.ttl .cnt{margin-left:auto;color:var(--ink3)}
.hint{font-size:12px;color:var(--ink3);line-height:1.55;margin:11px 0 0}
.hint b{color:var(--ink2);font-weight:600}

.seg{display:grid;grid-template-columns:1fr 1fr 1fr;gap:5px;background:rgba(0,0,0,.28);border:1px solid var(--stroke);border-radius:11px;padding:4px}
.seg.seg2{grid-template-columns:1fr 1fr}
.seg button{font-family:var(--sans);font-size:12.5px;font-weight:600;color:var(--ink2);background:transparent;border:0;
  border-radius:8px;padding:11px 4px;cursor:pointer;transition:.18s;letter-spacing:.2px}
.seg button:hover{color:var(--ink)}
.seg button.on{color:#04121a;background:linear-gradient(180deg,var(--cyan),var(--cyan2));box-shadow:0 3px 12px rgba(56,225,255,.35)}

.aoiState{font-family:var(--mono);font-size:13px;color:var(--ink2);background:rgba(0,0,0,.25);border:1px dashed var(--stroke2);
  border-radius:9px;padding:11px 12px;line-height:1.55}
.aoiRes{font-family:var(--mono);font-size:12px;margin-top:9px;line-height:1.5}
.aoiRes .ok{color:var(--grn)}.aoiRes .warn{color:var(--amber)}.aoiRes .bad{color:var(--red)}
.btnrow{display:flex;gap:8px;margin-top:10px}
.btn{font-family:var(--sans);font-weight:600;font-size:13.5px;border-radius:10px;padding:12px 14px;cursor:pointer;border:1px solid var(--stroke2);
  background:var(--panel2);color:var(--ink);transition:.18s;letter-spacing:.3px}
.btn:hover{border-color:var(--cyan2);box-shadow:0 0 0 1px rgba(56,225,255,.2)}
.btn.ghost{flex:1;background:rgba(255,255,255,.02)}
.btn.run{width:100%;margin-top:12px;color:#04121a;font-weight:800;letter-spacing:1px;border:0;
  background:linear-gradient(120deg,var(--cyan),var(--grn));box-shadow:0 6px 22px rgba(56,225,255,.3)}
.btn.run:hover{filter:brightness(1.08)}
.btn:disabled{opacity:.5;cursor:not-allowed}

.fl{display:flex;flex-direction:column;gap:6px;margin-bottom:11px}
.fl span{font-size:11.5px;letter-spacing:.8px;color:var(--ink2);text-transform:uppercase}
.fl input,.fl textarea{font-family:var(--mono);font-size:14px;color:var(--ink);background:rgba(0,0,0,.3);
  border:1px solid var(--stroke2);border-radius:9px;padding:11px 12px;outline:none;transition:.15s;resize:vertical}
.fl input:focus,.fl textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(56,225,255,.12)}
.fl input[type=date]{color-scheme:dark}
.chk{display:flex;gap:10px;align-items:flex-start;margin:2px 0 12px;cursor:pointer;
  background:rgba(56,225,255,.05);border:1px solid var(--stroke2);border-radius:10px;padding:11px 12px}
.chk input{margin-top:2px;width:17px;height:17px;accent-color:var(--cyan);cursor:pointer;flex:0 0 auto}
.chk span{font-size:12.5px;color:var(--ink);line-height:1.45}
.chk em{display:block;color:var(--ink3);font-style:normal;font-size:11px;margin-top:2px}

/* jobs */
.jobs{flex:1 1 0;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-right:-4px;padding-right:4px}
.jobs::-webkit-scrollbar{width:7px}.jobs::-webkit-scrollbar-thumb{background:var(--stroke2);border-radius:6px}
.job{flex:0 0 auto;border:1px solid var(--stroke);border-radius:11px;padding:10px 11px;background:var(--panel2);cursor:pointer;transition:.16s;position:relative;overflow:hidden}
.job:hover{border-color:var(--stroke2);transform:translateY(-1px)}
.job.sel{border-color:var(--cyan);box-shadow:0 0 0 1px rgba(56,225,255,.3),0 6px 18px rgba(0,0,0,.4)}
.job::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ink3)}
.job.done::before{background:var(--grn)}.job.processing::before{background:var(--amber)}
.job.error::before{background:var(--red)}.job.queued::before{background:var(--cyan2)}
.job .jr{display:flex;align-items:center;gap:8px}
.job .jn{font-family:var(--mono);font-weight:600;font-size:14.5px;color:var(--ink)}
.job .op{font-size:10.5px;letter-spacing:1px;color:var(--ink3);text-transform:uppercase;margin-left:auto}
.chip{font-family:var(--mono);font-size:10px;letter-spacing:1px;padding:3px 8px;border-radius:20px;text-transform:uppercase;font-weight:600}
.chip.done{color:var(--grn);background:rgba(84,230,164,.12)}
.chip.processing{color:var(--amber);background:rgba(255,182,72,.13)}
.chip.queued{color:var(--cyan);background:rgba(56,225,255,.12)}
.chip.error{color:var(--red);background:rgba(255,93,108,.13)}
.job .jsub{font-family:var(--mono);font-size:11.5px;color:var(--ink3);margin-top:7px;display:flex;gap:9px;flex-wrap:wrap}
.job .del{position:absolute;right:8px;bottom:8px;font-size:10px;color:var(--ink3);opacity:0;transition:.15s;background:none;border:0;cursor:pointer}
.job:hover .del{opacity:1}.job .del:hover{color:var(--red)}
.spin{width:11px;height:11px;border:2px solid rgba(255,182,72,.3);border-top-color:var(--amber);border-radius:50%;animation:sp .7s linear infinite;display:inline-block}
@keyframes sp{to{transform:rotate(360deg)}}
.empty{color:var(--ink3);font-size:11px;text-align:center;padding:24px 0;font-family:var(--mono)}

/* ===== theatre / map ===== */
.theatre{grid-area:theatre;position:relative;overflow:hidden}
#map{position:absolute;inset:0;background:#05080e}
.leaflet-container{background:#05080e;font-family:var(--sans)}
/* search bar (top-center of the map) */
.searchbar{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:640;display:flex;align-items:center;gap:8px;
  background:var(--panel);border:1px solid var(--stroke2);border-radius:12px;backdrop-filter:blur(16px);padding:7px 9px 7px 13px;
  box-shadow:0 12px 34px rgba(0,0,0,.5);width:min(460px,60vw)}
.searchbar .sic{font-size:16px;color:var(--cyan)}
.searchbar input{flex:1;background:transparent;border:0;outline:none;color:var(--ink);font-family:var(--mono);font-size:13px}
.searchbar input::placeholder{color:var(--ink3)}
.searchbar button{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:1px;color:#04121a;cursor:pointer;border:0;
  border-radius:8px;padding:7px 13px;background:linear-gradient(120deg,var(--cyan),var(--cyan2))}
.searchbar button:hover{filter:brightness(1.08)}

/* live map HUD (zoom / AOI area / center) */
.mapinfo{position:absolute;left:14px;top:66px;z-index:600;display:flex;gap:2px;flex-direction:column;
  background:var(--panel);border:1px solid var(--stroke2);border-radius:12px;backdrop-filter:blur(16px);
  padding:10px 13px;box-shadow:0 12px 34px rgba(0,0,0,.5)}
.mapinfo .mi{display:flex;align-items:baseline;gap:7px;line-height:1.5}
.mapinfo label{font-family:var(--mono);font-size:9px;letter-spacing:1.5px;color:var(--ink3);min-width:64px}
.mapinfo b{font-family:var(--mono);font-size:14px;color:var(--cyan);font-weight:600}
.mapinfo .mi:nth-child(2) b{color:var(--grn)}
.mapinfo span{font-family:var(--mono);font-size:10px;color:var(--ink3)}
.watermark{position:absolute;left:14px;bottom:11px;z-index:500;font-family:var(--mono);font-size:9px;letter-spacing:2.5px;
  color:rgba(138,160,196,.35);pointer-events:none;text-transform:uppercase}
/* larger, more grabbable AOI handles */
.aoih{width:22px;height:22px;background:radial-gradient(circle,#eaf9ff 0 30%,var(--cyan) 32%);border:2.5px solid #04121a;
  border-radius:50%;box-shadow:0 0 0 2px rgba(56,225,255,.35),0 0 12px rgba(56,225,255,.8);cursor:grab}
.aoih:active{cursor:grabbing}
.aoih.center{background:radial-gradient(circle,#fff2d6 0 30%,var(--amber) 32%);box-shadow:0 0 0 2px rgba(255,182,72,.35),0 0 12px rgba(255,182,72,.8)}

/* custom swipe divider */
.swipe-divider{position:absolute;top:0;bottom:0;width:0;z-index:640;pointer-events:none;display:none}
.swipe-divider .sd-line{position:absolute;top:0;bottom:0;left:-9px;width:18px;cursor:ew-resize;pointer-events:auto}
.swipe-divider .sd-line::after{content:"";position:absolute;top:0;bottom:0;left:8px;width:2px;background:var(--cyan);box-shadow:0 0 14px rgba(56,225,255,.85)}
.swipe-divider .sd-knob{position:absolute;top:50%;left:-19px;width:38px;height:38px;transform:translateY(-50%);
  border-radius:50%;background:linear-gradient(180deg,#0c1322,#0a1018);border:2px solid var(--cyan);color:var(--cyan);
  display:flex;align-items:center;justify-content:center;font-size:15px;cursor:ew-resize;pointer-events:auto;
  box-shadow:0 0 16px rgba(56,225,255,.6),inset 0 1px 0 rgba(255,255,255,.1)}

/* segmentation legend on the map */
.maplegend{position:absolute;right:14px;bottom:78px;z-index:600;background:var(--panel);border:1px solid var(--stroke2);
  border-radius:13px;backdrop-filter:blur(16px);padding:11px 13px;max-width:230px;box-shadow:0 14px 40px rgba(0,0,0,.55)}
.maplegend .mlhead{font-family:var(--mono);font-size:10.5px;letter-spacing:2px;color:var(--ink3);margin-bottom:10px}
.maplegend .mlbody{display:flex;flex-direction:column;gap:7px}
.maplegend .li{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12.5px;color:var(--ink2)}
.maplegend .sw{width:12px;height:12px;border-radius:3px;border:1px solid rgba(255,255,255,.25);flex:0 0 auto}

/* mini danger button (queue header) */
.mini{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.5px;padding:3px 8px;border-radius:7px;
  border:1px solid var(--stroke2);background:rgba(255,93,108,.08);color:var(--red);cursor:pointer}
.mini:hover{background:rgba(255,93,108,.16)}
.pill.admin{text-decoration:none;color:var(--ink2);border-color:var(--stroke2);background:rgba(120,160,220,.06);cursor:pointer}
.pill.admin:hover{color:var(--cyan);border-color:var(--cyan2)}
.pill.admin .dot{display:none}

/* compare dock */
.dock{position:absolute;left:50%;transform:translateX(-50%);bottom:16px;z-index:600;width:min(860px,calc(100% - 40px));
  background:var(--panel);border:1px solid var(--stroke2);border-radius:16px;backdrop-filter:blur(18px);
  box-shadow:0 20px 60px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.05);padding:12px 14px}
.dockhead{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.dtitle{font-family:var(--disp);font-weight:700;letter-spacing:1px;font-size:16px}
.dmeta{font-family:var(--mono);font-size:12.5px;color:var(--ink2);display:flex;gap:13px;flex-wrap:wrap}
.dmeta b{color:var(--cyan)}
.dockhead .x{margin-left:auto;background:none;border:1px solid var(--stroke2);color:var(--ink2);border-radius:8px;padding:3px 9px;cursor:pointer}
.dockrow{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:14px;align-items:center}
.picker label{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;color:var(--ink3);display:block;margin-bottom:6px}
.picker select{width:100%;font-family:var(--mono);font-size:13px;color:var(--ink);background:rgba(0,0,0,.35);
  border:1px solid var(--stroke2);border-radius:9px;padding:10px 12px;outline:none}
.swipewrap{display:flex;flex-direction:column;gap:7px}
input[type=range]{-webkit-appearance:none;appearance:none;height:5px;border-radius:6px;background:linear-gradient(90deg,var(--cyan),var(--violet));outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#eaf6ff;
  border:2px solid var(--cyan);box-shadow:0 0 8px rgba(56,225,255,.6);cursor:pointer}
.opline{display:flex;align-items:center;gap:8px}
.opline label{font-family:var(--mono);font-size:8.5px;letter-spacing:1.5px;color:var(--ink3)}
.opline input{flex:1}
.legend{display:flex;flex-wrap:wrap;gap:6px 12px;margin-top:11px;padding-top:11px;border-top:1px solid var(--stroke)}
.legend .li{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;color:var(--ink2)}
.legend .sw{width:11px;height:11px;border-radius:3px;border:1px solid rgba(255,255,255,.25)}

/* side-by-side handle skin */
.leaflet-sbs-divider{background:var(--cyan)!important;width:2px!important;box-shadow:0 0 12px rgba(56,225,255,.7)}
.leaflet-sbs-range{z-index:650}

/* SweetAlert defence skin */
.swal2-popup.omni{background:#0c1322;border:1px solid var(--stroke2);border-radius:16px;color:var(--ink);font-family:var(--sans)}
.swal2-popup.omni .swal2-title{color:var(--ink);font-family:var(--disp)}
.swal2-popup.omni .swal2-timer-progress-bar{background:var(--cyan)}
.omni-ok{background:linear-gradient(120deg,var(--cyan),var(--grn))!important;color:#04121a!important;font-weight:700!important}

@media (max-width:1024px){.app{grid-template-columns:1fr;grid-template-rows:58px auto 1fr;grid-template-areas:"top" "panel" "theatre"}
  .panel{max-height:44vh}}

/* ===== admin login ===== */
.loginwrap{height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.logincard{width:min(400px,92vw);background:var(--panel);border:1px solid var(--stroke2);border-radius:18px;
  padding:26px 24px;backdrop-filter:blur(16px);box-shadow:0 30px 80px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.05);
  display:flex;flex-direction:column;gap:2px}
.loginbrand{display:flex;align-items:center;gap:13px;margin-bottom:6px}
.loginbrand .lb1{font-family:var(--disp);font-weight:800;letter-spacing:2px;font-size:17px}
.loginbrand .lb1 span{color:var(--cyan)}
.loginbrand .lb2{font-size:10px;letter-spacing:2px;color:var(--ink3);text-transform:uppercase;margin-top:3px}
.cls{font-family:var(--mono);font-size:9px;letter-spacing:2px;color:var(--amber);background:rgba(255,182,72,.08);
  border:1px solid rgba(255,182,72,.2);border-radius:7px;padding:6px 9px;text-align:center;margin:8px 0 16px}
.lerr{font-family:var(--mono);font-size:11px;color:var(--red);background:rgba(255,93,108,.1);border:1px solid rgba(255,93,108,.3);
  border-radius:8px;padding:8px 11px;margin-bottom:12px}
.autofill{width:100%;margin-bottom:10px;font-family:var(--mono);font-size:12px;color:var(--cyan);cursor:pointer;
  background:rgba(56,225,255,.07);border:1px solid rgba(56,225,255,.25);border-radius:9px;padding:9px}
.autofill:hover{background:rgba(56,225,255,.14)}
.lback{display:block;text-align:center;margin-top:14px;font-size:12px;color:var(--ink3);text-decoration:none}
.lback:hover{color:var(--cyan)}

/* ===== admin dashboard ===== */
.adminbody{overflow:auto}
.adminmain{padding:20px;display:flex;flex-direction:column;gap:16px;max-width:1500px;margin:0 auto}
.statgrid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.statcard{background:var(--panel);border:1px solid var(--stroke);border-radius:13px;padding:15px 16px;backdrop-filter:blur(12px)}
.statcard label{font-size:9px;letter-spacing:1.6px;color:var(--ink3);display:block;margin-bottom:8px}
.statcard b{font-family:var(--disp);font-size:26px;font-weight:800}
.card.wide{background:var(--panel);border:1px solid var(--stroke);border-radius:16px;padding:16px;backdrop-filter:blur(12px)}
.btn.danger{margin-left:auto;color:#fff;background:linear-gradient(120deg,#ff5d6c,#c0293a);border:0;font-weight:700;padding:7px 14px}
.tablewrap{overflow:auto;border:1px solid var(--stroke);border-radius:11px;max-height:64vh}
.dbtable{width:100%;border-collapse:collapse;font-size:12px}
.dbtable th{position:sticky;top:0;background:#0c1322;color:var(--ink3);font-family:var(--mono);font-size:9.5px;letter-spacing:1.2px;
  text-align:left;padding:11px 12px;border-bottom:1px solid var(--stroke2)}
.dbtable td{padding:10px 12px;border-bottom:1px solid var(--stroke);color:var(--ink)}
.dbtable tr:hover td{background:rgba(56,225,255,.04)}
.dbtable .mono{font-family:var(--mono)}.dbtable .sm{font-size:10.5px;color:var(--ink2)}
.tt{font-family:var(--mono);font-size:9px;letter-spacing:.5px;padding:2px 7px;border-radius:6px;text-transform:uppercase}
.tt-superres{color:var(--cyan);background:rgba(56,225,255,.1)}
.tt-change{color:var(--amber);background:rgba(255,182,72,.1)}
.tt-segment{color:var(--violet);background:rgba(155,140,255,.12)}
.rowdel{font-family:var(--mono);font-size:9.5px;color:var(--ink3);background:none;border:1px solid var(--stroke2);
  border-radius:6px;padding:3px 9px;cursor:pointer}
.rowdel:hover{color:var(--red);border-color:var(--red)}
@media(max-width:1100px){.statgrid{grid-template-columns:repeat(3,1fr)}}
