*,:before,:after{box-sizing:border-box;margin:0;padding:0}@font-face{font-family:Melon Honey;src:url(/fonts/MelonHoney.ttf)format("truetype");font-display:swap}@font-face{font-family:Handwritten;src:url(/fonts/Handwritten.ttf)format("truetype");font-display:swap}:root{--bg:#0d0b08;--bg-card:#161210;--bg-input:#1e1a15;--border:#3a2e22;--border-hi:#6b4f2e;--gold:#c9922a;--gold-hi:#e8b84b;--red:#8b2c2c;--red-hi:#c0392b;--text:#d4c5a9;--text-dim:#7a6a54;--text-hi:#f0e6ce;--font-title:"Melon Honey", "Cinzel", serif;--font-body:"Crimson Text", Georgia, serif;--font-hand:"Handwritten", "Crimson Text", Georgia, serif;--radius:6px;--shadow:0 4px 24px #0009}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.6;overflow:hidden}.app-shell,.ui-overlay,.top-bar,.bottom-hud{-webkit-user-select:none;user-select:none}input,textarea,select{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hi)}h1,h2,h3{font-family:var(--font-title);color:var(--gold);letter-spacing:.04em}h1{font-size:1.8rem}h2{font-size:1.3rem}h3{font-size:1rem}button{cursor:pointer;color:var(--text-hi);font-family:var(--font-title);letter-spacing:.04em;text-shadow:0 1px 2px #000000d9;filter:brightness(.92);background-color:#0000;background-image:url(/wooden-ui/Tex_Plank_07.png);background-repeat:no-repeat;background-size:100% 100%;border:0;border-radius:0;min-height:30px;padding:.35em 1em;font-size:.82rem;transition:filter .12s,transform 60ms,color .12s}button:hover{filter:brightness(1.05)saturate(1.05);color:var(--gold-hi);background-color:#0000}button:active{filter:brightness(.85);transform:translateY(1px)}button:disabled{filter:grayscale(.55)brightness(.6);cursor:not-allowed;opacity:1}button.primary{color:var(--gold-hi);filter:brightness()saturate(1.1);background-image:url(/wooden-ui/Tex_Plank_09.png)}button.primary:hover{filter:brightness(1.1)saturate(1.15)}input,textarea,select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);outline:none;width:100%;padding:.45em .7em;font-size:.95rem}input:focus,textarea:focus,select:focus{border-color:var(--gold)}.app-shell{flex-direction:column;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.scene-viewport{z-index:0;position:absolute;inset:0}.ui-overlay{z-index:10;pointer-events:none;flex-direction:column;width:100%;height:100%;display:flex;position:relative}.ui-overlay>*{pointer-events:auto}.top-bar{z-index:30;background:url(/wooden-ui/Tex_Plank_07.png) 0 0/auto 100% repeat-x,#2a1a0c;border-top:8px solid #0000;border-bottom:10px solid #0000;border-image:url(/wooden-ui/Tex_obj_07.png) 8/8px 0 10px round;flex-shrink:0;justify-content:space-between;align-items:center;min-height:96px;padding:.65rem 1.25rem .85rem;display:flex;position:relative;box-shadow:0 6px 14px #000000bf,inset 0 -2px #0006,inset 0 2px #ffc87814}.top-bar-title{font-family:var(--font-title);color:var(--gold-hi);letter-spacing:.1em;text-shadow:0 2px 4px #000000f2,0 0 16px #e8b84b73,0 1px #ffdc8c40;font-size:2rem;line-height:1.05}.top-bar-status{color:var(--text-dim);align-items:center;gap:.4rem;font-size:.75rem;display:flex}.status-dot{background:var(--red);border-radius:50%;width:8px;height:8px}.status-dot.connected{background:#4a7c59}.bottom-hud{background:linear-gradient(#0000 0%,#0f0a058c 40%,#0f0a05e6 100%);flex-direction:column;gap:.5rem;margin-top:auto;padding:1rem 1.5rem 1.25rem;display:flex;position:relative}.bottom-hud:before{content:"";opacity:.85;pointer-events:none;z-index:1;background:url(/wooden-ui/Tex_obj_07.png) 0/auto 100% repeat-x;height:18px;position:absolute;bottom:0;left:0;right:0}.nav-row{z-index:2;justify-content:center;align-items:flex-end;gap:1rem;display:flex;position:relative}.nav-btn{cursor:pointer;filter:drop-shadow(0 3px 5px #000000b3);image-rendering:auto;width:84px;height:84px;min-height:unset;text-shadow:none;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;margin-top:22px;padding:0;transition:filter .12s,transform 80ms;display:flex;position:relative;overflow:visible}.nav-btn:before{content:"";z-index:0;background:radial-gradient(at 50% 35%,#2a1c10 0%,#14100a 70%,#0a0805 100%);border-radius:6px;position:absolute;inset:6px;box-shadow:inset 0 2px 5px #000000d9,inset 0 -1px 1px #ffc8780f}.nav-btn:after{content:"";pointer-events:none;z-index:2;background:url(/wooden-ui/Tex_frame_s_01.png) 50%/100% 100% no-repeat;position:absolute;inset:0}.nav-btn:hover{filter:brightness(1.1)saturate(1.05)drop-shadow(0 5px 8px #000000bf);color:var(--gold-hi);background:0 0;border:none;transform:translateY(-2px)}.nav-btn:active{filter:brightness(.85);transform:translateY(1px)}.nav-btn.active{filter:drop-shadow(0 0 8px #e8b84b99)drop-shadow(0 0 18px #e8b84b59)drop-shadow(0 3px 5px #000000b3)}.nav-btn.active:before{background:radial-gradient(at 50% 35%,#4a2f15 0%,#1f1408 70%,#0a0805 100%);box-shadow:inset 0 2px 5px #000000d9,inset 0 0 12px #e8b84b40}.nav-btn-label{font-family:var(--font-title);color:var(--gold-hi);letter-spacing:.08em;text-shadow:0 1px 2px #000000f2,0 0 4px #000c;white-space:nowrap;z-index:3;pointer-events:none;font-variant:small-caps;font-size:.82rem;line-height:1;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.nav-btn.active .nav-btn-label{color:#fff8e0;text-shadow:0 1px 2px #000000f2,0 0 8px #e8b84bb3}.nav-btn-icon{z-index:1;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;display:flex;position:relative}.nav-btn-icon img{object-fit:contain;filter:drop-shadow(0 2px 3px #000000e6);width:100%;height:100%}.nav-btn-icon-crossed{position:relative}.nav-btn-icon-crossed .cross-sword{object-fit:contain;width:100%;height:100%;position:absolute;inset:0}.nav-btn-icon-crossed .cross-sword-a{transform:rotate(-45deg)}.nav-btn-icon-crossed .cross-sword-b{transform:rotate(45deg)scaleY(-1)}.encounter-wrap{z-index:20;pointer-events:none;position:absolute;bottom:1.25rem;left:1.5rem}.encounter-btn{width:130px;height:200px;min-height:unset;cursor:pointer;text-shadow:none;pointer-events:auto;filter:drop-shadow(0 6px 12px #000c);background:0 0;border:none;border-radius:0;margin:0;padding:0;transition:filter .15s,transform .1s;position:relative}.encounter-btn:hover{filter:drop-shadow(0 0 10px #ff8c288c)drop-shadow(0 8px 14px #000000d9);color:inherit;background:0 0;border:none;transform:translateY(-2px)scale(1.02)}.encounter-btn:active{filter:brightness(.9);transform:translateY(1px)scale(.98)}.encounter-banner{pointer-events:none;z-index:1;transform-origin:top;width:70px;height:auto;animation:4s ease-in-out infinite encounter-banner-sway;position:absolute;top:100px;left:50%;transform:translate(-50%)}@keyframes encounter-banner-sway{0%,to{transform:translate(-50%)rotate(-1.5deg)}50%{transform:translate(-50%)rotate(1.5deg)}}.encounter-shield{pointer-events:none;z-index:2;filter:drop-shadow(0 3px 4px #000000b3);width:105px;height:auto;position:absolute;top:28px;left:50%;transform:translate(-50%)}.encounter-helmet{pointer-events:none;z-index:3;filter:drop-shadow(0 3px 4px #0009);width:130px;height:auto;position:absolute;top:0;left:50%;transform:translate(-50%)}.connected-badge{z-index:100;font-family:var(--font-title);letter-spacing:.14em;color:var(--gold-hi);text-shadow:0 1px 3px #000000f2,0 0 6px #e8b84b59;text-align:center;pointer-events:none;text-transform:uppercase;filter:drop-shadow(0 4px 8px #000000b3);background:url(/wooden-ui/Tex_Plank_07.png) 50%/100% 100% no-repeat;min-width:160px;padding:.55rem 1.6rem .65rem 1.4rem;font-size:.82rem;position:fixed;bottom:1.4rem;right:5.8rem}.pose-menu{background:#14100abf;border:1px solid #b48c5040;border-radius:6px;flex-direction:column;gap:.5rem;padding:.6rem .75rem;display:flex}.pose-row{flex-wrap:wrap;justify-content:center;gap:.4rem;display:flex}.pose-chip{font-family:var(--font-title);letter-spacing:.04em;color:var(--gold);cursor:pointer;text-shadow:0 1px 2px #000c;background:#281e12e6;border:1px solid #b48c504d;border-radius:3px;padding:.35em .8em;font-size:.7rem}.pose-chip:hover{background:#3c2d19f2}.pose-chip.active{color:var(--gold-hi);border-color:var(--gold);background:#785528e6}.pose-scrub{align-items:center;gap:.5rem;display:flex}.pose-scrub input[type=range]{accent-color:var(--gold);flex:1}.pose-play{width:2rem;height:2rem;color:var(--gold);cursor:pointer;background:#281e12e6;border:1px solid #b48c504d;border-radius:3px;justify-content:center;align-items:center;font-size:.85rem;display:flex}.pose-play:hover{background:#3c2d19f2}.hf-import-row{flex-direction:column;gap:.3rem;margin:.5rem 0;display:flex}.hf-import button{font-family:var(--font-title);letter-spacing:.04em;color:var(--gold);cursor:pointer;background:#281e12e6;border:1px solid #b48c504d;border-radius:3px;width:100%;padding:.5em 1em;font-size:.7rem}.hf-import button:disabled{opacity:.6;cursor:wait}.hf-import button:hover:not(:disabled){background:#3c2d19f2}.hf-import-status{color:var(--gold);align-items:center;gap:.5rem;margin:0;font-size:.7rem;display:flex}.link-btn{color:var(--gold-hi);cursor:pointer;background:0 0;border:none;padding:0;font-size:.7rem;text-decoration:underline}.server-gem{z-index:100;pointer-events:auto;justify-content:center;align-items:center;width:72px;height:72px;transition:filter .3s;display:flex;position:fixed;bottom:1rem;right:1rem}.gem-img{object-fit:contain;image-rendering:auto;width:100%;height:100%}.server-gem--online .gem-img{filter:drop-shadow(0 0 12px #50b4ffe6)drop-shadow(0 0 24px #50b4ff80);animation:3s ease-in-out infinite gem-pulse}@keyframes gem-pulse{0%,to{filter:drop-shadow(0 0 12px #50b4ffe6)drop-shadow(0 0 24px #50b4ff80)}50%{filter:drop-shadow(0 0 18px #78c8ff)drop-shadow(0 0 36px #50b4ffb3)}}.server-gem--connecting .gem-img{filter:hue-rotate(-150deg)saturate(.9)drop-shadow(0 0 10px #ffb43ccc)drop-shadow(0 0 20px #ffa02880);animation:1.2s ease-in-out infinite gem-pulse-connecting}@keyframes gem-pulse-connecting{0%,to{opacity:.55}50%{opacity:1}}.server-gem--offline .gem-img{filter:grayscale(.75)brightness(.45)drop-shadow(0 2px 4px #0009);opacity:.7}.connection-screen{background:radial-gradient(ellipse at center, #c9922a0f 0%, transparent 70%), var(--bg);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.connection-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:1.25rem;width:360px;max-width:90vw;padding:2rem 1.5rem;display:flex;box-shadow:0 8px 48px #000c,0 0 0 1px #c9922a1a}.connection-card h1{text-align:center;font-size:1.5rem;line-height:1.3}.connection-card p{color:var(--text-dim);text-align:center;font-size:.88rem}.connect-form{flex-direction:column;gap:.75rem;width:100%;display:flex}.connect-form label{font-family:var(--font-title);color:var(--gold);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.connect-form input{text-align:center;letter-spacing:.05em;font-size:1.1rem}.connect-error{color:var(--red-hi);text-align:center;font-size:.82rem}.connect-hint{color:var(--text-dim);text-align:center;font-size:.75rem;line-height:1.4}.connect-waiting-msg{font-family:var(--font-title);color:var(--gold);text-align:center;font-size:1rem}.profile-list-card{width:420px}.profile-list{flex-direction:column;gap:.5rem;width:100%;max-height:50vh;display:flex;overflow-y:auto}.profile-row{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);align-items:stretch;gap:.3rem;transition:border-color .15s;display:flex;overflow:hidden}.profile-row:hover{border-color:var(--gold)}.profile-row-main{text-align:left;color:var(--text);background:0 0;border:none;border-radius:0;flex:1;align-items:center;gap:.75rem;padding:.6rem .75rem;display:flex}.profile-row-main:hover{background:#c9922a14;border:none}.profile-row-portrait{object-fit:cover;border:2px solid var(--border-hi);background:var(--bg-card);border-radius:50%;flex-shrink:0;width:48px;height:48px}.profile-row-portrait.placeholder{font-family:var(--font-title);color:var(--gold);justify-content:center;align-items:center;font-size:1.3rem;display:flex}.profile-row-text{flex:1;min-width:0}.profile-row-char{font-family:var(--font-title);color:var(--gold-hi);white-space:nowrap;text-overflow:ellipsis;font-size:1.05rem;overflow:hidden}.profile-row-meta{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.profile-row-actions{border-left:1px solid var(--border);flex-direction:column;display:flex}.profile-row-icon{color:var(--text-dim);background:0 0;border:none;border-radius:0;flex:1;padding:0 .6rem;font-size:.9rem}.profile-row-icon:hover{color:var(--gold);background:#c9922a1a;border:none}.profile-row-icon+.profile-row-icon{border-top:1px solid var(--border)}.profile-waiting-hero{flex-direction:column;align-items:center;gap:.5rem;display:flex}.profile-waiting-portrait{object-fit:cover;border:2px solid var(--border-hi);border-radius:50%;width:96px;height:96px;box-shadow:0 0 24px #c9922a40}.profile-waiting-portrait.placeholder{background:var(--bg-input);font-family:var(--font-title);color:var(--gold);justify-content:center;align-items:center;font-size:2.5rem;display:flex}.profile-editor-card{width:420px;max-height:90vh;overflow-y:auto}.profile-form{flex-direction:column;gap:.6rem;width:100%;display:flex}.profile-form label{flex-direction:column;gap:.2rem;display:flex}.profile-form label span{font-family:var(--font-title);color:var(--gold);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem}.profile-form-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.portrait-row{align-items:center;gap:1rem;width:100%;display:flex}.portrait-thumb{border:2px solid var(--border-hi);background:var(--bg-input);border-radius:50%;flex-shrink:0;width:96px;height:96px;overflow:hidden}.portrait-thumb img{object-fit:cover;width:100%;height:100%;display:block}.portrait-placeholder-small{width:100%;height:100%;color:var(--text-dim);text-align:center;justify-content:center;align-items:center;padding:0 .25rem;font-size:.7rem;display:flex}.portrait-buttons{flex-direction:column;flex:1;gap:.35rem;display:flex}.portrait-buttons button{font-size:.85rem}.portrait-hint{color:var(--text-dim);margin-top:.15rem;font-size:.72rem;font-style:italic;line-height:1.3}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:500;background:#000000bf;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;width:420px;max-width:100%;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 8px 48px #000000d9,0 0 0 1px #c9922a26}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.modal-close{color:var(--text-dim);background:0 0;border:none;padding:0 .25rem;font-size:1.4rem;line-height:1}.modal-close:hover{color:var(--text);background:0 0;border:none}.modal-body{flex-direction:column;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.field-label{font-family:var(--font-title);color:var(--gold);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem}.portrait-preview{aspect-ratio:1;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.portrait-preview img{object-fit:cover;width:100%;height:100%;display:block}.portrait-loading,.portrait-placeholder{color:var(--text-dim);font-size:.9rem;font-style:italic}.portrait-loading{color:var(--gold)}.top-bar-char{align-items:center;gap:1rem;display:flex}.top-bar-portrait-wrap{flex-shrink:0;width:78px;height:78px;position:relative}.top-bar-portrait{object-fit:cover;filter:drop-shadow(0 2px 4px #000000bf);border:0;border-radius:50%;width:78px;height:78px;display:block}.top-bar-portrait.placeholder{color:var(--gold-hi);font-family:var(--font-title);background:radial-gradient(circle at 35% 30%,#5a3f1c 0%,#2a1a08 75%);border-radius:50%;justify-content:center;align-items:center;font-size:2.2rem;display:flex}.top-bar-portrait-frame{pointer-events:none;z-index:2;filter:drop-shadow(0 3px 4px #000000b3);background:url(/wooden-ui/Tex_frame_c_06.png) 50%/contain no-repeat;position:absolute;inset:-16px}.top-bar-char-text{flex-direction:column;padding-left:.4rem;line-height:1.1;display:flex}.top-bar-subtitle{color:var(--gold);font-size:.8rem;font-family:var(--font-title);letter-spacing:.12em;text-transform:uppercase;text-shadow:0 1px 2px #000000e6;opacity:.85}.top-bar-leave{font-family:var(--font-title);letter-spacing:.12em;text-transform:uppercase;min-height:32px;color:var(--gold-hi);text-shadow:0 1px 2px #000000e6;filter:brightness(.95)drop-shadow(0 3px 4px #0009);background-color:#0000;background-image:url(/wooden-ui/Tex_plank_14.png);background-repeat:no-repeat;background-size:100% 100%;border:none;border-radius:0;align-self:center;padding:.35em 1.1em;font-size:.72rem}.top-bar-leave:hover{filter:brightness(1.1)saturate(1.1)drop-shadow(0 4px 6px #000000b3);color:#fff8e0;background-image:url(/wooden-ui/Tex_plank_14.png)}.connect-waiting-dots{justify-content:center;gap:.4rem;margin:.25rem 0 .5rem;display:flex}.connect-waiting-dots span{background:var(--gold);opacity:.3;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite waiting-dot}.connect-waiting-dots span:nth-child(2){animation-delay:.2s}.connect-waiting-dots span:nth-child(3){animation-delay:.4s}@keyframes waiting-dot{0%,to{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.map-menu{margin-left:auto;margin-right:.5rem;position:relative}.map-menu-toggle{color:var(--gold);cursor:pointer;font-family:var(--font-title);letter-spacing:.04em;background:#281e12e6;border:1px solid #b48c504d;border-radius:4px;align-items:center;gap:.35rem;padding:.3em .7em;font-size:.75rem;display:flex}.map-menu-toggle:hover{background:#3c2d19f2}.map-menu.open .map-menu-toggle{color:var(--gold-hi);border-color:var(--gold);background:#785528e6}.map-menu-icon{font-size:1rem;line-height:1}.map-menu-label{font-size:.7rem}.map-menu-panel{background:#14100af2;border:1px solid #b48c504d;border-radius:6px;min-width:220px;max-width:280px;max-height:70vh;padding:.35rem;position:absolute;top:calc(100% + .35rem);right:0;overflow-y:auto;box-shadow:0 6px 24px #000000b3}.map-menu-dim{color:var(--text-dim);margin:0;padding:.35rem .5rem;font-size:.7rem}.map-acc{margin-bottom:.15rem}.map-acc-head{width:100%;color:var(--gold);cursor:pointer;font-family:var(--font-title);letter-spacing:.03em;text-align:left;background:#281e12d9;border:1px solid #b48c5033;border-radius:3px;align-items:center;gap:.4rem;padding:.4em .55em;font-size:.75rem;display:flex}.map-acc-head:hover{background:#3c2d19f2}.map-acc.open .map-acc-head{color:var(--gold-hi);border-color:var(--gold);background:#5a411ee6}.map-acc-chev{width:.8rem;font-size:.7rem;display:inline-block}.map-acc-ico{font-size:.9rem}.map-acc-title{flex:1}.map-acc-count{color:var(--text-dim);font-size:.65rem}.map-acc-body{flex-direction:column;gap:.2rem;padding:.25rem .25rem .25rem 1.1rem;display:flex}.map-entry-btn{text-align:left;color:var(--gold);cursor:pointer;font-size:.7rem;font-family:var(--font-title);background:#1e160eb3;border:1px solid #b48c5026;border-radius:3px;padding:.3em .55em}.map-entry-btn:hover{color:var(--gold-hi);border-color:var(--gold);background:#503719e6}.map-dungeon-head{width:100%;color:var(--gold);cursor:pointer;font-family:var(--font-title);text-align:left;background:#1e160eb3;border:1px solid #b48c5026;border-radius:3px;align-items:center;gap:.35rem;padding:.3em .5em;font-size:.7rem;display:flex}.map-dungeon-head:hover{background:#3c2d19e6}.map-dungeon-acc.open .map-dungeon-head{color:var(--gold-hi);border-color:var(--gold);background:#503719e6}.map-dungeon-title{flex:1}.map-dungeon-body{flex-direction:column;gap:.3rem;padding:.35rem .5rem .35rem 1rem;display:flex}.map-dungeon-meta{color:var(--text-dim);margin:0;font-size:.65rem}.map-dungeon-meta em{color:var(--gold);font-style:normal}.map-dungeon-open{color:var(--gold-hi);border:1px solid var(--gold);cursor:pointer;font-size:.65rem;font-family:var(--font-title);background:#785528e6;border-radius:3px;align-self:flex-start;padding:.25em .6em}.map-dungeon-open:hover{background:#a06e32f2}@keyframes map-unfold{0%{opacity:0;transform:translate(-50%,-28%)scale(.07)rotate(-10deg)}55%{opacity:1}78%{transform:translate(-50%,-51%)scale(1.04)rotate(1.5deg)}to{transform:translate(-50%,-50%)scale(1)rotate(0)}}.map-window{z-index:50;background:#0a0806;border:1px solid #b48c5073;border-radius:6px;flex-direction:column;animation:.38s cubic-bezier(.34,1.56,.64,1) both map-unfold;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 16px 72px #000000e0,0 0 0 1px #c9922a2e}.map-window-header{cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;background:#281e12f7;border-bottom:1px solid #b48c5047;flex-shrink:0;justify-content:space-between;align-items:center;padding:.45rem .75rem;display:flex}.map-window-header:active{cursor:grabbing}.map-window-title{font-family:var(--font-title);color:var(--gold);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.map-window-actions{flex-shrink:0;gap:.4rem;margin-left:.75rem;display:flex}.map-window-btn{color:var(--gold);cursor:pointer;font-family:var(--font-title);letter-spacing:.03em;background:#3c2d19e6;border:1px solid #b48c504d;border-radius:3px;padding:.2em .55em;font-size:.65rem}.map-window-btn:hover{color:var(--gold-hi);background:#64461ef2;border:none}.map-window-close{color:var(--text-dim)}.map-window-close:hover{color:var(--red-hi);border-color:var(--red-hi)!important}.map-window-stage{touch-action:none;cursor:grab;background:#0a0806;flex:1;min-height:0;position:relative;overflow:hidden}.map-window-stage:active{cursor:grabbing}.map-window-transform{transform-origin:0 0;will-change:transform;position:absolute;top:0;left:0}.map-window-img{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:100%;display:block}.player-map-pin{transform:translate(-50%, -100%) scale(var(--pin-scale,1));transform-origin:bottom;cursor:pointer;z-index:10;pointer-events:auto;filter:drop-shadow(0 2px 4px #000000d9);background:0 0;border:0;flex-direction:column;align-items:center;min-height:0;padding:0;transition:filter .15s;display:flex;position:absolute}.player-map-pin:hover{filter:drop-shadow(0 0 8px)brightness(1.2);z-index:20}.player-map-pin.selected{filter:drop-shadow(0 0 10px)brightness(1.3)}.player-pin-icon{text-shadow:0 1px 3px #000000f2;font-size:2rem;line-height:1;display:block}.player-pin-label{font-family:var(--font-title);letter-spacing:.04em;color:var(--gold-hi);white-space:nowrap;text-shadow:0 1px 3px #000,0 0 6px #000;margin-top:2px;font-size:.8rem}.player-pin-region .player-pin-icon{display:none}.player-pin-region{transform:translate(-50%, -50%) scale(var(--pin-scale,1))}.player-pin-region .player-pin-label{font-family:"Melon Honey", var(--font-title);letter-spacing:.14em;opacity:.85;font-size:1.1rem}.pin-summary-card{border:1px solid var(--border-hi);z-index:50;pointer-events:auto;width:min(320px,80%);max-height:calc(100% - 1.5rem);font-family:var(--font-body);background:#0f0b07f5;border-radius:6px;flex-direction:column;display:flex;position:absolute;top:.75rem;right:.75rem;overflow:hidden;box-shadow:0 6px 24px #000000b3}.pin-summary-header{border-bottom:2px solid var(--gold);background:#281c0ca6;flex-shrink:0;align-items:center;gap:.55rem;padding:.55rem .7rem;display:flex}.pin-summary-icon{flex-shrink:0;font-size:1.6rem;line-height:1}.pin-summary-titles{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.pin-summary-name{font-family:"Melon Honey", var(--font-title);color:var(--gold-hi);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.05rem;overflow:hidden}.pin-summary-type{font-family:var(--font-title);letter-spacing:.1em;text-transform:uppercase;opacity:.85;font-size:.68rem}.pin-summary-close{color:var(--text-dim);cursor:pointer;background:0 0;border:0;flex-shrink:0;min-height:0;padding:.15em .4em;font-size:1rem}.pin-summary-close:hover{color:var(--text-hi);background:0 0}.pin-summary-body{flex:1;padding:.65rem .75rem .8rem;overflow-y:auto}.pin-summary-img{object-fit:cover;border:1px solid var(--border);border-radius:4px;width:100%;max-height:160px;margin-bottom:.55rem;display:block}.pin-summary-desc{font-family:var(--font-hand,"Crimson Text", Georgia, serif);color:var(--text);white-space:pre-wrap;font-size:.95rem;line-height:1.5}.pin-summary-empty{color:var(--text-dim);font-size:.9rem;font-style:italic}.map-resize-grip{cursor:nwse-resize;touch-action:none;background:linear-gradient(135deg,#0000 40%,#b48c5073 40% 50%,#0000 50% 65%,#b48c5073 65% 75%,#0000 75%);width:22px;height:22px;position:absolute;bottom:0;right:0}.map-menu-controlled{width:100%;position:static}.map-menu-controlled .map-menu-panel{border-bottom:none;border-radius:6px 6px 0 0;min-width:0;max-width:100%;max-height:40vh;position:static}.inv-overlay{z-index:60;font-family:var(--font-hand);background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.inv-window{filter:drop-shadow(0 12px 32px #000000bf);flex-direction:row;align-items:flex-start;gap:1.25rem;max-width:96vw;max-height:92vh;display:flex}.inv-side{background:url(/wooden-ui/Tex_black_01_03.png) 50%/100% 100% no-repeat;flex-direction:column;align-items:center;width:clamp(300px,38vw,380px);padding:1.4rem 1.1rem 1.5rem;display:flex;position:relative}.inv-side:before{content:"";pointer-events:none;opacity:.9;z-index:0;background:url(/wooden-ui/Tex_black_01_01.png) 50%/100% 100% no-repeat;position:absolute;inset:0}.inv-header-plank{z-index:2;text-align:center;min-width:78%;font-family:var(--font-title);color:#1a0e05;letter-spacing:.08em;text-shadow:0 1px #ffdca040;filter:drop-shadow(0 4px 6px #0000008c);background:url(/wooden-ui/Tex_plank_13.png) 50%/100% 100% no-repeat;justify-content:center;align-items:center;margin-top:-2.2rem;margin-bottom:.9rem;padding:.55rem 2.4rem .85rem;font-size:1.6rem;display:flex;position:relative}.inv-header-plank>span{line-height:1}.inv-close-btn{color:#1a0e05;font-size:1rem;font-family:var(--font-hand);cursor:pointer;min-height:unset;text-shadow:none;filter:none;background:0 0;border:none;padding:.15em .4em;position:absolute;top:50%;right:.9rem;transform:translateY(-50%)}.inv-close-btn:hover{color:#5a2c0a;background:0 0}.inv-parchment{z-index:1;background:url(/wooden-ui/Tex_bg_01_02.png) 50%/100% 100% no-repeat;justify-content:center;align-items:center;width:100%;padding:1.1rem .9rem;display:flex;position:relative}.inv-loading{text-align:center;color:#4a2f15;font-family:var(--font-hand);padding:2rem;font-size:1.1rem}.inv-grid{background:0 0;grid-template-columns:repeat(4,1fr);gap:.35rem;width:100%;padding:0;display:grid}.inv-slot{aspect-ratio:1;cursor:pointer;filter:brightness();background:url(/wooden-ui/Tex_frame_c2_02.png) 50%/100% 100% no-repeat;justify-content:center;align-items:center;transition:filter .12s,transform 80ms;display:flex;position:relative}.inv-slot.empty{cursor:default}.inv-slot:not(.empty):hover{filter:brightness(1.15)drop-shadow(0 0 6px #ffc85099);transform:translateY(-1px)}.inv-slot.selected{filter:brightness(1.2)drop-shadow(0 0 8px #e8b84bd9)}.inv-slot-img{object-fit:contain;width:70%;height:70%;image-rendering:pixelated;filter:drop-shadow(0 1px 2px #0006)}.inv-slot-emoji{filter:drop-shadow(0 1px 2px #00000080);font-size:1.5rem;line-height:1}.inv-slot-qty{font-family:var(--font-hand);color:#fff;text-shadow:0 1px 2px #000,0 0 3px #000000e6;pointer-events:none;font-size:.8rem;position:absolute;bottom:2px;right:4px}.inv-footer-plate{z-index:2;text-align:center;min-width:60%;font-family:var(--font-hand);color:#1a0e05;letter-spacing:.02em;filter:drop-shadow(0 3px 4px #00000080);background:url(/wooden-ui/Tex_plank_13.png) 50%/100% 100% no-repeat;margin-top:1rem;padding:.45rem 1.4rem .55rem;font-size:1.1rem;position:relative}.inv-detail-page{width:clamp(280px,36vw,360px);min-height:460px;font-family:var(--font-hand);color:#2a1408;filter:drop-shadow(0 8px 18px #000000a6);background:url(/wooden-ui/Tex_bg_01_02.png) 50%/100% 100% no-repeat;flex-direction:column;padding:2.2rem 2rem;display:flex}.inv-detail-empty{text-align:center;font-family:var(--font-hand);color:#6b3f1c;opacity:.7;margin:auto;font-size:1.15rem}.inv-detail-content{flex-direction:column;gap:.9rem;height:100%;display:flex}.inv-detail-header{border-bottom:1px dashed #50280f66;align-items:flex-start;gap:.85rem;padding-bottom:.7rem;display:flex}.inv-detail-img{object-fit:contain;width:56px;height:56px;image-rendering:pixelated;filter:drop-shadow(0 1px 2px #0000004d);flex-shrink:0}.inv-detail-emoji{flex-shrink:0;font-size:2.4rem;line-height:1}.inv-detail-meta{flex-direction:column;gap:.2rem;display:flex}.inv-detail-name{font-family:var(--font-title);color:#2a1408;letter-spacing:.03em;font-size:1.35rem;line-height:1.1}.inv-detail-rarity{font-family:var(--font-hand);letter-spacing:.03em;text-transform:capitalize;font-size:1rem}.inv-detail-qty{font-family:var(--font-hand);color:#5a341a;font-size:.95rem}.inv-detail-desc{font-family:var(--font-hand);color:#2e1a0a;margin:0;font-size:1.05rem;line-height:1.5}.inv-detail-stats{border-top:1px dashed #50280f66;margin-top:auto;padding-top:.7rem}.inv-detail-stats-title{font-family:var(--font-title);color:#4a2c12;letter-spacing:.04em;font-size:1.05rem}.inv-detail-stats-text{font-family:var(--font-hand);color:#2e1a0a;white-space:pre-wrap;margin-top:.3rem;font-size:1rem;line-height:1.4}.rarity-text-common{color:#4a4a4a}.rarity-text-uncommon{color:#1f6b1f}.rarity-text-rare{color:#1a4d8a}.rarity-text-epic{color:#5a2e7a}.rarity-text-legendary{color:#a8530a;text-shadow:0 0 5px #ff8c2859}@media (width<=820px){.inv-window{flex-direction:column;align-items:center;gap:.75rem;max-height:92vh;overflow-y:auto}.inv-side,.inv-detail-page{width:min(94vw,380px)}.inv-detail-page{min-height:240px}}.talk-panel{z-index:65;flex-direction:column;display:flex;position:fixed;inset:0}.talk-bg{z-index:0;position:absolute;inset:0;overflow:hidden}.talk-bg img{object-fit:cover;filter:brightness(.52);width:100%;height:100%}.talk-close{z-index:10;border:1px solid var(--border-hi);color:var(--text-dim);cursor:pointer;background:#0f0a05cc;border-radius:4px;padding:.2em .55em;font-size:.8rem;position:absolute;top:.6rem;right:.8rem}.talk-close:hover{color:var(--gold-hi);border-color:var(--gold)}.talk-portrait-area{z-index:1;flex:0 0 36%;justify-content:center;align-items:center;padding-top:.5rem;display:flex;position:relative}.talk-npc-portrait-wrap{width:min(180px,38vw);height:min(240px,52vw);position:relative}.talk-npc-portrait-wrap img{object-fit:cover;border-radius:4px;width:100%;height:100%;box-shadow:0 4px 24px #000000b3}.talk-npc-placeholder{border:1px solid var(--border-hi);width:100%;height:100%;font-family:var(--font-title);color:var(--gold);background:#1e160ab3;border-radius:4px;justify-content:center;align-items:center;font-size:4rem;display:flex}.talk-npc-frame{pointer-events:none;z-index:2;background:url(/wooden-ui/Tex_frame_k_01.png) 50%/contain no-repeat;position:absolute;inset:-14px}.talk-info-strip{z-index:1;text-align:center;font-family:var(--font-title);color:var(--gold-hi);letter-spacing:.04em;background:url(/wooden-ui/Tex_strip_bg01.png) 50%/100% 100% no-repeat;flex-shrink:0;padding:.35rem 1rem;font-size:.78rem;position:relative}.talk-npc-name{color:var(--gold-hi)}.talk-npc-meta{color:var(--text-dim)}.talk-npc-mood{color:var(--text);font-style:italic}.talk-chat-area{z-index:1;background:#040302a6;flex-direction:column;flex:1;gap:.35rem;padding:.6rem .75rem;display:flex;position:relative;overflow-y:auto}.talk-hint{text-align:center;color:var(--text-dim);font-family:var(--font-body);padding:1rem;font-size:.85rem;font-style:italic}.talk-bubble{max-width:82%;font-size:.88rem;line-height:1.5;font-family:var(--font-body);border-radius:8px;padding:.45rem .7rem}.talk-bubble.npc{border:1px solid var(--border-hi);color:var(--text);background:#231a0ce0;align-self:flex-start}.talk-bubble.player{color:var(--text-hi);background:#192a19e0;border:1px solid #4a7c59;align-self:flex-end}.talk-typing{opacity:.7}.talk-dots{align-items:center;gap:3px;padding:.1rem 0;display:flex}.talk-dots span{background:var(--gold);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite dot-pulse}.talk-dots span:nth-child(2){animation-delay:.2s}.talk-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.talk-input-row{z-index:1;border-top:1px solid var(--border);background:#040302d9;gap:.5rem;padding:.5rem .75rem;display:flex;position:relative}.talk-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);resize:none;border-radius:6px;flex:1;padding:.4rem .7rem;font-size:.88rem;line-height:1.4}.talk-input:focus{border-color:var(--gold);outline:none}.talk-send-btn{background:var(--gold);color:#1a1208;font-family:var(--font-title);cursor:pointer;border:none;border-radius:6px;flex-shrink:0;padding:.4rem 1rem;font-size:.82rem;font-weight:700;transition:background .12s}.talk-send-btn:hover:not(:disabled){background:var(--gold-hi)}.talk-send-btn:disabled{opacity:.45;cursor:not-allowed}.talk-mic-btn{border:1px solid var(--border-hi);width:40px;height:40px;color:var(--gold);cursor:pointer;background:#140e08d9;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:border-color .12s,background .12s,color .12s;display:flex}.talk-mic-btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold-hi)}.talk-mic-btn:disabled{opacity:.45;cursor:not-allowed}.talk-mic-btn.listening{color:#ffeaea;background:#7a1f1f;border-color:#ff5050;animation:1.1s ease-in-out infinite mic-pulse}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ff50508c}50%{box-shadow:0 0 0 8px #ff505000}}.nav-btn.has-npc .nav-btn-icon{animation:1.8s ease-in-out infinite npc-pulse}@keyframes npc-pulse{0%,to{filter:drop-shadow(0 0 0px var(--gold))}50%{filter:drop-shadow(0 0 7px var(--gold-hi))}}.combat-alert{z-index:400;background:radial-gradient(circle,#50140a8c 0%,#000000d9 70%);justify-content:center;align-items:center;animation:.25s ease-out combat-alert-fade;display:flex;position:fixed;inset:0}@keyframes combat-alert-fade{0%{opacity:0}to{opacity:1}}.combat-alert-body{text-align:center;filter:drop-shadow(0 12px 36px #000000d9);background-image:url(/wooden-ui/Tex_obj_04.png);background-repeat:no-repeat;background-size:100% 100%;flex-direction:column;align-items:center;gap:.55rem;width:min(86vw,420px);padding:1.6rem 1.4rem 1.4rem;animation:.35s cubic-bezier(.2,1.2,.3,1) combat-alert-pop;display:flex;position:relative}@keyframes combat-alert-pop{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.combat-alert-glyph{color:var(--gold-hi);text-shadow:0 0 14px #ffb450d9,0 2px 4px #000000e6;font-size:3rem;animation:2.4s ease-in-out infinite combat-glyph-spin}@keyframes combat-glyph-spin{0%,to{transform:rotate(-6deg)scale(1)}50%{transform:rotate(6deg)scale(1.08)}}.combat-alert-title{font-family:var(--font-title);color:var(--gold-hi);letter-spacing:.08em;text-shadow:0 2px 4px #000000f2;margin:0;font-size:1.6rem}.combat-alert-sub{font-family:var(--font-title);color:var(--text);letter-spacing:.12em;text-transform:uppercase;opacity:.85;margin:0;font-size:.8rem}.combat-alert-btn{min-height:40px;font-family:var(--font-title);letter-spacing:.08em;color:var(--gold-hi);cursor:pointer;text-shadow:0 1px 3px #000000d9;filter:brightness(.95);background-color:#0000;background-image:url(/wooden-ui/Tex_Plank_07.png);background-repeat:no-repeat;background-size:100% 100%;border:0;margin-top:.65rem;padding:.55rem 1.6rem;font-size:.9rem;transition:filter .12s,transform 80ms}.combat-alert-btn:hover{filter:brightness(1.12)saturate(1.1);transform:translateY(-1px)}.combat-alert-btn:active{filter:brightness(.85);transform:translateY(1px)}.combat-alert-btn:disabled{filter:grayscale(.5)brightness(.6);cursor:not-allowed}.combat-alert-btn.primary{color:#fff5d6;background-image:url(/wooden-ui/Tex_Plank_09.png)}.combat-alert-spotlight{cursor:pointer}.modal-close,.map-window-close,.pin-summary-close,.inv-close-btn,.talk-close{cursor:pointer;filter:brightness(.95);flex-shrink:0;transition:filter .12s,transform 80ms;color:#0000!important;width:32px!important;min-width:32px!important;height:32px!important;min-height:32px!important;text-shadow:none!important;background-color:#0000!important;background-image:url(/wooden-ui/Tex_checkbox_01.png)!important;background-position:50%!important;background-repeat:no-repeat!important;background-size:100% 100%!important;border:0!important;border-radius:0!important;padding:0!important;font-size:0!important;line-height:0!important}.modal-close:hover,.map-window-close:hover,.pin-summary-close:hover,.inv-close-btn:hover,.talk-close:hover{filter:brightness(1.15)saturate(1.1);transform:scale(1.06);background-color:#0000!important}.modal-close:active,.map-window-close:active,.pin-summary-close:active,.inv-close-btn:active,.talk-close:active{filter:brightness(.85);transform:scale(.97)}.inv-close-btn{position:absolute;top:50%;right:.9rem;transform:translateY(-50%)}.inv-close-btn:hover{transform:translateY(-50%)scale(1.06)}.inv-close-btn:active{transform:translateY(-50%)scale(.97)}.talk-close{z-index:10;position:absolute;top:.6rem;right:.8rem}
