:root{
  --bg:#0f1115; --panel:#171a21; --panel2:#1e2230; --line:#2a2f3d;
  --txt:#e7e9ee; --muted:#9aa3b2; --accent:#5b8cff; --good:#3ddc84; --warn:#ffb13d;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--txt);
  font:14px/1.45 system-ui,Segoe UI,Roboto,sans-serif}
#app{display:flex;height:100vh}

#sidebar{width:330px;flex:0 0 330px;background:var(--panel);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:14px;gap:12px;overflow-y:auto}
#sidebar h1{font-size:19px;margin:0;font-weight:800;letter-spacing:.3px}
#sidebar h1 span{color:var(--accent)}

.field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
select{background:var(--panel2);color:var(--txt);border:1px solid var(--line);
  border-radius:8px;padding:9px;font-size:14px}

#route-summary{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px}
.kc-row{display:flex;align-items:baseline;gap:6px}
#kc-percent{font-size:26px;font-weight:800;color:var(--good)}
#kc-target{font-size:12px;color:var(--muted)}
.bar{height:8px;background:#0c0e13;border-radius:6px;margin:8px 0;overflow:hidden}
#kc-bar{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--good));transition:width .15s}
.bosses{font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:4px}
.boss-chip{padding:2px 7px;border-radius:20px;border:1px solid var(--line)}
.boss-chip.done{color:#0c0e13;background:var(--good);border-color:var(--good);font-weight:700}

.actions{display:flex;gap:6px}
.actions button{flex:1;background:var(--panel2);color:var(--txt);border:1px solid var(--line);
  border-radius:8px;padding:8px 4px;cursor:pointer;font-size:12px}
.actions button:hover{border-color:var(--accent)}

.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line)}
.tab{flex:1;background:none;border:none;color:var(--muted);padding:9px;cursor:pointer;
  font-size:13px;font-weight:700;border-bottom:2px solid transparent}
.tab.active{color:var(--txt);border-bottom-color:var(--accent)}
.tabpanel{display:none;flex-direction:column;gap:10px}
.tabpanel.active{display:flex}

