:root{--bg:#070b12;--panel:rgba(15,23,42,.82);--panel-strong:rgba(2,6,23,.9);--line:rgba(148,163,184,.18);--line-strong:rgba(34,211,238,.42);--text:#f8fafc;--muted:#94a3b8;--cyan:#22d3ee;--green:#34d399;--amber:#fbbf24;--monster:#ef4444;--npc:#38bdf8;--portal:#a78bfa}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;min-height:100vh;overflow:auto;background:radial-gradient(circle at 8% -8%,rgba(34,211,238,.26),transparent 30rem),radial-gradient(circle at 90% 8%,rgba(52,211,153,.14),transparent 24rem),linear-gradient(180deg,#070b12,#0b1020 58%,#05070d);color:var(--text);font-family:Pretendard,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
body::before{content:"";position:fixed;inset:0;background-image:url("/img/noise.png");opacity:.04;pointer-events:none}
.toolbar button{border:1px solid var(--line);background:rgba(15,23,42,.72);color:var(--text);padding:9px 12px;border-radius:13px;cursor:pointer;text-decoration:none;font-weight:800;transition:.16s ease}
.toolbar button:hover{border-color:var(--cyan);background:rgba(8,145,178,.18);transform:translateY(-1px)}
.toolbar button:disabled{opacity:.5;cursor:not-allowed;transform:none}
.appShell{width:min(1500px,100%);height:calc(100vh - var(--site-header-offset,0px) - 32px);min-height:760px;margin:0 auto;display:grid;grid-template-columns:minmax(300px,360px) minmax(0,1fr);gap:16px;padding:16px}
.sidebar,.mainPanel{min-height:0}
.sidebar{display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:14px}
.mainPanel{display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px}
.panel,.heroCard{border:1px solid var(--line);border-radius:24px;background:linear-gradient(135deg,var(--panel),rgba(2,6,23,.72));box-shadow:0 24px 70px rgba(0,0,0,.28);backdrop-filter:blur(10px)}
.heroCard{padding:20px;overflow:hidden;position:relative}
.heroCard::after{content:"";position:absolute;right:-50px;top:-60px;width:170px;height:170px;border-radius:999px;background:radial-gradient(circle,rgba(34,211,238,.22),transparent 70%)}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#67e8f9;font-weight:1000}
.heroCard h1{margin:6px 0 8px;font-size:34px;line-height:1;font-weight:1000;letter-spacing:-.04em}
.heroCard p{margin:0;color:#cbd5e1;font-size:14px;line-height:1.55}
.statusText{margin-top:12px;color:#93c5fd;font-size:12px;font-weight:800}
.controlsPanel,.listPanel,.infoPanel{padding:14px}
.fieldLabel{display:block;margin-bottom:8px;color:#93c5fd;font-size:11px;font-weight:1000;letter-spacing:.14em;text-transform:uppercase}
.searchBox input,.mapSelect{width:100%;padding:12px 13px;border-radius:15px;border:1px solid rgba(51,65,85,.9);background:rgba(2,6,23,.72);color:var(--text);outline:none}
.searchBox input:focus,.mapSelect:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.12)}
.regionLabel{margin-top:12px}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:11px;color:#cbd5e1;font-size:13px}
.filters label{display:inline-flex;gap:5px;align-items:center;padding:7px 9px;background:rgba(15,23,42,.78);border-radius:999px;border:1px solid rgba(148,163,184,.18)}
.toolbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
.toolbar button{padding:8px 9px}
.toolbar #zoomText{display:grid;place-items:center;min-width:56px;color:#cffafe;font-size:13px;border:1px solid rgba(34,211,238,.18);border-radius:13px;background:rgba(8,145,178,.1)}
.panelHead{display:flex;align-items:center;justify-content:space-between;gap:12px}
.panelHead h2,.panelHead h3{margin:0;font-size:15px;font-weight:1000}
.panelHead span{color:var(--muted);font-size:12px}
.mapList{height:100%;overflow:auto;padding:10px 2px 2px}
.mapItem{width:100%;text-align:left;padding:12px;margin:5px 0;background:rgba(15,23,42,.48);border:1px solid transparent;border-radius:16px}
.mapItem:hover{background:rgba(8,47,73,.42)}
.mapItem.active{border-color:var(--line-strong);background:rgba(8,145,178,.18);box-shadow:0 0 0 3px rgba(34,211,238,.08)}
.mapItem strong{display:block;font-size:14px}
.mapItem span{display:block;margin-top:4px;font-size:12px;color:var(--muted)}
.infoPanel{overflow:hidden}
.mapHead{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.mapHead h2{margin:4px 0 0;font-size:24px;font-weight:1000;letter-spacing:-.03em}
.muted{color:var(--muted);font-size:13px;margin-top:4px}
.stats{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.stat{padding:8px 10px;border-radius:14px;background:rgba(2,6,23,.48);border:1px solid rgba(148,163,184,.16);min-width:84px}
.stat b{display:block;font-size:16px;color:#fff}
.stat span{font-size:11px;color:var(--muted)}
.monsterBox{margin-top:12px}
.monsterSummary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;max-height:134px;overflow:auto;padding-top:8px}
.monsterCard{padding:10px;border-radius:14px;background:rgba(2,6,23,.46);border:1px solid rgba(148,163,184,.14)}
.monsterCard .name{font-weight:900}
.monsterCard .meta{margin-top:4px;font-size:12px;color:var(--muted)}
.viewerWrap{position:relative;overflow:hidden;padding:0}
.viewer{position:relative;width:100%;height:100%;overflow:hidden;border-radius:24px;background:#11151c;background-position:center;background-repeat:no-repeat;background-size:cover;touch-action:none}
.viewer.checker{background-color:#11151c;background-image:linear-gradient(45deg,#151a22 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#151a22 75%),linear-gradient(45deg,transparent 75%,#151a22 75%),linear-gradient(45deg,#151a22 25%,#0f131a 25%);background-position:0 0,0 0,16px 16px,16px 16px;background-size:32px 32px}
.viewer.coverbg{background-blend-mode:normal}
.world{position:absolute;left:0;top:0;transform-origin:0 0;will-change:transform}
.world img{display:block;max-width:none!important;width:auto!important;height:auto!important;user-select:none}
.markerLayer{position:absolute;left:0;top:0;pointer-events:none}
.marker{position:absolute;width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.9);transform:translate(-50%,-50%);cursor:pointer;pointer-events:auto;box-shadow:0 0 0 2px rgba(0,0,0,.35),0 4px 14px rgba(0,0,0,.5);transition:transform .12s ease,filter .12s ease}
.marker:hover{transform:translate(-50%,-50%) scale(1.18);filter:drop-shadow(0 0 10px rgba(255,255,255,.32))}
.marker.monster{background:linear-gradient(135deg,#f97316,var(--monster))}
.marker.npc{background:linear-gradient(135deg,#38bdf8,#2563eb)}
.marker.portal{background:linear-gradient(135deg,#c4b5fd,#7c3aed)}
.marker.hidden{display:none}
.emptyState{position:absolute;inset:0;display:grid;place-items:center;color:var(--muted);pointer-events:none}
.emptyState.hidden{display:none}
.tooltip{position:absolute;min-width:220px;max-width:320px;background:rgba(2,6,23,.94);border:1px solid rgba(103,232,249,.38);border-radius:18px;padding:12px;color:var(--text);box-shadow:0 18px 56px rgba(0,0,0,.5);z-index:20;pointer-events:none;backdrop-filter:blur(12px)}
.tooltip.hidden{display:none}
.tooltip h3{margin:0 0 8px;font-size:14px}
.tooltip p{margin:4px 0;color:#cbd5e1;font-size:12px}
.overview{position:absolute;right:14px;bottom:14px;width:220px;padding:10px;border:1px solid rgba(103,232,249,.28);border-radius:18px;background:rgba(2,6,23,.82);box-shadow:0 18px 56px rgba(0,0,0,.5);z-index:15;backdrop-filter:blur(12px)}
.overview.hidden{display:none}
.overviewTitle{font-size:12px;font-weight:1000;color:var(--text);margin-bottom:7px}
.overviewCanvas{position:relative;display:grid;place-items:center;width:100%;height:140px;border:1px solid rgba(148,163,184,.18);border-radius:12px;background:#020617;overflow:hidden;cursor:crosshair}
.overviewCanvas img{max-width:100%;max-height:100%;width:auto;height:auto;user-select:none;pointer-events:none}
.overviewViewport{position:absolute;border:2px solid var(--green);background:rgba(52,211,153,.16);box-shadow:0 0 0 1px rgba(0,0,0,.65);pointer-events:none}
.overviewHint{margin-top:6px;font-size:11px;color:var(--muted)}

@media (max-width:1100px){body{overflow:auto}
.appShell{height:auto;min-height:calc(100vh - var(--site-header-offset,0px) - 32px);grid-template-columns:1fr}
.sidebar{grid-template-rows:auto auto auto}
.listPanel{max-height:320px;overflow:hidden}
.mapList{max-height:240px;height:auto}
.viewerWrap{height:70vh}
.appShell{padding:12px}
.toolbar{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:640px){.appShell{gap:10px;padding:10px}
.heroCard,.controlsPanel,.listPanel,.infoPanel{padding:12px;border-radius:18px}
.heroCard p{display:none}
.controlsPanel{position:sticky;top:calc(var(--site-header-offset,0px) + 8px);z-index:5}
.mapHead{flex-direction:column}
.stats{justify-content:flex-start}
.stat{min-width:72px;padding:7px 8px}
.monsterSummary{max-height:180px;grid-template-columns:1fr}
.listPanel{max-height:220px}
.mapList{max-height:150px}
.mapItem{padding:10px;margin:4px 0}
.viewerWrap{height:68vh;min-height:420px;order:-1}
.viewer{border-radius:18px}
.overview{width:150px;right:8px;bottom:8px}
.overviewCanvas{height:92px}
.heroCard h1{font-size:28px}
}

