:root{--bg:#0b0e14;--panel:#141a24;--panel-2:#1c2533;--accent:#d9a441;--accent-2:#c8821f;--text:#e6e6e6;--muted:#8a93a3;--danger:#e0533d;--good:#6fd06a;--info:#3498db;--skillmsg:#b48ce0;--warn:var(--accent-2);--grid-line:#28303d;--row-hover:#ffffff0a;--hotbar-h:calc(96px * var(--ui-scale));--pip-sphere:#ffb84d;--pip-coin:#e8c34a;--pip-soul:#9bd0ff;--pip-charm:#cdd6e0;--pip-shield:#9aa7b5;--pip-scar:#e0533d;--ui-scale:1;font-family:Segoe UI,system-ui,sans-serif}*{box-sizing:border-box}html,body,#app{background:var(--bg);height:100%;color:var(--text);margin:0}#app{justify-content:center;align-items:center;display:flex}.screen{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.panel{background:var(--panel);border:1px solid #28303d;border-radius:12px;width:360px;padding:28px 32px;box-shadow:0 18px 50px #00000080}.panel h1{letter-spacing:.5px;margin:0 0 4px;font-size:22px}.panel .subtitle{color:var(--muted);margin-bottom:20px;font-size:13px}.field{margin-bottom:14px}.field label{color:var(--muted);margin-bottom:6px;font-size:12px;display:block}.field input{background:var(--panel-2);width:100%;color:var(--text);border:1px solid #2c3543;border-radius:8px;padding:10px 12px;font-size:14px}.field input:focus{border-color:var(--accent);outline:none}button.primary{background:linear-gradient(180deg, var(--accent), var(--accent-2));color:#1a1206;cursor:pointer;border:none;border-radius:8px;width:100%;padding:11px;font-size:15px;font-weight:600}button.primary:hover{filter:brightness(1.07)}button.primary:disabled{opacity:.5;cursor:not-allowed}.status{min-height:18px;margin-top:14px;font-size:13px}.status.error{color:var(--danger)}.status.info{color:var(--muted)}.char-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.char-card{background:var(--panel-2);cursor:pointer;text-align:center;border:1px solid #2c3543;border-radius:10px;padding:14px;transition:border-color .15s,transform .1s}.char-card:hover{border-color:var(--accent);transform:translateY(-2px)}.char-card .name{margin-bottom:4px;font-weight:600}.char-card .meta{color:var(--muted);font-size:12px}.char-card.empty{color:var(--muted);cursor:default;opacity:.5}.pincode-dots{justify-content:center;gap:10px;margin:18px 0;display:flex}.pincode-dots .dot{background:var(--panel-2);border:1px solid #3a4453;border-radius:50%;width:14px;height:14px}.pincode-dots .dot.filled{background:var(--accent)}.keypad{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.keypad button{background:var(--panel-2);color:var(--text);cursor:pointer;border:1px solid #2c3543;border-radius:8px;padding:14px;font-size:18px}.keypad button:hover{border-color:var(--accent)}#game-canvas{width:100vw;height:100vh;display:block}.hud{pointer-events:none;background:#0a0e14b3;border:1px solid #28303d;border-radius:8px;padding:10px 14px;font-size:13px;position:fixed;top:12px;left:12px}.hud .row{margin:2px 0}.hud .label{color:var(--muted)}.overlay{pointer-events:none;z-index:10;position:fixed}.overlay button,.overlay input,.inv-cell,.skill-row,.npc-menu-item,.hot-slot{pointer-events:auto;cursor:pointer}.panel-box{background:#0a0e14d1;border:1px solid #28303d;border-radius:8px}.status-panel{width:calc(300px * var(--ui-scale));padding:calc(10px * var(--ui-scale));font-size:calc(12px * var(--ui-scale));background:linear-gradient(#131923eb,#080c12e0);border:1px solid #74849c5c;border-radius:8px;top:12px;left:12px;box-shadow:0 10px 26px #0000005c,inset 0 1px #ffffff0d}.hud-identity{grid-template-columns:calc(42px * var(--ui-scale)) minmax(0, 1fr) auto;align-items:center;gap:calc(8px * var(--ui-scale));margin-bottom:calc(8px * var(--ui-scale));display:grid}.hud-portrait{width:calc(42px * var(--ui-scale));height:calc(42px * var(--ui-scale));color:#ffe7a8;font-size:calc(13px * var(--ui-scale));letter-spacing:0;font-variant-numeric:tabular-nums;text-shadow:0 1px 2px #000;background:linear-gradient(135deg,#d9a4412e,#b48ce024),radial-gradient(circle at 50% 28%,#ffffff1a,#0d121afa 62%);border:1px solid #d9a4417a;border-radius:8px;place-items:center;font-weight:900;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 0 2px #00000047,0 3px 8px #00000047}.hud-portrait.has-art{color:#0000;text-shadow:none;background-position:50%;background-repeat:no-repeat;background-size:cover}.hud-portrait>canvas.self-3d{width:100%;height:100%;display:none;position:absolute;inset:0}.hud-portrait.has-3d>canvas.self-3d{display:block}.hud-portrait.has-3d{color:#0000;text-shadow:none;background-image:none!important}.hud-title{gap:calc(2px * var(--ui-scale));flex-direction:column;min-width:0;display:flex}.hud-name{font-weight:800;font-size:calc(14px * var(--ui-scale));text-overflow:ellipsis;white-space:nowrap;line-height:1.1;overflow:hidden}.hud-job{color:var(--muted);font-size:calc(11px * var(--ui-scale));text-overflow:ellipsis;white-space:nowrap;line-height:1.1;overflow:hidden}.hud-levels{gap:calc(3px * var(--ui-scale));flex-direction:column;align-items:flex-end;display:flex}.hud-level-chip{align-items:baseline;gap:calc(4px * var(--ui-scale));min-width:calc(54px * var(--ui-scale));padding:calc(2px * var(--ui-scale)) calc(6px * var(--ui-scale));font-variant-numeric:tabular-nums;background:#ffffff09;border:1px solid #74849c4d;border-radius:5px;justify-content:space-between;display:inline-flex}.hud-level-base{border-color:#d9a4416b}.hud-level-job{border-color:#b48ce070}.hud-level-key{color:var(--muted);font-size:calc(9px * var(--ui-scale));text-transform:uppercase}.hud-level-value{color:var(--text);font-size:calc(13px * var(--ui-scale));font-weight:800}.hud-resource-bars{gap:calc(5px * var(--ui-scale));flex-direction:column;display:flex}.hud-row{color:var(--muted);margin-top:0}.status-panel .bar{height:calc(16px * var(--ui-scale));background:#05080cd1;border:1px solid #74849c38;border-radius:5px;margin-top:0;position:relative;overflow:hidden;box-shadow:inset 0 1px 3px #0000008c}.hud-progression{gap:calc(4px * var(--ui-scale));margin-top:calc(8px * var(--ui-scale));padding-top:calc(7px * var(--ui-scale));border-top:1px solid #74849c2e;flex-direction:column;display:flex}.hud-progress-row{grid-template-columns:calc(34px * var(--ui-scale)) minmax(0, 1fr);align-items:center;gap:calc(6px * var(--ui-scale));display:grid}.hud-progress-label{color:var(--muted);font-size:calc(9px * var(--ui-scale));text-transform:uppercase;letter-spacing:0;font-weight:800}.status-panel .exp-bar{height:calc(11px * var(--ui-scale))}.bar-fill{width:0%;height:100%;transition:width .2s}.bar-fill.hp{z-index:1;background:linear-gradient(90deg,#c0392b,#e0533d);position:relative}.bar-fill.hp-ghost{z-index:0;background:linear-gradient(90deg,#7a1f17,#a3392f);transition:width .4s ease-out;position:absolute;top:0;left:0}body.reduce-flashing .bar-fill.hp-ghost{transition:none}.bar-fill.sp{background:linear-gradient(90deg,#2471a3,#3498db)}.bar-fill.exp.base-exp{background:linear-gradient(90deg, #c8821f, var(--accent))}.bar-fill.exp.job-exp{background:linear-gradient(90deg, #7f58b8, var(--skillmsg))}.bar-text{z-index:2;text-align:center;font-size:calc(11px * var(--ui-scale));line-height:calc(16px * var(--ui-scale));color:#fff;text-shadow:0 1px 1px #000000b3;position:absolute;inset:0}.status-panel .exp-bar .bar-text{line-height:calc(11px * var(--ui-scale));font-size:calc(9px * var(--ui-scale))}.hud-economy{align-items:center;gap:calc(6px * var(--ui-scale));margin-top:calc(8px * var(--ui-scale));grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);display:grid}.hud-economy .hud-row:first-child{text-overflow:ellipsis;white-space:nowrap;color:#ffe066;font-variant-numeric:tabular-nums;text-shadow:0 1px 1px #000;min-width:0;font-weight:800;overflow:hidden}.party-frames{top:calc(244px * var(--ui-scale));width:calc(300px * var(--ui-scale));pointer-events:auto;gap:calc(3px * var(--ui-scale));flex-direction:column;display:flex;left:12px}.pf-grip{height:calc(12px * var(--ui-scale));cursor:move;-webkit-user-select:none;user-select:none;color:var(--muted);opacity:0;background:#0a0e1480;border-radius:4px;justify-content:center;align-items:center;transition:opacity .12s;display:flex}.party-frames:hover .pf-grip{opacity:.7}.pf-grip-dots{font-size:calc(11px * var(--ui-scale));letter-spacing:2px;line-height:1}.pf-list{gap:calc(4px * var(--ui-scale));flex-direction:column;display:flex}.pf-frame{cursor:pointer;text-align:left;padding:calc(5px * var(--ui-scale)) calc(8px * var(--ui-scale));gap:calc(3px * var(--ui-scale));background:#0a0e14d1;border:1px solid #28303d;border-left:3px solid #3a4555;border-radius:6px;flex-direction:column;transition:border-color .12s,background-color .12s;display:flex;position:relative}.pf-frame:hover{border-color:var(--accent);background:#10161fe6}.pf-frame:focus-visible{outline-offset:1px;outline:2px solid #7fd0ff}.pf-frame.pf-self{border-left-color:var(--accent)}.pf-frame.pf-offline{opacity:.45}.pf-frame.pf-oor{opacity:.6;cursor:default}.pf-frame.pf-dead{filter:grayscale(.6);border-left-color:#e0533d}.pf-frame.pf-lowhp{border-left-color:#e0533d;animation:1s ease-in-out infinite pf-pulse}@keyframes pf-pulse{0%,to{background:#0a0e14d1}50%{background:#4a1818b3}}.pf-top{align-items:baseline;gap:calc(4px * var(--ui-scale));display:flex}.pf-crown{color:var(--accent);font-size:calc(11px * var(--ui-scale));flex:none}.pf-name{min-width:0;font-size:calc(12px * var(--ui-scale));color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:600;overflow:hidden}.pf-bar{height:calc(9px * var(--ui-scale));background:var(--panel-2);border-radius:3px;position:relative;overflow:hidden}.pf-fill{width:0%;height:100%;transition:width .2s}.pf-hp .pf-fill{background:linear-gradient(90deg,#2e8b57,#5fd35f)}.pf-frame.pf-lowhp .pf-hp .pf-fill{background:linear-gradient(90deg,#c0392b,#e0533d)}.pf-pct{font-size:calc(8px * var(--ui-scale));color:#fff;text-shadow:0 1px 1px #000;pointer-events:none;letter-spacing:.3px;justify-content:center;align-items:center;font-weight:700;display:flex;position:absolute;inset:0}.pf-buffs{flex-wrap:wrap;gap:2px;display:flex}.pf-chip{width:calc(16px * var(--ui-scale));height:calc(16px * var(--ui-scale));background-position:50%;background-repeat:no-repeat;background-size:cover;border:1px solid #5fd35f80;border-radius:3px}.pf-chip.bad{border-color:#e0533d99}.pf-sp{height:calc(6px * var(--ui-scale));margin-top:calc(2px * var(--ui-scale))}.pf-sp .pf-fill{background:linear-gradient(90deg,#2b6cb0,#4aa3ff)}.pf-sp .pf-pct{font-size:calc(7px * var(--ui-scale))}.menu-buttons{pointer-events:auto;background:#0a0e14cc;border:1px solid #28303d;border-radius:12px;align-items:center;gap:5px;padding:4px;display:flex;inset:202px 14px auto auto;box-shadow:0 2px 8px #0006}.menu-divider{background:linear-gradient(#0000,#36404f 30% 70%,#0000);align-self:stretch;width:1px;margin:3px 1px}.menu-btn{width:30px;height:30px;color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;padding:0;transition:color .12s,background-color .12s,border-color .12s;display:flex;position:relative}.menu-glyph{width:18px;height:18px;color:inherit;display:flex}.menu-glyph svg{width:100%;height:100%;display:block}.menu-btn:hover{color:var(--text);background:#d9a4411f;border-color:#d9a44166}.menu-btn:active{background:#d9a4412e}.menu-btn[aria-pressed=true]{color:var(--accent);border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset, 0 0 8px #d9a4414d;background:#d9a44129}.menu-key{color:var(--muted);text-shadow:0 1px 1px #000;pointer-events:none;font-size:8px;font-weight:700;line-height:1;position:absolute;bottom:0;right:1px}.menu-btn:hover .menu-key,.menu-btn[aria-pressed=true] .menu-key{color:var(--accent)}.target-panel{background:#0a0e14d1;border:1px solid #28303d;border-radius:6px;padding:6px 16px;top:12px;left:50%;transform:translate(-50%)}.target-name{font-weight:600}.window{background:var(--panel);pointer-events:auto;border:1px solid #28303d;border-radius:10px;flex-direction:column;width:300px;top:80px;left:50%;transform:translate(-50%);box-shadow:0 18px 50px #00000080}.window.win-stats{top:80px;left:auto;right:70px;transform:none}.window.win-inv{width:360px;top:130px;left:auto;right:24px;transform:none}.window.win-skills{width:560px;max-width:92vw;top:120px;left:auto;right:120px;transform:none}.win-head{letter-spacing:.3px;background:linear-gradient(#3640528c,#36405200);border-bottom:1px solid #28303d;border-radius:10px 10px 0 0;justify-content:space-between;align-items:center;padding:9px 12px;font-weight:600;display:flex}.win-close{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:18px;line-height:1}.win-close:hover{color:var(--text)}.win-body{max-height:60vh;padding:12px;overflow-y:auto}.window.win-stats{width:calc(520px * var(--ui-scale));max-width:94vw}.stats-grid{gap:calc(12px * var(--ui-scale));flex-direction:column;display:flex}.stats-cols2{gap:calc(16px * var(--ui-scale));grid-template-columns:1fr 1fr;align-items:start;display:grid}.stats-col{gap:calc(12px * var(--ui-scale));flex-direction:column;min-width:0;display:flex}.stats-col .derived-grid{grid-template-columns:1fr}@media (max-width:560px),(pointer:coarse){.stats-cols2{grid-template-columns:1fr}}.stats-identity{gap:2px calc(10px * var(--ui-scale));padding:calc(8px * var(--ui-scale)) calc(10px * var(--ui-scale));background:linear-gradient(#d9a4411f,#d9a44100);border:1px solid #2a3342;border-radius:8px;grid-template-columns:1fr auto;align-items:center;display:grid}.si-name{font-size:calc(15px * var(--ui-scale));letter-spacing:.3px;color:var(--text);text-overflow:ellipsis;white-space:nowrap;grid-column:1;font-weight:700;overflow:hidden}.si-job{font-size:calc(16px * var(--ui-scale));letter-spacing:.3px;color:var(--accent);grid-column:1;font-weight:700}.si-levels{flex-direction:column;grid-area:1/2/span 2;align-items:flex-end;gap:3px;display:flex}.si-lv{align-items:baseline;gap:6px;display:inline-flex}.si-lv-k{font-size:calc(10px * var(--ui-scale));text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}.si-lv-v{font-size:calc(13px * var(--ui-scale));color:var(--text);font-variant-numeric:tabular-nums;font-weight:700}.stats-points{padding:calc(7px * var(--ui-scale)) calc(12px * var(--ui-scale));background:var(--panel-2);border:1px solid #2a3342;border-radius:8px;justify-content:space-between;align-items:center;display:flex}.stats-points.has{border-color:var(--accent-2);background:linear-gradient(#d9a44129,#d9a4410a)}.sp-key{font-size:calc(11px * var(--ui-scale));text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.stats-points.has .sp-key{color:var(--text)}.sp-val{font-size:calc(16px * var(--ui-scale));color:var(--muted);font-variant-numeric:tabular-nums;font-weight:800}.stats-points.has .sp-val{color:var(--accent)}.stats-cols{grid-template-columns:1fr 1fr;gap:0;display:grid}.sub-col{padding-left:calc(14px * var(--ui-scale));border-left:1px solid #232c3a}.col-head{font-size:calc(10px * var(--ui-scale));text-transform:uppercase;letter-spacing:.6px;color:var(--muted);border-bottom:1px solid #232c3a;align-items:center;gap:7px;margin-bottom:5px;padding-bottom:4px;display:flex}.col-head:before{content:"";width:3px;height:calc(12px * var(--ui-scale));background:var(--grp,var(--accent));border-radius:2px;flex:none}.col-head.def{margin-top:calc(10px * var(--ui-scale))}.grp-attr{--grp:var(--accent);--grp-soft:#d9a44124}.grp-off{--grp:#e8895c;--grp-soft:#e8895c26}.grp-def{--grp:#5aa0e0;--grp-soft:#5aa0e026}.stat-ico{color:var(--grp,var(--accent));flex:none;justify-content:center;align-items:center;display:inline-flex}.stat-ico svg{width:calc(15px * var(--ui-scale));height:calc(15px * var(--ui-scale));fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.stat-ico svg.is-fill{fill:currentColor;stroke:none}.stat-ico--tile{width:calc(28px * var(--ui-scale));height:calc(28px * var(--ui-scale));background:var(--grp-soft);border:1px solid var(--grp-soft);border-radius:8px;box-shadow:inset 0 1px #ffffff0d}.stat-ico--tile svg{width:calc(17px * var(--ui-scale));height:calc(17px * var(--ui-scale))}.derived-head{align-items:center;gap:calc(7px * var(--ui-scale));min-width:0;display:inline-flex}.attr-list{flex-direction:column;display:flex}.attr-row{grid-template-columns:auto 1fr auto 2.6em calc(20px * var(--ui-scale));align-items:center;column-gap:calc(8px * var(--ui-scale));padding:calc(7px * var(--ui-scale)) 0;cursor:help;border-bottom:1px solid #1e2630;row-gap:1px;display:grid}.attr-row:last-child{border-bottom:none}.attr-row .stat-ico--tile{grid-row:1/span 2;align-self:center}.attr-name{align-items:baseline;gap:6px;min-width:0;display:flex;overflow:hidden}.attr-full{font-size:calc(13px * var(--ui-scale));color:var(--text);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:700;overflow:hidden}.attr-val{white-space:nowrap}.attr-abbr{font-size:calc(10px * var(--ui-scale));letter-spacing:.5px;color:var(--muted);font-weight:600}.attr-hint{font-size:calc(10px * var(--ui-scale));color:var(--muted);grid-column:2/-1;line-height:1.25}.attr-label{font-size:calc(12px * var(--ui-scale));letter-spacing:.4px;color:var(--text);font-weight:700}.attr-val{text-align:right;font-size:calc(14px * var(--ui-scale));color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:700}.attr-bonus{color:#7fd0ff;font-weight:700;font-size:calc(11px * var(--ui-scale));margin-left:3px}.attr-cost{text-align:center;background:var(--panel-2);border:1px solid var(--accent-2);min-width:2ch;font-size:calc(10px * var(--ui-scale));color:var(--accent);font-variant-numeric:tabular-nums;border-radius:9px;justify-self:center;padding:1px 5px;font-weight:600}.attr-cost.off{color:var(--muted);opacity:.55;border-color:#2f3a49}.attr-plus{width:calc(20px * var(--ui-scale));height:calc(20px * var(--ui-scale));background:var(--panel-2);border:1px solid var(--accent);color:var(--accent);font-size:calc(14px * var(--ui-scale));cursor:pointer;border-radius:4px;place-items:center;line-height:1;transition:background .1s,color .1s,transform 50ms;display:grid}.attr-plus:hover:not(:disabled){background:var(--accent);color:#1a1206}.attr-plus:active:not(:disabled){transform:scale(.88)}.attr-plus:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.attr-plus:disabled{color:#4a5363;cursor:default;border-color:#2f3a49}.sub-row{padding:calc(2px * var(--ui-scale)) 0;justify-content:space-between;align-items:baseline;display:flex}.sub-label{font-size:calc(11px * var(--ui-scale));letter-spacing:.3px;color:var(--muted)}.sub-val{font-size:calc(12px * var(--ui-scale));color:var(--text);font-variant-numeric:tabular-nums;font-weight:600}.stats-section{gap:calc(6px * var(--ui-scale));flex-direction:column;display:flex}.derived-grid{gap:calc(6px * var(--ui-scale));grid-template-columns:1fr 1fr;display:grid}.derived-cell{padding:calc(6px * var(--ui-scale)) calc(9px * var(--ui-scale));background:linear-gradient(180deg, var(--grp-soft,transparent), transparent), var(--panel-2);cursor:help;border:1px solid #2a3342;border-radius:7px;justify-content:space-between;align-items:center;gap:6px;transition:border-color .12s,background .12s;display:flex}.derived-cell:hover{border-color:var(--grp,var(--accent-2))}.derived-label{font-size:calc(11px * var(--ui-scale));color:var(--muted);text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.derived-val{font-size:calc(13px * var(--ui-scale));color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap;flex:none;font-weight:700}.derived-sub{font-size:calc(10px * var(--ui-scale));color:var(--muted);margin-left:6px;font-weight:600}body.high-contrast .stats-identity,body.high-contrast .stats-points,body.high-contrast .attr-cost,body.high-contrast .attr-plus{border-width:2px}body.high-contrast .attr-plus:disabled{color:#9aa4b3;border-color:#6f7d92}.inv-window{flex-direction:column;gap:8px;display:flex}.win-inv .win-body{max-height:74vh;overflow:hidden}.inv-window .inv-grid{flex:auto;align-content:start;min-height:104px;padding:2px 2px 2px 0;overflow-y:auto}.inv-grid{box-sizing:border-box;grid-template-columns:repeat(auto-fill,46px);justify-content:start;gap:6px;display:grid}.inv-cell{cursor:pointer;background:linear-gradient(160deg,#1b222d,#141a23);border:1px solid #2c3543;border-radius:6px;justify-content:center;align-items:center;width:46px;height:46px;padding:0;transition:border-color .12s,transform 80ms,box-shadow .12s;display:flex;position:relative}.inv-cell:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 10px #00000061}.inv-cell:active{transform:translateY(0)}.inv-cell.equipped{border-color:var(--accent);background:#23303f}.inv-cell .inv-icon{pointer-events:none;width:36px;height:36px}.inv-name{font-size:12px}.inv-amt{z-index:1;color:#fff;text-shadow:0 1px 1px #000;background:#080c12d9;border-radius:3px;padding:0 2px;font-size:10px;font-weight:700;line-height:1;position:absolute;bottom:1px;right:2px}.inv-refine{z-index:1;color:#ffe066;text-shadow:0 1px 1px #000;font-size:10px;font-weight:700;line-height:1;position:absolute;top:1px;left:2px}.inv-tabs{box-sizing:border-box;gap:4px;width:100%;margin:6px 0;display:flex}.inv-tab{cursor:pointer;background:var(--panel-2);min-width:0;color:var(--muted);border:1px solid #2c3543;border-radius:6px;flex:1;padding:5px 8px;font-size:12px}.inv-tab:hover{border-color:var(--accent)}.inv-tab.active{color:var(--accent);border-color:var(--accent);background:#141c26f2}.inv-bag-head{box-sizing:border-box;align-items:center;gap:6px;width:100%;margin-bottom:6px;display:flex}.inv-search{color:#e6e6e6;background:#0a0e14d9;border:1px solid #28303d;border-radius:5px;flex:1;min-width:60px;padding:4px 7px;font-size:12px}.inv-search:focus{border-color:var(--accent);outline:none}.inv-hint{color:var(--muted);margin-bottom:6px;font-size:11px}.inv-ctx .context-item{width:100%;color:inherit;font:inherit;text-align:left;background:0 0;border:none;padding:6px 10px;font-size:12px;display:block}.inv-ctx .context-item.drop{color:#d9a3a3}.inv-ctx .context-item.drop:hover{color:#fff;background:#7a3a3a}.skill-list{flex-direction:column;gap:4px;display:flex}.skill-tree-head:first-child{margin-top:0}.skill-row{background:var(--panel-2);border:1px solid #2c3543;border-radius:6px;justify-content:space-between;align-items:flex-start;gap:8px;padding:8px 10px;display:flex}.skill-row:hover{border-color:var(--accent)}.skill-row.skill-child{border-left:2px solid var(--accent-2)}.skill-name-col{flex-wrap:wrap;flex:1;align-items:baseline;gap:1px 6px;min-width:0;display:flex}.skill-name{word-break:break-word;-webkit-line-clamp:2;line-clamp:2;min-width:0;font-size:calc(13px * var(--ui-scale));-webkit-box-orient:vertical;flex:1;display:-webkit-box;overflow:hidden}.skill-lv{color:var(--muted);font-size:calc(12px * var(--ui-scale));flex-shrink:0}.skill-req{color:var(--muted);font-size:calc(10px * var(--ui-scale));flex-basis:100%;line-height:1.2}.skill-passive-tag{font-size:calc(11px * var(--ui-scale));color:var(--muted);white-space:nowrap;background:#ffffff08;border:1px solid #2c3543;border-radius:6px;align-self:center;padding:2px 8px}.win-body.skill-mode-graph{flex-direction:column;gap:8px;min-width:0;height:64vh;max-height:none;padding:8px;display:flex;overflow:hidden}.skill-graph-wrap{flex-direction:column;flex:1;gap:8px;min-width:0;min-height:0;display:flex}.skill-legend{flex-wrap:wrap;gap:6px 12px;padding:2px 2px 0;display:flex}.skill-legend-chip{font-size:calc(11px * var(--ui-scale));color:var(--muted);align-items:center;gap:5px;display:inline-flex}.skill-legend-chip i{border-radius:50%;width:10px;height:10px;display:inline-block}.skill-graph-scroll{background:radial-gradient(circle at 1px 1px, #ffffff09 1px, transparent 0) 0 0 / 22px 22px, var(--panel-2);border:1px solid #232b36;border-radius:8px;flex:1;min-width:0;min-height:0;overflow:auto}.skill-graph{position:relative}.skill-graph-inner{transform-origin:0 0;position:relative}.skill-graph-svg{pointer-events:none;position:absolute;inset:0;overflow:visible}.skill-toolbar{justify-content:space-between;align-items:center;gap:10px;padding:2px 2px 0;display:flex}.skill-points{background:var(--panel-2);border:1px solid #2c3543;border-radius:7px;align-items:center;gap:7px;padding:3px 10px;display:flex}.skill-points-label{font-size:calc(11px * var(--ui-scale));color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.skill-points-val{font-size:calc(14px * var(--ui-scale));color:var(--muted);text-align:center;min-width:1ch;font-weight:700}.skill-points.has-points{border-color:#6fc06a;box-shadow:0 0 0 1px #6fc06a40}.skill-points.has-points .skill-points-val{color:#9fe39a}.skill-zoom{align-items:center;gap:6px;display:flex}.skill-zoom-val{font-size:calc(11px * var(--ui-scale));color:var(--muted);text-align:center;min-width:40px}.skill-zoom-btn{background:var(--panel-2);width:24px;height:24px;color:var(--text);cursor:pointer;border:1px solid #2c3543;border-radius:6px;padding:0;font-size:15px;line-height:1}.skill-zoom-btn:hover:not([disabled]){border-color:var(--accent)}.skill-zoom-btn[disabled]{opacity:.4;cursor:default}.skill-edge{fill:none;stroke-width:2px}.skill-edge-ok{stroke:var(--accent);opacity:.75}.skill-edge-bad{stroke:#b65b54;opacity:.6;stroke-dasharray:5 4}.skill-card{box-sizing:border-box;background:linear-gradient(180deg, var(--panel), var(--panel-2));border:1px solid #2c3543;border-left:3px solid var(--job-accent,#2c3543);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:9px;grid-template-rows:30px auto;grid-template-columns:30px 1fr auto;align-items:center;gap:5px 7px;width:132px;height:78px;padding:8px 9px;transition:border-color .12s,box-shadow .12s,transform 80ms;display:grid;position:absolute;box-shadow:0 2px 6px #00000059}.skill-card:hover{z-index:1;transform:translateY(-1px);box-shadow:0 5px 12px #00000080}.skill-card:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.skill-card-icon{width:30px;height:30px;image-rendering:pixelated;grid-area:1/1}.skill-card-lv{font-size:calc(10px * var(--ui-scale));color:var(--muted);background:#0a0e148c;border-radius:999px;grid-area:1/3;place-self:start end;padding:1px 5px;font-weight:600}.skill-card-name{font-size:calc(11px * var(--ui-scale));max-height:calc(2 * 1.16em * var(--ui-scale));-webkit-line-clamp:2;line-clamp:2;overflow-wrap:anywhere;-webkit-box-orient:vertical;grid-area:2/1/auto/-1;align-self:start;font-weight:600;line-height:1.16;display:-webkit-box;overflow:hidden}.skill-card.skill-learned{border-color:var(--accent)}.skill-card.skill-learnable{border-color:#6fc06a;box-shadow:0 0 0 1px #6fc06a59,0 2px 6px #00000059}.skill-card.skill-locked{opacity:.5;filter:grayscale(.55)}.skill-card.skill-selected{border-color:#ffd479;box-shadow:0 0 0 2px #ffd4798c,0 4px 12px #00000080}.skill-card-flash{animation:.5s ease-out skillCardFlash}@keyframes skillCardFlash{0%{box-shadow:0 0 0 3px #6fc06ad9}to{box-shadow:0 0 #0000}}body.reduce-flashing .skill-card-flash{animation:none}.skill-card-plus{color:#b9f0b3;cursor:pointer;z-index:2;background:#1d2a1d;border:1px solid #6fc06a;border-radius:50%;width:20px;height:20px;padding:0;font-size:13px;line-height:18px;position:absolute;top:-8px;right:-8px}.skill-card-plus:hover{background:#284a28}.skill-card-plus--chain{color:#bcdcfb;background:#1a2636;border-color:#6aa8e0}.skill-card-plus--chain:hover{background:#243a52}.skill-detail{background:var(--panel-2);border:1px solid #2c3543;border-radius:8px;align-items:center;gap:10px;min-height:40px;padding:6px 10px;display:flex}.skill-detail-empty{color:var(--muted);justify-content:center}.skill-detail-hint{font-size:calc(12px * var(--ui-scale));color:var(--muted)}.skill-detail-icon{width:28px;height:28px;image-rendering:pixelated}.skill-detail-title{flex-direction:column;flex:1;min-width:0;display:flex}.skill-detail-name{font-weight:600;font-size:calc(13px * var(--ui-scale));text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.skill-detail-lv{font-size:calc(11px * var(--ui-scale));color:var(--muted)}.skill-detail-acts{flex-shrink:0;align-items:center;gap:6px;display:flex}.skill-detail-note{font-size:calc(11px * var(--ui-scale));color:var(--muted);white-space:nowrap}.skill-req-block{font-size:calc(10px * var(--ui-scale));flex-direction:column;flex-basis:100%;gap:1px;margin-top:2px;line-height:1.25;display:flex}.skill-req-block .skill-req,.skill-req-block .skill-gate{flex-basis:auto}.skill-req-block .skill-gate{color:var(--muted)}.skill-req-have{opacity:.85}.skill-req-ok{color:#7fc08a}.skill-req-bad{color:#d98b8b}.tt-desc{color:var(--muted);font-size:calc(11px * var(--ui-scale));margin:1px 0;line-height:1.3}.skill-tt-icon{vertical-align:middle;border-radius:4px;width:20px;height:20px;margin-right:6px}.npc-win{background:var(--panel);pointer-events:auto;border:1px solid #28303d;border-radius:10px;flex-direction:column;width:460px;max-width:90vw;padding:16px;bottom:90px;left:50%;transform:translate(-50%);box-shadow:0 18px 50px #00000080}.npc-text{white-space:pre-wrap;margin-bottom:12px;line-height:1.4}.npc-controls{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.npc-btn{background:linear-gradient(180deg, var(--accent), var(--accent-2));color:#1a1206;cursor:pointer;border:none;border-radius:6px;align-self:flex-end;padding:7px 18px;font-weight:600}.npc-btn:hover{filter:brightness(1.07)}.npc-menu-item{background:var(--panel-2);border:1px solid #2c3543;border-radius:6px;width:100%;padding:7px 10px}.npc-menu-item:hover{border-color:var(--accent)}.npc-menu-item.cancel{color:var(--muted)}.npc-input{background:var(--panel-2);width:100%;color:var(--text);border:1px solid #2c3543;border-radius:6px;padding:8px 10px}.hotbar{gap:6px;display:flex;bottom:12px;left:50%;transform:translate(-50%)}.hot-slot{width:calc(56px * var(--ui-scale));height:calc(56px * var(--ui-scale));background:linear-gradient(#161c26eb,#0a0e14eb);border:1px solid #2c3543;border-radius:9px;justify-content:center;align-items:flex-end;padding:4px;transition:border-color .12s,box-shadow .12s,transform 80ms;display:flex;position:relative;box-shadow:inset 0 1px #ffffff0a,0 2px 6px #0006}.hot-slot.filled{border-color:var(--accent);box-shadow:inset 0 0 0 1px #d9a44138,0 2px 8px #00000073}.hot-slot:hover{border-color:var(--accent);transform:translateY(-1px)}.hot-key{z-index:2;font-size:calc(10px * var(--ui-scale));color:var(--muted);text-shadow:0 1px 2px #000;font-weight:600;position:absolute;top:2px;left:5px}.hot-name{z-index:2;font-size:calc(11px * var(--ui-scale));color:#eef1f5;text-shadow:0 1px 2px #000;text-overflow:ellipsis;white-space:nowrap;background:#080c1299;border-radius:5px;max-width:84%;padding:1px 4px;font-weight:700;line-height:1;position:absolute;bottom:2px;right:3px;overflow:hidden}.hot-name:empty{display:none}.chat-log{max-height:180px;font-size:calc(12px * var(--ui-scale));pointer-events:auto;padding:2px;overflow-y:auto}.chat-line{word-wrap:break-word;line-height:1.3;font-size:calc(12px * var(--ui-scale));margin:1px 0}.chat-line.public{color:var(--text)}.chat-line.system{color:var(--accent)}.chat-line.whisper{color:#4fd0e0}.chat-line.party{color:#5fd35f}.chat-line.guild{color:#e0913d}.inv-section{color:var(--accent);font-weight:600;font-size:calc(12px * var(--ui-scale));text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #28303d;align-items:center;gap:6px;margin:8px 0 4px;padding-bottom:4px;display:flex}.inv-section:before{content:"";background:linear-gradient(180deg, var(--accent), var(--accent-2));border-radius:2px;flex:none;width:3px;height:12px}.inv-empty{color:var(--muted);padding:2px 0 6px;font-size:12px}.inv-footer{border-top:1px solid #28303d;flex:none;align-items:center;gap:10px;padding-top:8px;display:flex}.inv-weight-bar{background:#0a0e14b3;border:1px solid #2c3543;border-radius:5px;flex:1;height:16px;position:relative;overflow:hidden}.inv-weight-fill{width:0;transition:width .2s;position:absolute;top:0;bottom:0;left:0}.inv-weight-text{color:#eef1f5;text-shadow:0 1px 1px #000;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:flex;position:absolute;inset:0}.inv-zeny{color:#ffe066;white-space:nowrap;text-shadow:0 1px 1px #000;flex:none;font-size:12px;font-weight:700}.inv-row{justify-content:space-between;align-items:center;gap:8px;padding:4px 0;display:flex}.inv-row-name{font-size:calc(12px * var(--ui-scale));text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.inv-row-name--stacked{white-space:normal;flex-direction:column;gap:1px;display:flex;overflow:visible}.inv-row-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.inv-row-opts{font-size:calc(10px * var(--ui-scale));opacity:.85;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;overflow:hidden}.inv-row-acts{flex-shrink:0;gap:4px;display:flex}.inv-act{pointer-events:auto;cursor:pointer;background:var(--panel-2);border:1px solid var(--accent);color:var(--accent);border-radius:5px;padding:3px 8px;font-size:11px}.inv-act:hover{background:var(--accent);color:#1a1206}.inv-act.drop{color:#a98;border-color:#5a4453}.inv-act.drop:hover{color:#fff;background:#7a3a3a;border-color:#7a3a3a}.target-panel{pointer-events:none;background:#0a0e14d1;border:1px solid #28303d;border-radius:8px;flex-direction:column;align-items:center;gap:4px;min-width:160px;padding:6px 14px;top:50px;left:50%;transform:translate(-50%)}.target-name{font-weight:700;font-size:calc(14px * var(--ui-scale));text-shadow:0 1px 2px #000}.target-hp{width:100%;height:calc(16px * var(--ui-scale));background:#2a1316;border:1px solid #3a4453;border-radius:4px;min-height:16px;transition:border-color .12s;position:relative;overflow:hidden}.target-hp-fill{z-index:1;background:linear-gradient(90deg,#c0392b,#e0533d);width:100%;height:100%;transition:width .15s,background .15s;position:relative}.target-hp-fill.target-hp-ghost{z-index:0;background:linear-gradient(90deg,#7a1f17,#a3392f);transition:width .4s ease-out;position:absolute;top:0;left:0}body.reduce-flashing .target-hp-fill.target-hp-ghost{transition:none}.target-hp-fill.execute{background:linear-gradient(90deg,#e0b020,#f5853a)}.target-hp-text{z-index:2;text-align:center;font-size:calc(11px * var(--ui-scale));line-height:calc(16px * var(--ui-scale));color:#fff;text-shadow:0 1px 1px #000;white-space:nowrap;text-overflow:ellipsis;padding:0 calc(30px * var(--ui-scale));pointer-events:none;position:absolute;inset:0;overflow:hidden}.target-panel.unit-frame{background:#080b10e0;border:1px solid #28303d;border-radius:9px;flex-direction:row;align-items:flex-start;gap:8px;min-width:240px;max-width:300px;padding:7px 9px;box-shadow:0 4px 14px #00000073}.target-portrait{width:calc(54px * var(--ui-scale));height:calc(54px * var(--ui-scale));font:700 calc(20px * var(--ui-scale))/1 "Segoe UI", sans-serif;color:#9aa7b5;background:#0c1016 50%/cover no-repeat;border:1px solid #3a4453;border-radius:7px;flex:none;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.target-portrait>canvas.tgt-3d{width:100%;height:100%;display:none;position:absolute;inset:0}.target-portrait.has-3d>canvas.tgt-3d{display:block}.target-portrait.has-3d{background-image:none!important}.target-portrait.has-3d .target-portrait-initial{display:none}.target-portrait.elite{border-color:#ffb030;box-shadow:0 0 6px #ffb03073}.target-portrait.mvp{border-color:#ffd54a;animation:2.4s ease-in-out infinite tgt-mvp-breath;box-shadow:0 0 8px #ffd54a8c}@keyframes tgt-mvp-breath{0%,to{box-shadow:0 0 6px #ffd54a66}50%{box-shadow:0 0 12px 2px #ffd54ab3}}.target-size-pip{font:700 calc(9px * var(--ui-scale))/1 monospace;color:#dfe3ea;background:#0009;border-radius:3px;padding:1px 3px;position:absolute;top:1px;left:1px}.target-weak{background:#000000a8;border-top-left-radius:5px;align-items:center;gap:1px;padding:1px 2px;display:flex;position:absolute;bottom:0;right:0}.target-weak-glyph{width:calc(13px * var(--ui-scale));height:calc(13px * var(--ui-scale));display:block}.target-weak-chev{font:700 calc(9px * var(--ui-scale))/1 monospace;color:#fff}.target-body{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.target-head{justify-content:space-between;align-items:baseline;gap:6px;display:flex}.unit-frame .target-name{font-weight:700;font-size:calc(14px * var(--ui-scale));text-shadow:0 1px 2px #000;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.target-dist{font-size:calc(11px * var(--ui-scale));color:#9aa7b5;font-variant-numeric:tabular-nums;white-space:nowrap;flex:none;transition:color .12s}.target-dist.oor{color:var(--danger,#e0533d)}.target-class{flex-wrap:wrap;gap:4px;display:flex}.tgt-class-chip{font-size:calc(10px * var(--ui-scale));color:#cdd3dd;background:#ffffff0a;border:1px solid #3a4453;border-radius:7px;align-items:center;gap:3px;padding:0 5px 0 3px;line-height:1.4;display:inline-flex}.tgt-class-chip img{width:12px;height:12px;display:block}.tgt-class-chip.elem{color:var(--elem-color,#cdd3dd)}.target-hp-pct{z-index:3;line-height:calc(16px * var(--ui-scale));font:700 calc(10px * var(--ui-scale))/calc(16px * var(--ui-scale)) "Segoe UI", sans-serif;color:#fff;text-shadow:0 1px 1px #000;font-variant-numeric:tabular-nums;position:absolute;top:0;right:5px}.target-cast{width:100%;height:calc(13px * var(--ui-scale));background:#2a2410;border:1px solid #5a4a20;border-radius:4px;min-height:13px;margin-top:2px;position:relative;overflow:hidden}.target-cast-fill{background:linear-gradient(90deg,#e0b020,#f5d35a);width:100%;height:100%;transition:width 60ms linear}.target-cast-label{z-index:2;text-align:center;font:700 calc(10px * var(--ui-scale))/calc(13px * var(--ui-scale)) "Segoe UI", sans-serif;color:#fff;text-shadow:0 1px 1px #000;pointer-events:none;white-space:nowrap;text-overflow:ellipsis;padding:0 5px;position:absolute;inset:0;overflow:hidden}.target-cast.interrupted{border-color:#ff6b6b}.target-cast.interrupted .target-cast-fill{background:#ff6b6b}.target-cast.interrupted .target-cast-label{color:#ff6b6b}.target-status{justify-content:flex-start}@media (prefers-reduced-motion:reduce){.target-portrait.mvp{animation:none;box-shadow:0 0 8px #ffd54a8c}}body.reduce-flashing .target-portrait.mvp{animation:none;box-shadow:0 0 8px #ffd54a8c}body.high-contrast .tgt-class-chip{color:#fff;border-width:2px}.hot-slot.flash{animation:.6s ease-out hotflash}@keyframes hotflash{0%{box-shadow:0 0 0 3px var(--accent)}to{box-shadow:0 0 #0000}}.hot-slot.ready{animation:.5s ease-out hotready}@keyframes hotready{0%{box-shadow:0 0 0 3px var(--accent-2,#5fd38a)}to{box-shadow:0 0 #0000}}.context-menu{z-index:200;pointer-events:auto;background:#0c1018f7;border:1px solid #3a4453;border-radius:7px;flex-direction:column;min-width:130px;padding:4px;display:flex;position:fixed;box-shadow:0 8px 24px #00000080}.context-title{color:var(--accent);border-bottom:1px solid #28303d;padding:4px 8px 6px;font-size:12px;font-weight:700}.context-item{text-align:left;width:100%;font-size:calc(13px * var(--ui-scale));cursor:pointer;border-radius:5px;padding:7px 10px}.context-item:hover{background:var(--accent);color:#1a1206}.status-tray{top:calc(244px * var(--ui-scale));left:calc(324px * var(--ui-scale));max-width:calc(220px * var(--ui-scale));flex-wrap:wrap;gap:4px;display:flex}.status-icon{width:calc(40px * var(--ui-scale));height:calc(40px * var(--ui-scale));border:1px solid var(--accent-2);pointer-events:auto;cursor:default;--frac:1;background:#0a0e14e6;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative}.status-icon.timed:before{content:"";border-radius:inherit;z-index:0;pointer-events:none;background:conic-gradient(var(--ring,#ffffff29) calc(var(--frac) * 360deg), transparent 0);position:absolute;inset:0;-webkit-mask:radial-gradient(circle,#0000 58%,#000 60%);mask:radial-gradient(circle,#0000 58%,#000 60%)}.status-icon.timed.buff{--ring:#6fd06a8c}.status-icon.timed.debuff{--ring:#e0533d99}.status-icon .status-abbr,.status-icon .status-time{z-index:1;position:relative}.status-abbr{font-size:calc(11px * var(--ui-scale));color:var(--accent);font-weight:700}.status-time{font-size:calc(9px * var(--ui-scale));color:var(--muted)}.status-icon.arted{cursor:help;background-position:50%;background-repeat:no-repeat;background-size:cover;justify-content:flex-end}.status-icon.arted .status-time{text-align:center;color:#fff;text-shadow:0 1px 2px #000;background:linear-gradient(#0000,#000c);border-radius:0 0 5px 5px;width:100%;font-weight:700;line-height:1.6}.status-icon.arted .status-time:empty{background:0 0}.tgt-status-chip{width:calc(20px * var(--ui-scale));height:calc(20px * var(--ui-scale));pointer-events:auto;background-position:50%;background-repeat:no-repeat;background-size:cover;border:1px solid #4f9d4f;border-radius:4px}.tgt-status-chip.debuff{border-color:var(--danger)}.status-icon.buff{border-color:#4f9d4f}.status-icon.buff .status-abbr{color:#6fd06a}.status-icon.debuff{border-color:var(--danger);animation:1.1s ease-in-out infinite debuff-pulse}.status-icon.debuff .status-abbr{color:#ff8a76}.status-icon.status-overflow{border-style:dashed;border-color:var(--accent-2);cursor:help}.status-icon.status-overflow .status-abbr{color:var(--muted)}@keyframes debuff-pulse{0%,to{box-shadow:0 0 #e0533d00}50%{box-shadow:0 0 7px 1px #e0533db3}}@supports not (background:conic-gradient(#000 0deg, #000 0)){.status-icon.timed:before{height:3px;width:calc(var(--frac) * 100%);background:var(--ring,#ffffff4d);border-radius:0 0 6px 6px;inset:auto 0 0;-webkit-mask:none;mask:none}}@media (prefers-reduced-motion:reduce){.status-icon.debuff{animation:none;box-shadow:0 0 6px 1px #e0533d99}.status-icon.timed:before{transition:none}}.item-tooltip{z-index:210;pointer-events:none;background:#080c12f7;border:1px solid #3a4453;border-radius:7px;min-width:150px;max-width:210px;padding:8px 10px;position:fixed;box-shadow:0 8px 24px #0000008c}.tt-name{font-weight:700;font-size:calc(13px * var(--ui-scale));margin-bottom:4px}.tt-line{font-size:calc(11px * var(--ui-scale));color:#b8c0cc;margin:1px 0}.tt-on{color:var(--accent)}.tt-id{color:var(--muted);margin-top:4px;font-size:10px}.tt-rowlabel{font-size:calc(10px * var(--ui-scale));text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:6px 0 3px}.tt-stats{gap:3px calc(10px * var(--ui-scale));grid-template-columns:auto 1fr;display:grid}.tt-amt{color:var(--accent);font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap;font-weight:700}.tt-eff{color:#cdd3dd;font-size:calc(11px * var(--ui-scale))}.info-bar{z-index:18;pointer-events:none;color:#8a93a3;text-shadow:0 1px 2px #000;background:#0a0e1480;border-radius:5px;padding:2px 8px;font-size:11px;position:fixed;bottom:8px;right:12px}.toast-layer{z-index:36;pointer-events:none;flex-direction:column;align-items:center;gap:6px;display:flex;position:fixed;top:120px;left:50%;transform:translate(-50%)}.toast{text-shadow:0 1px 2px #000;opacity:0;background:#0a0e14eb;border:1px solid #3a4453;border-radius:8px;padding:8px 18px;font-size:14px;font-weight:600;transition:opacity .3s,transform .3s;transform:translateY(-8px)}.toast.show{opacity:1;transform:translateY(0)}.toast-levelup{color:#ffe066;border-color:var(--accent)}.toast-item{color:#9be07a;border-color:#4f7d3d}.toast-info{color:#cdd3dd}.chat-name{color:#9fd3ff;cursor:pointer;pointer-events:auto;font-weight:600}.chat-name:hover{text-decoration:underline}.chat-log{pointer-events:auto;overflow-y:auto}.map-banner{z-index:30;pointer-events:none;letter-spacing:1px;color:#fff;text-shadow:0 2px 10px #000,0 0 24px #d9a44180;opacity:0;font-size:34px;font-weight:800;transition:opacity .6s,transform .6s;position:fixed;top:28%;left:50%;transform:translate(-50%,-50%)scale(.9)}.map-banner.show{opacity:1;transform:translate(-50%,-50%)scale(1)}.window{pointer-events:auto}.win-head{-webkit-user-select:none;user-select:none}.hot-slot{position:relative;overflow:hidden}.hot-cd{color:#fff;text-shadow:0 1px 2px #000;pointer-events:none;background:#0a0e14b8;justify-content:center;align-items:center;width:100%;font-size:13px;font-weight:700;display:flex;position:absolute;bottom:0;left:0}.weight-row{height:calc(16px * var(--ui-scale));background:#1a2028;border:1px solid #28303d;border-radius:4px;min-width:0;margin-top:0;position:relative;overflow:hidden}.weight-fill{background:#4f9d4f;height:100%;transition:width .2s,background .2s;position:absolute;top:0;left:0}.weight-text{text-align:center;font-size:calc(10px * var(--ui-scale));line-height:calc(16px * var(--ui-scale));color:#fff;text-shadow:0 1px 1px #000;position:absolute;inset:0}.map-transition{z-index:44;pointer-events:none;opacity:0;background:#05070b;transition:opacity .28s;position:fixed;inset:0}.map-transition.show{opacity:1;pointer-events:auto}.safe-compass{z-index:17;pointer-events:none;text-align:center;position:fixed;top:96px;left:50%;transform:translate(-50%)}.safe-arrow{color:#7fd0ff;text-shadow:0 0 8px #7fd0ffcc,0 2px 3px #000;font-size:30px;line-height:1}.safe-dist{color:#cfe6ff;text-shadow:0 1px 2px #000;margin-top:2px;font-size:11px}.threat-chevron{z-index:18;pointer-events:none;color:#ff5a4a;text-shadow:0 0 10px #ff5a4ae6,0 2px 4px #000;opacity:0;font-size:34px;line-height:1;position:fixed}.threat-chevron.show{animation:1s ease-out threat-flash}@keyframes threat-flash{0%{opacity:0}12%{opacity:1}60%{opacity:.9}to{opacity:0}}body.reduce-flashing .threat-chevron.show{opacity:.85;animation:none}.menu-select{color:#e6e6e6;width:100%;font-size:calc(12px * var(--ui-scale));cursor:pointer;background:#0a0e14cc;border:1px solid #28303d;border-radius:6px;padding:6px 8px}.menu-select:hover{border-color:var(--accent)}.inv-icon{image-rendering:auto;border-radius:5px;flex-shrink:0}.inv-row{align-items:center;gap:8px}.paperdoll{background:radial-gradient(120% 90% at 50% 0,#242e3e80,#080c1280);border:1px solid #2c3543;border-radius:8px;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;margin-bottom:2px;padding:10px;display:grid}.pd-col{flex-direction:column;gap:6px;display:flex}.pd-slot{text-align:center;cursor:pointer;background:linear-gradient(160deg,#161c26e6,#0c1016e6);border:1px solid #2c3543;border-radius:6px;justify-content:center;align-items:center;width:44px;height:44px;transition:border-color .12s,box-shadow .12s;display:flex;position:relative}.pd-slot.pd-filled{border-color:var(--accent);background:linear-gradient(160deg,#1e2a3a,#16202c)}.pd-slot:not(.pd-filled){cursor:default}.pd-slot:not(.pd-filled):hover{border-color:#3a4555}.pd-slot.pd-filled:hover{box-shadow:0 0 0 1px var(--accent) inset, 0 0 10px #508cc840}.pd-label{color:var(--muted);overflow-wrap:anywhere;padding:0 2px;font-size:9px;line-height:1.15}.pd-figure{justify-content:center;align-self:stretch;align-items:center;min-width:64px;display:flex}.pd-figure svg{fill:#46566a;filter:drop-shadow(0 3px 6px #0006);width:80%;max-width:84px;height:auto}.pd-refine{z-index:1;color:#ffe066;text-shadow:0 1px 1px #000;font-size:10px;font-weight:700;line-height:1;position:absolute;top:1px;left:2px}.inv-draggable{cursor:grab}.inv-draggable:active{cursor:grabbing}.pd-slot.pd-drop{border-color:#6fd06a;box-shadow:inset 0 0 0 2px #6fd06a80}:focus-visible{outline-offset:2px;outline:2px solid #7fd0ff}button:focus-visible,.menu-btn:focus-visible,.hot-slot:focus-visible,.inv-act:focus-visible{outline-offset:1px;outline:2px solid #7fd0ff}@media (prefers-reduced-motion:reduce){.toast,.map-banner,.map-transition,.target-hp-fill,.target-hp,.target-dist,.weight-fill,.menu-btn{transition:none!important}}.announce-bar{z-index:38;pointer-events:none;text-align:center;color:#ffe9a8;text-shadow:0 1px 2px #000;background:linear-gradient(90deg,#3c280a00 0%,#50370ceb 20% 80%,#3c280a00 100%);padding:7px 16px;font-size:13px;font-weight:600;transition:transform .35s;position:fixed;top:0;left:0;right:0;transform:translateY(-110%)}.announce-bar.show{transform:translateY(0)}#game-canvas{touch-action:none}@media (max-width:820px),(pointer:coarse){.hot-slot{width:52px;height:52px}.menu-btn{width:40px;height:40px}.menu-glyph{width:22px;height:22px}.inv-act{padding:8px 12px}.window{max-width:94vw}.chat-wrap{width:64vw}.status-tray{max-width:60vw}.target-panel.unit-frame{min-width:200px;max-width:78vw}}@media (max-width:560px){.info-bar{font-size:9px}.menu-buttons{transform:scale(.92)}.target-class{display:none}}.chat-wrap{z-index:19;pointer-events:auto;background:#0a0e14c7;border:1px solid #28303d;border-radius:8px;flex-direction:column;width:360px;max-width:92vw;padding:6px;display:flex;position:fixed;bottom:12px;left:12px;box-shadow:0 8px 24px #0006}.chat-tabs{pointer-events:auto;gap:3px;margin-bottom:4px;display:flex}.chat-tab{cursor:pointer;color:var(--muted);background:#0a0e14b3;border:1px solid #28303d;border-radius:5px;padding:3px 9px;font-size:11px}.chat-tab.active{color:var(--accent);border-color:var(--accent);background:#141c26f2}.chat-tab{align-items:center;gap:5px;display:inline-flex;position:relative}.chat-badge{text-align:center;color:#1a1206;background:linear-gradient(180deg, var(--accent), var(--accent-2));border-radius:9px;min-width:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:15px}.chat-ts-toggle{margin-left:auto;padding:3px 7px}.chat-log{max-height:150px;overflow-y:auto}.chat-new-msgs{cursor:pointer;color:#1a1206;pointer-events:auto;background:linear-gradient(180deg, var(--accent), var(--accent-2));border:none;border-radius:10px;align-self:center;margin-top:3px;padding:2px 12px;font-size:11px;font-weight:600;box-shadow:0 2px 6px #0006}.chat-new-msgs:hover{filter:brightness(1.08)}.chat-input{box-sizing:border-box;color:#e6e6e6;width:100%;font-size:calc(12px * var(--ui-scale));background:#0a0e14d9;border:1px solid #28303d;border-radius:6px;margin-top:5px;padding:7px 9px}.chat-input:focus{border-color:var(--accent);outline:none}.chat-line.channel{color:var(--accent-2)}.chat-line.server{color:#8fd6ff}.chat-line.announce{color:var(--accent);font-weight:600}.chat-line.error{color:#ff7a7a}.chat-line.emote{color:#c9a0ff;font-style:italic}.chat-source{color:#c9ecff;text-transform:uppercase;background:#419ddc2e;border:1px solid #8fd6ff73;border-radius:4px;margin-right:4px;padding:0 4px;font-size:.85em;font-weight:700;line-height:1.25;display:inline-block}.chat-time{color:var(--muted);opacity:.8;font-size:.85em}.qd-overlay{z-index:220;background:#080a108c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.qd-panel{width:320px}.qd-field{margin:14px 0 18px}.qd-field input[type=number]{background:var(--panel-2);width:100%;color:var(--text);border:1px solid #2c3543;border-radius:8px;padding:9px 12px;font-size:14px}.qd-field input[type=number]:focus{border-color:var(--accent);outline:none}.qd-slider{width:100%;accent-color:var(--accent);margin-top:10px}.qd-actions{gap:8px;display:flex}.qd-actions .primary{flex:1}.qd-cancel{background:var(--panel-2);color:var(--text);cursor:pointer;border:1px solid #2c3543;border-radius:8px;flex:1;padding:11px;font-size:15px;font-weight:600}.qd-cancel:hover{border-color:var(--accent)}.qd-ok.qd-danger{color:#fff;background:linear-gradient(#e0533d,#b3382a)}.bar-fill.hp.critical{animation:.7s ease-in-out infinite hp-pulse}@keyframes hp-pulse{0%,to{filter:brightness();background:linear-gradient(90deg,#c0392b,#e0533d)}50%{filter:brightness(1.5);background:linear-gradient(90deg,#ff5a44,#ff8a76)}}.bar-fill.sp.critical{animation:.7s ease-in-out infinite sp-pulse}@keyframes sp-pulse{0%,to{filter:brightness();background:linear-gradient(90deg,#2471a3,#3498db)}50%{filter:brightness(1.5);background:linear-gradient(90deg,#4aa3ff,#8fd0ff)}}.status-panel.critical{border-color:var(--danger)}.crit-vignette{z-index:9;pointer-events:none;opacity:0;transition:opacity .3s;position:fixed;inset:0;box-shadow:inset 0 0 110px 30px #e0352d8c}.crit-vignette.show{opacity:1;animation:1.4s ease-in-out infinite vignette-pulse}@keyframes vignette-pulse{0%,to{opacity:.55}50%{opacity:1}}@media (prefers-reduced-motion:reduce){.bar-fill.hp.critical,.bar-fill.sp.critical,.crit-vignette.show{animation:none}}body.reduce-flashing .bar-fill.hp.critical,body.reduce-flashing .bar-fill.sp.critical,body.reduce-flashing .crit-vignette.show,body.reduce-flashing .status-icon.debuff{animation:none}body.reduce-motion .toast,body.reduce-motion .map-banner,body.reduce-motion .map-transition,body.reduce-motion .target-hp-fill,body.reduce-motion .target-hp,body.reduce-motion .target-dist,body.reduce-motion .weight-fill,body.reduce-motion .announce-bar,body.reduce-flashing .target-hp,body.reduce-flashing .target-dist{transition:none!important}body.reduce-motion .bar-fill.hp.critical,body.reduce-motion .bar-fill.sp.critical,body.reduce-motion .crit-vignette.show,body.reduce-motion .status-icon.debuff,body.reduce-motion .threat-chevron.show{animation:none}body.reduce-motion .status-icon.timed:before{transition:none}.ground-prompt{z-index:40;pointer-events:none;color:#cdecff;text-shadow:0 1px 2px #000;background:#142846eb;border:1px solid #6fc3ff;border-radius:8px;padding:9px 20px;font-size:15px;font-weight:700;position:fixed;top:130px;left:50%;transform:translate(-50%);box-shadow:0 0 16px #6fc3ff80}body.high-contrast{--muted:#d2d8e2;--text:#fff;--danger:#ff5a44}body.high-contrast .status-panel,body.high-contrast .target-panel,body.high-contrast .menu-buttons,body.high-contrast .menu-btn,body.high-contrast .panel-box,body.high-contrast .hot-slot,body.high-contrast .chat-log,body.high-contrast .chat-tab,body.high-contrast .npc-win{background:#0a0e14!important;border-color:#6f7d92!important}body.high-contrast .window{background:#0a0e14;border-color:#6f7d92}body.high-contrast .win-head{border-bottom-color:#6f7d92}body.high-contrast .overlay,body.high-contrast .window,body.high-contrast .hud-name{text-shadow:0 1px 2px #000,0 0 1px #000}body.high-contrast .bar-fill.hp{background:#ff4d3d}body.high-contrast .bar-fill.sp{background:#3fa9ff}body.high-contrast .bar-fill.exp.base-exp{background:#ffd21a}body.high-contrast .bar-fill.exp.job-exp{background:#d7a8ff}body.high-contrast .status-panel .bar{background:#000;border:1px solid #6f7d92}body.high-contrast .inv-search{background:#0a0e14!important;border-color:#6f7d92!important}.window.win-party,.window.win-friends,.window.win-guild{width:240px;top:60px;left:auto;transform:none}.window.win-party{right:12px}.window.win-friends{top:96px;right:24px}.window.win-guild{width:380px;max-width:92vw;top:132px;right:36px}.win-party .win-body,.win-friends .win-body,.win-guild .win-body{flex-direction:column;gap:8px;max-height:72vh;display:flex}.win-party input,.win-friends input,.win-guild input{box-sizing:border-box}.win-party button.primary,.win-friends button.primary,.win-guild button.primary{background:linear-gradient(180deg, var(--accent), var(--accent-2));border-radius:6px;width:auto;padding:5px 12px;font-size:12px}.social-leave{cursor:pointer;background:var(--panel-2);color:#d9a3a3;border:1px solid #5a4453;border-radius:6px;align-self:flex-start;padding:4px 12px;font-size:12px}.social-leave:hover{color:#fff;background:#7a3a3a;border-color:#7a3a3a}.social-leave.sw-danger{color:#f0a8a8;border-color:#6e3030}.sw-tabs{border-bottom:1px solid #2c3543;gap:2px;margin-bottom:8px;display:flex}.sw-tab{color:var(--muted);letter-spacing:.3px;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:6px 8px;font-size:12px;font-weight:600;transition:color .12s,border-color .12s,background-color .12s}.sw-tab:hover{color:var(--text);background:#d9a44114}.sw-tab[aria-selected=true]{color:var(--accent);border-bottom-color:var(--accent)}.sw-card{background:linear-gradient(#20283699,#141a2499);border:1px solid #2c3543;border-radius:8px;flex-direction:column;gap:7px;padding:10px 12px;display:flex;box-shadow:inset 0 1px #ffffff0a}.sw-stat{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.sw-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.sw-stat-val{color:var(--text);font-size:12px;font-weight:600}.sw-bar{background:#10151d;border-radius:6px;height:11px;position:relative;overflow:hidden;box-shadow:inset 0 1px 2px #0000008c}.sw-bar-fill{background:linear-gradient(180deg, var(--accent), var(--accent-2));border-radius:6px;height:100%;transition:width .3s;position:relative;box-shadow:0 0 8px #d9a44166}.sw-bar-fill:after{content:"";background:linear-gradient(#ffffff38,#0000);border-radius:6px 6px 0 0;position:absolute;inset:0 0 50%}.sw-bar-label{color:#fff;text-shadow:0 1px 1px #000;justify-content:center;align-items:center;font-size:9px;font-weight:700;display:flex;position:absolute;inset:0}.sw-dot{border-radius:50%;flex:none;width:8px;height:8px}.sw-dot.on{background:#5fd35f;box-shadow:0 0 6px #5fd35fd9}.sw-dot.off{background:#46505f}.sw-row{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:5px 6px;transition:background-color .1s;display:flex}.sw-row:hover{background:#d9a4411a}.sw-row:focus-visible{outline-offset:-2px;outline:2px solid #7fd0ff}.sw-row.off{opacity:.55}.sw-id{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sw-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.sw-sub{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.sw-rolechip{color:#0c0f15;border-radius:6px;flex:none;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:800;display:flex;box-shadow:inset 0 0 0 1px #ffffff26}.sw-badge{color:var(--accent);white-space:nowrap;background:#d9a4412e;border:1px solid #d9a44159;border-radius:999px;padding:1px 6px;font-size:9px;font-weight:700}.sw-badge.lead{background:#d9a44147}.sw-section{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);align-items:center;gap:6px;margin:6px 0 3px;font-size:10px;display:flex}.sw-section:after{content:"";background:linear-gradient(90deg,#2c3543,#0000);flex:1;height:1px}.sw-skill{background:linear-gradient(#1c243080,#12182080);border:1px solid #2c3543;border-radius:8px;align-items:center;gap:9px;padding:7px;display:flex}.sw-skill img{background:#10151d;border-radius:6px;flex:none;width:30px;height:30px}.sw-skill-lv{color:var(--accent);flex:none;margin-left:auto;font-size:11px;font-weight:700}.sw-skill.maxed .sw-skill-lv{color:#5fd35f}.sw-sortbar{gap:4px;margin:2px 0 6px;display:flex}.sw-sort{cursor:pointer;color:var(--muted);background:0 0;border:1px solid #2c3543;border-radius:999px;padding:2px 8px;font-size:10px}.sw-sort:hover{border-color:var(--accent);color:var(--text)}.sw-sort[aria-pressed=true]{border-color:var(--accent);color:var(--accent);background:#d9a44129}.sw-icon-btn{color:var(--muted);cursor:pointer;background:0 0;border:1px solid #2c3543;border-radius:5px;flex:none;padding:2px 8px;font-size:11px}.sw-icon-btn:hover{border-color:var(--accent);color:var(--accent)}.gw-guildhead{border-bottom:1px solid #2c3543;align-items:center;gap:12px;margin-bottom:4px;padding:2px 2px 10px;display:flex}.gw-crest{width:48px;height:48px;color:var(--accent);text-shadow:0 1px 2px #0009;background:radial-gradient(circle at 30% 25%,#d9a4414d,#141a24eb);border:1px solid #d9a44173;border-radius:12px;flex:none;justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0d,0 2px 8px #00000073}.gw-crest-img{object-fit:cover;border-radius:inherit;width:100%;height:100%;position:absolute;inset:0}.gw-crest.editable{cursor:pointer}.gw-crest.editable:hover{border-color:var(--accent);box-shadow:inset 0 0 0 1px #ffffff0d,0 0 10px #d9a44159}.gw-crest-file{display:none}.gw-crest-edit{z-index:2;pointer-events:none;background:var(--accent);color:#1a1206;opacity:.95;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;line-height:16px;transition:transform .12s;display:flex;position:absolute;bottom:-2px;right:-2px;box-shadow:0 1px 3px #0009}.gw-crest.editable:hover .gw-crest-edit{transform:scale(1.12)}.gw-crest.uploading{opacity:.55}.gw-crest.uploading:after{content:"…";z-index:2;color:var(--accent);background:#141a2499;justify-content:center;align-items:center;font-size:20px;display:flex;position:absolute;inset:0}.gw-guildhead-text{flex-direction:column;gap:2px;min-width:0;display:flex}.gw-guildname{color:var(--text);letter-spacing:.3px;text-overflow:ellipsis;white-space:nowrap;font-size:16px;font-weight:700;overflow:hidden}.gw-guildsub{color:var(--muted);font-size:11px}.unit-tooltip{z-index:90;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(#161c26f7,#0f141cf7);border:1px solid #d9a44166;border-radius:9px;align-items:center;gap:9px;max-width:260px;padding:8px 11px;display:none;position:fixed;box-shadow:0 6px 20px #0000008c}.unit-tooltip .ut-crest{width:34px;height:34px;color:var(--accent);background:radial-gradient(circle at 30% 25%,#d9a44147,#141a24eb) 50%/cover;border:1px solid #d9a44173;border-radius:8px;flex:none;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.unit-tooltip .ut-crest.has-img{color:#0000}.unit-tooltip .ut-text{flex-direction:column;gap:1px;min-width:0;display:flex}.unit-tooltip .ut-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700;overflow:hidden}.unit-tooltip .ut-job{color:var(--muted);font-size:11px}.unit-tooltip .ut-guild{color:#d9a441;text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.gw-skilltree{flex-direction:column;gap:6px;margin-bottom:2px;display:flex}.gw-node{position:relative}.gw-node.gw-learned{background:linear-gradient(#2822148c,#16181e8c);border-color:#d9a44180}.gw-node.gw-locked{opacity:.5;filter:grayscale(.65)}.gw-node.gw-locked img{filter:grayscale()}.gw-node.gw-info{border-style:dashed}.gw-plus{text-align:center;min-width:22px;margin-left:6px;font-weight:800;line-height:1}.menu-root,.menu-overlay,.menu-toast{--line:#28303d;--line-strong:#3a4453;--panel-3:#232e3e;--ink:#1a1206;--text-2:#b9c0cc;--success:#5bbf7a;--glass:#141a24b8;--glass-2:#1c25338c;--glass-hi:#263143b3;--blur:12px;--accent-soft:#d9a44124;--accent-line:#d9a4418c;--danger-soft:#e0533d24;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-pill:999px;--s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;--elev-1:0 2px 8px #00000059;--elev-2:0 18px 50px #0000008c;--elev-3:0 30px 80px #000000a6;--elev-hero:0 24px 70px #0009, 0 0 0 1px var(--accent-line), 0 0 40px -8px #d9a44140;--inset-top:inset 0 1px 0 #ffffff0a;--dur-fast:.12s;--dur:.17s;--dur-slow:.24s;--ease:cubic-bezier(.2, .8, .2, 1);--ease-in:cubic-bezier(.4, 0, 1, 1);--focus-ring:0 0 0 2px var(--bg), 0 0 0 4px var(--accent);--panel-w:400px;--hero-w:460px;--rail-w:248px;--stage-max:960px}.menu-root{width:100%;height:100%;padding:var(--s5);justify-content:center;align-items:center;display:flex;position:relative;overflow:auto}.menu-root>*{z-index:1;position:relative}.menu-sr{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.menu-bg{z-index:0;pointer-events:none;background:radial-gradient(120% 80% at 50% -10%, #16203a 0%, #0c1018 45%, var(--bg) 75%);position:fixed;inset:0;overflow:hidden}.menu-bg:after{content:"";background:radial-gradient(120% 100% at 50% 40%,#0000 55%,#0000008c 100%);position:absolute;inset:0}.menu-aurora{filter:blur(60px);opacity:.5;will-change:transform;background:radial-gradient(40% 30% at 30% 25%,#40789673,#0000 70%),radial-gradient(45% 35% at 70% 20%,#7864a059,#0000 70%),radial-gradient(35% 25% at 55% 15%,#d9a4411a,#0000 70%);animation:48s ease-in-out infinite alternate menu-aurora-drift;position:absolute;inset:-20%}.menu-aurora.menu-aurora--b{opacity:.32;filter:blur(80px);animation-duration:67s;animation-direction:alternate-reverse}@keyframes menu-aurora-drift{0%{transform:translate(-3%)scale(1.05)}to{transform:translate(3%,2%)scale(1.12)}}.menu-particles{width:100%;height:100%;position:absolute;inset:0}.menu-panel{background:var(--glass);-webkit-backdrop-filter:blur(var(--blur)) saturate(120%);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--elev-2), var(--inset-top);color:var(--text);animation:menu-surface-in var(--dur) var(--ease) both;padding:clamp(24px,3vw,32px);position:relative}@supports not ((-webkit-backdrop-filter:blur(1px)) or (backdrop-filter:blur(1px))){.menu-panel,.menu-overlay__card,.menu-toast{background:var(--panel)}}.menu-panel:before{content:"";border-radius:var(--r-lg) var(--r-lg) 0 0;background:linear-gradient(90deg, transparent, var(--accent), transparent);opacity:.7;height:2px;position:absolute;inset:0 0 auto}.menu-panel.is-danger:before{background:linear-gradient(90deg, transparent, var(--danger), transparent)}.menu-panel__title{font:700 calc(20px * var(--ui-scale)) / 1.2 inherit;letter-spacing:.3px;margin:0}.menu-panel__sub{color:var(--muted);font-size:calc(12px * var(--ui-scale));margin:var(--s1) 0 var(--s5)}.menu-panel__body{gap:var(--s4);flex-direction:column;display:flex}.menu-panel__actions{gap:var(--s3);margin-top:var(--s2);display:flex}@keyframes menu-surface-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.menu-button{border-radius:var(--r-sm);font:600 calc(14px * var(--ui-scale)) / 1 inherit;white-space:nowrap;cursor:pointer;color:var(--text);background:var(--glass-2);transition:background var(--dur), box-shadow var(--dur), border-color var(--dur), filter var(--dur), transform var(--dur-fast);border:1px solid #0000;padding:11px 16px;position:relative}.menu-button:active{transform:translateY(1px)scale(.99)}.menu-button:focus-visible{box-shadow:var(--focus-ring);outline:none}.menu-button[disabled],.menu-button[aria-disabled=true]{opacity:.45;cursor:not-allowed;pointer-events:none}.menu-button--primary{background:linear-gradient(180deg, var(--accent), var(--accent-2));color:var(--ink);border-color:#0000;font-weight:700}.menu-button--primary:hover{filter:brightness(1.07)}.menu-button--block{width:100%}.menu-button--ghost{border-color:var(--line);color:var(--text);background:0 0}.menu-button--ghost:hover{background:var(--panel-3);border-color:var(--line-strong)}.menu-button--danger{color:var(--danger);background:0 0;border-color:#e0533d80}.menu-button--danger:hover{background:var(--danger-soft);border-color:var(--danger)}.menu-button.is-loading{color:#0000;pointer-events:none}.menu-button.is-loading:after{content:"";width:calc(16px * var(--ui-scale));height:calc(16px * var(--ui-scale));color:var(--ink);background:conic-gradient(#0000,currentColor);border-radius:50%;margin:auto;animation:.8s linear infinite menu-spin;position:absolute;inset:0;-webkit-mask:radial-gradient(circle,#0000 52%,#000 54%);mask:radial-gradient(circle,#0000 52%,#000 54%)}.menu-button--ghost.is-loading:after,.menu-button--danger.is-loading:after{color:var(--accent)}.menu-field{flex-direction:column;gap:6px;display:flex}.menu-field__label{font:600 calc(12px * var(--ui-scale)) / 1.3 inherit;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}.menu-input-wrap{align-items:center;display:flex;position:relative}.menu-input{width:100%;color:var(--text);font-size:calc(14px * var(--ui-scale));background:var(--glass-2);border:1px solid var(--line);border-radius:var(--r-sm);transition:border-color var(--dur), box-shadow var(--dur), background var(--dur);padding:11px 12px}.menu-input::placeholder{color:#5f6877}.menu-input:hover{border-color:var(--line-strong)}.menu-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--glass-hi);outline:none}.menu-input[aria-invalid=true]{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-soft);padding-right:34px}.menu-field.is-invalid .menu-input-wrap:after{content:"!";color:var(--danger);pointer-events:none;font-weight:800;position:absolute;top:50%;right:11px;transform:translateY(-50%)}.menu-field__hint{font-size:calc(11px * var(--ui-scale));color:var(--muted)}.menu-reveal{border-radius:var(--r-sm);width:32px;height:32px;color:var(--muted);cursor:pointer;transition:color var(--dur), background var(--dur);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute;right:6px}.menu-reveal:hover{color:var(--text);background:var(--glass-2)}.menu-reveal:focus-visible{box-shadow:var(--focus-ring);outline:none}.menu-reveal svg{fill:none;stroke:currentColor;stroke-width:1.6px;width:18px;height:18px}.menu-status{min-height:calc(18px * var(--ui-scale));font-size:calc(12px * var(--ui-scale));color:var(--muted);align-items:center;gap:6px;display:flex}.menu-status:before{font-weight:800}.menu-status:empty{visibility:hidden}.menu-status.is-info{color:var(--muted)}.menu-status.is-info:before{content:"ⓘ"}.menu-status.is-error{color:var(--danger)}.menu-status.is-error:before{content:"⚠"}.menu-spinner{background:conic-gradient(from 0deg, transparent, var(--accent));border-radius:50%;width:24px;height:24px;animation:.8s linear infinite menu-spin;-webkit-mask:radial-gradient(circle,#0000 52%,#000 54%);mask:radial-gradient(circle,#0000 52%,#000 54%)}@keyframes menu-spin{to{transform:rotate(360deg)}}.menu-bar{background:var(--panel-2);border-radius:3px;height:6px;position:relative;overflow:hidden}.menu-bar__fill{border-radius:inherit;width:0;transition:width var(--dur-slow) var(--ease);position:absolute;inset:0 auto 0 0}.menu-bar--hp .menu-bar__fill{background:linear-gradient(90deg, #3a7d4a, var(--success))}.menu-bar--hp.is-low .menu-bar__fill{background:linear-gradient(90deg,#b07a1f,#e0a13d)}.menu-bar--hp.is-crit .menu-bar__fill{background:linear-gradient(90deg, #8f2b22, var(--danger))}.menu-bar--sp .menu-bar__fill{background:linear-gradient(90deg,#2f5a8a,#4a8fd6)}.menu-vital{align-items:center;gap:var(--s2);grid-template-columns:26px 1fr auto;display:grid}.menu-vital__key{font:600 calc(11px * var(--ui-scale)) / 1 inherit;letter-spacing:.4px;color:var(--muted)}.menu-vital__num{font-size:calc(12px * var(--ui-scale));color:var(--text-2);font-variant-numeric:tabular-nums;white-space:nowrap}.menu-crest{width:64px;height:64px;color:var(--accent);background:radial-gradient(circle at 50% 35%, var(--crest-tint,#d9a44138), #080c1299 70%);border:2px solid var(--crest-ring,var(--accent-line));border-radius:50%;place-items:center;display:grid;position:relative;box-shadow:inset 0 1px #ffffff14,0 4px 14px #0006}.menu-crest__glyph{filter:drop-shadow(0 1px 2px #0009);font-size:28px;line-height:1}.menu-crest--sm{width:40px;height:40px}.menu-crest--sm .menu-crest__glyph{font-size:18px}.login-screen{align-items:center;gap:var(--s6);width:min(var(--panel-w), 92vw);flex-direction:column;display:flex}.login-brand{text-align:center;align-items:center;gap:var(--s2);flex-direction:column;display:flex}.login-wordmark{align-items:center;gap:var(--s3);font:700 calc(48px * var(--ui-scale)) / 1.1 inherit;letter-spacing:.5px;background:linear-gradient(180deg, #f0cd7a, var(--accent-2));color:#0000;text-shadow:0 2px 24px #d9a44140;-webkit-background-clip:text;background-clip:text;display:inline-flex}.login-wordmark svg{width:30px;height:30px;fill:var(--accent);-webkit-text-fill-color:initial}.login-kicker{font:600 calc(11px * var(--ui-scale)) / 1 inherit;letter-spacing:2px;text-transform:uppercase;color:var(--muted)}.login-panel{width:100%}.menu-footer{left:0;right:0;bottom:max(var(--s4), env(safe-area-inset-bottom));z-index:1;justify-content:center;align-items:center;gap:var(--s4);font:600 calc(11px * var(--ui-scale)) / 1 inherit;letter-spacing:.4px;color:var(--muted);pointer-events:none;display:flex;position:fixed}.menu-footer>*{pointer-events:auto}.menu-locale{gap:2px;display:inline-flex}.menu-locale__opt{color:var(--muted);cursor:pointer;border-radius:var(--r-sm);font:inherit;text-transform:uppercase;background:0 0;border:none;padding:4px 6px}.menu-locale__opt:hover{color:var(--text)}.menu-locale__opt.is-active{color:var(--accent)}.menu-locale__opt:focus-visible{box-shadow:var(--focus-ring);outline:none}.cs-screen{gap:var(--s4);width:min(calc(var(--hero-w) + var(--rail-w) + var(--s5)), 94vw);flex-direction:column;display:flex}.cs-header{align-items:center;gap:var(--s3);display:flex}.cs-header__brand{align-items:center;gap:var(--s2);font:700 calc(18px * var(--ui-scale)) / 1 inherit;color:var(--accent);display:inline-flex}.cs-header__brand svg{width:20px;height:20px;fill:var(--accent)}.cs-header__title{font:700 calc(20px * var(--ui-scale)) / 1.2 inherit;letter-spacing:.3px}.cs-header__spacer{flex:1}.cs-body{grid-template-columns:var(--hero-w) var(--rail-w);gap:var(--s5);align-items:start;display:grid}.cs-hero{box-shadow:var(--elev-hero), var(--inset-top);gap:var(--s4);flex-direction:column;display:flex}.cs-hero__head{gap:var(--s4);grid-template-columns:auto 1fr;align-items:center;display:grid}.cs-hero__id{flex-direction:column;gap:2px;min-width:0;display:flex}.cs-hero__name{font:700 calc(22px * var(--ui-scale)) / 1.15 inherit;letter-spacing:.3px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cs-hero__class{color:var(--muted);font-size:calc(13px * var(--ui-scale))}.cs-hero__vitals{gap:var(--s2);flex-direction:column;display:flex}.cs-hero__stats{gap:var(--s2);grid-template-columns:repeat(3,1fr);display:grid}.cs-stat{justify-content:space-between;align-items:baseline;gap:var(--s1);border-radius:var(--r-sm);background:var(--glass-2);border:1px solid var(--line);padding:6px 10px;display:flex}.cs-stat__key{font:600 calc(10px * var(--ui-scale)) / 1 inherit;letter-spacing:.6px;color:var(--muted)}.cs-stat__val{font:700 calc(14px * var(--ui-scale)) / 1 inherit;color:var(--text);font-variant-numeric:tabular-nums}.cs-hero__meta{justify-content:space-between;align-items:center;gap:var(--s3);font-size:calc(12px * var(--ui-scale));color:var(--muted);display:flex}.cs-hero__meta b{color:#ffe066;font-variant-numeric:tabular-nums;font-weight:700}.cs-hero__actions{gap:var(--s3);margin-top:auto;display:flex}.cs-hero__actions .menu-button--primary{flex:1}.cs-hero.is-promoting{animation:menu-fade-in var(--dur) var(--ease) both}@keyframes menu-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.cs-hero.is-empty{text-align:center;justify-content:center;align-items:center;gap:var(--s4);min-height:320px}.cs-hero.is-empty .cs-empty-plus{font-size:calc(56px * var(--ui-scale));color:var(--accent);opacity:.8;line-height:1}.cs-rail{gap:var(--s2);flex-direction:column;max-height:70vh;padding-right:2px;display:flex;overflow-y:auto}.cs-slot{align-items:center;gap:var(--s3);text-align:left;border-radius:var(--r-md);border:1px solid var(--line);background:var(--glass-2);width:100%;color:var(--text);cursor:pointer;transition:border-color var(--dur), background var(--dur), transform var(--dur), box-shadow var(--dur);padding:10px 12px;display:flex}.cs-slot:hover{border-color:var(--line-strong);background:var(--glass-hi);box-shadow:var(--elev-1);transform:translateY(-2px)}.cs-slot:focus-visible{box-shadow:var(--focus-ring);outline:none}.cs-slot[aria-current=true]{border-color:var(--accent);background:var(--accent-soft);box-shadow:inset 0 0 0 1px var(--accent-line)}.cs-slot__dot{border:1px solid var(--line-strong);border-radius:50%;flex:none;width:8px;height:8px}.cs-slot[aria-current=true] .cs-slot__dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px #d9a441b3}.cs-slot__body{flex-direction:column;gap:1px;min-width:0;display:flex}.cs-slot__name{font:600 calc(13px * var(--ui-scale)) / 1.2 inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cs-slot__meta{font-size:calc(11px * var(--ui-scale));color:var(--muted)}.cs-slot.is-create{color:var(--muted);border-style:dashed;justify-content:center}.cs-slot.is-create:hover{color:var(--accent);border-color:var(--accent-line)}.cs-slot.is-empty{cursor:default;opacity:.4;justify-content:center}.cs-slot.is-empty:hover{box-shadow:none;border-color:var(--line);background:var(--glass-2);transform:none}.create-grid{gap:var(--s5);grid-template-columns:auto 1fr;align-items:start;display:grid}.create-preview{align-items:center;gap:var(--s2);flex-direction:column;display:flex}.create-preview .menu-crest{width:88px;height:88px}.create-preview .menu-crest__glyph{font-size:40px}.create-fields{gap:var(--s4);flex-direction:column;display:flex}.create-count{font-size:calc(11px * var(--ui-scale));color:var(--muted);font-variant-numeric:tabular-nums;align-self:flex-end}.create-stepper{align-items:center;gap:var(--s2);display:flex}.create-stepper__btn{border-radius:var(--r-sm);border:1px solid var(--line);background:var(--glass-2);width:34px;height:34px;color:var(--text);cursor:pointer;transition:border-color var(--dur), background var(--dur);flex:none;place-items:center;font-size:16px;display:grid}.create-stepper__btn:hover{border-color:var(--accent)}.create-stepper__btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.create-stepper__val{text-align:center;font:700 calc(15px * var(--ui-scale)) / 1 inherit;font-variant-numeric:tabular-nums;flex:1}.create-swatches{gap:var(--s2);flex-wrap:wrap;display:flex}.create-swatch{border:2px solid var(--line-strong);cursor:pointer;width:30px;height:30px;transition:transform var(--dur), border-color var(--dur), box-shadow var(--dur);border-radius:50%;padding:0;position:relative}.create-swatch:hover{transform:scale(1.08)}.create-swatch:focus-visible{box-shadow:var(--focus-ring);outline:none}.create-swatch[aria-checked=true]{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft), 0 0 10px #d9a44180}.create-swatch[aria-checked=true]:after{content:"✓";color:#fff;text-shadow:0 1px 2px #000000e6;place-items:center;font-size:14px;font-weight:800;display:grid;position:absolute;inset:0}.delete-echo{align-items:center;gap:var(--s3);padding:var(--s3);border-radius:var(--r-md);background:var(--glass-2);border:1px solid var(--line);display:flex}.delete-echo__body{flex-direction:column;gap:1px;min-width:0;display:flex}.delete-echo__name{font:700 calc(15px * var(--ui-scale)) / 1.2 inherit;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.delete-echo__meta{font-size:calc(12px * var(--ui-scale));color:var(--muted)}.pin-panel{text-align:center;width:min(340px,92vw)}.pin-panel__icon{color:var(--accent);margin-bottom:var(--s2);font-size:28px;line-height:1}.pin-dots{justify-content:center;gap:var(--s4);margin:var(--s5) 0;display:flex}.pin-dot{border:2px solid var(--accent-line);width:14px;height:14px;transition:transform var(--dur-fast) var(--ease), background var(--dur-fast);background:0 0;border-radius:50%}.pin-dot.is-filled{background:var(--accent);border-color:var(--accent);animation:pin-pop var(--dur-fast) var(--ease)}@keyframes pin-pop{0%{transform:scale(1)}50%{transform:scale(1.25)}to{transform:scale(1)}}.pin-pad{gap:var(--s2);grid-template-columns:repeat(3,1fr);display:grid}.pin-key{border-radius:var(--r-sm);border:1px solid var(--line);background:var(--glass-2);min-height:clamp(48px,9vw,56px);color:var(--text);font:700 calc(20px * var(--ui-scale)) / 1 inherit;cursor:pointer;transition:background var(--dur), border-color var(--dur), transform var(--dur-fast)}.pin-key:hover{border-color:var(--accent);background:var(--glass-hi)}.pin-key:active{transform:translateY(1px)scale(.97)}.pin-key:focus-visible{box-shadow:var(--focus-ring);outline:none}.pin-key--util{color:var(--muted);font-size:calc(18px * var(--ui-scale))}.pin-panel.is-error .pin-dot{border-color:var(--danger)}.pin-panel.is-error .pin-dot.is-filled{background:var(--danger)}.pin-panel.is-error .pin-dots{animation:pin-shake .3s var(--ease)}@keyframes pin-shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(2px)}}.menu-overlay{z-index:50;padding:var(--s5);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.menu-overlay--fatal{z-index:60}.menu-overlay__scrim{-webkit-backdrop-filter:blur(4px);animation:menu-fade var(--dur) var(--ease) both;background:#080b10b8;position:absolute;inset:0}.menu-overlay__card{z-index:1;text-align:center;align-items:center;gap:var(--s4);background:var(--glass);width:min(360px,90vw);-webkit-backdrop-filter:blur(var(--blur)) saturate(120%);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--elev-3), var(--inset-top);padding:var(--s6);color:var(--text);animation:menu-pop var(--dur-slow) var(--ease) both;flex-direction:column;display:flex;position:relative}.menu-overlay__icon{font-size:34px;line-height:1}.menu-overlay--fatal .menu-overlay__icon{color:var(--danger)}.menu-overlay--disconnect .menu-overlay__icon{color:var(--muted)}.menu-overlay__title{font:700 calc(18px * var(--ui-scale)) / 1.2 inherit}.menu-overlay__msg{font-size:calc(12px * var(--ui-scale));color:var(--muted);max-width:420px;line-height:1.45}@keyframes menu-fade{0%{opacity:0}to{opacity:1}}@keyframes menu-pop{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:none}}.menu-toast{left:50%;bottom:max(var(--s5), env(safe-area-inset-bottom));z-index:55;align-items:center;gap:var(--s2);border-radius:var(--r-pill);background:var(--glass);-webkit-backdrop-filter:blur(var(--blur));border:1px solid var(--line);box-shadow:var(--elev-1);color:#ffd24a;font:600 calc(13px * var(--ui-scale)) / 1 inherit;animation:menu-toast-in var(--dur-slow) var(--ease) both;padding:8px 16px;display:flex;position:fixed;transform:translate(-50%)}.menu-toast .menu-spinner{width:14px;height:14px}@keyframes menu-toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@media (max-width:959px){.cs-body{grid-template-columns:1fr}.cs-rail{flex-flow:row;max-height:none;padding-bottom:4px;overflow:auto hidden}.cs-slot{flex:none;min-width:180px}}@media (max-width:639px){.login-wordmark{font-size:calc(40px * var(--ui-scale))}.create-grid{grid-template-columns:1fr;justify-items:center}.cs-hero__stats{grid-template-columns:repeat(2,1fr)}.cs-hero__actions,.menu-panel__actions{flex-direction:column}}@media (pointer:coarse){.cs-slot{min-height:56px}.pin-key{min-height:64px}}@media (prefers-reduced-motion:reduce){.menu-aurora{animation:none}.menu-particles{display:none}.menu-panel,.menu-overlay__scrim,.menu-overlay__card,.menu-toast,.cs-hero.is-promoting{animation:none}.menu-bar__fill{transition:none}.pin-dot,.pin-dot.is-filled{transition:none;animation:none}.pin-panel.is-error .pin-dots{animation:none}.cs-slot:hover,.menu-button:active,.pin-key:active{transform:none}}body.high-contrast .menu-root,body.high-contrast .menu-overlay,body.high-contrast .menu-toast{--line:#6f7d92}body.high-contrast .menu-panel,body.high-contrast .cs-slot,body.high-contrast .menu-input,body.high-contrast .menu-overlay__card,body.high-contrast .menu-toast{border-width:2px}.action-bars{pointer-events:none;z-index:30;flex-direction:column-reverse;align-items:center;gap:4px;display:flex;position:fixed;bottom:12px;left:50%;transform:translate(-50%)}.action-bar{background:#0a0e146b;border-radius:8px;flex-direction:row;gap:3px;padding:3px;display:flex;box-shadow:inset 0 0 0 1px #ffffff0a}.action-bar.is-hidden{display:none}.action-bars .hot-slot{width:calc(40px * var(--ui-scale));height:calc(40px * var(--ui-scale));pointer-events:auto;box-shadow:inset 0 0 0 1px #ffffff0f}.action-bars .hot-slot:hover{box-shadow:inset 0 0 0 1px #ffffff1f,0 0 6px #78c8ff59}.action-bars .hot-slot:not(.filled){opacity:.4}.action-bars .hot-slot.filled{box-shadow:inset 0 0 0 1px #78c8ff2e}.action-bars .hot-slot.hot-dragging{opacity:.35;cursor:grabbing}.action-bars .hot-slot.pd-drop{box-shadow:inset 0 0 0 2px var(--accent), 0 0 8px #78c8ff80}.action-bars .hot-key{font-size:calc(10px * var(--ui-scale));color:var(--muted);text-shadow:0 1px 1px #000;font-weight:600;top:1px;left:auto;right:3px}.action-bars__config{pointer-events:auto;position:absolute;bottom:0;right:-34px}.action-bar__handle{width:26px;height:26px;color:var(--muted);cursor:pointer;background:#0a0e14d1;border:1px solid #2c3543;border-radius:6px;padding:0;font-size:14px;line-height:1}.action-bar__handle:hover{color:var(--accent);border-color:var(--accent)}.action-bars__popover{white-space:nowrap;background:#0a0e14f0;border:1px solid #2c3543;border-radius:8px;flex-direction:column;gap:6px;padding:8px 10px;display:flex;position:absolute;bottom:32px;right:0;box-shadow:0 6px 18px #00000080}.action-bars__opt{color:#d6dde6;cursor:pointer;align-items:center;gap:7px;font-size:12px;display:flex}.action-bars__opt input,.action-bars.is-locked .hot-slot{cursor:pointer}.action-bars.is-locked .action-bar__handle{color:var(--accent-2,#5fd38a)}.esc-root{z-index:45;background:#080a1099;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.esc-root__panel{flex-direction:column;gap:8px;width:240px;display:flex}.esc-root__panel h1{margin:0 0 6px}.esc-root__btn{width:100%}.settings-win{z-index:45;background:#080a1099;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.settings-dialog{flex-direction:column;gap:10px;width:600px;max-width:94vw;max-height:88vh;display:flex;overflow:hidden}.settings-dialog__title{margin:0}.settings-body{flex:1;gap:14px;min-height:0;display:flex}.settings-rail{border-right:1px solid #28303d;flex-direction:column;flex:0 0 140px;gap:4px;width:140px;padding-right:10px;display:flex}.settings-rail__tab{text-align:left;color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;padding:8px 10px;font-size:13px}.settings-rail__tab:hover{background:var(--panel-2);color:#e6e6e6}.settings-rail__tab.is-active{background:var(--panel-2);color:var(--accent);border-color:#28303d;font-weight:600}.settings-pane-host{flex:1;min-width:0;overflow-y:auto}.settings-pane{flex-direction:column;gap:10px;display:none}.settings-row{flex-direction:column;gap:4px;display:flex}.settings-row--check{color:var(--muted);cursor:pointer;flex-direction:row;align-items:center;gap:8px;font-size:12px}.settings-row__label{color:var(--muted);font-size:12px}.settings-row__head{color:var(--muted);justify-content:space-between;font-size:12px;display:flex}.settings-footer{border-top:1px solid #28303d;justify-content:flex-end;gap:8px;margin-top:6px;padding-top:10px;display:flex}.settings-footer__btn{background:var(--panel-2);color:var(--muted);cursor:pointer;border:1px solid #28303d;border-radius:6px;padding:4px 12px;font-size:11px}.settings-footer__btn:hover{color:#e6e6e6}.settings-footer__btn--danger{color:#ff9b9b;border-color:#5a2630}.settings-controls{flex-direction:column;gap:8px;display:flex}.settings-controls__grid{grid-template-columns:1fr auto;align-items:center;gap:4px 10px;font-size:12px;display:grid}.settings-controls__label{color:var(--muted)}.settings-controls__key{background:var(--panel-2);color:#e6e6e6;cursor:pointer;border:1px solid #28303d;border-radius:6px;min-width:110px;padding:3px 8px;font-size:11px}.settings-controls__key.is-reassigned{transition:box-shadow .12s ease-out;box-shadow:0 0 0 2px #d9a441}.settings-controls__ref{color:var(--muted);margin-top:4px;font-size:11px;line-height:1.6}.settings-controls__ref b{color:var(--accent)}.weapon-kit-bar.is-hidden{display:none}.alert-stack{left:50%;bottom:calc(var(--hotbar-h,calc(96px * var(--ui-scale))) + 12px * var(--ui-scale));align-items:center;gap:calc(4px * var(--ui-scale));pointer-events:none;z-index:22;flex-direction:column-reverse;max-width:90vw;display:flex;position:fixed;transform:translate(-50%)}.alert-line{align-items:baseline;gap:calc(6px * var(--ui-scale));max-width:100%;padding:calc(4px * var(--ui-scale)) calc(12px * var(--ui-scale));border:1px solid #28303d;border-left:calc(3px * var(--ui-scale)) solid var(--accent);border-radius:calc(6px * var(--ui-scale));color:var(--text);font-size:calc(13px * var(--ui-scale));text-shadow:0 1px 2px #000;background:#0a0e14db;font-weight:600;line-height:1.3;animation:.14s ease-out both alert-in;display:flex}.alert-line .alert-msg{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.alert-line.error{color:var(--danger);background:#e0533d1f}.alert-line.warn{color:var(--accent-2);border-left-color:var(--accent-2);background:#c8821f1f}.alert-line.info{color:var(--muted);border-left-color:var(--muted);background:#8a93a31a}.alert-line.skill{color:var(--skillmsg,#b48ce0);border-left-color:var(--skillmsg,#b48ce0);background:#b48ce01f}.alert-line .alert-x{font-variant-numeric:tabular-nums;font-size:calc(11px * var(--ui-scale));color:var(--accent);opacity:.9;font-weight:700}.alert-line .alert-x:empty{display:none}.alert-line.leaving{animation:.2s ease-in both alert-out}@keyframes alert-in{0%{opacity:0;transform:translateY(calc(8px * var(--ui-scale)))}to{opacity:1;transform:translateY(0)}}@keyframes alert-out{0%{opacity:1}to{opacity:0}}@media (prefers-reduced-motion:reduce){.alert-line,.alert-line.leaving{animation:none}}body.reduce-flashing .alert-line,body.reduce-flashing .alert-line.leaving,body.reduce-motion .alert-line,body.reduce-motion .alert-line.leaving{animation:none}@keyframes rf-success{0%{box-shadow:0 0 #d9a441d9}to{box-shadow:0 0 0 calc(16px * var(--ui-scale)) #d9a44100}}@keyframes rf-fail{0%,to{box-shadow:0 0 0 calc(2px * var(--ui-scale)) #e0533d00;transform:translate(0)}20%{transform:translateX(calc(-4px * var(--ui-scale)));box-shadow:0 0 0 calc(2px * var(--ui-scale)) #e0533df2}40%{transform:translateX(calc(4px * var(--ui-scale)))}60%{transform:translateX(calc(-3px * var(--ui-scale)));box-shadow:0 0 0 calc(2px * var(--ui-scale)) #e0533db3}80%{transform:translateX(calc(3px * var(--ui-scale)))}}@keyframes rf-proc{0%{box-shadow:0 0 0 0 var(--rf-tint,var(--accent))}55%{box-shadow:0 0 calc(9px * var(--ui-scale)) calc(3px * var(--ui-scale)) var(--rf-tint,var(--accent))}to{box-shadow:0 0 #0000}}@keyframes rf-levelup{0%{filter:brightness(1.35);box-shadow:0 0 #d9a441e6}to{box-shadow:0 0 0 calc(22px * var(--ui-scale)) #d9a44100;filter:brightness()}}.rf-glow{border-radius:inherit}.rf-glow.success{animation:.36s ease-out rf-success}.rf-glow.fail{animation:.36s ease-in-out rf-fail}.rf-glow.proc{animation:.42s ease-out rf-proc}.rf-glow.levelup{animation:.9s ease-out rf-levelup}.rf-glow.heal{--rf-tint:var(--good);animation:.42s ease-out rf-proc}.rf-glow.mana{--rf-tint:var(--info);animation:.42s ease-out rf-proc}.rf-static{border-radius:inherit;box-shadow:0 0 0 calc(2px * var(--ui-scale)) var(--rf-tint,var(--accent))}.rf-static.success,.rf-static.levelup,.rf-static.proc{--rf-tint:var(--accent)}.rf-static.fail{--rf-tint:var(--danger)}.rf-static.heal{--rf-tint:var(--good)}.rf-static.mana{--rf-tint:var(--info)}@keyframes float-rise{0%{opacity:0;transform:translate(-50%, calc(2px * var(--ui-scale))) translateX(var(--rf-drift,0px))}12%{opacity:1}to{opacity:0;transform:translate(-50%, calc(-28px * var(--ui-scale))) translateX(var(--rf-drift,0px))}}.float-num{font:700 calc(15px * var(--ui-scale)) / 1 "Segoe UI", system-ui, sans-serif;text-shadow:0 1px 2px #000000e6;pointer-events:none;white-space:nowrap;z-index:30;animation:.9s ease-out forwards float-rise;position:absolute;top:0;left:50%;transform:translate(-50%)}.float-num.heal{color:var(--good)}.float-num.mana{color:var(--info)}.float-num.crit{color:var(--accent);font-size:calc(21px * var(--ui-scale));font-weight:800}.float-num.static{transform:translate(-50%, calc(-6px * var(--ui-scale)));transition:opacity .24s linear;animation:none}.big-burst{pointer-events:none;z-index:120;text-align:center;font:800 calc(34px * var(--ui-scale)) / 1.05 "Cinzel", "Segoe UI", serif;letter-spacing:calc(2px * var(--ui-scale));text-shadow:0 2px 12px #000000d9;animation:1.2s ease-out forwards rf-levelup;position:fixed;top:38%;left:50%;transform:translate(-50%,-50%)}.big-burst.levelup{color:var(--accent)}.big-burst.refine-ok{color:var(--good)}.big-burst.refine-fail{color:var(--danger)}.big-burst.gameover{color:var(--danger);font-size:calc(40px * var(--ui-scale))}.big-burst.static{box-shadow:none;transition:opacity .26s linear;animation:none;top:22%}@media (prefers-reduced-motion:reduce){.rf-glow,.float-num,.big-burst{animation-duration:1ms!important}}body.reduce-motion .rf-glow,body.reduce-motion .float-num,body.reduce-motion .big-burst{animation-duration:1ms!important}:root{--pip-sphere:#ffb84d;--pip-coin:#e8c34a;--pip-soul:#9bd0ff;--pip-charm:#cdd6e0;--pip-shield:#9aa7b5;--pip-scar:#e0533d}.res-pips{justify-content:center;align-items:center;gap:calc(3px * var(--ui-scale));margin-top:calc(3px * var(--ui-scale));pointer-events:none;flex-wrap:wrap;line-height:1;display:flex}.res-pip{--pip-c:var(--muted);font-size:calc(11px * var(--ui-scale));width:calc(13px * var(--ui-scale));height:calc(13px * var(--ui-scale));color:var(--pip-c);opacity:.3;font-variant-numeric:tabular-nums;justify-content:center;align-items:center;transition:opacity .14s,transform .14s,text-shadow .14s;display:inline-flex;transform:scale(.92)}.res-pip.filled{opacity:1;text-shadow:0 0 calc(5px * var(--ui-scale)) var(--pip-c);transform:scale(1)}.res-pip.sphere{--pip-c:var(--pip-sphere)}.res-pip.coin{--pip-c:var(--pip-coin)}.res-pip.soul{--pip-c:var(--pip-soul)}.res-pip.charm{--pip-c:var(--pip-charm)}.res-pip.shield{--pip-c:var(--pip-shield)}.res-pip.scar{--pip-c:var(--pip-scar)}.res-pip.charm[data-elem=fire]{--pip-c:#ff6a3d}.res-pip.charm[data-elem=water]{--pip-c:#4db5ff}.res-pip.charm[data-elem=wind]{--pip-c:#6fe0a8}.res-pip.charm[data-elem=earth]{--pip-c:#d8a861}.res-pip.charm[data-elem=ghost]{--pip-c:#b48ce0}.res-pip.charm[data-elem=holy]{--pip-c:#ffe7a3}.res-pip.charm[data-elem=dark],.res-pip.charm[data-elem=shadow]{--pip-c:#8a7fb0}.res-pip.charm[data-elem=poison]{--pip-c:#9bcf4a}.res-pips.compact{gap:calc(2px * var(--ui-scale));margin-top:calc(1px * var(--ui-scale))}.res-pips.compact .res-pip{font-size:calc(8px * var(--ui-scale));width:calc(9px * var(--ui-scale));height:calc(9px * var(--ui-scale))}@keyframes pip-spawn{0%{opacity:0;text-shadow:0 0 #0000;transform:scale(.4)}60%{opacity:1;text-shadow:0 0 calc(8px * var(--ui-scale)) var(--pip-c);transform:scale(1.25)}to{opacity:1;transform:scale(1)}}@keyframes pip-pop{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0)}}.res-pip.pip-spawn{animation:.18s ease-out pip-spawn}.res-pip.pip-pop{animation:.14s ease-in pip-pop}body.high-contrast .res-pip{opacity:.55;text-shadow:none}body.high-contrast .res-pip.filled{text-shadow:none;outline:calc(1px * var(--ui-scale)) solid var(--pip-c);border-radius:50%}@media (prefers-reduced-motion:reduce){.res-pip{transition:none}.res-pip.pip-spawn,.res-pip.pip-pop{animation:none}}body.reduce-motion .res-pip,body.reduce-flashing .res-pip{transition:none}body.reduce-motion .res-pip.pip-spawn,body.reduce-motion .res-pip.pip-pop,body.reduce-flashing .res-pip.pip-spawn,body.reduce-flashing .res-pip.pip-pop{animation:none}.item-slot{--slot-size:calc(40px * var(--ui-scale));width:var(--slot-size);height:var(--slot-size);box-sizing:border-box;border:1px solid var(--grid-line,#28303d);border-radius:calc(5px * var(--ui-scale));cursor:pointer;-webkit-user-select:none;user-select:none;background:#141a22f2;justify-content:center;align-items:center;display:inline-flex;position:relative}.item-slot.empty{cursor:default}.item-slot.locked{cursor:default;opacity:.7}.item-slot.filled:hover,.item-slot.filled:focus-visible{outline:calc(2px * var(--ui-scale)) solid var(--accent);outline-offset:-1px}.item-slot .is-icon{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.item-slot .is-icon img{image-rendering:auto;width:100%;height:100%;display:block}.item-slot .is-empty-glyph{font-size:calc(18px * var(--ui-scale));color:var(--muted);opacity:.35;line-height:1}.item-slot .is-stars{left:calc(2px * var(--ui-scale));bottom:calc(1px * var(--ui-scale));font-size:calc(8px * var(--ui-scale));color:var(--accent);text-shadow:0 1px 2px #000;pointer-events:none;line-height:1;position:absolute}.item-slot .is-qty{right:calc(2px * var(--ui-scale));bottom:calc(1px * var(--ui-scale));font-size:calc(10px * var(--ui-scale));font-variant-numeric:tabular-nums;color:var(--text);text-shadow:0 1px 2px #000;pointer-events:none;font-weight:700;position:absolute}.item-slot .is-badge.refine-up{left:calc(2px * var(--ui-scale));top:calc(1px * var(--ui-scale));font-size:calc(9px * var(--ui-scale));color:var(--accent);text-shadow:0 1px 2px #000;pointer-events:none;font-weight:700;position:absolute}.item-slot .is-flag{top:calc(1px * var(--ui-scale));right:calc(2px * var(--ui-scale));font-size:calc(10px * var(--ui-scale));text-shadow:0 1px 2px #000;pointer-events:none;line-height:1;position:absolute}.item-slot .is-flag.damaged{color:var(--danger)}.item-slot .is-flag.bound{color:var(--accent)}.item-slot.damaged{border-color:var(--danger)}.item-slot.damaged .is-icon img{filter:grayscale(.7)brightness(.85)}.item-slot.bound{border-color:var(--accent)}.item-slot.switch{outline:calc(2px * var(--ui-scale)) dashed var(--accent);outline-offset:calc(-2px * var(--ui-scale));opacity:.92}.paperdoll{justify-content:center;align-items:center;gap:calc(8px * var(--ui-scale));display:flex}.paperdoll .pd-col{gap:calc(4px * var(--ui-scale));flex-direction:column;display:flex}.paperdoll .pd-mannequin{width:calc(72px * var(--ui-scale));border:1px solid var(--grid-line,#28303d);border-radius:calc(6px * var(--ui-scale));background:#0c101699;flex:none;align-self:stretch}.paperdoll .pd-slot[data-eqp]{flex:none}body.high-contrast .item-slot{border-width:2px}body.high-contrast .item-slot.filled:hover,body.high-contrast .item-slot.filled:focus-visible{outline-width:calc(3px * var(--ui-scale))}.dgrid{height:100%;min-height:0;font-size:calc(13px * var(--ui-scale));color:var(--text);flex-direction:column;display:flex;position:relative}.dgrid-tools{align-items:center;gap:calc(8px * var(--ui-scale));padding:calc(4px * var(--ui-scale)) calc(6px * var(--ui-scale));border-bottom:1px solid var(--grid-line,#28303d);display:flex}.dgrid-search{min-width:0;padding:calc(4px * var(--ui-scale)) calc(8px * var(--ui-scale));background:var(--panel-2,#1c2533);border:1px solid var(--grid-line,#28303d);border-radius:calc(5px * var(--ui-scale));color:var(--text);font-size:calc(13px * var(--ui-scale));flex:auto}.dgrid-search:focus-visible{outline:calc(2px * var(--ui-scale)) solid var(--accent);outline-offset:0}.dgrid-search:disabled{opacity:.5}.dgrid-count{font-variant-numeric:tabular-nums;font-size:calc(11px * var(--ui-scale));color:var(--muted);flex:none}.dgrid-head{align-items:stretch;gap:calc(2px * var(--ui-scale));padding:0 calc(6px * var(--ui-scale));border-bottom:1px solid var(--grid-line,#28303d);background:var(--panel,#141a24);z-index:1;display:grid;position:sticky;top:0}.dgrid-th{align-items:center;gap:calc(3px * var(--ui-scale));padding:calc(5px * var(--ui-scale)) calc(4px * var(--ui-scale));font-size:calc(11px * var(--ui-scale));letter-spacing:.02em;text-transform:uppercase;color:var(--muted);-webkit-user-select:none;user-select:none;font-weight:700;display:flex}.dgrid-th.align-r{justify-content:flex-end}.dgrid-th.align-c{justify-content:center}.dgrid-th.sortable{cursor:pointer}.dgrid-th.sortable:hover{color:var(--text)}.dgrid-th.sortable:focus-visible{outline:calc(2px * var(--ui-scale)) solid var(--accent);outline-offset:-2px}.dgrid-th.sorted{color:var(--text)}.dgrid-sort{font-size:calc(9px * var(--ui-scale));color:var(--accent);line-height:1}.dgrid-sort:empty{display:none}.dgrid-body{min-height:0;padding:0 calc(6px * var(--ui-scale)) calc(4px * var(--ui-scale));flex:auto;overflow-y:auto}.dgrid-row{align-items:center;gap:calc(2px * var(--ui-scale));padding:calc(4px * var(--ui-scale)) 0;border-bottom:1px solid var(--grid-line,#28303d);border-left:calc(3px * var(--ui-scale)) solid transparent;cursor:default;display:grid}.dgrid-row:hover{outline:1px solid var(--accent);outline-offset:calc(-1px * var(--ui-scale));background:var(--row-hover,#d9a4411a)}.dgrid-row.selected{border-left-color:var(--sel-bar,var(--accent));background:var(--row-hover,#d9a4411a)}.dgrid-cell{min-width:0;padding:0 calc(4px * var(--ui-scale));white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.dgrid-cell.align-r{text-align:right;font-variant-numeric:tabular-nums}.dgrid-cell.align-c{text-align:center}.dgrid-foot{justify-content:flex-end;align-items:center;gap:calc(8px * var(--ui-scale));padding:calc(5px * var(--ui-scale)) calc(8px * var(--ui-scale));border-top:1px solid var(--grid-line,#28303d);font-variant-numeric:tabular-nums;font-size:calc(12px * var(--ui-scale));color:var(--muted);flex:none;display:flex}.dgrid-empty{padding:calc(24px * var(--ui-scale));color:var(--muted);font-size:calc(12px * var(--ui-scale));justify-content:center;align-items:center;font-style:italic;display:flex}.dgrid-busy{z-index:3;background:#0a0e1480;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.dgrid-spinner{width:calc(28px * var(--ui-scale));height:calc(28px * var(--ui-scale));border:calc(3px * var(--ui-scale)) solid var(--grid-line,#28303d);border-top-color:var(--accent);border-radius:50%;animation:.72s linear infinite dgrid-spin}@keyframes dgrid-spin{to{transform:rotate(360deg)}}@keyframes dgrid-row-in{0%{opacity:0}to{opacity:1}}@keyframes dgrid-row-out{0%{opacity:1}to{opacity:0}}.dgrid-row.dgrid-entering{animation:.12s ease-out both dgrid-row-in}.dgrid-row.dgrid-leaving{pointer-events:none;animation:.12s ease-in both dgrid-row-out}body.high-contrast .dgrid-row{border-bottom-width:calc(1px * var(--ui-scale))}body.high-contrast .dgrid-row.selected{border-left-width:calc(4px * var(--ui-scale))}body.high-contrast .dgrid-row:hover{outline-width:calc(2px * var(--ui-scale));background:0 0}@media (prefers-reduced-motion:reduce){.dgrid-spinner,.dgrid-row.dgrid-entering,.dgrid-row.dgrid-leaving{animation:none}}body.reduce-motion .dgrid-spinner,body.reduce-flashing .dgrid-spinner,body.reduce-motion .dgrid-row.dgrid-entering,body.reduce-motion .dgrid-row.dgrid-leaving,body.reduce-flashing .dgrid-row.dgrid-entering,body.reduce-flashing .dgrid-row.dgrid-leaving{animation:none}.enhance-win{gap:calc(10px * var(--ui-scale));min-width:calc(260px * var(--ui-scale));padding:calc(4px * var(--ui-scale));color:var(--text);font-size:calc(13px * var(--ui-scale));flex-direction:column;display:flex}.enhance-win .enhance-target{align-items:center;gap:calc(10px * var(--ui-scale));display:flex}.enhance-win .enhance-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:600;overflow:hidden}.enhance-win .enhance-name.muted{color:var(--muted);font-style:italic;font-weight:400}.enhance-win .enhance-mats{height:calc(132px * var(--ui-scale));display:flex}.enhance-win .enhance-mats .dgrid{min-height:0}.enhance-win .dgrid-row.insufficient .enhance-have-short,.enhance-win .enhance-have-short{color:var(--danger);font-weight:700}.enhance-win .enhance-zeny{font-variant-numeric:tabular-nums;color:var(--muted)}.enhance-win .enhance-gauge{gap:calc(3px * var(--ui-scale));flex-direction:column;display:flex}.enhance-win .enhance-gauge-label{font-size:calc(11px * var(--ui-scale));letter-spacing:.02em;text-transform:uppercase;color:var(--muted);font-weight:700}.enhance-win .enhance-gauge .bar{height:calc(16px * var(--ui-scale));background:var(--panel-2,#1c2533);border:1px solid var(--grid-line,#28303d);border-radius:calc(4px * var(--ui-scale));position:relative;overflow:hidden}.enhance-win .bar-fill.chance{background:linear-gradient(90deg, #c8821f, var(--accent))}.enhance-win .enhance-safe{font-size:calc(12px * var(--ui-scale));color:var(--good,#6fd06a);font-weight:600}.enhance-win .enhance-action{padding:calc(7px * var(--ui-scale)) calc(12px * var(--ui-scale));background:var(--accent);border:1px solid var(--accent);border-radius:calc(6px * var(--ui-scale));color:#1a1206;font-size:calc(13px * var(--ui-scale));cursor:pointer;align-self:stretch;font-weight:700}.enhance-win .enhance-action:hover{filter:brightness(1.08)}.enhance-win .enhance-action:disabled{opacity:.5;cursor:default;filter:none}body.high-contrast .enhance-win .enhance-gauge .bar{border-width:2px}.smith-pick{gap:calc(8px * var(--ui-scale));min-width:calc(220px * var(--ui-scale));padding:calc(4px * var(--ui-scale));color:var(--text);font-size:calc(13px * var(--ui-scale));flex-direction:column;display:flex}.smith-pick .smith-pick-grid{height:calc(220px * var(--ui-scale));display:flex}.smith-pick .smith-pick-grid .dgrid{min-height:0}.smith-pick .smith-pick-action{padding:calc(7px * var(--ui-scale)) calc(12px * var(--ui-scale));background:var(--accent);border:1px solid var(--accent);border-radius:calc(6px * var(--ui-scale));color:#1a1206;font-size:calc(13px * var(--ui-scale));cursor:pointer;align-self:stretch;font-weight:700}.smith-pick .smith-pick-action:hover{filter:brightness(1.08)}