.affix-block{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px}
.affix-head{display:flex;justify-content:space-between;align-items:center;font-weight:700}
.switch{position:relative;display:inline-block;width:42px;height:23px}
.switch input{display:none}
.slider{position:absolute;inset:0;background:#333a4a;border-radius:20px;cursor:pointer;transition:.15s}
.slider::before{content:"";position:absolute;width:17px;height:17px;left:3px;top:3px;background:#fff;
  border-radius:50%;transition:.15s}
.switch input:checked+.slider{background:var(--warn)}
.switch input:checked+.slider::before{transform:translateX(19px)}

.winter-choice{display:flex;align-items:center;gap:8px;padding:7px;border:1px solid var(--line);
  border-radius:8px;margin-top:6px;cursor:pointer}
.winter-choice img{width:34px;height:34px;border-radius:50%;border:2px solid #6db3ff;object-fit:cover}
.winter-choice.active{outline:2px solid #6db3ff;outline-offset:-2px;background:#16263a}
.winter-choice .wc-name{font-weight:700}
.winter-choice .wc-sub{font-size:11px;color:var(--muted)}
#winter-summary{font-size:12px;color:var(--muted);margin-top:8px}
#winter-summary b{color:#9ad0ff}
#winter-summary .corr{color:var(--good)}
.mini-btn{margin-top:6px;background:var(--panel2);color:var(--txt);border:1px solid var(--line);
  border-radius:7px;padding:5px 9px;cursor:pointer;font-size:12px}
.mini-btn:hover{border-color:var(--accent)}
.mini-btn.on{border-color:#6db3ff;color:#9ad0ff}

.tool-grid{display:flex;flex-wrap:wrap;gap:6px}
.tool-btn{flex:1 1 30%;background:var(--panel2);color:var(--txt);border:1px solid var(--line);
  border-radius:8px;padding:10px 6px;cursor:pointer;font-size:13px}
.tool-btn:hover{border-color:var(--accent)}
.tool-btn.active{border-color:var(--accent);background:#1c2740;color:#cfe0ff}
.trinket-row{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:7px 9px;border:1px solid var(--line);border-radius:8px;margin-top:6px;font-size:12.5px}
.trinket-row button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px}
.trinket-row button:hover{color:#ff6b6b}

.toolbar{display:flex;flex-wrap:wrap;gap:6px}
.toolbar button{flex:1 1 auto;background:var(--panel2);color:var(--txt);border:1px solid var(--line);
  border-radius:8px;padding:8px 6px;cursor:pointer;font-size:12.5px}
.toolbar button:hover{border-color:var(--accent)}
.toolbar button.on{border-color:var(--accent);color:#cfe0ff;background:#1c2740}
.auto-cfg{display:flex;gap:10px;flex-wrap:wrap;font-size:11.5px;color:var(--muted);margin-top:2px}
.auto-cfg label{display:flex;align-items:center;gap:5px}
.auto-cfg input{width:46px;background:var(--panel2);color:var(--txt);border:1px solid var(--line);
  border-radius:6px;padding:3px 5px;font-size:12px}
.toolbar button.on{border-color:var(--warn);color:var(--warn)}

#pulls{display:flex;flex-direction:column;gap:7px}
.pull{background:var(--panel2);border:1px solid var(--line);border-left:5px solid;border-radius:8px;
  padding:8px 10px;cursor:pointer}
.pull.active{outline:2px solid var(--accent);outline-offset:-2px}
.pull-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.pull-name{font-weight:700}
.pull-pct{font-weight:800}
.pull-meta{font-size:11.5px;color:var(--muted);margin-top:3px}
.pull-sub{font-size:11px;color:var(--muted);font-weight:500}
.pull-chev{background:none;border:none;color:var(--muted);cursor:pointer;font-size:11px;padding:0 4px 0 0}
.pull-chev:hover{color:var(--txt)}
.pmob-list{margin-top:6px;display:flex;flex-direction:column;gap:3px}
.pmob-list.hidden{display:none}
.pmob{display:flex;align-items:center;gap:6px;font-size:12.5px;padding:2px 0}
.pmob-img{width:22px;height:22px;flex:0 0 22px;border-radius:50%;object-fit:cover;
  background:#0c0e13;border:1px solid var(--line)}
.pmob-c{color:var(--muted);min-width:20px}
.pmob-n{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pmob-cast{display:inline-flex;gap:2px}
.pmob-cast .cast{font-size:12px}
.pmob-s{font-weight:700;min-width:26px;text-align:right}
.pmob.empty{color:var(--muted);font-style:italic}
.winter-line{color:#9ad0ff}
.winter-mini{display:flex!important;align-items:center;justify-content:center;background:#16263a!important;
  border-color:#6db3ff!important;font-size:13px}
.pack-grp{margin-top:6px;border-top:1px dashed var(--line);padding-top:4px}
.pack-grp:first-child{border-top:none}
.pack-grp-head{font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);margin:2px 0 3px}
.pmob-act{background:none;border:none;cursor:pointer;font-size:13px;opacity:.4;padding:0 1px;line-height:1}
.pmob-act:hover{opacity:.8}
.pmob-act.on{opacity:1;filter:drop-shadow(0 0 3px #ffb13d)}
.chk-tag{color:#ffd24d;font-size:11px}
.pull{cursor:grab}
.pull.dragging{opacity:.45}
.pull.drag-over{outline:2px dashed var(--accent);outline-offset:-2px}
.pull-name{cursor:grab}
.pull-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px}
.pull-del:hover{color:#ff6b6b}

.hint{font-size:11.5px;color:var(--muted);margin:4px 0 0}
.credit{font-size:10.5px;color:#5a6172;margin:auto 0 0}

#map-wrap{flex:1;position:relative}
#map{position:absolute;inset:0;background:#0a0c10}
#map-tools{position:absolute;top:10px;right:10px;z-index:850;display:flex;flex-direction:column;gap:6px;align-items:flex-end;
  background:rgba(20,23,30,.93);border:1px solid var(--line);border-radius:10px;padding:7px;width:max-content;max-width:230px}
.mt-btns{display:flex;gap:4px}
#map-tools .tool-btn,#mt-list-toggle{width:34px;height:34px;flex:0 0 34px;font-size:16px;padding:0;
  display:flex;align-items:center;justify-content:center;background:var(--panel2);border:1px solid var(--line);
  border-radius:8px;color:var(--txt);cursor:pointer}
#map-tools .tool-btn:hover,#mt-list-toggle:hover{border-color:var(--accent)}
#map-tools .tool-btn.active{border-color:var(--accent);background:#1c2740;color:#cfe0ff}
.mt-hint{font-size:11px;color:var(--muted);max-width:215px}
.mt-hint:empty{display:none}
#map-tools .draw-options{gap:6px}
#map-tools #btn-clear-draw{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  border-radius:7px;padding:5px 8px;cursor:pointer;font-size:11.5px}
#map-tools #trinket-list{max-height:170px;overflow-y:auto}
#map-tools #trinket-list.hidden{display:none}

#floor-tabs{position:absolute;top:10px;left:10px;z-index:500;display:flex;gap:4px}

/* dark-themed Leaflet zoom control */
.leaflet-control-zoom{border:none!important;box-shadow:0 1px 6px #0006!important;margin:12px!important}
.leaflet-control-zoom a{background:rgba(20,23,30,.93)!important;color:var(--txt)!important;
  border:1px solid var(--line)!important;width:32px!important;height:32px!important;line-height:30px!important;
  font-size:18px!important;font-weight:600!important}
.leaflet-control-zoom a:first-child{border-radius:9px 9px 0 0!important}
.leaflet-control-zoom a:last-child{border-radius:0 0 9px 9px!important;border-top:none!important}
.leaflet-control-zoom a:hover{background:#1c2740!important;color:#cfe0ff!important;border-color:var(--accent)!important}
#floor-tabs button{background:var(--panel);color:var(--txt);border:1px solid var(--line);
  border-radius:7px;padding:6px 11px;cursor:pointer;font-weight:600}
#floor-tabs button.active{background:var(--accent);border-color:var(--accent);color:#fff}

#draw-layer{position:absolute;inset:0;z-index:800;cursor:crosshair;touch-action:none;background:transparent}
#draw-layer.hidden{display:none}

#toast{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:900;
  background:#000a;border:1px solid var(--line);padding:8px 14px;border-radius:8px;opacity:0;
  transition:opacity .2s;pointer-events:none}
#toast.show{opacity:1}

/* leaflet marker styles — portrait pins */
.mob-pin{width:100%;height:100%;border-radius:50%;border:2.5px solid var(--bc);
  overflow:hidden;background:#11141c;box-shadow:0 0 0 1px #000a;cursor:pointer;
  transition:transform .08s}
.mob-pin img{width:100%;height:100%;object-fit:cover;display:block}
.mob-pin__dot{display:block;width:100%;height:100%;background:var(--bc)}
.mob-pin.on{box-shadow:0 0 0 1px #000,0 0 7px 1px var(--bc)}
.mob-pin:not(.on):not(.boss){filter:grayscale(.35) brightness(.92)}
.mob-pin.boss{border-width:3px;border-color:#ffd84d;box-shadow:0 0 7px 2px #ffd84d77;
  transform:scale(.92);filter:saturate(.8) brightness(.9)}
.mob-pin.boss.on{transform:scale(1.22);filter:none;
  box-shadow:0 0 0 2px var(--bc),0 0 11px 3px #ffd84dcc}
.mob-pin.hl{transform:scale(1.28);position:relative;z-index:1000;border-color:#fff}
.mob-pin.emp{border:4px solid #ff8c1a !important;box-shadow:0 0 11px 3px #ff8c1a,0 0 0 1px #000 !important;filter:none !important}
.mob-pin.winter{border-color:#6db3ff;box-shadow:0 0 9px 2px #6db3ffcc;filter:saturate(.6) brightness(1.05)}
.winter-pack{position:relative;width:100%;height:100%;border-radius:50%;border:3px solid var(--bc,#6db3ff);
  overflow:hidden;background:#11141c;box-shadow:0 0 8px 2px #6db3ff88;cursor:pointer;
  filter:saturate(.7) brightness(.92)}
.winter-pack.on{filter:none;box-shadow:0 0 0 2px #000,0 0 11px 3px var(--bc)}
.winter-pack img{width:100%;height:100%;object-fit:cover;display:block}
.route-num{transform:translate(-50%,-50%);min-width:19px;height:19px;padding:0 3px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:#0c0e13;font-weight:800;font-size:11px;
  border:2px solid rgba(0,0,0,.55);box-shadow:0 0 4px #000}
.entry-flag{transform:translate(-50%,-90%);font-size:20px;filter:drop-shadow(0 1px 2px #000)}
.nav-node{width:14px;height:14px;border-radius:50%;background:#3ddc84;border:2px solid #06110a;
  box-shadow:0 0 0 1px #3ddc8480;cursor:pointer}
.nav-node.entry{background:#ffd24d;box-shadow:0 0 6px 2px #ffd24d}
.nav-node.boss{background:#ff5470;box-shadow:0 0 7px 2px #ff5470}
.nav-node.sel{outline:2px solid #fff;outline-offset:2px}
.nav-mode.active{border-color:var(--accent);background:#1c2740;color:#cfe0ff}
.packnum{transform:translate(-50%,-50%);background:#000c;border:1px solid #ffffff44;border-radius:6px;
  padding:1px 5px;color:#fff;font-size:11px;font-weight:700;white-space:nowrap;text-align:center;line-height:1.15}
.packnum small{display:block;font-weight:400;color:#9ad0ff;font-size:9.5px}
.winter-badge{position:absolute;bottom:-4px;right:-4px;font-size:11px;line-height:1;
  filter:drop-shadow(0 1px 1px #000)}
.mob-pin.chicken{border-color:#ffce4d!important;box-shadow:0 0 8px 2px #ffce4d99!important;filter:none!important}
.chicken-face{display:flex;align-items:center;justify-content:center;width:100%;height:100%;
  font-size:17px;background:radial-gradient(circle,#5a4a1e,#2a2410)}
.chicken-badge{position:absolute;bottom:-5px;left:-5px;font-size:13px;line-height:1;
  filter:drop-shadow(0 1px 1px #000)}
.cast-badge{position:absolute;top:-5px;left:-5px;font-size:12px;line-height:1;
  filter:drop-shadow(0 1px 1px #000)}
.trinket-ico{display:flex;align-items:center;justify-content:center;font-size:20px;
  filter:drop-shadow(0 1px 2px #000)}
.trinket-pending{opacity:.6}
.note-ico{display:flex;align-items:center;justify-content:center;font-size:18px;
  filter:drop-shadow(0 1px 2px #000)}
.draw-options{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.draw-options.hidden{display:none}
.swatches{display:inline-flex;gap:5px}
.swatch{width:18px;height:18px;border-radius:50%;cursor:pointer;border:2px solid #0006}
.swatch.active{border-color:#fff;box-shadow:0 0 0 1px #000}
.note-edit{width:220px;height:70px;background:var(--panel2);color:var(--txt);
  border:1px solid var(--line);border-radius:6px;padding:6px;font:13px system-ui;resize:vertical}
.note-del{margin-top:6px;background:var(--panel2);color:#ff8a8a;border:1px solid var(--line);
  border-radius:6px;padding:4px 8px;cursor:pointer}
.emp-badge{position:absolute;top:-4px;right:-4px;font-size:11px;line-height:1;
  filter:drop-shadow(0 1px 1px #000)}
.emp-badge-ico{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;
  border:2px solid #ff8c1a;object-fit:cover;background:#11141c;box-shadow:0 0 4px #000}
.mob-pin{position:relative}
.mob-label{background:#000d;border:1px solid var(--line);border-radius:6px;padding:3px 6px;
  font-size:12px;color:#fff;white-space:nowrap;line-height:1.35}

.modal{position:fixed;inset:0;background:#000a;display:flex;align-items:center;justify-content:center;z-index:1000}
.modal.hidden{display:none}
.modal-box{background:var(--panel);border:1px solid var(--line);border-radius:12px;width:min(520px,92vw);
  max-height:80vh;display:flex;flex-direction:column}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line)}
.modal-head h2{margin:0;font-size:16px}
#modal-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer}
#modal-body{padding:12px 16px;overflow-y:auto}
.saved-route{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:9px;border:1px solid var(--line);border-radius:8px;margin-bottom:7px}
.saved-route b{font-weight:700}
.saved-route small{color:var(--muted)}
.saved-route .sr-actions button{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  border-radius:7px;padding:6px 10px;cursor:pointer;margin-left:5px}
.saved-route .sr-actions button:hover{border-color:var(--accent)}
