*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#030814;--panel:rgba(7,15,33,.84);--panel2:rgba(7,15,33,.76);--line:rgba(35,216,255,.22);--line2:rgba(95,255,230,.18);--txt:#e9fbff;--muted:#8fbcd4;--dim:#557a98;--purple:#19d8ff;--purple2:#8f6cff;--cyan:#5fffe6;--green:#2cff92;--red:#ff4d6d;--blue:#546bff;--glass:blur(18px) saturate(145%);--shadow:0 18px 60px rgba(0,0,0,.45);--r:16px}
html,body{width:100%;height:100%;overflow:hidden;background:radial-gradient(circle at 50% -20%,#08345c 0,#040b1b 42%,#01040d 100%);font-family:Inter,-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;color:var(--txt);-webkit-font-smoothing:antialiased}
body.orizon-ui::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:linear-gradient(90deg,rgba(35,216,255,.055) 1px,transparent 1px),linear-gradient(rgba(95,255,230,.035) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(circle at center,#000 0,transparent 75%)}
#map{position:fixed;inset:0;z-index:1;background:#040a16;filter:saturate(.82) brightness(.76) contrast(1.08)}
.map-vignette{position:fixed;inset:0;z-index:2;pointer-events:none;background:radial-gradient(circle at center,transparent 0 45%,rgba(2,4,14,.48) 83%,rgba(2,4,14,.92) 100%),linear-gradient(90deg,rgba(4,7,19,.62),transparent 25%,transparent 72%,rgba(4,7,19,.66));}
.leaflet-control-zoom{border:1px solid var(--line)!important;border-radius:14px!important;overflow:hidden;box-shadow:var(--shadow)!important;background:rgba(7,15,33,.85)!important;backdrop-filter:var(--glass);right:26px;top:86px}.leaflet-control-zoom a{background:rgba(7,15,33,.9)!important;color:var(--txt)!important;border-bottom:1px solid var(--line)!important}.leaflet-control-zoom a:hover{background:rgba(35,216,255,.35)!important;color:white!important}
.landing-overlay{position:fixed;inset:0;z-index:5000;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 35% 30%,rgba(35,216,255,.38),transparent 34%),radial-gradient(circle at 73% 70%,rgba(95,255,230,.22),transparent 30%),#030814;overflow:hidden}.landing-overlay.hidden{display:none}.landing-overlay::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px);background-size:64px 64px;opacity:.55}.landing-overlay::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(3,7,19,.5)),url('https://game.gtimg.cn/images/dfm/cp/a20240729directory/img/map_htjd/3_4_3.jpg');background-size:cover;background-position:center;opacity:.19;filter:blur(1px) saturate(1.2)}
.landing-scene{position:relative;z-index:1;width:min(1120px,92vw);height:min(640px,86vh);display:grid;grid-template-columns:1.05fr .9fr;gap:38px;align-items:center;padding:42px;border:1px solid rgba(35,216,255,.3);border-radius:30px;background:linear-gradient(135deg,rgba(7,12,30,.72),rgba(10,12,30,.38));box-shadow:0 35px 120px rgba(0,0,0,.55),inset 0 0 0 1px rgba(255,255,255,.04);backdrop-filter:blur(20px)}.landing-brand{align-self:end;padding:0 0 55px 16px}.brand-kicker{font-size:12px;letter-spacing:5px;color:var(--cyan);text-transform:uppercase;margin-bottom:18px}.brand-title{font-size:54px;line-height:.92;font-weight:900;letter-spacing:8px;text-shadow:0 0 35px rgba(35,216,255,.45)}.brand-title span{color:#8f6cff;text-shadow:0 0 30px #19d8ff}.landing-brand p{margin-top:18px;color:var(--muted);font-size:14px;letter-spacing:1px}.landing-card{justify-self:end;width:min(410px,100%);padding:32px;border:1px solid rgba(35,216,255,.24);border-radius:22px;background:linear-gradient(180deg,rgba(15,19,46,.83),rgba(7,10,26,.82));box-shadow:var(--shadow);backdrop-filter:var(--glass)}.access-chip{display:inline-flex;padding:7px 10px;border-radius:999px;background:rgba(95,255,230,.1);border:1px solid rgba(95,255,230,.22);color:var(--cyan);font-size:10px;font-weight:800;letter-spacing:1.5px}.landing-title{font-size:24px;letter-spacing:2px;margin:20px 0 7px;text-transform:uppercase}.landing-desc,.landing-hint{color:var(--muted);font-size:13px}.landing-input-wrap{display:grid;gap:12px;margin:22px 0 14px}.landing-input{height:48px;padding:0 16px;border:1px solid rgba(35,216,255,.22);border-radius:12px;background:rgba(2,5,15,.74);color:var(--txt);outline:none;font-size:15px}.landing-input:focus{border-color:var(--purple2);box-shadow:0 0 0 4px rgba(35,216,255,.16)}.landing-btn{height:48px;border:0;border-radius:12px;color:white;background:linear-gradient(135deg,var(--purple),#1758a6);font-weight:900;letter-spacing:1px;cursor:pointer;box-shadow:0 12px 35px rgba(35,216,255,.35)}.landing-btn:hover{filter:brightness(1.14)}.landing-btn:disabled{opacity:.65;cursor:not-allowed}.landing-error{color:var(--red);font-size:13px;margin-top:10px}
.sidebar{position:fixed;left:12px;top:12px;bottom:12px;width:248px;z-index:50;padding:14px;display:flex;flex-direction:column;gap:12px;border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,rgba(7,15,33,.88),rgba(4,8,21,.78));box-shadow:var(--shadow);backdrop-filter:var(--glass);transition:transform .28s ease,opacity .2s}.sidebar.collapsed{transform:translateX(calc(-100% - 24px));opacity:.35}.rail-brand{height:52px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line);padding-bottom:12px}.brand-mark{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:radial-gradient(circle,#fff 0 8%,#5fffe6 18%,#1758a6 55%,#081a35 100%);box-shadow:0 0 28px rgba(35,216,255,.58);font-weight:900}.rail-title{font-size:11px;letter-spacing:3px;font-weight:900;color:#fff}.rail-subtitle{font-size:21px;letter-spacing:4px;line-height:1;color:#8f6cff;font-weight:900}.rail-section-title{margin:4px 4px -4px;color:#737f9d;text-transform:uppercase;letter-spacing:1.6px;font-size:10px;font-weight:900}.rail-menu{display:grid;gap:5px}.rail-item,.map-tab{height:36px;display:flex;align-items:center;gap:10px;border:1px solid transparent;border-radius:10px;background:transparent;color:#d8f7ff;padding:0 11px;font-size:12px;font-weight:700;text-align:left;cursor:pointer;transition:.16s}.rail-item:hover,.map-tab:hover{background:rgba(255,255,255,.05);color:white}.rail-item.active,.map-tab.active{background:linear-gradient(135deg,rgba(35,216,255,.75),rgba(90,85,255,.58));border-color:rgba(35,216,255,.45);color:white;box-shadow:0 8px 22px rgba(35,216,255,.24)}.compact-map-tabs{display:grid;grid-template-columns:1fr;gap:5px;flex:none;overflow:visible}.map-tab{justify-content:flex-start;white-space:nowrap}
.command-topbar{position:fixed;left:276px;right:336px;top:12px;height:56px;z-index:45;display:flex;align-items:center;gap:12px;padding:0 16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(90deg,rgba(7,15,33,.82),rgba(7,15,33,.58));box-shadow:var(--shadow);backdrop-filter:var(--glass)}.top-nav{display:flex;gap:10px}.top-nav-item{height:36px;padding:0 18px;border:1px solid transparent;border-radius:11px;background:transparent;color:#8fbcd4;font-size:12px;font-weight:900;letter-spacing:1px;cursor:pointer}.top-nav-item.active{background:rgba(35,216,255,.26);border-color:rgba(35,216,255,.45);color:#fff;box-shadow:inset 0 -2px 0 var(--purple2)}.top-nav-item:hover{color:#fff;background:rgba(255,255,255,.05)}.topbar-spacer{flex:1}.topbar-pill{height:36px;display:inline-flex;align-items:center;gap:8px;padding:0 13px;border:1px solid var(--line);border-radius:12px;background:rgba(7,15,33,.75);color:#d8f7ff;font-weight:800;font-size:12px;cursor:pointer}.topbar-pill:hover,.topbar-pill.active{border-color:rgba(95,255,230,.36);color:white;background:rgba(95,255,230,.1)}.status-pill{min-width:150px;justify-content:flex-start}.conn-dot{width:8px;height:8px;border-radius:50%;background:#586071;box-shadow:0 0 0 4px rgba(88,96,113,.12)}.conn-dot.ok{background:var(--green);box-shadow:0 0 12px var(--green),0 0 0 4px rgba(44,255,146,.12)}.conn-dot.err{background:var(--red);box-shadow:0 0 12px rgba(255,77,109,.4)}
.ops-panel{position:fixed;right:12px;top:12px;bottom:12px;width:312px;z-index:46;display:flex;flex-direction:column;gap:12px}.ops-card,.panel{border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(7,15,33,.86),rgba(4,11,25,.72));box-shadow:var(--shadow);backdrop-filter:var(--glass)}.system-card{height:62px;display:flex;align-items:center;gap:12px;padding:12px 14px}.system-dot{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 18px var(--green)}.system-card b{display:block;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--green)}.system-card span{font-size:11px;color:var(--muted)}.panel{padding:14px}.panel-title{display:flex;align-items:center;gap:9px;color:#e9fbff;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:12px}.panel-title::before{content:'';width:4px;height:14px;border-radius:4px;background:linear-gradient(var(--cyan),var(--purple));box-shadow:0 0 16px var(--purple)}.panel-layers{overflow:visible;min-height:0}.layer-grid{display:grid;grid-template-columns:1fr;gap:6px}.layer-row{position:relative;min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid rgba(95,255,230,.11);border-radius:10px;background:rgba(255,255,255,.025);color:#b8c2dc;cursor:pointer;font-size:12px;transition:.14s}.layer-row:hover{background:rgba(35,216,255,.12);border-color:rgba(35,216,255,.25);color:#fff}.layer-row.wide{background:rgba(95,255,230,.035)}.layer-lbl{display:flex;align-items:center;gap:8px;min-width:0}.ldot,.legend-dot,.fs-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:0 0 auto}.enemy-dot{background:#ff4d6d;box-shadow:0 0 10px rgba(255,77,109,.5)}.team-dot{background:#2cff92;box-shadow:0 0 10px rgba(44,255,146,.45)}.ai-dot{background:#7b85a2}.box-dot{background:#19d8ff}.loot-dot{background:#35e8ff}.exit-dot{background:#35e8ff}.list-dot{background:#7c5cff}.chat-dot{background:#66e2ff}.mini-gear{color:var(--muted)}.ltog{width:36px;height:19px;border-radius:99px;background:rgba(93,103,130,.3);border:1px solid rgba(255,255,255,.09);position:relative;flex:0 0 auto}.ltog::after{content:'';position:absolute;left:2px;top:2px;width:13px;height:13px;border-radius:50%;background:#818aa5;transition:.16s}.ltog.on{background:rgba(35,216,255,.35);border-color:rgba(35,216,255,.45)}.ltog.on::after{left:19px;background:#fff;box-shadow:0 0 12px var(--purple2)}.settings-check-row input[type=checkbox]{accent-color:var(--purple);width:16px;height:16px}.box-cfg-pop{position:absolute;left:calc(100% + 12px);top:0;z-index:100;display:none;min-width:170px;padding:10px;border:1px solid var(--line);border-radius:14px;background:rgba(7,15,33,.96);box-shadow:var(--shadow);backdrop-filter:var(--glass)}.box-cfg-pop.open{display:grid;gap:7px}.box-chk-row{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:8px;color:#cbd4ee;font-size:12px;cursor:pointer}.box-chk-row:hover{background:rgba(255,255,255,.06)}.box-chk-row input{accent-color:var(--purple)}.scale-row{display:grid;grid-template-columns:54px 1fr 42px;align-items:center;gap:8px;margin-top:10px}.cfg-lbl{font-size:11px;color:#8fbcd4;text-transform:uppercase;font-weight:900}.scale-slider{width:100%;accent-color:var(--purple)}.scale-val,.scale-val-input{height:26px;display:grid;place-items:center;text-align:center;border:1px solid var(--line);border-radius:8px;background:rgba(2,5,15,.55);color:#fff;font-size:11px}.scale-val-input{width:54px;outline:none}.sidebar-toggle{margin-top:auto;height:38px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.04);color:#d8f7ff;font-size:12px;font-weight:900;letter-spacing:.8px;cursor:pointer}.sidebar-toggle:hover{background:rgba(95,255,230,.18);color:#fff}.sidebar-toggle.collapsed{position:fixed;left:12px;bottom:12px;width:102px;z-index:80;background:rgba(7,15,33,.9);backdrop-filter:var(--glass)}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat-row{min-height:58px;padding:10px;border:1px solid rgba(95,255,230,.12);border-radius:13px;background:rgba(255,255,255,.035);display:flex;flex-direction:column;justify-content:center}.stat-lbl{font-size:10px;color:#8d97b7;text-transform:uppercase;font-weight:900;letter-spacing:.8px}.stat-val{font-size:25px;line-height:1.05;font-weight:900;color:#fff}.stat-val.small{font-size:15px}.wide-stat{grid-column:span 3}.spectate-card select{width:100%;height:38px;border:1px solid var(--line);border-radius:10px;background:rgba(2,5,15,.7);color:var(--txt);padding:0 10px;outline:none}.btn{height:38px;border:1px solid rgba(95,255,230,.24);border-radius:10px;background:linear-gradient(135deg,rgba(95,255,230,.65),rgba(95,255,230,.22));color:#fff;font-weight:900;cursor:pointer;margin-top:8px;width:100%}.btn:hover{filter:brightness(1.12)}.btn-accent{box-shadow:0 0 22px rgba(35,216,255,.35)}.hint{margin-top:8px;color:var(--muted);font-size:11px}.team-float{display:none}.team-float.show{display:flex;flex-direction:column;gap:8px;min-height:0;overflow:auto}.team-card{padding:10px;border:1px solid rgba(95,255,230,.16);border-radius:14px;background:rgba(255,255,255,.035);cursor:pointer}.team-card:hover,.team-card.active{border-color:rgba(95,255,230,.36);background:rgba(95,255,230,.08)}.tc-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px}.tc-name{font-size:12px;font-weight:900;color:white;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tc-gear{display:flex;gap:5px;color:#8fbcd4;font-size:10px}.tc-bar{height:4px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.tc-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--cyan))}
.float-stats{position:fixed;left:14px;top:80px;z-index:44;display:none;grid-template-columns:repeat(2,1fr);gap:6px;width:180px;padding:10px;border:1px solid var(--line);border-radius:16px;background:rgba(7,15,33,.78);box-shadow:var(--shadow);backdrop-filter:var(--glass)}.float-stats.show{display:grid}.fs-title{grid-column:span 2;color:#e9fbff;font-size:11px;text-transform:uppercase;font-weight:900;letter-spacing:1px}.fs-row{display:flex;align-items:center;gap:5px;font-size:11px}.fs-val{font-weight:900;color:#fff}.fs-lbl{color:var(--muted)}.fs-dot.player{background:var(--red)}.fs-dot.ai{background:#7b85a2}.fs-dot.body{background:#19d8ff}.fs-dot.loot{background:#35e8ff}.fs-dot.box{background:#19d8ff}.fs-dot.exit{background:var(--cyan)}.hud-legend{position:fixed;left:292px;bottom:22px;z-index:40;display:flex;gap:14px;align-items:center;padding:9px 12px;border:1px solid var(--line);border-radius:14px;background:rgba(7,15,33,.72);backdrop-filter:var(--glass);color:#d8f7ff;font-size:11px}.hud-legend span{display:flex;align-items:center;gap:6px}.map-region-name span{font-family:inherit!important;color:rgba(228,236,255,.9)!important;text-shadow:0 0 10px #000,0 0 18px rgba(95,255,230,.28)!important;letter-spacing:1px!important;text-transform:uppercase}
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);z-index:3000;opacity:0;transition:.2s;padding:10px 14px;border:1px solid var(--line);border-radius:12px;background:rgba(7,15,33,.92);color:white;box-shadow:var(--shadow)}#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.room-chat-window,.loot-window{position:fixed;z-index:70;border:1px solid var(--line);border-radius:18px;background:rgba(7,15,33,.86);box-shadow:var(--shadow);backdrop-filter:var(--glass);overflow:hidden}.room-chat-window{right:340px;bottom:22px;width:320px;display:none}.room-chat-window.show{display:block}.room-chat-header,.loot-window-header{padding:12px 14px;border-bottom:1px solid var(--line);background:rgba(35,216,255,.1);display:flex;align-items:flex-start;justify-content:space-between;gap:10px;cursor:move}.room-chat-title,.loot-window-title{font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:1px}.room-chat-subtitle{font-size:11px;color:var(--muted);margin-top:2px}.room-chat-close{width:26px;height:26px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.04);color:white;cursor:pointer}.room-chat-name-row{display:flex;gap:6px;align-items:center;margin-top:8px;font-size:10px;color:var(--muted)}.room-chat-name-input{height:24px;min-width:0;border:1px solid var(--line);border-radius:8px;background:rgba(2,5,15,.7);color:white;padding:0 8px;outline:none}.room-chat-messages{height:210px;overflow:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.room-chat-empty{color:var(--muted);font-size:12px;text-align:center;margin-top:72px}.room-chat-msg{padding:8px 10px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05)}.room-chat-msg.mine{background:rgba(95,255,230,.14);border-color:rgba(35,216,255,.22)}.room-chat-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:10px;margin-bottom:4px}.room-chat-text{font-size:12px;color:#e9fbff;word-break:break-word}.room-chat-form{display:flex;gap:8px;padding:10px;border-top:1px solid var(--line)}.room-chat-form input{flex:1;height:34px;border:1px solid var(--line);border-radius:10px;background:rgba(2,5,15,.72);color:white;padding:0 10px;outline:none}.room-chat-form button{width:64px;border:0;border-radius:10px;background:var(--purple);color:white;font-weight:900}.loot-window{left:292px;top:84px;width:340px;max-height:56vh;display:none}.loot-window.show{display:block}.item-list-wrap{max-height:calc(56vh - 45px);overflow:auto;padding:8px}.loot-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:9px 10px;margin-bottom:6px;border:1px solid rgba(95,255,230,.12);border-radius:12px;background:rgba(255,255,255,.035);cursor:pointer}.loot-row:hover{border-color:rgba(95,255,230,.36);background:rgba(95,255,230,.08)}.loot-row-name{font-size:12px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loot-row-meta{font-size:10px;color:var(--muted);margin-top:2px}.loot-row-value{font-size:12px;font-weight:900;color:#fff}
@media(max-width:1100px){.ops-panel{display:none}.command-topbar{right:12px}.sidebar{width:230px}.hud-legend{left:260px}}@media(max-width:760px){.sidebar{width:218px}.command-topbar{left:12px;right:12px;top:auto;bottom:12px}.top-nav-item:not(.active){display:none}.hud-legend{display:none}.landing-scene{grid-template-columns:1fr;height:auto;padding:24px}.landing-brand{display:none}.room-chat-window{right:12px;width:calc(100vw - 24px)}}


/* Layout fix patch: map buttons moved to top, sidebar opens correctly, windows show correctly */
.sidebar{
  overflow-y:auto;
  overflow-x:hidden;
  padding-bottom:18px;
  scrollbar-width:thin;
  scrollbar-color:rgba(35,216,255,.75) rgba(255,255,255,.04);
}
.sidebar::-webkit-scrollbar{width:7px}
.sidebar::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:99px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(35,216,255,.65);border-radius:99px}
.sidebar.collapsed{transform:translateX(calc(-100% - 28px));opacity:1;pointer-events:none}
.sidebar-toggle{
  position:fixed;
  left:22px;
  bottom:22px;
  width:194px;
  height:32px;
  z-index:90;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(7,15,33,.92);
  color:#d8f7ff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.8px;
  cursor:pointer;
  box-shadow:var(--shadow);
  backdrop-filter:var(--glass);
}
.sidebar-toggle:hover{background:rgba(35,216,255,.22);color:#fff}
.sidebar-toggle.collapsed{left:14px;bottom:14px;width:118px;pointer-events:auto}
.command-topbar{left:276px;right:336px;gap:12px;overflow:hidden}
.top-map-tabs{
  display:flex;
  align-items:center;
  gap:8px;
  flex:1 1 auto;
  min-width:0;
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
}
.top-map-tabs::-webkit-scrollbar{display:none}
.top-map-tabs .map-tab{
  flex:0 0 auto;
  height:36px;
  padding:0 17px;
  justify-content:center;
  text-transform:uppercase;
  letter-spacing:.8px;
  font-size:12px;
}
.orizon-rail .panel-layers{margin-top:4px;flex:0 0 auto}
.rail-menu,.compact-map-tabs{display:none!important}
.hud-legend{display:none!important}
.room-chat-window.show,.loot-window.show{display:block!important}
.item-list-wrap{max-height:calc(56vh - 45px);overflow:auto;padding:8px}
.item-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  padding:9px 10px;
  margin-bottom:6px;
  border:1px solid rgba(95,255,230,.12);
  border-radius:12px;
  background:rgba(255,255,255,.035);
  cursor:pointer;
}
.item-row:hover,.item-row.highlight-loot-row{border-color:rgba(95,255,230,.36);background:rgba(95,255,230,.08)}
.item-row-left{display:flex;align-items:center;gap:8px;min-width:0}.item-rank{color:var(--muted);font-size:10px;font-weight:900}.item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:800}.item-price{font-size:12px;font-weight:900;color:#fff}
@media(max-width:1100px){.command-topbar{right:12px}.top-map-tabs .map-tab{padding:0 12px}}
@media(max-width:760px){.command-topbar{left:12px;right:12px;top:auto;bottom:12px}.top-map-tabs .map-tab:not(.active){display:none}.sidebar-toggle{bottom:66px}}

/* Collapse should clear the right-side panels too */
body.menu-collapsed .ops-panel,
body.menu-collapsed .float-stats,
body.menu-collapsed .team-float{
  display:none!important;
}
body.menu-collapsed .command-topbar{
  right:14px;
}
@media(max-width:760px){
  body.menu-collapsed .command-topbar{right:12px}
}


/* High Value Loot docking: sits under Spectate & Follow, moves up when the side UI collapses. */
.loot-window{
  left:auto!important;
  right:12px!important;
  width:312px;
  top:520px;
  max-height:calc(100vh - 532px);
  transition:top .28s ease,right .28s ease,max-height .28s ease,opacity .18s ease,transform .28s ease;
}
.loot-window.show{display:block!important}
.loot-window .item-list-wrap{max-height:calc(100% - 45px)!important;overflow:auto}
body.menu-collapsed .loot-window{
  top:84px!important;
  right:12px!important;
  max-height:calc(100vh - 96px)!important;
}
@media(max-width:1100px){
  .loot-window{right:12px!important;top:84px!important;max-height:calc(100vh - 96px)!important}
}


/* Spectate & Follow docked inside left menu */
.sidebar .sidebar-spectate-card{
  flex:0 0 auto;
}
.sidebar .spectate-card select{
  width:100%;
}
.sidebar .team-float{
  position:static!important;
  width:100%;
  min-width:0;
  max-width:none;
  z-index:auto;
  margin-top:-4px;
}
.sidebar .team-float.show{
  display:flex;
}
body.menu-collapsed .sidebar .team-float,
body.menu-collapsed .sidebar .spectate-card{
  display:none!important;
}


/* Side attached collapse handle + cleaned right panel + fixed layer popup menus */
.sidebar-toggle{
  position:fixed!important;
  left:259px!important;
  top:50%!important;
  bottom:auto!important;
  transform:translateY(-50%)!important;
  width:28px!important;
  height:70px!important;
  z-index:120!important;
  border:1px solid rgba(35,216,255,.38)!important;
  border-left:0!important;
  border-radius:0 14px 14px 0!important;
  background:linear-gradient(180deg,rgba(35,216,255,.38),rgba(7,15,33,.94))!important;
  color:#fff!important;
  font-size:24px!important;
  font-weight:900!important;
  letter-spacing:0!important;
  padding:0!important;
  box-shadow:0 0 24px rgba(35,216,255,.34), var(--shadow)!important;
  backdrop-filter:var(--glass);
}
.sidebar-toggle:hover{background:linear-gradient(180deg,rgba(35,216,255,.62),rgba(7,15,33,.96))!important}
.sidebar-toggle.collapsed{
  left:12px!important;
  top:50%!important;
  bottom:auto!important;
  width:30px!important;
  height:74px!important;
  border-left:1px solid rgba(35,216,255,.38)!important;
  border-radius:0 14px 14px 0!important;
}
.system-card{display:none!important}
.ops-panel{top:76px!important}
body.menu-collapsed .ops-panel{display:none!important}
.box-cfg-pop{
  position:fixed!important;
  left:auto;
  top:auto;
  z-index:6000!important;
  min-width:180px;
  pointer-events:auto;
}
.box-cfg-pop.open{display:grid!important}
.sidebar,.panel-layers,.layer-grid,.layer-row.wide{overflow:visible}
.sidebar{overflow-y:auto;overflow-x:visible}
@media(max-width:760px){
  .sidebar-toggle{left:231px!important;top:50%!important;bottom:auto!important}
  .sidebar-toggle.collapsed{left:12px!important;top:50%!important}
}


/* Final right-panel and popup fixes */
.ops-panel{top:12px!important}
.box-cfg-pop{
  position:fixed!important;
  left:272px!important;
  top:120px;
  z-index:10000!important;
  min-width:190px;
  display:none;
  overflow:visible!important;
}
.box-cfg-pop.open{display:grid!important}
.sidebar{overflow-y:auto!important;overflow-x:visible!important}
body.menu-collapsed .ops-panel{display:none!important}


/* Delta Force cyber theme override */


/* =========================================================
   Delta Force Cyber Theme Override — blue/violet/cyan
   ========================================================= */
:root{
  --bg:#030814!important;
  --panel:rgba(7,15,33,.90)!important;
  --panel2:rgba(8,18,42,.82)!important;
  --line:rgba(53,232,255,.30)!important;
  --line2:rgba(124,77,255,.26)!important;
  --txt:#e9fbff!important;
  --muted:#8fbcd4!important;
  --dim:#557a98!important;
  --purple:#35e8ff!important;
  --purple2:#7c4dff!important;
  --cyan:#5fffe6!important;
  --blue:#5a8dff!important;
  --green:#50ffa8!important;
  --red:#ff4d88!important;
  --shadow:0 14px 46px rgba(0,0,0,.72),0 0 28px rgba(53,232,255,.14)!important;
}
html,body{background:radial-gradient(circle at 18% 12%,rgba(53,232,255,.13),transparent 30%),radial-gradient(circle at 82% 80%,rgba(124,77,255,.12),transparent 32%),linear-gradient(135deg,#030814 0%,#07172f 54%,#020612 100%)!important;color:var(--txt)!important}
body.orizon-ui::before{background:linear-gradient(90deg,rgba(53,232,255,.055) 1px,transparent 1px),linear-gradient(rgba(124,77,255,.04) 1px,transparent 1px)!important;background-size:46px 46px!important}
#map{background:#040a16!important;filter:saturate(.95) brightness(.80) contrast(1.10)!important}
.map-vignette{background:radial-gradient(circle at center,transparent 0 48%,rgba(1,6,18,.46) 82%,rgba(1,4,13,.90) 100%),linear-gradient(90deg,rgba(2,9,24,.64),transparent 25%,transparent 72%,rgba(2,9,24,.68))!important}
.landing-overlay{background:radial-gradient(circle at 30% 22%,rgba(53,232,255,.26),transparent 32%),radial-gradient(circle at 72% 76%,rgba(124,77,255,.20),transparent 34%),linear-gradient(135deg,#030814,#06172e 56%,#020612)!important}
.landing-overlay::after{opacity:.12!important;filter:hue-rotate(175deg) saturate(1.25) brightness(.70)!important}
.landing-scene,.landing-card,.sidebar,.command-topbar,.ops-card,.panel,.room-chat-window,.loot-window,.box-cfg-pop{background:linear-gradient(180deg,rgba(7,15,33,.93),rgba(4,11,25,.86)),repeating-linear-gradient(135deg,rgba(53,232,255,.035) 0 1px,transparent 1px 8px)!important;border-color:rgba(53,232,255,.30)!important;box-shadow:var(--shadow),inset 0 0 0 1px rgba(233,251,255,.025)!important}
.command-topbar{background:linear-gradient(90deg,rgba(7,15,33,.94),rgba(4,11,25,.78))!important}
.brand-title,.rail-title,.rail-subtitle,.top-nav-item.active,.panel-title,.landing-title{color:#e9fbff!important;text-shadow:0 0 14px rgba(53,232,255,.50)!important}
.brand-title span{color:#5fffe6!important;text-shadow:0 0 26px rgba(124,77,255,.62)!important}
.brand-mark{background:radial-gradient(circle,#f2fdff 0 8%,#5fffe6 18%,#185fbd 56%,#081a35 100%)!important;box-shadow:0 0 28px rgba(53,232,255,.55)!important;color:#06111f!important}
.brand-kicker,.access-chip{color:#5fffe6!important}
.access-chip,.topbar-pill,.rail-item,.map-tab,.layer-row,.item-row,.loot-row{border-color:rgba(53,232,255,.18)!important;color:#c9f7ff!important;background:rgba(53,232,255,.045)!important}
.rail-item:hover,.map-tab:hover,.layer-row:hover,.item-row:hover,.loot-row:hover{background:rgba(53,232,255,.11)!important;border-color:rgba(53,232,255,.36)!important;color:#ffffff!important}
.rail-item.active,.map-tab.active,.top-nav-item.active,.landing-btn,.btn,.room-chat-form button,.ltog.on{background:linear-gradient(135deg,#35e8ff,#7c4dff)!important;color:#ffffff!important;border-color:rgba(95,255,230,.48)!important;box-shadow:0 0 18px rgba(53,232,255,.30)!important}
.top-nav-item{color:#8fbcd4!important;background:transparent!important}.top-nav-item:hover{background:rgba(53,232,255,.08)!important;color:#ffffff!important}
.topbar-pill:hover,.topbar-pill.active{background:rgba(95,255,230,.13)!important;color:#ffffff!important;border-color:rgba(95,255,230,.42)!important}
.panel-title::before{background:linear-gradient(90deg,#5fffe6,#7c4dff)!important;box-shadow:0 0 12px rgba(53,232,255,.68)!important}
.sidebar-toggle{background:linear-gradient(90deg,rgba(4,11,25,.96),rgba(124,77,255,.32))!important;border-color:rgba(53,232,255,.46)!important;color:#5fffe6!important;box-shadow:4px 0 24px rgba(53,232,255,.28),2px 0 6px rgba(0,0,0,.55)!important}.sidebar-toggle:hover{background:linear-gradient(90deg,rgba(4,11,25,.98),rgba(53,232,255,.34))!important;color:#ffffff!important}
input,select,.landing-input,.room-chat-form input,.room-chat-name-input,.scale-val-input{background:rgba(53,232,255,.065)!important;border-color:rgba(53,232,255,.25)!important;color:#e9fbff!important}input:focus,select:focus,.landing-input:focus{border-color:rgba(95,255,230,.72)!important;box-shadow:0 0 0 3px rgba(95,255,230,.12)!important}
.room-chat-header,.loot-window-header{background:rgba(53,232,255,.10)!important;border-color:rgba(53,232,255,.24)!important}.room-chat-msg.mine{background:rgba(53,232,255,.12)!important;border-color:rgba(53,232,255,.26)!important}
.map-region-name span{color:rgba(226,252,255,.94)!important;text-shadow:0 0 8px #01040d,0 0 14px rgba(53,232,255,.34)!important}
.leaflet-control-zoom{background:rgba(7,15,33,.90)!important;border-color:rgba(53,232,255,.30)!important}.leaflet-control-zoom a{background:rgba(7,15,33,.92)!important;color:#5fffe6!important;border-color:rgba(53,232,255,.22)!important}.leaflet-control-zoom a:hover{background:rgba(53,232,255,.16)!important;color:#ffffff!important}
.sidebar::-webkit-scrollbar-thumb{background:rgba(53,232,255,.65)!important}
.enemy-dot{background:#ff4d88!important;box-shadow:0 0 10px rgba(255,77,136,.52)!important}.team-dot{background:#50ffa8!important;box-shadow:0 0 10px rgba(80,255,168,.45)!important}.box-dot,.loot-dot,.exit-dot{background:#35e8ff!important}.list-dot{background:#7c4dff!important}.chat-dot{background:#5fffe6!important}

/* =========================================================
   Mobile rescue patch
   ========================================================= */
@media (max-width: 760px) {
  html, body {
    overflow: hidden;
  }

  .sidebar {
    width: min(84vw, 320px) !important;
    left: 10px !important;
    top: 10px !important;
    bottom: 10px !important;
    padding: 12px !important;
    border-radius: 18px !important;
    transform: translateX(0);
  }

  .sidebar.collapsed {
    transform: translateX(calc(-100% - 18px)) !important;
    opacity: 1 !important;
    pointer-events: none !important;
  }

  .sidebar-toggle,
  .sidebar-toggle.collapsed {
    left: 10px !important;
    top: 50% !important;
    bottom: auto !important;
    transform: translateY(-50%) !important;
    width: 34px !important;
    height: 58px !important;
    border-radius: 0 14px 14px 0 !important;
    border-left: 0 !important;
    padding: 0 !important;
    font-size: 22px !important;
    z-index: 120 !important;
  }

  .command-topbar {
    left: 10px !important;
    right: 10px !important;
    top: auto !important;
    bottom: 10px !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 8px !important;
    gap: 8px !important;
    border-radius: 18px !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
    z-index: 60 !important;
  }

  .topbar-spacer {
    display: none !important;
  }

  .top-map-tabs {
    order: 1;
    flex: 1 1 100% !important;
    width: 100% !important;
    gap: 6px !important;
    padding-bottom: 2px !important;
  }

  .top-map-tabs .map-tab {
    display: inline-flex !important;
    height: 34px !important;
    padding: 0 12px !important;
    font-size: 11px !important;
    letter-spacing: .2px !important;
    border-radius: 10px !important;
  }

  .topbar-pill {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    justify-content: center !important;
    height: 36px !important;
    padding: 0 10px !important;
    font-size: 11px !important;
    white-space: nowrap !important;
  }

  #btnRegion,
  #btnFullscreen {
    order: 2;
  }

  .status-pill {
    order: 2;
    flex: 1 1 100% !important;
    min-width: 0 !important;
    justify-content: center !important;
  }

  .ops-panel,
  .float-stats,
  .team-float,
  .hud-legend {
    display: none !important;
  }

  .loot-window,
  body.menu-collapsed .loot-window {
    left: 10px !important;
    right: 10px !important;
    width: auto !important;
    top: 10px !important;
    max-height: 34vh !important;
    border-radius: 18px !important;
  }

  .loot-window .item-list-wrap {
    max-height: calc(34vh - 48px) !important;
  }

  .room-chat-window,
  .room-chat-window.show {
    left: 10px !important;
    right: 10px !important;
    width: auto !important;
    bottom: 96px !important;
    top: auto !important;
    max-height: calc(100vh - 116px) !important;
  }

  .room-chat-messages {
    height: min(36vh, 280px) !important;
  }

  .box-cfg-pop {
    left: 10px !important;
    right: 10px !important;
    top: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  .leaflet-control-zoom {
    right: 10px !important;
    top: auto !important;
    bottom: 108px !important;
  }
}


/* =========================================================
   MOBILE ONLY: attached hide/show handles
   ========================================================= */
.mobile-bottom-bar-handle,
.mobile-loot-window-handle {
  display: none;
}

@media (max-width: 760px) {
  /* Menu must always be above loot/window overlays on mobile */
  .sidebar {
    z-index: 10000 !important;
  }

  .sidebar-toggle {
    z-index: 10001 !important;
  }

  .loot-window,
  body.menu-collapsed .loot-window {
    z-index: 600 !important;
  }

  .command-topbar {
    z-index: 700 !important;
  }

  .command-topbar,
  .loot-window {
    transition: transform .24s ease, opacity .18s ease !important;
  }

  .mobile-bottom-bar-handle,
  .mobile-loot-window-handle {
    position: fixed !important;
    display: grid !important;
    place-items: center !important;
    z-index: 9000 !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
    user-select: none !important;
    -webkit-user-select: none !important;
    border: 1px solid rgba(95,255,230,.52) !important;
    background: linear-gradient(180deg,rgba(95,255,230,.40),rgba(7,15,33,.98)) !important;
    color: #35e8ff !important;
    box-shadow: 0 0 22px rgba(124,77,255,.34), 0 6px 18px rgba(0,0,0,.62) !important;
    backdrop-filter: var(--glass);
    -webkit-backdrop-filter: var(--glass);
    font-weight: 900 !important;
    cursor: pointer !important;
  }

  /* Attached to the TOP edge of the bottom bar */
  .mobile-bottom-bar-handle {
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 78px !important;
    height: 32px !important;
    bottom: 118px;
    border-radius: 14px 14px 0 0 !important;
    font-size: 18px !important;
  }

  body.mobile-bottom-bar-hidden .command-topbar {
    transform: translateY(calc(100% + 26px)) !important;
    pointer-events: none !important;
  }

  body.mobile-bottom-bar-hidden .mobile-bottom-bar-handle {
    bottom: 8px !important;
  }

  /* Attached to the BOTTOM edge of the loot window */
  .mobile-loot-window-handle {
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 96px !important;
    height: 28px !important;
    top: 10px;
    border-radius: 0 0 14px 14px !important;
    font-size: 11px !important;
  }

  body.mobile-loot-window-hidden .loot-window {
    transform: translateY(calc(-100% - 22px)) !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  body.mobile-loot-window-disabled .mobile-loot-window-handle {
    display: none !important;
  }

  body.mobile-bottom-bar-hidden .leaflet-control-zoom {
    bottom: 16px !important;
  }

  body.mobile-bottom-bar-hidden .room-chat-window,
  body.mobile-bottom-bar-hidden .room-chat-window.show {
    bottom: 48px !important;
  }
}


/* =========================================================
   User patch: default chat off, UI scale slider, mobile loot size
   ========================================================= */
:root { --ui-scale: 1; }

.sidebar,
.command-topbar,
.ops-panel,
.float-stats,
.room-chat-window,
.loot-window,
.sidebar-toggle,
.box-cfg-pop,
.leaflet-control-zoom,
.mobile-bottom-bar-handle,
.mobile-loot-window-handle {
  zoom: var(--ui-scale);
}

@media (max-width: 760px) {
  .loot-window,
  body.menu-collapsed .loot-window {
    left: 10px !important;
    right: auto !important;
    width: min(280px, calc(100vw - 20px)) !important;
    top: 10px !important;
    max-height: 104px !important;
    border-radius: 14px !important;
  }

  .loot-window-header {
    padding: 7px 10px !important;
  }

  .loot-window-title {
    font-size: 11px !important;
  }

  .loot-window .item-list-wrap {
    max-height: 50px !important;
    overflow-y: auto !important;
    padding: 5px !important;
  }

  .item-row {
    min-height: 42px !important;
    padding: 6px 8px !important;
    margin-bottom: 6px !important;
    border-radius: 10px !important;
  }

  .item-name,
  .item-price {
    font-size: 11px !important;
  }

  .item-rank {
    font-size: 9px !important;
  }
}


/* =========================================================
   Patch v3: safer UI scale slider + dock compensation
   ========================================================= */
#uiScale {
  touch-action: pan-x;
}

/* The UI uses zoom for broad compatibility; ui.js compensates fixed panel
   positions so the loot window stays anchored after scaling. */


/* Spectator/follow fixed: no dropdown. Player cards are the selector. */
#spectateSelect,
#spectateCustomWrap,
.spectate-custom-wrap,
#spectateCustomMenu {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
.spectate-selected {
  width: 100% !important;
  min-height: 34px !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 10px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(214,167,42,.55) !important;
  background: rgba(10,8,1,.72) !important;
  color: #ffe28a !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.sidebar .team-float.show {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  width: 100% !important;
  min-height: 0 !important;
  max-height: 220px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}
#sfBtnList {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  min-width: 0 !important;
}
.team-card {
  width: 100% !important;
  min-width: 0 !important;
}
.team-card.active {
  border-color: rgba(53,232,255,.9) !important;
  background: rgba(53,232,255,.16) !important;
  box-shadow: inset 3px 0 0 #35e8ff, 0 0 14px rgba(53,232,255,.12) !important;
}
.tc-top { min-width: 0 !important; }
.tc-name {
  min-width: 0 !important;
  max-width: 145px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* Follow system v6: mark the real room host/local player in the player list. */
.team-card.local-player {
  border-color: rgba(48, 209, 88, .72) !important;
  background: linear-gradient(180deg, rgba(48,209,88,.11), rgba(53,232,255,.05)) !important;
  box-shadow: inset 3px 0 0 #30d158, 0 0 14px rgba(48,209,88,.12) !important;
}
.team-card.local-player.active {
  border-color: rgba(53,232,255,.95) !important;
  box-shadow: inset 3px 0 0 #30d158, 0 0 18px rgba(53,232,255,.18) !important;
}
.tc-name-wrap {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
}
.tc-name-wrap .tc-name {
  flex: 1 1 auto !important;
  max-width: none !important;
}
.tc-local-badge {
  flex: 0 0 auto !important;
  padding: 2px 5px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(48,209,88,.7) !important;
  background: rgba(48,209,88,.16) !important;
  color: #7CFF9B !important;
  font-size: 8px !important;
  line-height: 1 !important;
  font-weight: 1000 !important;
  letter-spacing: .5px !important;
}


/* Rotating map follow mode */
.rotate-map-row{
  margin-top:8px;
  min-height:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:0 10px;
  border:1px solid rgba(53,232,255,.18);
  border-radius:10px;
  background:rgba(255,255,255,.035);
  color:var(--txt);
  font-size:12px;
  font-weight:900;
  cursor:pointer;
}
.rotate-map-row:hover{background:rgba(95,255,230,.08);border-color:rgba(53,232,255,.32)}
.rotate-map-row input{accent-color:var(--purple2);cursor:pointer}
#map.rotating-map-active .leaflet-tile-pane,
#map.rotating-map-active .leaflet-overlay-pane{
  transform:rotate(var(--map-rotation,0deg)) scale(var(--map-rotation-scale,1.85))!important;
  transform-origin:50% 50%!important;
  will-change:transform;
}
#map.rotating-map-active > canvas{
  transform:none!important;
}
#map:not(.rotating-map-active){--map-rotation:0deg;--map-rotation-scale:1}


/* Follow/rotate v3: more room for player cards, no selected-info box, no hint text. */
.compact-follow-card { padding-bottom: 10px !important; }
.compact-follow-card .spectate-selected,
.compact-follow-card .hint,
#spectateCurrentTarget { display: none !important; }
.compact-follow-card .btn { margin-top: 6px !important; }
.compact-follow-card .rotate-map-row { margin-top: 7px !important; min-height: 30px !important; }
.sidebar .team-float.show {
  flex: 1 1 auto !important;
  max-height: none !important;
  min-height: 150px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-right: 2px !important;
}
.sidebar .team-card { padding: 8px !important; }
.sidebar .tc-top { margin-bottom: 6px !important; }

/* Rotating map v3: rotate map layers around the actual followed target in Leaflet layer coordinates. */
#map.rotating-map-active .leaflet-tile-pane,
#map.rotating-map-active .leaflet-overlay-pane{
  transform:rotate(var(--map-rotation,0deg)) scale(var(--map-rotation-scale,1.42)) !important;
  transform-origin:var(--map-rotation-origin-x,50%) var(--map-rotation-origin-y,50%) !important;
  will-change:transform;
}
#map.rotating-map-active > canvas{ transform:none !important; }
#map:not(.rotating-map-active){
  --map-rotation:0deg;
  --map-rotation-scale:1;
  --map-rotation-origin-x:50%;
  --map-rotation-origin-y:50%;
}
