:root{--tile: 70px;--cols: 0;--rows: 0;--bg: #0b0d10;--font-title: "Cinzel", ui-serif, Georgia, "Times New Roman", serif;--font-ui: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{width:100%;min-height:100%;font-family:var(--font-ui),sans-serif}body{margin:0;background:var(--bg);color:#e5e7eb;overflow:auto}h1,.logo,.title{font-family:var(--font-title),sans-serif;letter-spacing:.02em}.num{font-variant-numeric:tabular-nums}.rune,.spell-name{font-family:"Uncial Antiqua",var(--font-title),serif;letter-spacing:.01em}#app{min-height:100%;overflow:visible}#board-wrap{width:100%;height:auto;overflow:auto;margin:130px 0;padding:0 20px}#board{position:relative;display:block;width:calc(var(--cols) * var(--tile));height:calc(var(--rows) * var(--tile));overflow:hidden;image-rendering:pixelated;transform:translateZ(0)}#board:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;outline:1px solid rgba(255,255,255,.06)}.g-floor,.g-walls,.g-other,.g-furniture{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.g-floor{z-index:10}.g-walls{z-index:20}.g-other{z-index:25}.g-furniture{z-index:30}.tl{position:absolute;width:var(--tile);height:var(--tile);background-repeat:no-repeat;image-rendering:pixelated;will-change:transform,left,top;contain:paint}#entities{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:40}.entity{position:absolute;width:var(--tile);height:var(--tile);background-repeat:no-repeat;image-rendering:pixelated;will-change:transform,left,top}.entity.furniture{z-index:30}.entity.vendor{z-index:33}.entity.monster{z-index:35}.entity.hero{z-index:40}.tile.cell{width:var(--tile);height:var(--tile)}.tile.cell.fogged{filter:brightness(0)}.tile.cell.explored:not(.fogged){filter:none}.hidden{display:none!important}#board.show-grid{background-image:linear-gradient(to right,rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.06) 1px,transparent 1px);background-size:var(--tile) var(--tile)}.g-heroes{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:40}.hero-sprite{width:var(--tile);height:var(--tile);background-repeat:no-repeat;image-rendering:pixelated}.g-actors{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:45}.actor{position:absolute;width:var(--tile);height:var(--tile);background-repeat:no-repeat;image-rendering:pixelated}.actor.hero{z-index:46}.actor.monster{z-index:45}.g-fog{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:60}.fog-tile{background:#000000e6}.map-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:9999}.map-panel{width:min(980px,96vw);max-height:92vh;background:#121212;color:#eee;border:1px solid #2a2a2a;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px #00000073}.map-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#1b1b1b;border-bottom:1px solid #2a2a2a}.map-header h2{margin:0;font-size:18px}.map-close{background:transparent;border:0;color:#eee;font-size:20px;cursor:pointer}.map-body{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px}.inv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:9999;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial}.inv-panel{width:min(980px,96vw);max-height:92vh;background:#121212;color:#eee;border:1px solid #2a2a2a;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px #00000073}.inv-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#1b1b1b;border-bottom:1px solid #2a2a2a}.inv-header h2{margin:0;font-size:18px}.inv-close{background:transparent;border:0;color:#eee;font-size:20px;cursor:pointer}.inv-body{display:grid;grid-template-columns:2fr 1fr;gap:16px;padding:16px}.inv-gear{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;background:#161616;padding:12px;border-radius:10px;border:1px solid #2a2a2a}.gear-slot{display:grid;gap:6px}.gear-slot-title{font-size:12px;opacity:.9}.gear-slot-box{min-height:140px;display:grid;place-items:center;background:#0f0f0f;border:1px dashed #3a3a3a;border-radius:8px;padding:6px}.gear-slot-empty{opacity:.4}.inv-stats{background:#161616;padding:12px;border-radius:10px;border:1px solid #2a2a2a;height:fit-content}.stat-list{display:grid;gap:8px}.stat-row{display:flex;justify-content:space-between;font-size:14px}.inv-bag{grid-column:1 / -1;background:#161616;padding:12px;border-radius:10px;border:1px solid #2a2a2a}.bag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.item-btn{display:grid;grid-template-columns:48px 1fr;gap:8px;background:#0f0f0f;border:1px solid #2a2a2a;color:#eee;padding:8px;border-radius:8px;cursor:pointer}.item-btn:hover{border-color:#3f7cff}.item-icon{width:48px;height:48px;display:grid;place-items:center;background:#111;border-radius:6px;overflow:hidden}.item-icon img{width:100%;height:100%;object-fit:cover}.item-name{font-weight:600}.item-sub{opacity:.8;font-size:12px}.item-action{margin-top:6px;font-size:12px;opacity:.9}.fx-proj.fx-arrow{mix-blend-mode:normal}.fx-proj.fx-fireball{mix-blend-mode:screen}.fx-splat{mix-blend-mode:multiply}#close-tavern,#close-shop,.shop-item-buy{display:block;width:100px;margin:6px 0;padding:8px;border:none;border-radius:8px;background:#e2b714;color:#000;cursor:pointer;font-weight:600}.screen-overlay{opacity:0;transition:opacity .18s ease}.screen-overlay.is-open{opacity:1}.path-preview-root .path-node{border-radius:2px;animation:pathPulse .5s infinite ease-in-out;z-index:100;box-shadow:0 0 30px currentColor;transform-origin:35px 35px}.path-preview-root .path-target{border-radius:2px;animation:pathPulseStrong .5s infinite ease-in-out;z-index:100;box-shadow:0 0 30px currentColor;transform-origin:35px 35px}@keyframes pathPulse{0%{filter:drop-shadow(0 0 2px rgba(158,255,141,.3))}to{filter:drop-shadow(0 0 6px rgba(158,255,141,.6))}}@keyframes pathPulseStrong{0%{filter:drop-shadow(0 0 4px rgba(106,255,83,.4))}to{filter:drop-shadow(0 0 10px rgba(106,255,83,.8))}}.audio-controls{position:absolute;z-index:10000;right:1rem;bottom:1rem;width:240px;padding:.75rem 1rem;background:#141419d9;color:#e6e6e6;border:1px solid rgba(255,255,255,.08);border-radius:12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.audio-controls__header{margin-bottom:.5rem}.audio-controls__header h3{margin:0;font-size:.95rem;letter-spacing:.02em}.audio-controls__row{display:grid;grid-template-columns:1fr;gap:.35rem;margin:.5rem 0}.audio-controls__label{font-size:.9rem;display:flex;align-items:center;gap:.5rem}input[type=range]{width:100%}.buff-icons{position:absolute;top:2px;left:50%;transform:translate(-50%);display:flex;gap:4px;font-size:1.2em;pointer-events:none}.buff-icon{filter:drop-shadow(0 0 2px black)}.actor--active{outline:2px solid #eab308!important;box-shadow:0 0 0 3px #eab30840,0 6px 18px #00000059!important;border-radius:6px;animation:pulseActive 1.2s ease-in-out infinite}@keyframes pulseActive{0%{outline-offset:0px}50%{outline-offset:2px}to{outline-offset:0px}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background-color:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:#fff3}
