@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap";:root{--bg: #06070f;--bg2: #0a0c18;--panel: #0c0e1c;--panel2: #10132a;--border: #1a2040;--brd2: #26305a;--gold: #c8a020;--gold2: #f0d060;--gold3: #7a5c0e;--red2: #e74c3c;--grn2: #2ecc71;--purp2: #9b59b6;--txt: #c8bea0;--muted: #404870;--hp: #e74c3c;--mp: #3498db;--xp: #e67e22;--ink: #d7cba6;--ink-dim: #8a82a8;--glass: rgba(14, 17, 34, .72);--glass-brd: rgba(120, 140, 220, .14);--gold-grad: linear-gradient(135deg, #fbe9a8 0%, #f0d060 22%, #c8a020 50%, #8a6a14 78%, #5a3c06 100%);--r-magic: #4a86ff;--r-rare: #e8d24a;--r-set: #2ee07a;--r-unique: #d9893f;--r-leg: #f0c030;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--hud-h: 56px;--action-h: 72px;--panel-w: 0px;--vph: 100dvh}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{font-size:16px;height:100%;color-scheme:dark}html,body,#app{width:100vw;height:var(--vph, 100dvh);min-height:var(--vph, 100dvh);max-height:var(--vph, 100dvh);overflow:hidden;background:var(--bg);color:var(--txt);font-family:Crimson Pro,serif;touch-action:manipulation}@media(min-width:900px)and (pointer:fine){html{font-size:17px}:root{--hud-h: 58px;--action-h: 66px}}@media(min-width:1280px){html{font-size:18px}:root{--hud-h: 60px;--panel-w: 320px}}@media(min-width:1600px){:root{--panel-w: 340px}}body{background:radial-gradient(1200px 700px at 50% -10%,rgba(40,34,80,.35),transparent 60%),radial-gradient(900px 600px at 90% 110%,rgba(120,90,20,.12),transparent 55%),var(--bg)}#rotate-lock{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:var(--bg);align-items:center;justify-content:center;padding:max(16px,var(--safe-top)) max(16px,var(--safe-right)) max(16px,var(--safe-bottom)) max(16px,var(--safe-left));text-align:center}html.portrait-lock #rotate-lock{display:flex}html.portrait-lock #title,html.portrait-lock #game{visibility:hidden;pointer-events:none}html.screenshot-debug #rotate-lock{display:none!important}html.screenshot-debug.portrait-lock #title,html.screenshot-debug.portrait-lock #game{visibility:visible;pointer-events:auto}.rot-inner{max-width:280px}.rot-ico{font-size:3rem;margin-bottom:1rem;display:inline-block;animation:rot-wiggle 1.8s ease-in-out infinite}@keyframes rot-wiggle{0%,to{transform:rotate(0)}35%{transform:rotate(-90deg)}65%{transform:rotate(-90deg)}}.rot-title{font-family:Cinzel,serif;font-size:1.1rem;color:var(--gold2);margin-bottom:.45rem;letter-spacing:.04em}.rot-sub{font-size:.82rem;color:var(--muted);line-height:1.4}::selection{background:#c8a02059;color:#fff}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--brd2),var(--border));border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gold3)}#title{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;width:100vw;height:var(--vph, 100dvh);max-height:var(--vph, 100dvh);display:flex;align-items:center;justify-content:center;background:var(--bg);transition:opacity .7s;padding:max(12px,var(--safe-top)) max(12px,var(--safe-right)) max(12px,var(--safe-bottom)) max(12px,var(--safe-left));overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain}#title:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 45%,rgba(0,0,0,.55) 100%);z-index:1}#title-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.t-wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;width:min(440px,100%);max-width:100%;margin:auto;padding:.5rem 0 1rem;animation:rise .9s cubic-bezier(.2,.8,.2,1) both}.t-hero{display:flex;flex-direction:column;align-items:center;width:100%;text-align:center}@keyframes rise{0%{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}.t-eye{font-family:Cinzel,serif;font-size:.62rem;letter-spacing:.38em;color:var(--gold3);text-transform:uppercase;margin-bottom:.65rem;white-space:nowrap}.t-logo{font-family:Cinzel,serif;font-weight:900;font-size:clamp(2.4rem,8vw,3.6rem);line-height:1.05;background:linear-gradient(180deg,#fff3c4,#f0d060 35%,#c8a020 60%,#6a4c0a);background-size:100% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 32px rgba(200,160,32,.5));margin-bottom:.35rem;letter-spacing:.04em;animation:shimmer 5s ease-in-out infinite}@keyframes shimmer{0%,to{background-position:0 0}50%{background-position:0 100%}}.t-tag{font-style:italic;font-size:.92rem;color:var(--ink-dim);margin-bottom:1.1rem;letter-spacing:.02em}.t-sep{width:min(220px,70%);height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin-bottom:1.1rem;position:relative}.t-sep:after{content:"✦";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--gold2);font-size:.7rem;background:var(--bg);padding:0 .5rem;text-shadow:0 0 10px rgba(240,208,96,.6)}.t-card{position:relative;width:100%;background:linear-gradient(160deg,#121428eb,#0a0c1af0);border:1px solid var(--glass-brd);border-radius:14px;padding:1.35rem 1.4rem;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 24px 64px #0000008c,inset 0 1px #ffffff0d}.t-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;padding:1px;background:linear-gradient(160deg,rgba(200,160,32,.5),transparent 40%,transparent 60%,rgba(200,160,32,.3));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.t-lbl{font-family:Cinzel,serif;font-size:.58rem;letter-spacing:.16em;color:var(--muted);margin-bottom:.35rem;display:block;text-transform:uppercase}.t-input{width:100%;background:#04050ccc;border:1px solid var(--brd2);border-radius:8px;padding:.65rem .85rem;color:var(--ink);font-family:inherit;font-size:1rem;outline:none;margin-bottom:.95rem;transition:border-color .2s,box-shadow .2s}.t-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c8a0201f}.t-hint{font-size:.72rem;color:var(--muted);margin-top:.75rem;text-align:center;line-height:1.35}.cs-header{margin-bottom:.5rem}.cs-sub{font-size:.76rem;color:var(--muted);margin:.25rem 0 0;line-height:1.35}.cs-roster{display:flex;gap:8px;overflow-x:auto;padding:.25rem 0 .5rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.cs-roster::-webkit-scrollbar{height:4px}.cs-card{flex:0 0 min(132px,38vw);scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;gap:3px;background:#06070fb8;border:1px solid var(--border);border-radius:12px;padding:.7rem .45rem .55rem;cursor:pointer;text-align:center;transition:border-color .2s,box-shadow .2s,transform .15s;touch-action:manipulation}.cs-card:hover{border-color:var(--brd2)}.cs-card.active{border-color:var(--gold);box-shadow:0 0 20px #c8a02047,inset 0 0 16px #c8a0200f;transform:translateY(-2px)}.cs-card-new{border-style:dashed;opacity:.9}.cs-portrait{font-size:2.2rem;line-height:1;margin-bottom:.15rem;filter:drop-shadow(0 3px 8px rgba(0,0,0,.55))}.cs-portrait-new{font-size:1.8rem;color:var(--gold3);font-family:Cinzel,serif;font-weight:700}.cs-name{font-family:Cinzel,serif;font-size:.72rem;color:var(--ink);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cs-meta{font-size:.62rem;color:var(--gold2)}.cs-zone{font-size:.56rem;color:var(--muted);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cs-actions{display:flex;flex-direction:column;gap:8px;margin-top:.35rem}.cs-play{margin-top:0!important}.cs-create{width:100%;min-height:40px}.cs-back{background:none;border:none;color:var(--muted);font-family:Cinzel,serif;font-size:.62rem;letter-spacing:.08em;cursor:pointer;margin-bottom:.65rem;padding:0;text-align:left}.cs-back:hover{color:var(--gold2)}.t-saved{margin-top:.85rem}.t-saved-lbl{font-family:Cinzel,serif;font-size:.58rem;letter-spacing:.16em;color:var(--muted);margin-bottom:.4rem;text-transform:uppercase}.t-saved-list{display:flex;flex-direction:column;gap:6px;max-height:9rem;overflow-y:auto}.t-saved-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;background:#06070fa6;border:1px solid var(--border);border-radius:8px;padding:.55rem .7rem;cursor:pointer;text-align:left;transition:border-color .2s,background .2s}.t-saved-btn:hover{border-color:var(--gold);background:#c8a02014}.tsb-name{font-family:Cinzel,serif;font-size:.78rem;color:var(--ink)}.tsb-meta{font-size:.68rem;color:var(--muted)}.cls-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:.95rem}.cls-btn{position:relative;background:#06070fb3;border:1px solid var(--border);border-radius:10px;padding:.65rem .15rem;cursor:pointer;text-align:center;font-family:Cinzel,serif;font-size:.54rem;color:var(--ink-dim);-webkit-user-select:none;user-select:none;transition:transform .18s cubic-bezier(.2,.8,.2,1),border-color .2s,background .2s,box-shadow .2s;overflow:hidden}.cls-btn:hover{transform:translateY(-2px);border-color:var(--brd2);color:var(--ink)}.cls-btn.active{border-color:var(--gold);color:var(--gold2);background:#c8a0201a;box-shadow:0 6px 20px #c8a0202e,inset 0 0 16px #c8a02014}.cls-btn .ci{font-size:1.55rem;display:block;margin-bottom:.2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));transition:transform .2s}.cls-btn.active .ci{transform:scale(1.08)}.t-enter{width:100%;background:var(--gold-grad);background-size:200% 100%;border:none;border-radius:10px;padding:.85rem;font-family:Cinzel,serif;font-size:.92rem;font-weight:700;color:#1a1200;cursor:pointer;letter-spacing:.04em;box-shadow:0 10px 28px #c8a0204d;transition:transform .15s,box-shadow .2s,background-position .4s;margin-top:.15rem}.t-enter:hover{transform:translateY(-2px);box-shadow:0 14px 36px #c8a02073;background-position:100% 0}.t-enter:active{transform:translateY(0) scale(.99)}.t-party-row{margin-bottom:.85rem}.t-party-in{margin-bottom:0!important;font-size:.82rem!important;padding:.55rem .75rem!important}.t-opt{color:var(--muted);font-style:italic;letter-spacing:0;text-transform:none;font-size:.9em}@media(min-width:960px)and (min-height:560px){.t-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.5rem);width:min(920px,94vw);align-items:center}.t-hero{padding-right:.5rem}.t-sep{margin-bottom:0}.t-tag{margin-bottom:1.4rem}.t-logo{font-size:clamp(2.6rem,4.5vw,3.5rem)}}@media(max-height:720px){.t-logo{font-size:clamp(2rem,7vw,2.6rem)}.t-tag{margin-bottom:.65rem;font-size:.82rem}.t-sep{margin-bottom:.65rem}.t-card{padding:1rem 1.1rem}.cls-btn{padding:.5rem .1rem}.cls-btn .ci{font-size:1.35rem}}@media(orientation:landscape)and (max-height:640px){html.touch-device #title{overflow:hidden;align-items:stretch;padding:max(6px,var(--safe-top)) max(8px,var(--safe-right)) max(6px,var(--safe-bottom)) max(8px,var(--safe-left))}html.touch-device .t-wrap{display:grid;grid-template-columns:minmax(0,36%) minmax(0,1fr);gap:clamp(.45rem,2vw,.85rem);width:100%;max-width:100%;max-height:100%;min-height:0;margin:0;padding:0;align-items:center;align-self:center;animation:rise-landscape .7s cubic-bezier(.2,.8,.2,1) both}@keyframes rise-landscape{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}html.touch-device .t-hero{align-items:flex-start;text-align:left;justify-content:center;min-width:0;padding-right:.15rem}html.touch-device .t-eye{font-size:clamp(.45rem,1.8vh,.55rem);letter-spacing:.22em;margin-bottom:clamp(.15rem,1vh,.35rem);white-space:normal;line-height:1.3}html.touch-device .t-logo{font-size:clamp(1.2rem,5.5vh,1.85rem);line-height:1.02;margin-bottom:clamp(.1rem,.8vh,.2rem);filter:drop-shadow(0 0 18px rgba(200,160,32,.4))}html.touch-device .t-tag{font-size:clamp(.58rem,2vh,.72rem);margin-bottom:clamp(.3rem,1.5vh,.5rem);line-height:1.25}html.touch-device .t-sep{width:min(140px,85%);margin-bottom:0;align-self:flex-start}html.touch-device .t-card{padding:clamp(.5rem,1.5vh,.7rem) clamp(.55rem,2vw,.75rem);max-height:calc(var(--vph, 100dvh) - max(12px,var(--safe-top)) - max(12px,var(--safe-bottom)));min-height:0;min-width:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}html.touch-device .cs-header{margin-bottom:.2rem}html.touch-device .cs-sub{font-size:.64rem;margin-top:.1rem;line-height:1.2}html.touch-device .cs-roster{gap:6px;padding:.1rem 0 .3rem}html.touch-device .cs-card{flex:0 0 min(96px,26vw);padding:.4rem .3rem .35rem;border-radius:10px}html.touch-device .cs-portrait{font-size:clamp(1.25rem,4.5vh,1.6rem)}html.touch-device .cs-portrait-new{font-size:1.35rem}html.touch-device .cs-name{font-size:.62rem}html.touch-device .cs-meta{font-size:.54rem}html.touch-device .cs-zone{font-size:.5rem}html.touch-device .cs-actions{flex-direction:row;gap:6px;margin-top:.2rem}html.touch-device .cs-play{flex:1;min-width:0}html.touch-device .cs-create{flex:0 0 auto;width:auto;min-height:36px;padding:0 .55rem;font-size:.58rem;white-space:nowrap}html.touch-device .t-enter{padding:clamp(.45rem,1.5vh,.6rem) .65rem;font-size:clamp(.68rem,2.2vh,.78rem)}html.touch-device .t-hint{display:none}html.touch-device .t-lbl{font-size:.5rem;margin-bottom:.15rem}html.touch-device .t-input{padding:.4rem .55rem;margin-bottom:.45rem;font-size:.85rem}html.touch-device .cls-grid{gap:4px;margin-bottom:.45rem}html.touch-device .cls-btn{padding:.3rem .08rem;font-size:.46rem}html.touch-device .cls-btn .ci{font-size:clamp(.95rem,3.5vh,1.15rem);margin-bottom:.08rem}html.touch-device .t-party-row{margin-bottom:.45rem}html.touch-device .t-party-in{padding:.4rem .55rem!important;font-size:.75rem!important}html.touch-device .cs-back{font-size:.56rem;margin-bottom:.4rem}}@media(orientation:landscape)and (max-height:400px){html.touch-device .t-wrap{grid-template-columns:minmax(0,32%) minmax(0,1fr);gap:.4rem}html.touch-device .t-logo{font-size:clamp(1rem,4.8vh,1.35rem)}html.touch-device .t-tag,html.touch-device .cs-sub{display:none}html.touch-device .cs-card{flex:0 0 min(84px,24vw);padding:.3rem .25rem .28rem}html.touch-device .cs-portrait{font-size:1.15rem}html.touch-device .t-card{padding:.4rem .5rem}}#game{display:none;position:fixed;top:0;right:0;bottom:0;left:0;flex-direction:column;width:100vw;height:var(--vph, 100dvh);max-height:var(--vph, 100dvh);overflow:hidden;padding-top:var(--safe-top);opacity:0}#game.active{display:flex;animation:fadein .6s ease both}@keyframes fadein{0%{opacity:0}to{opacity:1}}.hud-top{height:var(--hud-h);min-height:var(--hud-h);max-height:var(--hud-h);flex-shrink:0;background:linear-gradient(180deg,#080914f5,#0a0c1adb);border-bottom:1px solid var(--glass-brd);display:flex;align-items:center;padding:0 calc(10px + var(--safe-right)) 0 calc(10px + var(--safe-left));z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 6px 22px #0006;gap:6px;overflow:hidden}.hud-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.05rem;background:radial-gradient(circle at 35% 30%,#c8a02040,#06070fe6);box-shadow:0 0 14px #c8a0204d,inset 0 0 8px #0009;flex-shrink:0}.hud-name-lv{flex-shrink:0;min-width:0;max-width:110px}.hud-name{font-family:Cinzel,serif;font-weight:600;font-size:.72rem;color:var(--gold2);text-shadow:0 1px 4px rgba(0,0,0,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hud-lv{font-size:.56rem;color:var(--ink-dim);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hud-bars{flex:1;min-width:80px;max-width:360px;display:flex;flex-direction:column;gap:3px;margin:0 6px}.bar-row{display:flex;align-items:center;gap:4px;min-width:0}.bar-ico{font-size:.68rem;width:11px;flex-shrink:0;text-align:center;filter:drop-shadow(0 0 4px currentColor)}.bar-track{flex:1;min-width:40px;height:8px;background:#00000080;border:1px solid rgba(255,255,255,.06);border-radius:5px;overflow:hidden;position:relative}.bar-fill{height:100%;border-radius:5px;transition:width .35s cubic-bezier(.3,.8,.3,1);position:relative;overflow:hidden}.bar-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.35),transparent 55%)}.bar-fill:before{content:"";position:absolute;top:0;left:-40%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:sheen 3.2s ease-in-out infinite}@keyframes sheen{0%{left:-45%}60%,to{left:110%}}.bar-fill.hp{background:linear-gradient(90deg,#7a1a10,#e74c3c)}.bar-fill.mp{background:linear-gradient(90deg,#0e2c5a,#3498db)}.bar-fill.xp{background:linear-gradient(90deg,#5a3008,#f0a020)}.bar-txt{font-family:Cinzel,serif;font-size:.52rem;color:var(--ink-dim);min-width:30px;flex-shrink:0;text-align:right}.hud-gold{font-family:Cinzel,serif;font-size:.72rem;color:var(--gold2);display:flex;align-items:center;gap:2px;text-shadow:0 0 10px rgba(240,208,96,.3);flex-shrink:0;white-space:nowrap}.hud-right{display:flex;align-items:center;margin-left:auto;flex-shrink:0;gap:6px;min-width:0}.zone-pill{font-family:Cinzel,serif;font-size:.54rem;background:#c8a02014;border:1px solid var(--gold3);border-radius:20px;padding:.18rem .55rem;color:var(--gold);display:none;white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}.run-objective-pill{font-family:Cinzel,serif;font-size:.54rem;background:#5078c81f;border:1px solid rgba(120,160,240,.35);border-radius:20px;padding:.18rem .55rem;color:#a8c8ff;white-space:nowrap;max-width:min(220px,42vw);overflow:hidden;text-overflow:ellipsis}.run-objective-pill.run-boss{background:#b4282826;border-color:#dc505073;color:#f88;animation:run-pulse 1.2s ease-in-out infinite}.run-objective-pill.run-extract{background:#783cc826;border-color:#a064ff73;color:#d0a8ff}@keyframes run-pulse{0%,to{opacity:1}50%{opacity:.72}}.wx-pill{font-family:Cinzel,serif;font-size:.54rem;color:var(--ink-dim);white-space:nowrap;display:none}@media(min-width:900px)and (pointer:fine){.zone-pill,.wx-pill{display:block}.hud-bars{max-width:420px}}.online-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.hud-party-btn,.hud-party-code{flex-shrink:0;border-radius:16px;cursor:pointer;touch-action:manipulation;font-family:Cinzel,serif;transition:transform .14s,border-color .2s,background .2s}.hud-party-btn{background:#c8a0201a;border:1px solid var(--gold3);color:var(--gold2);font-size:.82rem;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;padding:0}.hud-party-btn:hover,.hud-party-code:hover{transform:translateY(-1px);border-color:var(--gold)}.hud-party-code{background:#04050cd9;border:1px solid var(--gold3);color:var(--gold2);font-size:.58rem;letter-spacing:.08em;padding:.2rem .55rem;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hud-party-code[hidden],.hud-party-btn[hidden]{display:none!important}.game-body{flex:1;display:flex;overflow:hidden;min-height:0;position:relative}.hub-screen{flex:1;min-width:0;min-height:0;display:none;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;position:relative;z-index:100;background:transparent;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}#town-screen,#map-screen{flex:1;min-width:0;min-height:0;position:relative;z-index:100}#map-screen{overflow:hidden}@media(min-width:900px)and (pointer:fine){#town-screen,#map-screen{flex:1 1 auto;width:100%;max-width:480px;margin:.5rem auto;align-self:center;max-height:calc(100% - 1rem);border:1px solid var(--glass-brd);border-radius:16px;box-shadow:0 24px 64px #00000080,0 0 0 1px #788cdc0f,inset 0 1px #ffffff0d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#0c0e1cbf}#map-screen{max-width:620px}}.town-inner,.map-inner{width:min(520px,100%);margin:0 auto;padding:.65rem calc(12px + var(--safe-right)) calc(.65rem + var(--safe-bottom)) calc(12px + var(--safe-left));display:flex;flex-direction:column;gap:.5rem;min-height:0}.town-inner{flex:1;min-height:0}@media(min-width:900px)and (pointer:fine){.town-inner{gap:.6rem}}.town-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:.65rem;padding:.15rem 0 .1rem;flex-shrink:0}.town-topbar-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.town-hub-btn--compact{min-height:38px;min-width:64px;padding:.3rem .55rem}.town-brand{min-width:0}.town-title{font-family:Cinzel,serif;font-weight:700;font-size:.95rem;color:var(--gold2);letter-spacing:.06em;margin:0}.town-sub{font-size:.72rem;color:var(--muted);margin:.2rem 0 0;line-height:1.3}.town-map-cta--top{display:none}.town-main{display:flex;flex-direction:column;gap:.45rem;flex:1;min-height:0}.town-hub-strip{display:flex;gap:6px;overflow-x:auto;flex-shrink:0;padding-bottom:2px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.town-hub-strip::-webkit-scrollbar{display:none}.town-hub-strip .town-hub-btn{flex:1 0 auto;min-width:72px;flex-direction:row;gap:5px;min-height:40px;padding:.35rem .55rem}.town-hub-strip .thb-ico{font-size:1rem}.town-hub-strip .thb-lbl{font-size:.52rem;white-space:nowrap}.town-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:.45rem}.town-stats-wrap{min-width:0}.town-char-stats{padding:.3rem .45rem}.town-char-stats .char-stats-inner{padding:0}.char-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 .5rem}.char-stats-grid .stat-row{padding:.18rem 0;font-size:.68rem}.char-stats-grid .stat-v{font-size:.62rem}.town-equip-wrap{min-width:0}.town-sec-lbl{font-family:Cinzel,serif;font-size:.52rem;letter-spacing:.14em;color:var(--gold3);text-transform:uppercase;margin:0 0 .35rem}.town-equip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.town-slot{position:relative;aspect-ratio:1;min-height:52px;background:linear-gradient(160deg,#101226b8,#080a16d9);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:default;transition:border-color .2s,box-shadow .2s;touch-action:manipulation}.town-slot.empty{opacity:.55}.town-slot-lbl{font-family:Cinzel,serif;font-size:.42rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.town-slot-ico{font-size:1.15rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.town-slot.c-magic{border-color:var(--r-magic);box-shadow:0 0 10px #4a86ff40}.town-slot.c-rare{border-color:var(--r-rare);box-shadow:0 0 10px #e8d24a40}.town-slot.c-set{border-color:var(--r-set);box-shadow:0 0 10px #2ee07a40}.town-slot.c-unique{border-color:var(--r-unique)}.town-slot.c-legendary{border-color:var(--r-leg);animation:legpulse 2.2s ease-in-out infinite}.town-hub-actions{display:contents}.town-hub-btn{min-height:48px;border-radius:10px;border:1px solid var(--glass-brd);background:linear-gradient(160deg,#121428d1,#0a0c18e6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:transform .14s,border-color .2s,box-shadow .2s;padding:.4rem .35rem;touch-action:manipulation}.town-hub-btn:active{transform:scale(.96)}.town-hub-btn:hover{border-color:var(--gold3);box-shadow:0 6px 18px #0000004d}.thb-ico{font-size:1.1rem;line-height:1}.thb-lbl{font-family:Cinzel,serif;font-size:.56rem;color:var(--gold2);letter-spacing:.03em}.town-footer{position:sticky;bottom:0;z-index:2;margin-top:auto;padding-top:.5rem;background:linear-gradient(180deg,transparent,rgba(6,7,15,.92) 28%)}.town-footer--desktop{display:block}.town-map-cta{width:100%;min-height:44px;margin:0;border:none;border-radius:10px;cursor:pointer;background:var(--gold-grad);background-size:200% 100%;font-family:Cinzel,serif;font-weight:700;font-size:.82rem;color:#1a1200;letter-spacing:.05em;box-shadow:0 8px 24px #c8a0204d;transition:transform .14s,box-shadow .2s,background-position .35s;touch-action:manipulation;padding:.5rem .75rem}.town-map-cta:active{transform:scale(.98)}.town-map-cta:hover{background-position:100% 0;box-shadow:0 12px 32px #c8a0206b}@media(pointer:coarse){#town-screen,#map-screen{flex:1 1 auto!important;width:100%!important;max-width:none!important;margin:0!important;align-self:stretch!important;max-height:none!important;border:none!important;border-radius:0!important;box-shadow:none!important;background:transparent!important}#game.hub-active .mob-nav{display:none!important}#game.hub-active{--mob-nav-h: 0px}#game.hub-active .hud-top{--hud-h: 44px;height:44px;min-height:44px;max-height:44px;padding-top:0;padding-bottom:0}#game.hub-active .hud-avatar{width:30px;height:30px;font-size:.9rem}#game.hub-active .hud-name-lv{max-width:76px}#game.hub-active .hud-name{font-size:.66rem}#game.hub-active .hud-lv{font-size:.5rem}#game.hub-active .hud-bars{max-width:min(240px,34vw);margin:0 4px}#game.hub-active .bar-row:nth-child(3){display:none}#game.hub-active .bar-track{height:6px}#game.hub-active .bar-txt{font-size:.46rem;min-width:24px}#game.hub-active .hud-gold{font-size:.66rem}#game.hub-active .zone-pill{display:none}#town-screen.hub-screen,#map-screen.hub-screen{overflow:hidden}.town-inner,.map-inner{width:100%;max-width:none;height:100%;margin:0;padding:.35rem calc(8px + var(--safe-right)) calc(.35rem + var(--safe-bottom)) calc(8px + var(--safe-left));gap:.3rem;overflow:hidden}.town-topbar{align-items:center;padding:0;flex-shrink:0;gap:.5rem}.town-sub{display:none}.town-title{font-size:.84rem}.town-map-cta--top{display:inline-flex;align-items:center;justify-content:center;width:auto;min-height:38px;padding:.3rem .65rem;font-size:.66rem;white-space:nowrap;flex-shrink:0}.town-footer--desktop{display:none}.town-main{gap:.35rem;flex:1;min-height:0;min-width:0}.town-hub-strip .town-hub-btn{min-height:38px;min-width:64px}.town-scroll{flex:1;min-height:0;overflow-y:auto}.town-equip-wrap{flex-shrink:0}.town-sec-lbl{margin-bottom:.25rem;font-size:.48rem}.town-equip-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:4px}.town-slot{min-height:36px;max-height:44px;aspect-ratio:auto;border-radius:7px}.town-slot-ico{font-size:.85rem}.town-slot-lbl{font-size:.32rem}.town-char-stats .stat-row{padding:.14rem 0}.map-topbar{padding:0;flex-shrink:0;gap:.35rem}.map-brand{min-width:0}.map-title{font-size:.84rem}.map-sub{display:none}.map-progress{padding:.2rem .45rem}.map-progress-val{font-size:.72rem}.map-back-btn{min-height:36px;padding:.3rem .55rem;margin:0}.map-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:.35rem}.map-canvas{padding:.15rem 0}.map-deco{display:none}.map-legend{flex-shrink:0;padding-bottom:.15rem}.zone-node-map{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;align-content:start;padding:0}.map-row{display:contents}.map-connector{display:none}.zone-node{width:100%;min-height:0;padding:.5rem .55rem;border-radius:12px;display:flex;align-items:flex-start;gap:.45rem}.zn-icon{width:34px;height:34px;font-size:1.05rem;border-radius:9px}.zn-body{gap:.12rem}.zn-top{flex-wrap:wrap;gap:.2rem .35rem}.zn-idx{width:18px;height:18px;font-size:.5rem}.zn-name{font-size:.68rem;flex:1 1 100%}.zn-bio{display:none}.zn-meta{gap:.2rem}.zn-chip{font-size:.5rem;padding:.1rem .35rem}.zn-hint{font-size:.52rem}.void-row .zone-node{grid-column:1 / -1}.zn-glow-ring{display:none}}@media(min-width:900px)and (pointer:fine){.town-main{gap:.55rem}.town-hub-strip{flex-wrap:wrap;overflow:visible}.town-hub-strip .town-hub-btn{flex:1;min-width:0;flex-direction:column;min-height:44px}.town-scroll{overflow:visible}.town-equip-grid{grid-template-columns:repeat(3,1fr)}.town-slot{min-height:48px;border-radius:8px;aspect-ratio:1;max-height:none}.town-slot-ico{font-size:1.05rem}.thb-ico{font-size:1rem}.thb-lbl{font-size:.52rem}.town-footer{padding-bottom:0;margin-bottom:0;background:none;padding-top:.35rem}.town-map-cta--top{display:none}.town-footer--desktop{display:block}}.map-inner{flex:1;min-height:0;gap:.55rem}.map-topbar{display:flex;align-items:center;justify-content:space-between;gap:.55rem;padding:.1rem 0 .15rem;flex-shrink:0}.map-topbar-left{display:flex;align-items:center;gap:6px;flex-shrink:0}.map-party-btn{flex-shrink:0;background:#c8a0201a;border:1px solid var(--gold3);border-radius:10px;padding:.4rem .65rem;font-family:Cinzel,serif;font-size:.62rem;color:var(--gold2);cursor:pointer;min-height:40px;touch-action:manipulation}.map-party-btn:hover{border-color:var(--gold)}.map-brand{flex:1;min-width:0;text-align:center}.map-back-btn{flex-shrink:0;margin:0;background:#06070fb8;border:1px solid var(--brd2);border-radius:10px;padding:.4rem .7rem;font-family:Cinzel,serif;font-size:.64rem;color:var(--ink-dim);cursor:pointer;min-height:40px;touch-action:manipulation;transition:color .2s,border-color .2s,background .2s}.map-back-btn:hover{color:var(--gold2);border-color:var(--gold3);background:#0c0e1cd9}.map-title{font-family:Cinzel,serif;font-size:1rem;font-weight:700;color:var(--gold2);letter-spacing:.06em;margin:0}.map-sub{font-size:.7rem;color:var(--muted);margin:.15rem 0 0;line-height:1.3}.map-progress{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:52px;padding:.28rem .5rem;border-radius:10px;border:1px solid var(--glass-brd);background:linear-gradient(160deg,#121428bf,#080a16e0)}.map-progress-lbl{font-family:Cinzel,serif;font-size:.42rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.map-progress-val{font-family:Cinzel,serif;font-size:.82rem;font-weight:700;color:var(--gold2);line-height:1.2}.map-scroll{flex:1;min-height:0;display:flex;flex-direction:column;gap:.45rem;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-gutter:stable}.map-canvas{position:relative;flex:0 0 auto;border-radius:14px;border:1px solid rgba(120,140,220,.1);background:radial-gradient(ellipse 120% 80% at 50% 0%,rgba(80,70,140,.14),transparent 55%),radial-gradient(ellipse 90% 60% at 80% 100%,rgba(200,160,32,.06),transparent 50%),linear-gradient(180deg,#0a0c1a8c,#06070fb8);overflow:visible;padding:.75rem .55rem 1rem}.map-deco{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.map-compass{position:absolute;top:.55rem;right:.65rem;font-size:1.35rem;opacity:.18;filter:grayscale(.4);transform:rotate(-12deg)}.map-deco-ring{position:absolute;border-radius:50%;border:1px solid rgba(200,160,32,.06)}.map-deco-ring--a{width:280px;height:280px;top:50%;left:50%;transform:translate(-50%,-48%)}.map-deco-ring--b{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-48%);border-style:dashed;opacity:.5}.map-legend{display:flex;align-items:center;justify-content:center;gap:.85rem;flex-shrink:0;padding:.1rem 0 .05rem}.map-leg-item{display:inline-flex;align-items:center;gap:.3rem;font-family:Cinzel,serif;font-size:.48rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}.map-leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.map-leg-dot--here{background:var(--gold);box-shadow:0 0 8px #c8a0208c}.map-leg-dot--done{background:var(--grn2);box-shadow:0 0 6px #2ecc7166}.map-leg-dot--lock{background:var(--muted);opacity:.65}.zone-node-map{position:relative;z-index:1;display:flex;flex-direction:column;align-items:stretch;gap:0;max-width:500px;margin:0 auto}.map-row{display:flex;flex-direction:column;align-items:stretch;width:100%}.map-row.side-left .zone-node{align-self:flex-start;margin-right:12%}.map-row.side-right .zone-node{align-self:flex-end;margin-left:12%}.map-row.side-center{align-items:center}.map-row.side-center .zone-node{align-self:center;width:min(340px,100%)}.map-connector{width:2px;height:22px;margin:0 auto;background:linear-gradient(180deg,#3c466e80,#28305059);border-radius:2px;flex-shrink:0}.map-connector.on{background:linear-gradient(180deg,var(--gold3),rgba(200,160,32,.35));box-shadow:0 0 10px #c8a02033}.map-connector.side-left{margin-left:22%;margin-right:auto;transform:rotate(28deg);transform-origin:top center;height:26px}.map-connector.side-right{margin-right:22%;margin-left:auto;transform:rotate(-28deg);transform-origin:top center;height:26px}.map-connector.side-center{margin:0 auto}.zone-node{position:relative;width:min(300px,88%);text-align:left;background:linear-gradient(155deg,#14162ceb,#0a0c1af5);border:1px solid var(--glass-brd);border-radius:14px;padding:.7rem .8rem;cursor:pointer;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:transform .16s ease,border-color .2s,box-shadow .25s;touch-action:manipulation;min-height:72px;display:flex;align-items:flex-start;gap:.65rem;overflow:hidden;box-shadow:0 8px 24px #00000047}.zone-node:not(.locked):hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--zn-accent, var(--gold3)) 55%,var(--glass-brd));box-shadow:0 14px 32px #00000061,0 0 20px var(--zn-glow, rgba(200, 160, 32, .15))}.zone-node:not(.locked):active{transform:scale(.98) translateY(-1px)}.zone-node.current{border-color:color-mix(in srgb,var(--gold) 70%,var(--zn-accent, var(--gold)));box-shadow:0 0 22px #c8a02038,0 8px 28px #00000052;animation:map-here-pulse 2.8s ease-in-out infinite}@keyframes map-here-pulse{0%,to{box-shadow:0 0 18px #c8a0202e,0 8px 28px #00000052}50%{box-shadow:0 0 28px #c8a02052,0 8px 32px #00000057}}.zone-node.cleared:not(.current){border-color:color-mix(in srgb,var(--grn2) 35%,var(--glass-brd))}.zone-node.locked{opacity:.52;filter:grayscale(.55) brightness(.88);cursor:not-allowed;box-shadow:none}.zn-accent-bar{position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--zn-accent, var(--gold)),transparent 85%);border-radius:14px 0 0 14px;opacity:.85}.zn-glow-ring{position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:radial-gradient(circle at 30% 50%,var(--zn-glow, transparent),transparent 55%);pointer-events:none;opacity:.7}.zn-icon{position:relative;z-index:1;width:42px;height:42px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.25rem;border-radius:11px;background:#00000047;border:1px solid color-mix(in srgb,var(--zn-accent, var(--gold3)) 40%,transparent);box-shadow:inset 0 1px #ffffff0f}.zn-body{position:relative;z-index:1;flex:1;min-width:0;display:flex;flex-direction:column;gap:.18rem}.zn-top{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.zn-idx{width:22px;height:22px;border-radius:50%;flex-shrink:0;background:#00000052;border:1px solid color-mix(in srgb,var(--zn-accent, var(--gold3)) 50%,var(--border));font-family:Cinzel,serif;font-size:.58rem;font-weight:700;color:var(--zn-accent, var(--gold));display:flex;align-items:center;justify-content:center}.zn-idx--void{font-size:.72rem}.zone-node.locked .zn-idx{border-color:var(--border);color:var(--muted)}.zn-name{font-family:Cinzel,serif;font-size:.8rem;font-weight:600;color:var(--gold2);flex:1;min-width:0;line-height:1.2}.zone-node.locked .zn-name{color:var(--muted)}.zn-badges{display:inline-flex;align-items:center;gap:.25rem;flex-shrink:0}.zn-badge{font-family:Cinzel,serif;font-size:.44rem;letter-spacing:.08em;text-transform:uppercase;padding:.12rem .38rem;border-radius:999px;line-height:1.2}.zn-badge--here{color:#1a1200;background:var(--gold-grad);box-shadow:0 0 10px #c8a02059}.zn-badge--done{color:#c8f0d8;background:#2ecc712e;border:1px solid rgba(46,204,113,.35)}.zn-badge--lock{font-size:.72rem;padding:0;background:none;border:none}.zn-bio{font-size:.66rem;color:var(--ink-dim);font-style:italic;line-height:1.25}.zn-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem .4rem;margin-top:.05rem}.zn-chip{font-family:Cinzel,serif;font-size:.52rem;letter-spacing:.04em;color:var(--ink-dim);padding:.14rem .42rem;border-radius:6px;background:#00000047;border:1px solid rgba(120,140,220,.12)}.zn-chip--void{color:#d0b0ff;border-color:#a070ff40;background:#643cb41f}.zn-hint{font-size:.6rem;color:var(--muted);font-style:italic}.zone-node.void-node:not(.locked){border-color:#8c5aff6b;background:linear-gradient(155deg,#20123af0,#0e0820fa)}.zone-node.void-node:not(.locked):hover{border-color:#a878ff;box-shadow:0 0 32px #8c5aff47,0 14px 36px #00000061}.zone-node.void-node .zn-name{color:#e0c8ff}@media(min-width:900px)and (pointer:fine){.map-inner{gap:.65rem}.map-canvas{padding:1rem .75rem 1.25rem}.map-title{font-size:1.08rem}.zone-node{min-height:78px;padding:.75rem .85rem}.zn-icon{width:44px;height:44px;font-size:1.3rem}.zn-name{font-size:.84rem}}#map-wrap{flex:1;position:relative;overflow:hidden;background:#04050c;min-width:0;flex-direction:column;z-index:1}#map-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10;box-shadow:inset 0 0 120px 24px #000000a6}#phaser-root{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:auto}#phaser-root canvas{display:block;width:100%!important;height:100%!important;touch-action:none}.side-panel{width:var(--panel-w);flex-shrink:0;background:linear-gradient(180deg,var(--panel2),var(--panel));border-left:1px solid var(--glass-brd);overflow:hidden;display:flex;flex-direction:column}@media(min-width:900px)and (pointer:fine){:root{--panel-w: 300px}}.panel-tabs{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border);background:#00000040}.ptab{background:none;border:none;cursor:pointer;padding:.65rem 0;font-family:Cinzel,serif;font-size:.58rem;color:var(--muted);border-bottom:2px solid transparent;transition:color .2s,background .2s}.ptab:hover{color:var(--ink);background:#ffffff05}.ptab.active{color:var(--gold);border-bottom-color:var(--gold);background:#c8a0200d}.ppage{display:none;flex:1;flex-direction:column;overflow:hidden;min-height:0}.ppage.active{display:flex;animation:fadein .3s ease}.inv-page{padding:.7rem;overflow-y:auto}.chat-msgs{flex:1;overflow-y:auto;padding:.6rem .7rem;font-size:.78rem;display:flex;flex-direction:column;gap:.25rem}.cmsg{padding:.25rem .5rem;border-radius:6px;background:#ffffff05;border-left:2px solid transparent;animation:msgin .25s ease;line-height:1.35}@keyframes msgin{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:none}}.cmsg .cs{font-family:Cinzel,serif;font-size:.62rem;margin-right:.35rem}.cmsg.sys{border-left-color:var(--gold3)}.cmsg.sys .cs{color:var(--gold)}.cmsg.plr{border-left-color:#2f6fa0}.cmsg.plr .cs{color:#7ec8e3}.cmsg.ai{border-left-color:#5a44a0}.cmsg.ai .cs{color:#b09fe8}.cmsg.loot{border-left-color:var(--gold)}.cmsg.loot .cs{color:var(--gold2)}.cmsg.boss{border-left-color:var(--red2)}.cmsg.boss .cs{color:var(--hp)}.cmsg.cbt .cs{color:var(--ink-dim)}.chat-in-wrap{display:flex;gap:6px;padding:7px;border-top:1px solid var(--border);background:#00000040}.chat-in{flex:1;background:#04050cd9;border:1px solid var(--border);border-radius:7px;padding:.45rem .65rem;color:var(--ink);font-family:inherit;font-size:.84rem;outline:none;transition:border-color .2s}.chat-in:focus{border-color:var(--gold3)}.chat-go{background:var(--gold-grad);border:none;border-radius:7px;width:34px;cursor:pointer;font-weight:700;color:#1a1200;transition:transform .12s,filter .2s}.chat-go:hover{filter:brightness(1.1)}.chat-go:active{transform:scale(.94)}.sec-lbl{font-family:Cinzel,serif;font-size:.56rem;letter-spacing:.15em;color:var(--gold3);margin:.7rem 0 .4rem;display:flex;align-items:center;gap:.5rem;text-transform:uppercase}.sec-lbl:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}.equip-grid,.bag-grid,.stash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.stash-grid{max-height:132px;overflow-y:auto;padding-right:2px}.islot{aspect-ratio:1;min-height:44px;background:radial-gradient(circle at 50% 30%,#1e223c80,#04050cd9);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:transform .14s cubic-bezier(.2,.8,.2,1),box-shadow .2s,border-color .2s;position:relative;touch-action:manipulation}.islot:hover{transform:translateY(-2px) scale(1.04);border-color:var(--brd2);z-index:2}.islot:active{transform:scale(.96)}.islot.c-magic{border-color:var(--r-magic);box-shadow:0 0 8px #4a86ff4d,inset 0 0 10px #4a86ff14}.islot.c-rare{border-color:var(--r-rare);box-shadow:0 0 9px #e8d24a4d,inset 0 0 10px #e8d24a14}.islot.empty{opacity:.35}.islot.locked{opacity:.28;border-style:dashed;font-size:.7rem;cursor:not-allowed}.islot.selected{box-shadow:0 0 0 2px var(--gold2),0 0 12px #f0d06059}.islot.c-set{border-color:var(--r-set);box-shadow:0 0 9px #2ee07a4d,inset 0 0 10px #2ee07a14}.islot.c-unique{border-color:var(--r-unique);box-shadow:0 0 9px #d9893f59,inset 0 0 10px #d9893f1a}.islot.c-legendary{border-color:var(--r-leg);animation:legpulse 2.2s ease-in-out infinite}.run-loot-lbl{margin-top:.55rem;color:var(--gold2);font-size:.72rem}.run-loot-slot{box-shadow:0 0 0 1px #f0d06059,inset 0 0 8px #f0d06014}@keyframes legpulse{0%,to{box-shadow:0 0 12px #f0c03066,inset 0 0 10px #f0c0301f}50%{box-shadow:0 0 26px #f0c030d9,inset 0 0 16px #f0c03033}}.char-stats{background:#00000038;border:1px solid var(--border);border-radius:8px;padding:.35rem .6rem}.stat-row{display:flex;justify-content:space-between;font-size:.78rem;padding:.24rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.stat-row:last-child{border-bottom:none}.stat-v{font-family:Cinzel,serif;font-size:.68rem;color:var(--gold2)}.loot-list{display:flex;flex-direction:column;gap:5px;max-height:min(42vh,280px);overflow-y:auto;-webkit-overflow-scrolling:touch}.loot-row{display:flex;align-items:flex-start;gap:8px;width:100%;background:#06070fa6;border:1px solid var(--border);border-radius:9px;padding:.45rem .55rem;cursor:pointer;text-align:left;transition:border-color .15s,background .15s;touch-action:manipulation}.loot-row:active{transform:scale(.99)}.loot-row.selected{border-color:var(--gold2);box-shadow:0 0 0 1px #f0d06059}.loot-row-empty{opacity:.55;border-style:dashed}.loot-row-ico{font-size:1.25rem;flex-shrink:0;line-height:1.2}.loot-row-body{min-width:0;flex:1}.loot-row-top{display:flex;align-items:flex-start;gap:6px;min-width:0}.loot-row-name{font-family:Cinzel,serif;font-size:.68rem;line-height:1.25;margin-bottom:2px}.loot-row-action{flex-shrink:0;margin-left:auto;font-family:Cinzel,serif;font-size:.48rem;letter-spacing:.05em;text-transform:uppercase;color:var(--gold2);border:1px solid rgba(200,160,32,.25);border-radius:999px;padding:.08rem .34rem;background:#c8a02014}.loot-row-mods{font-size:.62rem;color:var(--ink-dim);line-height:1.3;margin-bottom:1px}.loot-row-compare{display:flex;flex-wrap:wrap;gap:3px 5px;font-family:Cinzel,serif;font-size:.52rem;line-height:1.25;margin:2px 0}.loot-row-compare .cmp{white-space:nowrap}.loot-row-compare.good,.loot-row-compare .good{color:var(--grn2)}.loot-row-compare.bad,.loot-row-compare .bad{color:var(--red2)}.loot-row-compare.neutral,.loot-row-compare .neutral{color:var(--ink-dim)}.loot-row-good{border-left:2px solid rgba(46,204,113,.65)}.loot-row-bad{border-left:2px solid rgba(231,76,60,.55)}.loot-row-locked{opacity:.68}.loot-row-meta{font-size:.56rem;color:var(--muted)}.loot-list-empty{font-size:.68rem;color:var(--muted);text-align:center;padding:.5rem}.inv-transfer-list .loot-list{max-height:min(50vh,320px)}.inv-transfer-list{align-items:stretch}.town-bag-layout{display:grid;grid-template-columns:minmax(112px,34%) minmax(0,1fr);gap:.6rem;min-height:min(58vh,400px);flex:1}.town-bag-col{display:flex;flex-direction:column;min-height:0;min-width:0}.town-bag-col .sec-lbl{margin-top:0;flex-shrink:0}.town-bag-equip{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;flex-shrink:0}.town-bag-equip .islot{min-height:46px;font-size:1.1rem}.town-bag-col--bag .town-bag-grid,.town-bag-col--bag .loot-list{flex:1;min-height:0;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch;align-content:start}.town-bag-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px}.town-bag-stats-lbl{margin-top:.55rem!important}.town-bag-stats{flex-shrink:0;margin-top:.25rem;max-height:min(28vh,180px);overflow-y:auto;font-size:.72rem}.modal-scroll:has(.town-bag-layout){display:flex;flex-direction:column;min-height:0}@media(pointer:coarse){.town-bag-layout{grid-template-columns:minmax(100px,30%) minmax(0,1fr);min-height:min(62vh,100%);gap:.45rem}.town-bag-equip .islot{min-height:42px;font-size:1rem;padding-bottom:.58rem}.town-bag-equip .islot[data-slot-label]:after,.mob-inv-scroll .equip-grid .islot[data-slot-label]:after{content:attr(data-slot-label);position:absolute;left:3px;right:3px;bottom:3px;font-family:Cinzel,serif;font-size:.38rem;letter-spacing:.05em;color:var(--muted);text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.town-bag-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:4px}.town-bag-grid .islot{min-height:40px;font-size:1.05rem}.town-bag-col--bag .loot-list{gap:4px}.town-bag-hint{margin-bottom:.4rem}}.inv-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:.3rem;font-size:.72rem}.loot-filter-lbl{display:flex;align-items:center;gap:4px;color:var(--ink-dim);cursor:pointer}.inv-toolbar select{flex:1;background:#04050cd9;border:1px solid var(--border);color:var(--ink);border-radius:6px;padding:.3rem .4rem;font-family:inherit;cursor:pointer}.inv-toolbar select:focus{outline:none;border-color:var(--gold3)}#game:not(.hub-active) .action-bar,#game:not(.hub-active) .mob-nav{display:none!important}#game:not(.hub-active){--action-h: 0px;--mob-nav-h: 0px}.action-bar{height:calc(var(--action-h) + var(--safe-bottom));min-height:calc(var(--action-h) + var(--safe-bottom));max-height:calc(var(--action-h) + var(--safe-bottom));flex-shrink:0;background:linear-gradient(0deg,#06070ffc,#0a0c1ae6);border-top:1px solid var(--glass-brd);display:flex;align-items:center;padding:0 10px calc(var(--safe-bottom));gap:6px;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.action-bar::-webkit-scrollbar{height:0}.sk{width:52px;height:52px;min-width:52px;background:radial-gradient(circle at 50% 25%,#22284699,#04050ce6);border:1px solid var(--brd2);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:transform .14s,box-shadow .2s,border-color .2s;flex-shrink:0;overflow:hidden}.sk:hover{transform:translateY(-2px);border-color:var(--gold3)}.sk:active{transform:scale(.94)}.sk.active{border-color:var(--gold);box-shadow:0 0 18px #c8a02066,inset 0 0 14px #c8a0201a}.sk.active:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:10px;border:1px solid rgba(240,208,96,.4);animation:legpulse 1.8s ease-in-out infinite;pointer-events:none}.sk-icon{font-size:1.35rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}.sk-key{position:absolute;bottom:2px;right:4px;font-size:.48rem;color:var(--ink-dim);font-family:Cinzel,serif}.ab-sep{width:1px;height:36px;background:linear-gradient(180deg,transparent,var(--brd2),transparent);margin:0 2px;flex-shrink:0}.ab-btns{display:flex;gap:5px;margin-left:auto;flex-shrink:1;min-width:0;overflow-x:auto;scrollbar-width:none}.ab-btns::-webkit-scrollbar{display:none}.ab-btn{background:#06070fb3;border:1px solid var(--brd2);border-radius:7px;padding:.35rem .5rem;font-family:Cinzel,serif;font-size:.52rem;color:var(--ink-dim);cursor:pointer;white-space:nowrap;transition:transform .14s,color .2s,border-color .2s,background .2s;flex-shrink:0}.ab-btn:hover{transform:translateY(-2px);color:var(--gold2);border-color:var(--gold3);background:#c8a0200f}.ab-btn:active{transform:scale(.96)}@media(min-width:900px)and (pointer:fine){.sk{width:48px;height:48px;min-width:48px}.sk-icon{font-size:1.25rem}.ab-btn{padding:.32rem .45rem;font-size:.5rem}}@media(min-width:1280px){.ab-btns{flex-wrap:wrap;justify-content:flex-end;max-height:calc(var(--action-h) - 8px);overflow-y:auto}}.mob-nav{display:flex;height:calc(54px + var(--safe-bottom));background:linear-gradient(0deg,#06070ffc,#0a0c1aeb);border-top:1px solid var(--glass-brd);padding-bottom:var(--safe-bottom);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-shrink:0}.mob-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:none;color:var(--muted);font-family:Cinzel,serif;font-size:.5rem;cursor:pointer;transition:color .2s;position:relative}.mob-tab.active{color:var(--gold)}.mob-tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:26px;height:2px;background:var(--gold);border-radius:2px;box-shadow:0 0 8px var(--gold)}.mt-ico{font-size:1.15rem}#mob-panel{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000a6;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);align-items:flex-end}#mob-panel.open{display:flex;animation:fadein .25s ease}.mob-panel-inner{background:linear-gradient(180deg,var(--panel2),var(--panel));border-top:1px solid var(--glass-brd);border-radius:18px 18px 0 0;width:100%;max-height:85vh;display:flex;flex-direction:column;padding-bottom:var(--safe-bottom);box-shadow:0 -20px 60px #0009;animation:slideup .32s cubic-bezier(.2,.8,.2,1)}@media(pointer:coarse){.mob-panel-inner{max-height:92dvh;border-radius:14px 14px 0 0}}@keyframes slideup{0%{transform:translateY(100%)}to{transform:none}}.mob-panel-drag{width:44px;height:4px;background:var(--brd2);border-radius:2px;margin:.7rem auto .5rem;cursor:pointer}.mob-panel-tabs{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border)}.mob-ptab{background:none;border:none;padding:.55rem 0;font-family:Cinzel,serif;font-size:.58rem;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent}.mob-ptab.active{color:var(--gold);border-bottom-color:var(--gold)}.mob-pcontent{flex:1;overflow:hidden;display:flex;min-height:0}.mob-ppage{display:none;flex:1;overflow:hidden;flex-direction:column;padding:.7rem;min-height:0}.mob-ppage.active{display:flex}.mob-ppage.inv-page{padding:0}.mob-inv-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:.65rem calc(.65rem + var(--safe-right)) calc(.65rem + var(--safe-bottom)) calc(.65rem + var(--safe-left))}.mob-inv-scroll .stash-grid{max-height:none}.mob-bag-hint{font-size:.68rem;line-height:1.25;color:var(--ink-dim);margin:0 0 .3rem}@media(pointer:coarse){.mob-inv-scroll{display:grid;grid-template-columns:minmax(96px,30%) minmax(0,1fr);grid-template-rows:auto auto minmax(0,1fr) auto auto auto auto;grid-template-areas:"hint hint" "equip-lbl bag-lbl" "equip bag" "stash-lbl stash-lbl" "stash stash" "stats-lbl stats-lbl" "stats stats";gap:.34rem .45rem;overflow:hidden}.mob-inv-scroll .sec-lbl{margin:0}.mob-bag-hint{grid-area:hint;margin:0}.mob-equip-lbl{grid-area:equip-lbl}.mob-bag-lbl{grid-area:bag-lbl}.mob-stash-lbl{grid-area:stash-lbl}.mob-stats-lbl{grid-area:stats-lbl}#mob-equip-slots{grid-area:equip;grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:4px;min-height:0}.mob-inv-scroll .equip-grid .islot{min-height:48px;font-size:1.05rem;padding-bottom:.58rem}#mob-bag-grid,#mob-stash-grid{display:flex;flex-direction:column;gap:4px;min-height:0;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch}#mob-bag-grid{grid-area:bag}#mob-stash-grid{grid-area:stash}#mob-char-stats{grid-area:stats;min-height:0;max-height:26vh;overflow-y:auto}.mob-inv-scroll.combat-quickbag{grid-template-rows:auto auto auto minmax(0,1fr);grid-template-areas:"hint hint" "equip-lbl bag-lbl" "equip runloot" "equip bag"}.combat-quickbag .mob-bag-hint:after{content:" Tap a drop row to equip it immediately.";color:var(--gold2)}.combat-quickbag .mob-stash-lbl,.combat-quickbag #mob-stash-grid,.combat-quickbag .mob-stats-lbl,.combat-quickbag #mob-char-stats{display:none}.combat-quickbag .run-loot-section{grid-area:runloot;min-height:0}.combat-quickbag .run-loot-lbl{margin:0 0 .25rem;font-size:.58rem}.combat-quickbag .run-loot-grid{max-height:min(28vh,150px);overflow-y:auto;gap:4px}.combat-quickbag #mob-bag-grid{min-height:0}}#mobile-controls{display:none;position:absolute;top:0;right:0;bottom:0;left:0;z-index:25;pointer-events:none}@media(max-width:899px),(pointer:coarse){#mobile-controls{display:block}}#mobile-controls>*{pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none}#combat-overlay-left{position:absolute;top:0;right:0;bottom:0;left:0;z-index:14;pointer-events:none;display:none}#combat-overlay-left>*{pointer-events:auto}#mobile-left-row{position:absolute;bottom:max(14px,env(safe-area-inset-bottom,0px));left:max(14px,env(safe-area-inset-left,0px));display:flex;align-items:center;gap:10px}#joystick-wrap{position:relative;z-index:1;touch-action:none}.js-base{width:112px;height:112px;border-radius:50%;background:radial-gradient(circle,#c8a0201f,#c8a0200a);border:2px solid rgba(200,160,32,.35);position:relative;box-shadow:inset 0 0 24px #00000080,0 4px 20px #00000059;touch-action:none}.js-thumb{width:44px;height:44px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#f0d0608c,#c8a02066);border:2px solid rgba(240,208,96,.7);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 16px #c8a02073;pointer-events:none}.combat-bag-btn{width:52px;height:52px;min-width:52px;min-height:52px;border-radius:11px;border:1px solid var(--brd2);background:radial-gradient(circle at 50% 25%,#222846a6,#080a14eb);font-size:1.45rem;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000073;cursor:pointer;touch-action:none;transition:transform .1s}.combat-bag-btn:active{transform:scale(.88)}#atk-btn{position:absolute;bottom:max(14px,env(safe-area-inset-bottom,0px));right:max(14px,env(safe-area-inset-right,0px));z-index:1;width:76px;height:76px;min-width:76px;min-height:76px;border-radius:50%;background:radial-gradient(circle at 40% 30%,#dc462db3,#6e160ceb);border:2px solid rgba(230,80,55,.65);font-size:1.85rem;display:flex;align-items:center;justify-content:center;touch-action:none;cursor:pointer;box-shadow:0 0 28px #c8281480,inset 0 -4px 10px #0006;transition:transform .1s;overflow:hidden}#atk-btn:active{transform:scale(.88)}#atk-btn .cd-btn-ico{position:relative;z-index:2;line-height:1;pointer-events:none}#atk-btn.on-cd{background:radial-gradient(circle at 40% 30%,#dc462d38,#6e160c61);box-shadow:0 0 12px #c8281438,inset 0 -4px 10px #00000047}#atk-btn .cd-fill-atk{border-radius:50%;background:radial-gradient(circle at 40% 30%,#dc462db3,#6e160ceb);box-shadow:inset 0 -4px 10px #0006}#mob-skills{position:absolute;bottom:102px;right:10px;z-index:1;display:flex;flex-direction:column;gap:8px}.mob-sk{position:relative;width:52px;height:52px;min-width:52px;min-height:52px;border-radius:11px;background:radial-gradient(circle at 50% 25%,#222846a6,#080a14eb);border:1px solid var(--brd2);display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 4px 14px #00000073;transition:transform .1s;touch-action:none;overflow:hidden}.mob-sk:active{transform:scale(.88)}.mob-sk-ico{line-height:1;pointer-events:none;position:relative;z-index:2}.mob-sk-edit{position:absolute;top:-4px;left:-4px;width:16px;height:16px;border-radius:50%;background:#080a14eb;border:1px solid var(--brd2);font-size:.58rem;line-height:16px;text-align:center;color:var(--gold2);opacity:.65;pointer-events:none;z-index:3}.cd-fill{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;opacity:0}.cd-btn.on-cd .cd-fill{opacity:1;clip-path:inset(calc((1 - var(--cd-pct, 0)) * 100%) 0 0 0)}.mob-sk.on-cd,.sk.on-cd{background:radial-gradient(circle at 50% 25%,#22284652,#080a148c)}.pot-hp.on-cd{background:radial-gradient(circle at 50% 25%,#781e1e38,#2808086b)}.pot-mp.on-cd{background:radial-gradient(circle at 50% 25%,#1e3c7838,#0810286b)}.mob-sk .cd-fill,.sk .cd-fill{border-radius:10px;background:radial-gradient(circle at 50% 25%,#222846a6,#080a14eb)}.sk.on-cd.active:before{display:none}.sk-icon,.sk-key{position:relative;z-index:2}#potion-btns{position:absolute;bottom:max(18px,env(safe-area-inset-bottom,0px));right:98px;z-index:1;display:flex;gap:8px}.pot-btn{position:relative;width:52px;height:52px;min-width:52px;min-height:52px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 14px #00000073;transition:transform .1s,opacity .15s;touch-action:none;overflow:hidden}.pot-btn:active{transform:scale(.88)}.pot-hp{background:radial-gradient(circle at 50% 25%,#781e1e99,#280808eb);border:1px solid rgba(231,76,60,.5)}.pot-mp{background:radial-gradient(circle at 50% 25%,#1e3c7899,#081028eb);border:1px solid rgba(52,152,219,.5)}.pot-hp .cd-fill-hp{border-radius:11px;background:radial-gradient(circle at 50% 25%,#781e1e99,#280808eb)}.pot-mp .cd-fill-mp{border-radius:11px;background:radial-gradient(circle at 50% 25%,#1e3c7899,#081028eb)}.pot-ico{line-height:1;pointer-events:none;position:relative;z-index:2}.pot-count{position:absolute;bottom:-4px;right:-4px;min-width:18px;height:18px;padding:0 3px;border-radius:9px;background:#080a14f2;border:1px solid var(--brd2);font-family:Cinzel,serif;font-size:.56rem;line-height:16px;text-align:center;color:var(--gold2);pointer-events:none;z-index:3}.pot-btn.empty{opacity:.38;filter:grayscale(.6)}.pot-btn.empty .pot-count{color:var(--ink-dim)}.skill-pick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.skill-pick{display:flex;flex-direction:column;align-items:center;gap:4px;padding:.6rem .4rem;border-radius:10px;background:#14182cb3;border:1px solid var(--brd2);color:var(--ink);cursor:pointer;transition:border-color .15s,background .15s}.skill-pick:hover{border-color:var(--gold3)}.skill-pick.active{border-color:var(--gold);background:#3c2e0c80}.skill-pick-ico{font-size:1.6rem;line-height:1}.skill-pick-name{font-family:Cinzel,serif;font-size:.64rem;text-align:center}.skill-pick-tag{font-size:.54rem;color:var(--gold2)}.skill-pick-tag.alt{color:var(--muted)}@media(min-width:900px)and (hover:hover)and (pointer:fine){#mobile-controls{display:none!important}#mobile-left-row{display:none}#minimap-canvas{width:112px;height:84px}}@media(max-width:899px),(pointer:coarse){.action-bar{display:none!important}:root{--action-h: 0px}#game:not(.hub-active) .hud-top{background:linear-gradient(180deg,#08091485,#0a0c1a52);box-shadow:0 4px 14px #00000038;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}#boss-bar{width:min(300px,calc(100% - 150px));top:6px}#killfeed{max-width:38vw;gap:3px}.kf-row{font-size:.52rem;padding:.2rem .5rem}#minimap-canvas{width:88px;height:66px}#ai-bar{bottom:calc(10px + var(--safe-bottom))}#toasts{right:max(12px,var(--safe-right))}.tst{font-size:.68rem;padding:.34rem .7rem}}#minimap-wrap{position:absolute;top:max(10px,env(safe-area-inset-top,0px));left:max(12px,env(safe-area-inset-left,0px));z-index:1;pointer-events:none;display:flex;flex-direction:column;align-items:flex-start}#minimap-canvas{width:88px;height:66px;image-rendering:pixelated;image-rendering:crisp-edges;border:2px solid rgba(200,160,32,.55);border-radius:4px;box-shadow:0 4px 18px #0000008c,inset 0 0 12px #00000073,0 0 14px #c8a0201f;background:#04050c}#killfeed{position:absolute;top:calc(max(10px,env(safe-area-inset-top,0px)) + 118px);left:max(12px,env(safe-area-inset-left,0px));z-index:12;display:flex;flex-direction:column;gap:4px;pointer-events:none;align-items:flex-start;max-width:min(220px,42vw)}.kf-row{background:#0c0e1cd1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-left:2px solid var(--gold3);border-radius:0 5px 5px 0;padding:.24rem .6rem;font-family:Cinzel,serif;font-size:.58rem;animation:kfin .3s ease}@keyframes kfin{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.kf-row.boss{border-left-color:var(--red2);color:var(--hp);box-shadow:0 0 14px #e74c3c40}#status-wrap{position:absolute;top:calc(max(10px,env(safe-area-inset-top,0px)) + 72px);left:max(12px,env(safe-area-inset-left,0px));z-index:12;display:flex;flex-wrap:wrap;gap:5px;max-width:min(170px,40vw);pointer-events:none}.status-icon{display:flex;flex-direction:column;align-items:center;background:#0c0e1cd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--brd2);border-radius:9px;padding:3px 6px;min-width:36px;animation:msgin .25s ease}.status-ico{font-size:1.05rem;line-height:1}.status-t{font-family:Cinzel,serif;font-size:.48rem;color:var(--gold2);margin-top:1px}@media(min-width:900px)and (pointer:fine){#map-wrap #status-wrap{top:calc(max(10px,env(safe-area-inset-top,0px)) + 90px)}#map-wrap #killfeed{top:calc(max(10px,env(safe-area-inset-top,0px)) + 136px)}}#boss-bar{position:absolute;top:max(8px,env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);width:min(380px,calc(100% - 280px));z-index:13;display:none;pointer-events:none}#boss-bar.show{display:block;animation:fadein .3s ease}.bbar-name{font-family:Cinzel,serif;font-size:.74rem;color:var(--red2);text-align:center;margin-bottom:4px;text-shadow:0 0 12px rgba(231,76,60,.5);letter-spacing:.04em}.bbar-track{height:12px;background:#0009;border:1px solid rgba(231,76,60,.3);border-radius:6px;overflow:hidden}.bbar-fill{height:100%;background:linear-gradient(90deg,#4a1008,#e74c3c,#ff7a5a);transition:width .4s;box-shadow:0 0 12px #e74c3c80}.dmgf{position:absolute;pointer-events:none;font-family:Cinzel,serif;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.9);animation:floatup .9s cubic-bezier(.2,.7,.3,1) forwards;z-index:18}@keyframes floatup{0%{transform:translateY(0) scale(1.2);opacity:1}to{transform:translateY(-70px) scale(.55);opacity:0}}#toasts{position:fixed;top:calc(var(--hud-h) + 8px + var(--safe-top));right:max(12px,var(--safe-right));z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:6px;pointer-events:none;max-width:min(280px,calc(100vw - 24px))}.tst{background:linear-gradient(160deg,#121428f5,#0a0c1af5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;padding:.5rem .9rem;font-size:.8rem;border-left:3px solid var(--gold);box-shadow:0 8px 24px #00000080;animation:tin .25s cubic-bezier(.2,.8,.2,1),tout .35s ease 2.65s forwards}.tst.red{border-left-color:var(--red2)}.tst.green{border-left-color:var(--grn2)}.tst.purp{border-left-color:var(--purp2)}@keyframes tin{0%{transform:translate(28px);opacity:0}to{transform:none;opacity:1}}@keyframes tout{to{transform:translate(28px);opacity:0}}#mode-banner{position:fixed;top:calc(var(--hud-h) + 6px + var(--safe-top));left:50%;transform:translate(-50%);z-index:40;display:none;align-items:center;gap:.5rem;background:linear-gradient(160deg,#281408f2,#140c04f2);border:1px solid var(--gold3);border-radius:22px;padding:.35rem .95rem;font-family:Cinzel,serif;font-size:.68rem;color:var(--gold2);box-shadow:0 8px 28px #00000080,0 0 18px #c8a02040;max-width:calc(100vw - 24px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#mode-banner.show{display:flex;animation:dropin .3s cubic-bezier(.2,.8,.2,1)}@keyframes dropin{0%{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%)}}#mode-banner .mb-x{cursor:pointer;pointer-events:auto;color:var(--ink-dim);font-size:.9rem;line-height:1;padding:0 .1rem}#mode-banner .mb-x:hover{color:var(--red2)}#mode-banner .mb-dot{width:8px;height:8px;border-radius:50%;background:var(--gold2);box-shadow:0 0 8px var(--gold2);animation:legpulse 1.4s ease-in-out infinite}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c7;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:250;display:none;align-items:center;justify-content:center;padding:max(12px,var(--safe-top)) 16px max(12px,var(--safe-bottom));overflow-y:auto}.modal-bg.open{display:flex;animation:fadein .25s ease}.modal-box{position:relative;background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--glass-brd);border-radius:14px;padding:1.35rem;width:min(480px,100%);max-height:min(88dvh,860px);display:flex;flex-direction:column;min-height:0;overflow:hidden;box-shadow:0 30px 90px #000000b3;animation:modalin .3s cubic-bezier(.2,.8,.2,1);margin:auto}.modal-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-right:2px}#modal-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.modal-box h3{font-family:Cinzel,serif;color:var(--gold);margin-bottom:.75rem;border-bottom:1px solid var(--border);padding-bottom:.55rem;letter-spacing:.03em;font-weight:700;flex-shrink:0}.modal-acts{display:flex;gap:.55rem;margin-top:1.1rem;justify-content:flex-end;align-items:center;flex-shrink:0}.modal-acts-extra{display:contents}.mbtn{background:#06070f99;border:1px solid var(--brd2);border-radius:7px;padding:.45rem .9rem;font-family:Cinzel,serif;font-size:.68rem;color:var(--ink);cursor:pointer;transition:transform .14s,border-color .2s,color .2s,background .2s;touch-action:manipulation;min-height:40px}.mbtn:hover{transform:translateY(-2px);border-color:var(--gold3);color:var(--gold2)}.mbtn:active{transform:scale(.97)}.mbtn.gold{border-color:var(--gold);color:var(--gold2);background:linear-gradient(160deg,#c8a02024,#c8a0200a)}.mbtn.gold:hover{background:linear-gradient(160deg,#c8a0203d,#c8a02014)}.mbtn:disabled{opacity:.4;cursor:not-allowed;transform:none}@keyframes modalin{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}.modal-box:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;padding:1px;background:linear-gradient(160deg,rgba(200,160,32,.45),transparent 40%,transparent 60%,rgba(200,160,32,.25));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}@media(pointer:coarse){.modal-bg.open{align-items:stretch;padding:0}.modal-box.modal-sheet{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0;margin:0;padding:max(.65rem,var(--safe-top)) calc(.75rem + var(--safe-right)) calc(.65rem + var(--safe-bottom)) calc(.75rem + var(--safe-left))}.inv-touch-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:4px}.inv-touch-grid .islot{min-height:40px;font-size:1.05rem}.inv-transfer-wrap{display:grid;grid-template-columns:1fr 1fr;gap:.45rem;min-height:min(52vh,320px)}.inv-transfer-col{display:flex;flex-direction:column;min-height:0;min-width:0}.inv-transfer-col .sec-lbl{margin-top:0}.inv-transfer-col .inv-touch-grid,.inv-transfer-col .stash-grid{flex:1;min-height:0;max-height:none;overflow-y:auto;align-content:start}.inv-modal-hint{font-size:.7rem;margin-bottom:.45rem}}#item-tip{position:fixed;z-index:280;pointer-events:none;background:linear-gradient(160deg,#0c0a04fa,#120e05f7);border:1px solid var(--brd2);border-radius:10px;padding:.85rem 1.05rem;max-width:270px;max-height:calc(100dvh - 16px);overflow-y:auto;display:none;font-size:.8rem;box-shadow:0 12px 48px #000000d9;scrollbar-width:thin;scrollbar-color:rgba(201,168,76,.35) transparent}.tip-name{font-family:Cinzel,serif;font-weight:700;margin-bottom:.25rem;font-size:.92rem;letter-spacing:.02em}.tip-type{font-size:.66rem;color:var(--muted);margin-bottom:.45rem;text-transform:capitalize}.tip-mod{font-size:.76rem;color:var(--gold2);line-height:1.5}.tip-affix-meta{font-size:.62rem;color:var(--muted);margin:.1rem 0 0 .55rem;line-height:1.35;font-style:italic;letter-spacing:.01em}.tip-affix-roll{font-size:.68rem;color:#9a8a58;margin:0 0 .2rem .55rem;line-height:1.35;opacity:.9}.tip-req{font-size:.68rem;color:var(--muted);margin-top:.4rem;border-top:1px solid rgba(255,255,255,.08);padding-top:.35rem}#ai-bar{position:fixed;bottom:calc(var(--action-h) + 10px + var(--safe-bottom));left:50%;transform:translate(-50%);background:#0c0e1cf0;border:1px solid var(--brd2);border-radius:22px;padding:.34rem .95rem;font-size:.72rem;color:var(--gold2);display:none;align-items:center;gap:.5rem;z-index:30;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 24px #00000080;max-width:calc(100vw - 24px)}#ai-bar.show{display:flex;animation:dropin .3s ease}.spin{width:11px;height:11px;border:1.5px solid rgba(200,160,32,.25);border-top-color:var(--gold);border-radius:50%;animation:spin .65s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lvl-flash{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:60;animation:lvlf .75s ease-out forwards}@keyframes lvlf{0%{background:radial-gradient(circle at center,rgba(240,208,96,.35),transparent 70%)}to{background:transparent}}.evt-card{background:linear-gradient(160deg,#10122699,#080a1699);border:1px solid var(--border);border-left:2px solid var(--gold3);border-radius:7px;padding:.55rem .65rem;font-size:.76rem;margin-bottom:.45rem;animation:msgin .3s ease}.evt-title{font-family:Cinzel,serif;font-size:.64rem;color:var(--gold);margin-bottom:.15rem}.evt-ago{font-size:.6rem;color:var(--muted);margin-top:.2rem}.shop-grid,.zone-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.shop-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:.6rem}.shop-tab{flex:1 1 auto;min-width:0;font-size:.62rem;padding:.35rem .4rem}.inv-modal-hint{font-size:.76rem;color:var(--muted);margin-bottom:.6rem;line-height:1.35}.inv-transfer-wrap{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}.inv-transfer-col .stash-grid{max-height:180px}.inv-cap{color:var(--gold3);font-weight:400}.upgrade-card{display:flex;flex-direction:column;gap:.35rem;padding:.65rem .75rem;margin-bottom:.5rem;border:1px solid var(--border);border-radius:10px;background:#0c0e1c80}.upgrade-title{font-family:Cinzel,serif;font-size:.72rem;color:var(--gold2)}.upgrade-desc{font-size:.7rem;color:var(--muted);margin-bottom:.25rem}.shop-item,.zone-cell{background:linear-gradient(160deg,#10122699,#080a16b3);border:1px solid var(--border);border-radius:9px;padding:.7rem .6rem;cursor:pointer;text-align:center;font-size:.76rem;transition:transform .15s cubic-bezier(.2,.8,.2,1),border-color .2s,box-shadow .2s}.shop-item:hover,.zone-cell:hover{transform:translateY(-3px);border-color:var(--gold3);box-shadow:0 8px 20px #0006}.shop-item:active,.zone-cell:active{transform:scale(.97)}.shop-item>div:first-child{font-size:1.5rem;margin-bottom:.25rem}.zone-cell.active{border-color:var(--gold);color:var(--gold2);background:#c8a02014;box-shadow:0 0 16px #c8a02033}.shop-tabs{display:flex;gap:6px;margin-bottom:.7rem}.shop-tab{flex:1;padding:.45rem;background:#06070f99;border:1px solid var(--border);border-radius:7px;cursor:pointer;font-family:Cinzel,serif;font-size:.64rem;color:var(--muted);transition:color .2s,border-color .2s,background .2s}.shop-tab:hover{color:var(--ink)}.shop-tab.active{border-color:var(--gold);color:var(--gold2);background:#c8a02012}.quest-card{background:linear-gradient(160deg,#1012268c,#080a16a6);border:1px solid var(--border);border-radius:9px;padding:.7rem;transition:border-color .2s,transform .15s}.quest-card:hover{transform:translateY(-2px)}.smith-section{background:#00000038;border:1px solid var(--border);border-radius:9px;padding:.7rem .75rem}.smith-section .sec-lbl{margin-top:0}.st-branch{margin-bottom:1.1rem}.st-branch-name{font-family:Cinzel,serif;font-size:.74rem;color:var(--gold);margin-bottom:.55rem;border-bottom:1px solid var(--border);padding-bottom:.35rem;letter-spacing:.03em}.st-skills{display:flex;flex-direction:column;gap:.55rem}.st-skill{background:linear-gradient(160deg,#1012268c,#080a16a6);border:1px solid var(--border);border-radius:9px;padding:.6rem .7rem;transition:border-color .2s}.st-skill:hover{border-color:var(--brd2)}.st-skill-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}.st-skill-name{font-family:Cinzel,serif;font-size:.7rem;color:var(--gold2)}.st-rank{font-size:.62rem;color:var(--muted)}.st-pips{display:flex;gap:5px;margin-bottom:.35rem}.st-pip{width:9px;height:9px;border-radius:50%;background:var(--border);border:1px solid rgba(255,255,255,.06);transition:background .25s,box-shadow .25s}.st-pip.on{background:var(--gold);box-shadow:0 0 8px #c8a02099}.st-effect{font-size:.74rem;color:var(--ink-dim);margin-bottom:.45rem}.st-buy{width:100%;font-size:.62rem!important;padding:.35rem!important}.st-buy:disabled{opacity:.4;cursor:not-allowed}.world-page{padding:.7rem;overflow-y:auto}@media(pointer:coarse){:root{--panel-w: 0px;--mob-nav-h: 54px}.side-panel{display:none}}@media(min-width:900px)and (pointer:fine){.mob-nav,#mob-panel{display:none!important}}.t-party-row{margin-top:0}.t-party-global{margin-bottom:.65rem;max-width:100%}.party-modal{display:flex;flex-direction:column;gap:.65rem}.party-status-bar{display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;border-radius:10px;background:#00000047;border:1px solid var(--border)}.party-status-bar.live{border-color:#2ee07a59;background:#2ee07a0f}.party-status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);box-shadow:0 0 6px currentColor}.party-status-bar.live .party-status-dot{background:var(--grn2);animation:legpulse 1.6s ease-in-out infinite}.party-status-txt{font-family:Cinzel,serif;font-size:.66rem;color:var(--ink-dim);flex:1}.party-host-badge,.party-guest-badge{font-family:Cinzel,serif;font-size:.58rem;padding:.15rem .45rem;border-radius:12px}.party-host-badge{color:var(--gold2);background:#c8a0201f;border:1px solid var(--gold3)}.party-guest-badge{color:#9ed4f0;background:#2f6fa026;border:1px solid rgba(126,200,227,.25)}.party-id-block,.party-join-block{background:#00000038;border:1px solid var(--border);border-radius:10px;padding:.65rem .75rem}.party-id-block .sec-lbl,.party-join-block .sec-lbl{margin-top:0}.party-id-row,.party-join-row{display:flex;gap:.45rem;align-items:stretch;margin-top:.35rem}.party-id-code{flex:1;font-size:.68rem;color:var(--gold);word-break:break-all;line-height:1.45;padding:.45rem .55rem;background:#04050cd9;border:1px solid var(--brd2);border-radius:7px}.party-copy-btn{flex-shrink:0;align-self:stretch}.party-join-in{flex:1;background:#04050cd9;border:1px solid var(--border);border-radius:7px;padding:.45rem .6rem;color:var(--ink);font-family:inherit;font-size:.78rem;outline:none}.party-join-in:focus{border-color:var(--gold3)}.party-id-hint,.party-offline-msg{font-size:.72rem;color:var(--muted);margin-top:.4rem;line-height:1.4}.loot-rule-grid{display:grid;grid-template-columns:1fr;gap:6px}@media(min-width:420px){.loot-rule-grid{grid-template-columns:repeat(3,1fr)}}.loot-rule-card{position:relative;background:linear-gradient(160deg,#1012268c,#080a16a6);border:1px solid var(--border);border-radius:9px;padding:.55rem .6rem;cursor:pointer;transition:transform .14s,border-color .2s,box-shadow .2s;min-height:72px}.loot-rule-card:hover:not(.locked){transform:translateY(-2px);border-color:var(--brd2)}.loot-rule-card.active{border-color:var(--gold);box-shadow:0 0 16px #c8a02033,inset 0 0 12px #c8a0200f}.loot-rule-card.locked{opacity:.72;cursor:default}.lrc-title{font-family:Cinzel,serif;font-size:.62rem;color:var(--gold2);margin-bottom:.2rem}.lrc-desc{font-size:.68rem;color:var(--muted);line-height:1.3}.lrc-check{font-family:Cinzel,serif;font-size:.56rem;color:var(--grn2);margin-top:.35rem}.party-roster{display:flex;flex-direction:column;gap:5px;max-height:140px;overflow-y:auto}.party-member{display:flex;align-items:center;gap:.45rem;padding:.4rem .55rem;background:#00000038;border:1px solid var(--border);border-radius:8px;font-size:.78rem;animation:msgin .25s ease}.party-member.me{border-color:#c8a02059;background:#c8a0200d}.pm-av{font-size:1.1rem}.pm-name{flex:1;font-family:Cinzel,serif;font-size:.66rem;color:var(--ink)}.pm-crown{font-size:.75rem}.pm-dot{width:7px;height:7px;border-radius:50%;background:var(--muted)}.pm-dot.on{background:var(--grn2);box-shadow:0 0 8px var(--grn2)}.party-empty{font-size:.74rem;color:var(--muted);font-style:italic;padding:.5rem;text-align:center}.party-perks{background:#00000038;border:1px solid var(--border);border-radius:9px;padding:.35rem .6rem}.party-leave-btn{width:100%;margin-top:.25rem;color:var(--red2)!important;border-color:#e74c3c59!important}.party-id-short{font-size:1.35rem!important;letter-spacing:.18em;text-align:center;font-weight:700}.party-uuid-details{margin-top:.45rem;font-size:.68rem;color:var(--muted)}.party-uuid-details summary{cursor:pointer;color:var(--ink-dim)}.party-solo-actions{display:flex;flex-direction:column;gap:.55rem}.party-checklist{display:flex;flex-direction:column;gap:4px;background:#0000002e;border:1px solid var(--border);border-radius:9px;padding:.5rem .65rem}.party-check{font-size:.72rem;color:var(--muted)}.party-check.ok{color:var(--grn2)}.party-ready-row{display:flex;align-items:center;gap:.55rem}.party-ready-btn{flex:1}.party-ready-btn.ready{border-color:var(--grn2)!important;color:var(--grn2)!important}.party-ready-count{font-size:.68rem;color:var(--muted);font-family:Cinzel,serif;white-space:nowrap}.party-zone-banner{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .65rem;background:#5078c81f;border:1px solid rgba(120,160,240,.3);border-radius:9px;font-size:.74rem}.pm-info{flex:1;display:flex;flex-direction:column;min-width:0}.pm-zone{font-size:.54rem;color:var(--muted)}.pm-ready{color:var(--grn2);font-size:.72rem}.pm-wait{color:var(--muted);font-size:.72rem}.zone-node.party-highlight{border-color:#78a0f0a6!important;box-shadow:0 0 20px #648cdc59;animation:legpulse 1.6s ease-in-out infinite}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
