:root{--bg: #0b0e14;--panel: #141a24;--panel-2: #1c2533;--accent: #d9a441;--accent-2: #c8821f;--text: #e6e6e6;--muted: #8a93a3;--danger: #e0533d;--ui-scale: 1;font-family:Segoe UI,system-ui,sans-serif}*{box-sizing:border-box}html,body,#app{margin:0;height:100%;background:var(--bg);color:var(--text)}#app{display:flex;align-items:center;justify-content:center}.screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.panel{background:var(--panel);border:1px solid #28303d;border-radius:12px;padding:28px 32px;width:360px;box-shadow:0 18px 50px #00000080}.panel h1{margin:0 0 4px;font-size:22px;letter-spacing:.5px}.panel .subtitle{color:var(--muted);font-size:13px;margin-bottom:20px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}.field input{width:100%;padding:10px 12px;background:var(--panel-2);border:1px solid #2c3543;border-radius:8px;color:var(--text);font-size:14px}.field input:focus{outline:none;border-color:var(--accent)}button.primary{width:100%;padding:11px;background:linear-gradient(180deg,var(--accent),var(--accent-2));border:none;border-radius:8px;color:#1a1206;font-weight:600;font-size:15px;cursor:pointer}button.primary:hover{filter:brightness(1.07)}button.primary:disabled{opacity:.5;cursor:not-allowed}.status{margin-top:14px;font-size:13px;min-height:18px}.status.error{color:var(--danger)}.status.info{color:var(--muted)}.char-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.char-card{background:var(--panel-2);border:1px solid #2c3543;border-radius:10px;padding:14px;cursor:pointer;text-align:center;transition:border-color .15s,transform .1s}.char-card:hover{border-color:var(--accent);transform:translateY(-2px)}.char-card .name{font-weight:600;margin-bottom:4px}.char-card .meta{font-size:12px;color:var(--muted)}.char-card.empty{color:var(--muted);cursor:default;opacity:.5}.pincode-dots{display:flex;gap:10px;justify-content:center;margin:18px 0}.pincode-dots .dot{width:14px;height:14px;border-radius:50%;background:var(--panel-2);border:1px solid #3a4453}.pincode-dots .dot.filled{background:var(--accent)}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.keypad button{padding:14px;font-size:18px;background:var(--panel-2);border:1px solid #2c3543;border-radius:8px;color:var(--text);cursor:pointer}.keypad button:hover{border-color:var(--accent)}#game-canvas{width:100vw;height:100vh;display:block}.hud{position:fixed;top:12px;left:12px;background:#0a0e14b3;border:1px solid #28303d;border-radius:8px;padding:10px 14px;font-size:13px;pointer-events:none}.hud .row{margin:2px 0}.hud .label{color:var(--muted)}.overlay{position:fixed;pointer-events:none;z-index:10}.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{top:12px;left:12px;width:calc(230px * var(--ui-scale));background:#0a0e14d1;border:1px solid #28303d;border-radius:8px;padding:10px 12px;font-size:calc(12px * var(--ui-scale))}.hud-name{font-weight:600;font-size:calc(14px * var(--ui-scale))}.hud-lv{color:var(--muted);margin-bottom:6px}.hud-row{color:var(--muted);margin-top:4px}.status-panel .bar{position:relative;height:16px;margin-top:5px;background:var(--panel-2);border-radius:4px;overflow:hidden}.status-panel .exp-bar{height:12px}.bar-fill{height:100%;width:0%;transition:width .2s}.bar-fill.hp{background:linear-gradient(90deg,#c0392b,#e0533d);position:relative;z-index:1}.bar-fill.hp-ghost{position:absolute;left:0;top:0;z-index:0;background:linear-gradient(90deg,#7a1f17,#a3392f);transition:width .4s ease-out}body.reduce-flashing .bar-fill.hp-ghost{transition:none}.bar-fill.sp{background:linear-gradient(90deg,#2471a3,#3498db)}.bar-fill.exp{background:linear-gradient(90deg,#c8821f,var(--accent))}.bar-text{position:absolute;inset:0;z-index:2;text-align:center;font-size:11px;line-height:16px;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.7)}.status-panel .exp-bar .bar-text{line-height:12px;font-size:9px}.party-frames{top:calc(186px * var(--ui-scale));left:12px;width:calc(230px * var(--ui-scale));pointer-events:auto;display:flex;flex-direction:column;gap:calc(3px * var(--ui-scale))}.pf-grip{display:flex;align-items:center;justify-content:center;height:calc(12px * var(--ui-scale));cursor:move;user-select:none;color:var(--muted);opacity:0;transition:opacity .12s;border-radius:4px;background:#0a0e1480}.party-frames:hover .pf-grip{opacity:.7}.pf-grip-dots{font-size:calc(11px * var(--ui-scale));line-height:1;letter-spacing:2px}.pf-list{display:flex;flex-direction:column;gap:calc(4px * var(--ui-scale))}.pf-frame{position:relative;cursor:pointer;text-align:left;background:#0a0e14d1;border:1px solid #28303d;border-radius:6px;border-left:3px solid #3a4555;padding:calc(5px * var(--ui-scale)) calc(8px * var(--ui-scale));display:flex;flex-direction:column;gap:calc(3px * var(--ui-scale));transition:border-color .12s,background-color .12s}.pf-frame:hover{border-color:var(--accent);background:#10161fe6}.pf-frame:focus-visible{outline:2px solid #7fd0ff;outline-offset:1px}.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{border-left-color:#e0533d;filter:grayscale(.6)}.pf-frame.pf-lowhp{border-left-color:#e0533d;animation:pf-pulse 1s ease-in-out infinite}@keyframes pf-pulse{0%,to{background:#0a0e14d1}50%{background:#4a1818b3}}.pf-top{display:flex;align-items:baseline;gap:calc(4px * var(--ui-scale))}.pf-crown{flex:none;color:var(--accent);font-size:calc(11px * var(--ui-scale))}.pf-name{flex:1;min-width:0;font-size:calc(12px * var(--ui-scale));font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pf-bar{position:relative;height:calc(9px * var(--ui-scale));background:var(--panel-2);border-radius:3px;overflow:hidden}.pf-fill{height:100%;width:0%;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{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:calc(8px * var(--ui-scale));font-weight:700;color:#fff;text-shadow:0 1px 1px #000;pointer-events:none;letter-spacing:.3px}.pf-buffs{display:flex;flex-wrap:wrap;gap:2px}.pf-chip{font-size:calc(8px * var(--ui-scale));line-height:1.4;padding:0 3px;border-radius:3px;background:#5fd35f2e;color:#bfe9bf;border:1px solid rgba(95,211,95,.4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(34px * var(--ui-scale))}.pf-chip.bad{background:#e0533d2e;color:#f0b3a8;border-color:#e0533d73}.menu-buttons{inset:202px 14px auto auto;display:flex;align-items:center;gap:5px;padding:4px;pointer-events:auto;background:#0a0e14cc;border:1px solid #28303d;border-radius:12px;box-shadow:0 2px 8px #0006}.menu-divider{align-self:stretch;width:1px;margin:3px 1px;background:linear-gradient(180deg,transparent,#36404f 30%,#36404f 70%,transparent)}.menu-btn{position:relative;display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;background:transparent;border:1px solid transparent;border-radius:7px;color:var(--muted);cursor:pointer;transition:color .12s ease,background-color .12s ease,border-color .12s ease}.menu-glyph{display:flex;width:18px;height:18px;color:inherit}.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);background:#d9a44129;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset,0 0 8px #d9a4414d}.menu-key{position:absolute;bottom:0;right:1px;line-height:1;font-size:8px;font-weight:700;color:var(--muted);text-shadow:0 1px 1px #000;pointer-events:none}.menu-btn:hover .menu-key,.menu-btn[aria-pressed=true] .menu-key{color:var(--accent)}.target-panel{top:12px;left:50%;transform:translate(-50%);background:#0a0e14d1;border:1px solid #28303d;border-radius:6px;padding:6px 16px}.target-name{font-weight:600}.window{top:80px;left:50%;transform:translate(-50%);width:300px;flex-direction:column;background:var(--panel);border:1px solid #28303d;border-radius:10px;box-shadow:0 18px 50px #00000080;pointer-events:auto}.window.win-stats{top:80px;left:auto;right:70px;transform:none}.window.win-inv{top:130px;left:auto;right:24px;transform:none;width:360px}.window.win-skills{top:120px;left:auto;right:120px;transform:none;width:560px;max-width:92vw}.win-head{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border-bottom:1px solid #28303d;font-weight:600;letter-spacing:.3px;border-radius:10px 10px 0 0;background:linear-gradient(180deg,#3640528c,#36405200)}.win-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;line-height:1}.win-close:hover{color:var(--text)}.win-body{padding:12px;max-height:60vh;overflow-y:auto}.window.win-stats{width:calc(520px * var(--ui-scale));max-width:94vw}.stats-grid{display:flex;flex-direction:column;gap:calc(12px * var(--ui-scale))}.stats-cols2{display:grid;grid-template-columns:1fr 1fr;gap:calc(16px * var(--ui-scale));align-items:start}.stats-col{display:flex;flex-direction:column;gap:calc(12px * var(--ui-scale));min-width:0}.stats-col .derived-grid{grid-template-columns:1fr}@media (max-width: 560px),(pointer: coarse){.stats-cols2{grid-template-columns:1fr}}.stats-identity{display:grid;grid-template-columns:1fr auto;gap:2px calc(10px * var(--ui-scale));align-items:center;padding:calc(8px * var(--ui-scale)) calc(10px * var(--ui-scale));border-radius:8px;border:1px solid #2a3342;background:linear-gradient(180deg,#d9a4411f,#d9a44100)}.si-name{grid-column:1;font-size:calc(15px * var(--ui-scale));font-weight:700;letter-spacing:.3px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.si-job{grid-column:1;font-size:calc(16px * var(--ui-scale));font-weight:700;letter-spacing:.3px;color:var(--accent)}.si-levels{grid-column:2;grid-row:1 / span 2;display:flex;flex-direction:column;gap:3px;align-items:flex-end}.si-lv{display:inline-flex;gap:6px;align-items:baseline}.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));font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.stats-points{display:flex;justify-content:space-between;align-items:center;padding:calc(7px * var(--ui-scale)) calc(12px * var(--ui-scale));border-radius:8px;border:1px solid #2a3342;background:var(--panel-2)}.stats-points.has{border-color:var(--accent-2);background:linear-gradient(180deg,#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));font-weight:800;color:var(--muted);font-variant-numeric:tabular-nums}.stats-points.has .sp-val{color:var(--accent)}.stats-cols{display:grid;grid-template-columns:1fr 1fr;gap:0}.sub-col{padding-left:calc(14px * var(--ui-scale));border-left:1px solid #232c3a}.col-head{display:flex;align-items:center;gap:7px;font-size:calc(10px * var(--ui-scale));text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding-bottom:4px;margin-bottom:5px;border-bottom:1px solid #232c3a}.col-head:before{content:"";flex:0 0 auto;width:3px;height:calc(12px * var(--ui-scale));border-radius:2px;background:var(--grp, var(--accent))}.col-head.def{margin-top:calc(10px * var(--ui-scale))}.grp-attr{--grp: var(--accent);--grp-soft: rgba(217, 164, 65, .14)}.grp-off{--grp: #e8895c;--grp-soft: rgba(232, 137, 92, .15)}.grp-def{--grp: #5aa0e0;--grp-soft: rgba(90, 160, 224, .15)}.stat-ico{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;color:var(--grp, var(--accent))}.stat-ico svg{width:calc(15px * var(--ui-scale));height:calc(15px * var(--ui-scale));fill:none;stroke:currentColor;stroke-width:2;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));border-radius:8px;background:var(--grp-soft);border:1px solid var(--grp-soft);box-shadow:inset 0 1px #ffffff0d}.stat-ico--tile svg{width:calc(17px * var(--ui-scale));height:calc(17px * var(--ui-scale))}.derived-head{display:inline-flex;align-items:center;gap:calc(7px * var(--ui-scale));min-width:0}.attr-list{display:flex;flex-direction:column}.attr-row{display:grid;grid-template-columns:auto 1fr auto 2.6em calc(20px * var(--ui-scale));align-items:center;column-gap:calc(8px * var(--ui-scale));row-gap:1px;padding:calc(7px * var(--ui-scale)) 0;border-bottom:1px solid #1e2630;cursor:help}.attr-row:last-child{border-bottom:none}.attr-row .stat-ico--tile{grid-row:1 / span 2;align-self:center}.attr-name{display:flex;align-items:baseline;gap:6px;min-width:0;overflow:hidden}.attr-full{font-size:calc(13px * var(--ui-scale));font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.attr-val{white-space:nowrap}.attr-abbr{font-size:calc(10px * var(--ui-scale));font-weight:600;letter-spacing:.5px;color:var(--muted)}.attr-hint{grid-column:2 / -1;font-size:calc(10px * var(--ui-scale));color:var(--muted);line-height:1.25}.attr-label{font-size:calc(12px * var(--ui-scale));font-weight:700;letter-spacing:.4px;color:var(--text)}.attr-val{text-align:right;font-size:calc(14px * var(--ui-scale));font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap}.attr-bonus{margin-left:3px;color:#7fd0ff;font-weight:700;font-size:calc(11px * var(--ui-scale))}.attr-cost{justify-self:center;min-width:2ch;text-align:center;padding:1px 5px;border-radius:9px;background:var(--panel-2);border:1px solid var(--accent-2);font-size:calc(10px * var(--ui-scale));font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}.attr-cost.off{color:var(--muted);border-color:#2f3a49;opacity:.55}.attr-plus{width:calc(20px * var(--ui-scale));height:calc(20px * var(--ui-scale));display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--accent);border-radius:4px;color:var(--accent);font-size:calc(14px * var(--ui-scale));line-height:1;cursor:pointer;transition:background .1s ease,color .1s ease,transform .05s ease}.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{border-color:#2f3a49;color:#4a5363;cursor:default}.sub-row{display:flex;justify-content:space-between;align-items:baseline;padding:calc(2px * var(--ui-scale)) 0}.sub-label{font-size:calc(11px * var(--ui-scale));letter-spacing:.3px;color:var(--muted)}.sub-val{font-size:calc(12px * var(--ui-scale));font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.stats-section{display:flex;flex-direction:column;gap:calc(6px * var(--ui-scale))}.derived-grid{display:grid;grid-template-columns:1fr 1fr;gap:calc(6px * var(--ui-scale))}.derived-cell{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:calc(6px * var(--ui-scale)) calc(9px * var(--ui-scale));border-radius:7px;border:1px solid #2a3342;background:linear-gradient(180deg,var(--grp-soft, transparent),transparent),var(--panel-2);cursor:help;transition:border-color .12s ease,background .12s ease}.derived-cell:hover{border-color:var(--grp, var(--accent-2))}.derived-label{font-size:calc(11px * var(--ui-scale));color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.derived-val{font-size:calc(13px * var(--ui-scale));font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;flex:0 0 auto;white-space:nowrap}.derived-sub{margin-left:6px;font-size:calc(10px * var(--ui-scale));font-weight:600;color:var(--muted)}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{border-color:#6f7d92;color:#9aa4b3}.inv-window{display:flex;flex-direction:column;gap:8px}.win-inv .win-body{max-height:74vh;overflow:hidden}.inv-window .inv-grid{flex:1 1 auto;min-height:104px;overflow-y:auto;align-content:start;padding:2px 2px 2px 0}.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,46px);gap:6px;justify-content:start;box-sizing:border-box}.inv-cell{position:relative;width:46px;height:46px;padding:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#1b222d,#141a23);border:1px solid #2c3543;border-radius:6px;cursor:pointer;transition:border-color .12s,transform .08s,box-shadow .12s}.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{width:36px;height:36px;pointer-events:none}.inv-name{font-size:12px}.inv-amt{position:absolute;right:2px;bottom:1px;z-index:1;font-size:10px;font-weight:700;color:#fff;line-height:1;padding:0 2px;border-radius:3px;background:#080c12d9;text-shadow:0 1px 1px #000}.inv-refine{position:absolute;left:2px;top:1px;z-index:1;font-size:10px;font-weight:700;color:#ffe066;line-height:1;text-shadow:0 1px 1px #000}.inv-tabs{display:flex;gap:4px;width:100%;box-sizing:border-box;margin:6px 0}.inv-tab{flex:1;min-width:0;padding:5px 8px;cursor:pointer;font-size:12px;background:var(--panel-2);border:1px solid #2c3543;border-radius:6px;color:var(--muted)}.inv-tab:hover{border-color:var(--accent)}.inv-tab.active{background:#141c26f2;color:var(--accent);border-color:var(--accent)}.inv-bag-head{display:flex;align-items:center;gap:6px;margin-bottom:6px;width:100%;box-sizing:border-box}.inv-search{flex:1;min-width:60px;padding:4px 7px;font-size:12px;background:#0a0e14d9;border:1px solid #28303d;border-radius:5px;color:#e6e6e6}.inv-search:focus{outline:none;border-color:var(--accent)}.inv-hint{font-size:11px;color:var(--muted);margin-bottom:6px}.inv-ctx .context-item{display:block;width:100%;border:none;background:none;color:inherit;font:inherit;text-align:left;font-size:12px;padding:6px 10px}.inv-ctx .context-item.drop{color:#d9a3a3}.inv-ctx .context-item.drop:hover{background:#7a3a3a;color:#fff}.skill-list{display:flex;flex-direction:column;gap:4px}.skill-tree-head:first-child{margin-top:0}.skill-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;background:var(--panel-2);border:1px solid #2c3543;border-radius:6px;padding:8px 10px}.skill-row:hover{border-color:var(--accent)}.skill-row.skill-child{border-left:2px solid var(--accent-2)}.skill-name-col{display:flex;flex-wrap:wrap;align-items:baseline;column-gap:6px;row-gap:1px;flex:1;min-width:0}.skill-name{flex:1;min-width:0;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:calc(13px * var(--ui-scale))}.skill-lv{flex-shrink:0;color:var(--muted);font-size:calc(12px * var(--ui-scale))}.skill-req{flex-basis:100%;color:var(--muted);font-size:calc(10px * var(--ui-scale));line-height:1.2}.skill-passive-tag{align-self:center;padding:2px 8px;font-size:calc(11px * var(--ui-scale));color:var(--muted);border:1px solid #2c3543;border-radius:6px;background:#ffffff08;white-space:nowrap}.win-body.skill-mode-graph{display:flex;flex-direction:column;overflow:hidden;padding:8px;gap:8px;height:64vh;max-height:none;min-width:0}.skill-graph-wrap{display:flex;flex-direction:column;gap:8px;min-height:0;min-width:0;flex:1}.skill-legend{display:flex;flex-wrap:wrap;gap:6px 12px;padding:2px 2px 0}.skill-legend-chip{display:inline-flex;align-items:center;gap:5px;font-size:calc(11px * var(--ui-scale));color:var(--muted)}.skill-legend-chip i{width:10px;height:10px;border-radius:50%;display:inline-block}.skill-graph-scroll{flex:1;min-height:0;min-width:0;overflow:auto;border:1px solid #232b36;border-radius:8px;background:radial-gradient(circle at 1px 1px,rgba(255,255,255,.035) 1px,transparent 0) 0 0 / 22px 22px,var(--panel-2)}.skill-graph{position:relative}.skill-graph-inner{position:relative;transform-origin:0 0}.skill-graph-svg{position:absolute;inset:0;pointer-events:none;overflow:visible}.skill-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:2px 2px 0}.skill-points{display:flex;align-items:center;gap:7px;padding:3px 10px;border-radius:7px;background:var(--panel-2);border:1px solid #2c3543}.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));font-weight:700;color:var(--muted);min-width:1ch;text-align:center}.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{display:flex;align-items:center;gap:6px}.skill-zoom-val{font-size:calc(11px * var(--ui-scale));color:var(--muted);min-width:40px;text-align:center}.skill-zoom-btn{width:24px;height:24px;padding:0;line-height:1;border-radius:6px;border:1px solid #2c3543;background:var(--panel-2);color:var(--text);cursor:pointer;font-size:15px}.skill-zoom-btn:hover:not([disabled]){border-color:var(--accent)}.skill-zoom-btn[disabled]{opacity:.4;cursor:default}.skill-edge{fill:none;stroke-width:2}.skill-edge-ok{stroke:var(--accent);opacity:.75}.skill-edge-bad{stroke:#b65b54;opacity:.6;stroke-dasharray:5 4}.skill-card{position:absolute;width:132px;height:78px;box-sizing:border-box;display:grid;grid-template-columns:30px 1fr auto;grid-template-rows:30px auto;column-gap:7px;row-gap:5px;align-items:center;padding:8px 9px;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid #2c3543;border-left:3px solid var(--job-accent, #2c3543);border-radius:9px;cursor:pointer;user-select:none;box-shadow:0 2px 6px #00000059;transition:border-color .12s,box-shadow .12s,transform .08s}.skill-card:hover{transform:translateY(-1px);box-shadow:0 5px 12px #00000080;z-index:1}.skill-card:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.skill-card-icon{grid-column:1;grid-row:1;width:30px;height:30px;image-rendering:pixelated}.skill-card-lv{grid-column:3;grid-row:1;justify-self:end;align-self:start;font-size:calc(10px * var(--ui-scale));font-weight:600;color:var(--muted);padding:1px 5px;border-radius:999px;background:#0a0e148c}.skill-card-name{grid-column:1 / -1;grid-row:2;align-self:start;font-size:calc(11px * var(--ui-scale));line-height:1.16;font-weight:600;max-height:calc(2 * 1.16em * var(--ui-scale));display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere}.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:skillCardFlash .5s ease-out}@keyframes skillCardFlash{0%{box-shadow:0 0 0 3px #6fc06ad9}to{box-shadow:0 0 0 0 transparent}}body.reduce-flashing .skill-card-flash{animation:none}.skill-card-plus{position:absolute;top:-8px;right:-8px;width:20px;height:20px;padding:0;line-height:18px;border-radius:50%;border:1px solid #6fc06a;background:#1d2a1d;color:#b9f0b3;font-size:13px;cursor:pointer;z-index:2}.skill-card-plus:hover{background:#284a28}.skill-card-plus--chain{border-color:#6aa8e0;background:#1a2636;color:#bcdcfb}.skill-card-plus--chain:hover{background:#243a52}.skill-detail{display:flex;align-items:center;gap:10px;min-height:40px;padding:6px 10px;background:var(--panel-2);border:1px solid #2c3543;border-radius:8px}.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{display:flex;flex-direction:column;min-width:0;flex:1}.skill-detail-name{font-weight:600;font-size:calc(13px * var(--ui-scale));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.skill-detail-lv{font-size:calc(11px * var(--ui-scale));color:var(--muted)}.skill-detail-acts{display:flex;gap:6px;flex-shrink:0;align-items:center}.skill-detail-note{font-size:calc(11px * var(--ui-scale));color:var(--muted);white-space:nowrap}.skill-req-block{flex-basis:100%;display:flex;flex-direction:column;gap:1px;margin-top:2px;font-size:calc(10px * var(--ui-scale));line-height:1.25}.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));line-height:1.3;margin:1px 0}.skill-tt-icon{width:20px;height:20px;vertical-align:middle;margin-right:6px;border-radius:4px}.npc-win{bottom:90px;left:50%;transform:translate(-50%);width:460px;max-width:90vw;flex-direction:column;background:var(--panel);border:1px solid #28303d;border-radius:10px;box-shadow:0 18px 50px #00000080;padding:16px;pointer-events:auto}.npc-text{white-space:pre-wrap;margin-bottom:12px;line-height:1.4}.npc-controls{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.npc-btn{align-self:flex-end;padding:7px 18px;background:linear-gradient(180deg,var(--accent),var(--accent-2));border:none;border-radius:6px;color:#1a1206;font-weight:600;cursor:pointer}.npc-btn:hover{filter:brightness(1.07)}.npc-menu-item{width:100%;padding:7px 10px;background:var(--panel-2);border:1px solid #2c3543;border-radius:6px}.npc-menu-item:hover{border-color:var(--accent)}.npc-menu-item.cancel{color:var(--muted)}.npc-input{width:100%;padding:8px 10px;background:var(--panel-2);border:1px solid #2c3543;border-radius:6px;color:var(--text)}.hotbar{bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:6px}.hot-slot{width:calc(56px * var(--ui-scale));height:calc(56px * var(--ui-scale));background:linear-gradient(180deg,#161c26eb,#0a0e14eb);border:1px solid #2c3543;border-radius:9px;position:relative;display:flex;align-items:flex-end;justify-content:center;padding:4px;box-shadow:inset 0 1px #ffffff0a,0 2px 6px #0006;transition:border-color .12s,box-shadow .12s,transform .08s}.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{position:absolute;top:2px;left:5px;z-index:2;font-size:calc(10px * var(--ui-scale));font-weight:600;color:var(--muted);text-shadow:0 1px 2px #000}.hot-name{position:absolute;right:3px;bottom:2px;z-index:2;font-size:calc(11px * var(--ui-scale));font-weight:700;line-height:1;color:#eef1f5;text-shadow:0 1px 2px #000;padding:1px 4px;border-radius:5px;background:#080c1299;max-width:84%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hot-name:empty{display:none}.chat-log{max-height:180px;overflow-y:auto;padding:2px;font-size:calc(12px * var(--ui-scale));pointer-events:auto}.chat-line{margin:1px 0;line-height:1.3;word-wrap:break-word;font-size:calc(12px * var(--ui-scale))}.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{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--accent);margin:8px 0 4px;font-size:calc(12px * var(--ui-scale));text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #28303d;padding-bottom:4px}.inv-section:before{content:"";flex:0 0 auto;width:3px;height:12px;border-radius:2px;background:linear-gradient(180deg,var(--accent),var(--accent-2))}.inv-empty{color:var(--muted);font-size:12px;padding:2px 0 6px}.inv-footer{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding-top:8px;border-top:1px solid #28303d}.inv-weight-bar{position:relative;flex:1;height:16px;border-radius:5px;background:#0a0e14b3;border:1px solid #2c3543;overflow:hidden}.inv-weight-fill{position:absolute;left:0;top:0;bottom:0;width:0;transition:width .2s ease}.inv-weight-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#eef1f5;text-shadow:0 1px 1px #000}.inv-zeny{flex:0 0 auto;font-size:12px;font-weight:700;color:#ffe066;white-space:nowrap;text-shadow:0 1px 1px #000}.inv-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:4px 0}.inv-row-name{font-size:calc(12px * var(--ui-scale));flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-row-name--stacked{display:flex;flex-direction:column;gap:1px;overflow:visible;white-space:normal}.inv-row-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-row-opts{font-size:calc(10px * var(--ui-scale));opacity:.85;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-row-acts{display:flex;gap:4px;flex-shrink:0}.inv-act{pointer-events:auto;font-size:11px;padding:3px 8px;cursor:pointer;background:var(--panel-2);border:1px solid var(--accent);border-radius:5px;color:var(--accent)}.inv-act:hover{background:var(--accent);color:#1a1206}.inv-act.drop{border-color:#5a4453;color:#a98}.inv-act.drop:hover{background:#7a3a3a;color:#fff;border-color:#7a3a3a}.target-panel{top:50px;left:50%;transform:translate(-50%);flex-direction:column;align-items:center;gap:4px;background:#0a0e14d1;border:1px solid #28303d;border-radius:8px;padding:6px 14px;min-width:160px;pointer-events:none}.target-name{font-weight:700;font-size:calc(14px * var(--ui-scale));text-shadow:0 1px 2px #000}.target-hp{position:relative;width:100%;height:14px;background:#2a1316;border:1px solid #3a4453;border-radius:4px;overflow:hidden}.target-hp-fill{height:100%;width:100%;background:linear-gradient(90deg,#c0392b,#e0533d);position:relative;z-index:1;transition:width .15s,background .15s}.target-hp-fill.target-hp-ghost{position:absolute;left:0;top:0;z-index:0;background:linear-gradient(90deg,#7a1f17,#a3392f);transition:width .4s ease-out}body.reduce-flashing .target-hp-fill.target-hp-ghost{transition:none}.target-hp-fill.execute{background:linear-gradient(90deg,#e0b020,#f5853a)}.target-hp-text{position:absolute;inset:0;text-align:center;font-size:calc(11px * var(--ui-scale));line-height:14px;color:#fff;text-shadow:0 1px 1px #000}.hot-slot.flash{animation:hotflash .6s ease-out}@keyframes hotflash{0%{box-shadow:0 0 0 3px var(--accent)}to{box-shadow:0 0 0 0 transparent}}.hot-slot.ready{animation:hotready .5s ease-out}@keyframes hotready{0%{box-shadow:0 0 0 3px var(--accent-2, #5fd38a)}to{box-shadow:0 0 0 0 transparent}}.context-menu{position:fixed;z-index:200;min-width:130px;background:#0c1018f7;border:1px solid #3a4453;border-radius:7px;padding:4px;box-shadow:0 8px 24px #00000080;pointer-events:auto;display:flex;flex-direction:column}.context-title{font-weight:700;font-size:12px;color:var(--accent);padding:4px 8px 6px;border-bottom:1px solid #28303d}.context-item{width:100%;text-align:left;font-size:calc(13px * var(--ui-scale));padding:7px 10px;border-radius:5px;cursor:pointer}.context-item:hover{background:var(--accent);color:#1a1206}.status-tray{top:200px;left:12px;display:flex;flex-wrap:wrap;gap:4px;max-width:240px}.status-icon{position:relative;width:calc(40px * var(--ui-scale));height:calc(40px * var(--ui-scale));background:#0a0e14e6;border:1px solid var(--accent-2);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:auto;cursor:default;--frac: 1}.status-icon.timed:before{content:"";position:absolute;inset:0;border-radius:inherit;z-index:0;pointer-events:none;background:conic-gradient(var(--ring, rgba(255,255,255,.16)) calc(var(--frac) * 360deg),transparent 0);-webkit-mask:radial-gradient(circle,transparent 58%,#000 60%);mask:radial-gradient(circle,transparent 58%,#000 60%)}.status-icon.timed.buff{--ring: rgba(111,208,106,.55)}.status-icon.timed.debuff{--ring: rgba(224,83,61,.6)}.status-icon .status-abbr,.status-icon .status-time{position:relative;z-index:1}.status-abbr{font-size:calc(11px * var(--ui-scale));font-weight:700;color:var(--accent)}.status-time{font-size:calc(9px * var(--ui-scale));color:var(--muted)}.status-icon.buff{border-color:#4f9d4f}.status-icon.buff .status-abbr{color:#6fd06a}.status-icon.debuff{border-color:var(--danger);animation:debuff-pulse 1.1s ease-in-out infinite}.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{inset:auto 0 0;height:3px;border-radius:0 0 6px 6px;width:calc(var(--frac) * 100%);background:var(--ring, rgba(255,255,255,.3));-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{position:fixed;z-index:210;min-width:150px;max-width:210px;pointer-events:none;background:#080c12f7;border:1px solid #3a4453;border-radius:7px;padding:8px 10px;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{font-size:10px;color:var(--muted);margin-top:4px}.tt-rowlabel{font-size:calc(10px * var(--ui-scale));text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:6px 0 3px}.tt-stats{display:grid;grid-template-columns:auto 1fr;gap:3px calc(10px * var(--ui-scale))}.tt-amt{font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}.tt-eff{color:#cdd3dd;font-size:calc(11px * var(--ui-scale))}.info-bar{position:fixed;bottom:8px;right:12px;z-index:18;pointer-events:none;font-size:11px;color:#8a93a3;text-shadow:0 1px 2px #000;background:#0a0e1480;padding:2px 8px;border-radius:5px}.toast-layer{position:fixed;top:120px;left:50%;transform:translate(-50%);z-index:36;display:flex;flex-direction:column;gap:6px;align-items:center;pointer-events:none}.toast{padding:8px 18px;border-radius:8px;font-weight:600;font-size:14px;text-shadow:0 1px 2px #000;background:#0a0e14eb;border:1px solid #3a4453;opacity:0;transform:translateY(-8px);transition:opacity .3s,transform .3s}.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{position:fixed;top:28%;left:50%;transform:translate(-50%,-50%) scale(.9);z-index:30;pointer-events:none;font-size:34px;font-weight:800;letter-spacing:1px;color:#fff;text-shadow:0 2px 10px #000,0 0 24px rgba(217,164,65,.5);opacity:0;transition:opacity .6s ease,transform .6s ease}.map-banner.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.window{pointer-events:auto}.win-head{user-select:none}.hot-slot{position:relative;overflow:hidden}.hot-cd{position:absolute;left:0;bottom:0;width:100%;background:#0a0e14b8;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;text-shadow:0 1px 2px #000;pointer-events:none}.weight-row{position:relative;height:16px;background:#1a2028;border:1px solid #28303d;border-radius:4px;overflow:hidden;margin-top:3px}.weight-fill{position:absolute;left:0;top:0;height:100%;background:#4f9d4f;transition:width .2s,background .2s}.weight-text{position:absolute;inset:0;text-align:center;font-size:10px;line-height:16px;color:#fff;text-shadow:0 1px 1px #000}.map-transition{position:fixed;inset:0;z-index:44;pointer-events:none;background:#05070b;opacity:0;transition:opacity .28s ease}.map-transition.show{opacity:1;pointer-events:auto}.safe-compass{position:fixed;top:96px;left:50%;transform:translate(-50%);z-index:17;pointer-events:none;text-align:center}.safe-arrow{font-size:30px;color:#7fd0ff;text-shadow:0 0 8px rgba(127,208,255,.8),0 2px 3px #000;line-height:1}.safe-dist{font-size:11px;color:#cfe6ff;text-shadow:0 1px 2px #000;margin-top:2px}.threat-chevron{position:fixed;z-index:18;pointer-events:none;font-size:34px;color:#ff5a4a;line-height:1;text-shadow:0 0 10px rgba(255,90,74,.9),0 2px 4px #000;opacity:0}.threat-chevron.show{animation:threat-flash 1s ease-out}@keyframes threat-flash{0%{opacity:0}12%{opacity:1}60%{opacity:.9}to{opacity:0}}body.reduce-flashing .threat-chevron.show{animation:none;opacity:.85}.menu-select{width:100%;padding:6px 8px;border-radius:6px;background:#0a0e14cc;border:1px solid #28303d;color:#e6e6e6;font-size:calc(12px * var(--ui-scale));cursor:pointer}.menu-select:hover{border-color:var(--accent)}.inv-icon{flex-shrink:0;image-rendering:auto;border-radius:5px}.inv-row{align-items:center;gap:8px}.paperdoll{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;margin-bottom:2px;padding:10px;background:radial-gradient(120% 90% at 50% 0%,#242e3e80,#080c1280);border:1px solid #2c3543;border-radius:8px}.pd-col{display:flex;flex-direction:column;gap:6px}.pd-slot{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center;text-align:center;background:linear-gradient(160deg,#161c26e6,#0c1016e6);border:1px solid #2c3543;border-radius:6px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.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{font-size:9px;line-height:1.15;color:var(--muted);padding:0 2px;overflow-wrap:anywhere}.pd-figure{display:flex;align-items:center;justify-content:center;min-width:64px;align-self:stretch}.pd-figure svg{width:80%;max-width:84px;height:auto;fill:#46566a;filter:drop-shadow(0 3px 6px rgba(0,0,0,.4))}.pd-refine{position:absolute;left:2px;top:1px;z-index:1;font-size:10px;font-weight:700;color:#ffe066;line-height:1;text-shadow:0 1px 1px #000}.inv-draggable{cursor:grab}.inv-draggable:active{cursor:grabbing}.pd-slot.pd-drop{border-color:#6fd06a;box-shadow:0 0 0 2px #6fd06a80 inset}:focus-visible{outline:2px solid #7fd0ff;outline-offset:2px}button:focus-visible,.menu-btn:focus-visible,.hot-slot:focus-visible,.inv-act:focus-visible{outline:2px solid #7fd0ff;outline-offset:1px}@media (prefers-reduced-motion: reduce){.toast,.map-banner,.map-transition,.target-hp-fill,.weight-fill,.menu-btn{transition:none!important}}.announce-bar{position:fixed;top:0;left:0;right:0;z-index:38;pointer-events:none;padding:7px 16px;text-align:center;font-weight:600;font-size:13px;color:#ffe9a8;background:linear-gradient(90deg,#3c280a00,#50370ceb 20% 80%,#3c280a00);text-shadow:0 1px 2px #000;transform:translateY(-110%);transition:transform .35s ease}.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{min-width:130px}}@media (max-width: 560px){.info-bar{font-size:9px}.menu-buttons{transform:scale(.92)}}.chat-wrap{position:fixed;bottom:12px;left:12px;z-index:19;width:360px;max-width:92vw;display:flex;flex-direction:column;background:#0a0e14c7;border:1px solid #28303d;border-radius:8px;padding:6px;box-shadow:0 8px 24px #0006;pointer-events:auto}.chat-tabs{display:flex;gap:3px;margin-bottom:4px;pointer-events:auto}.chat-tab{font-size:11px;padding:3px 9px;cursor:pointer;border-radius:5px;background:#0a0e14b3;border:1px solid #28303d;color:var(--muted)}.chat-tab.active{background:#141c26f2;color:var(--accent);border-color:var(--accent)}.chat-tab{position:relative;display:inline-flex;align-items:center;gap:5px}.chat-badge{min-width:16px;padding:0 4px;border-radius:9px;font-size:10px;line-height:15px;text-align:center;color:#1a1206;font-weight:700;background:linear-gradient(180deg,var(--accent),var(--accent-2))}.chat-ts-toggle{margin-left:auto;padding:3px 7px}.chat-log{max-height:150px;overflow-y:auto}.chat-new-msgs{align-self:center;margin-top:3px;padding:2px 12px;cursor:pointer;font-size:11px;font-weight:600;color:#1a1206;pointer-events:auto;background:linear-gradient(180deg,var(--accent),var(--accent-2));border:none;border-radius:10px;box-shadow:0 2px 6px #0006}.chat-new-msgs:hover{filter:brightness(1.08)}.chat-input{width:100%;box-sizing:border-box;padding:7px 9px;margin-top:5px;background:#0a0e14d9;border:1px solid #28303d;border-radius:6px;color:#e6e6e6;font-size:calc(12px * var(--ui-scale))}.chat-input:focus{outline:none;border-color:var(--accent)}.chat-line.channel{color:var(--accent-2)}.chat-line.announce{color:var(--accent);font-weight:600}.chat-line.error{color:#ff7a7a}.chat-line.emote{color:#c9a0ff;font-style:italic}.chat-time{color:var(--muted);font-size:.85em;opacity:.8}.qd-overlay{position:fixed;inset:0;z-index:220;display:flex;align-items:center;justify-content:center;background:#080a108c}.qd-panel{width:320px}.qd-field{margin:14px 0 18px}.qd-field input[type=number]{width:100%;padding:9px 12px;background:var(--panel-2);border:1px solid #2c3543;border-radius:8px;color:var(--text);font-size:14px}.qd-field input[type=number]:focus{outline:none;border-color:var(--accent)}.qd-slider{width:100%;margin-top:10px;accent-color:var(--accent)}.qd-actions{display:flex;gap:8px}.qd-actions .primary{flex:1}.qd-cancel{flex:1;padding:11px;background:var(--panel-2);border:1px solid #2c3543;border-radius:8px;color:var(--text);font-weight:600;font-size:15px;cursor:pointer}.qd-cancel:hover{border-color:var(--accent)}.qd-ok.qd-danger{background:linear-gradient(180deg,#e0533d,#b3382a);color:#fff}.bar-fill.hp.critical{animation:hp-pulse .7s ease-in-out infinite}@keyframes hp-pulse{0%,to{background:linear-gradient(90deg,#c0392b,#e0533d);filter:brightness(1)}50%{background:linear-gradient(90deg,#ff5a44,#ff8a76);filter:brightness(1.5)}}.bar-fill.sp.critical{animation:sp-pulse .7s ease-in-out infinite}@keyframes sp-pulse{0%,to{background:linear-gradient(90deg,#2471a3,#3498db);filter:brightness(1)}50%{background:linear-gradient(90deg,#4aa3ff,#8fd0ff);filter:brightness(1.5)}}.status-panel.critical{border-color:var(--danger)}.crit-vignette{position:fixed;inset:0;z-index:9;pointer-events:none;opacity:0;box-shadow:inset 0 0 110px 30px #e0352d8c;transition:opacity .3s ease}.crit-vignette.show{opacity:1;animation:vignette-pulse 1.4s ease-in-out infinite}@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 .weight-fill,body.reduce-motion .announce-bar{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{position:fixed;top:130px;left:50%;transform:translate(-50%);z-index:40;pointer-events:none;padding:9px 20px;border-radius:8px;font-weight:700;font-size:15px;color:#cdecff;background:#142846eb;border:1px solid #6fc3ff;box-shadow:0 0 16px #6fc3ff80;text-shadow:0 1px 2px #000}body.high-contrast{--muted: #d2d8e2;--text: #ffffff;--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{background:#ffd21a}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{top:60px;left:auto;transform:none;width:240px}.window.win-party{right:12px}.window.win-friends{right:24px;top:96px}.window.win-guild{right:36px;top:132px;width:380px;max-width:92vw}.win-party .win-body,.win-friends .win-body,.win-guild .win-body{display:flex;flex-direction:column;gap:8px;max-height:72vh}.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{width:auto;padding:5px 12px;font-size:12px;border-radius:6px;background:linear-gradient(180deg,var(--accent),var(--accent-2))}.social-leave{align-self:flex-start;padding:4px 12px;font-size:12px;cursor:pointer;background:var(--panel-2);border:1px solid #5a4453;border-radius:6px;color:#d9a3a3}.social-leave:hover{background:#7a3a3a;border-color:#7a3a3a;color:#fff}.social-leave.sw-danger{border-color:#6e3030;color:#f0a8a8}.sw-tabs{display:flex;gap:2px;margin-bottom:8px;border-bottom:1px solid #2c3543}.sw-tab{flex:1;padding:6px 8px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.3px;cursor:pointer;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(180deg,#20283699,#141a2499);border:1px solid #2c3543;border-radius:8px;padding:10px 12px;box-shadow:inset 0 1px #ffffff0a;display:flex;flex-direction:column;gap:7px}.sw-stat{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.sw-stat-label{color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px}.sw-stat-val{color:var(--text);font-weight:600;font-size:12px}.sw-bar{position:relative;height:11px;background:#10151d;border-radius:6px;overflow:hidden;box-shadow:inset 0 1px 2px #0000008c}.sw-bar-fill{position:relative;height:100%;border-radius:6px;background:linear-gradient(180deg,var(--accent),var(--accent-2));box-shadow:0 0 8px #d9a44166;transition:width .3s}.sw-bar-fill:after{content:"";position:absolute;inset:0 0 50%;background:linear-gradient(180deg,rgba(255,255,255,.22),transparent);border-radius:6px 6px 0 0}.sw-bar-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;text-shadow:0 1px 1px #000}.sw-dot{width:8px;height:8px;border-radius:50%;flex:none}.sw-dot.on{background:#5fd35f;box-shadow:0 0 6px #5fd35fd9}.sw-dot.off{background:#46505f}.sw-row{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;cursor:pointer;transition:background-color .1s}.sw-row:hover{background:#d9a4411a}.sw-row:focus-visible{outline:2px solid #7fd0ff;outline-offset:-2px}.sw-row.off{opacity:.55}.sw-id{min-width:0;flex:1;display:flex;flex-direction:column;gap:1px}.sw-name{font-size:12px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sw-sub{font-size:10px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sw-rolechip{width:24px;height:24px;flex:none;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#0c0f15;box-shadow:inset 0 0 0 1px #ffffff26}.sw-badge{font-size:9px;font-weight:700;padding:1px 6px;border-radius:999px;background:#d9a4412e;color:var(--accent);border:1px solid rgba(217,164,65,.35);white-space:nowrap}.sw-badge.lead{background:#d9a44147}.sw-section{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);display:flex;align-items:center;gap:6px;margin:6px 0 3px}.sw-section:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,#2c3543,transparent)}.sw-skill{display:flex;align-items:center;gap:9px;padding:7px;border:1px solid #2c3543;border-radius:8px;background:linear-gradient(180deg,#1c243080,#12182080)}.sw-skill img{width:30px;height:30px;border-radius:6px;flex:none;background:#10151d}.sw-skill-lv{margin-left:auto;font-size:11px;font-weight:700;color:var(--accent);flex:none}.sw-skill.maxed .sw-skill-lv{color:#5fd35f}.sw-sortbar{display:flex;gap:4px;margin:2px 0 6px}.sw-sort{font-size:10px;padding:2px 8px;border-radius:999px;cursor:pointer;background:transparent;border:1px solid #2c3543;color:var(--muted)}.sw-sort:hover{border-color:var(--accent);color:var(--text)}.sw-sort[aria-pressed=true]{background:#d9a44129;border-color:var(--accent);color:var(--accent)}.sw-icon-btn{flex:none;padding:2px 8px;background:transparent;border:1px solid #2c3543;border-radius:5px;color:var(--muted);font-size:11px;cursor:pointer}.sw-icon-btn:hover{border-color:var(--accent);color:var(--accent)}.menu-root,.menu-overlay,.menu-toast{--line: #28303d;--line-strong: #3a4453;--panel-3: #232e3e;--ink: #1a1206;--text-2: #b9c0cc;--success: #5bbf7a;--glass: rgba(20, 26, 36, .72);--glass-2: rgba(28, 37, 51, .55);--glass-hi: rgba(38, 49, 67, .7);--blur: 12px;--accent-soft: rgba(217, 164, 65, .14);--accent-line: rgba(217, 164, 65, .55);--danger-soft: rgba(224, 83, 61, .14);--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 rgba(0, 0, 0, .35);--elev-2: 0 18px 50px rgba(0, 0, 0, .55);--elev-3: 0 30px 80px rgba(0, 0, 0, .65);--elev-hero: 0 24px 70px rgba(0, 0, 0, .6), 0 0 0 1px var(--accent-line), 0 0 40px -8px rgba(217, 164, 65, .25);--inset-top: inset 0 1px 0 rgba(255, 255, 255, .04);--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{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:var(--s5);overflow:auto}.menu-root>*{position:relative;z-index:1}.menu-sr{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.menu-bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:radial-gradient(120% 80% at 50% -10%,#16203a 0%,#0c1018 45%,var(--bg) 75%)}.menu-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(120% 100% at 50% 40%,transparent 55%,rgba(0,0,0,.55) 100%)}.menu-aurora{position:absolute;inset:-20%;filter:blur(60px);opacity:.5;will-change:transform;background:radial-gradient(40% 30% at 30% 25%,rgba(64,120,150,.45),transparent 70%),radial-gradient(45% 35% at 70% 20%,rgba(120,100,160,.35),transparent 70%),radial-gradient(35% 25% at 55% 15%,rgba(217,164,65,.1),transparent 70%);animation:menu-aurora-drift 48s ease-in-out infinite alternate}.menu-aurora.menu-aurora--b{opacity:.32;filter:blur(80px);animation-duration:67s;animation-direction:alternate-reverse}@keyframes menu-aurora-drift{0%{transform:translate3d(-3%,0,0) scale(1.05)}to{transform:translate3d(3%,2%,0) scale(1.12)}}.menu-particles{position:absolute;inset:0;width:100%;height:100%}.menu-panel{position:relative;background:var(--glass);backdrop-filter:blur(var(--blur)) saturate(120%);-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);padding:clamp(24px,3vw,32px);color:var(--text);animation:menu-surface-in var(--dur) var(--ease) both}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){.menu-panel,.menu-overlay__card,.menu-toast{background:var(--panel)}}.menu-panel:before{content:"";position:absolute;inset:0 0 auto;height:2px;border-radius:var(--r-lg) var(--r-lg) 0 0;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.7}.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{display:flex;flex-direction:column;gap:var(--s4)}.menu-panel__actions{display:flex;gap:var(--s3);margin-top:var(--s2)}@keyframes menu-surface-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.menu-button{position:relative;padding:11px 16px;border-radius:var(--r-sm);border:1px solid transparent;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)}.menu-button:active{transform:translateY(1px) scale(.99)}.menu-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.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);font-weight:700;border-color:transparent}.menu-button--primary:hover{filter:brightness(1.07)}.menu-button--block{width:100%}.menu-button--ghost{background:transparent;border-color:var(--line);color:var(--text)}.menu-button--ghost:hover{background:var(--panel-3);border-color:var(--line-strong)}.menu-button--danger{background:transparent;border-color:#e0533d80;color:var(--danger)}.menu-button--danger:hover{background:var(--danger-soft);border-color:var(--danger)}.menu-button.is-loading{color:transparent;pointer-events:none}.menu-button.is-loading:after{content:"";position:absolute;inset:0;margin:auto;width:calc(16px * var(--ui-scale));height:calc(16px * var(--ui-scale));border-radius:50%;background:conic-gradient(from 0deg,transparent,currentColor);-webkit-mask:radial-gradient(circle,transparent 52%,#000 54%);mask:radial-gradient(circle,transparent 52%,#000 54%);color:var(--ink);animation:menu-spin .8s linear infinite}.menu-button--ghost.is-loading:after,.menu-button--danger.is-loading:after{color:var(--accent)}.menu-field{display:flex;flex-direction:column;gap:6px}.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{position:relative;display:flex;align-items:center}.menu-input{width:100%;padding:11px 12px;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)}.menu-input::placeholder{color:#5f6877}.menu-input:hover{border-color:var(--line-strong)}.menu-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--glass-hi)}.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:"!";position:absolute;right:11px;top:50%;transform:translateY(-50%);font-weight:800;color:var(--danger);pointer-events:none}.menu-field__hint{font-size:calc(11px * var(--ui-scale));color:var(--muted)}.menu-reveal{position:absolute;right:6px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--r-sm);background:none;color:var(--muted);cursor:pointer;transition:color var(--dur),background var(--dur)}.menu-reveal:hover{color:var(--text);background:var(--glass-2)}.menu-reveal:focus-visible{outline:none;box-shadow:var(--focus-ring)}.menu-reveal svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.6}.menu-status{display:flex;align-items:center;gap:6px;min-height:calc(18px * var(--ui-scale));font-size:calc(12px * var(--ui-scale));color:var(--muted)}.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{width:24px;height:24px;border-radius:50%;background:conic-gradient(from 0deg,transparent,var(--accent));-webkit-mask:radial-gradient(circle,transparent 52%,#000 54%);mask:radial-gradient(circle,transparent 52%,#000 54%);animation:menu-spin .8s linear infinite}@keyframes menu-spin{to{transform:rotate(360deg)}}.menu-bar{position:relative;height:6px;border-radius:3px;background:var(--panel-2);overflow:hidden}.menu-bar__fill{position:absolute;inset:0 auto 0 0;width:0;border-radius:inherit;transition:width var(--dur-slow) var(--ease)}.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{display:grid;grid-template-columns:26px 1fr auto;align-items:center;gap:var(--s2)}.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{position:relative;display:grid;place-items:center;width:64px;height:64px;border-radius:50%;color:var(--accent);background:radial-gradient(circle at 50% 35%,var(--crest-tint, rgba(217, 164, 65, .22)),rgba(8,12,18,.6) 70%);border:2px solid var(--crest-ring, var(--accent-line));box-shadow:inset 0 1px #ffffff14,0 4px 14px #0006}.menu-crest__glyph{font-size:28px;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}.menu-crest--sm{width:40px;height:40px}.menu-crest--sm .menu-crest__glyph{font-size:18px}.login-screen{display:flex;flex-direction:column;align-items:center;gap:var(--s6);width:min(var(--panel-w),92vw)}.login-brand{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--s2)}.login-wordmark{display:inline-flex;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));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 2px 24px rgba(217,164,65,.25)}.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{position:fixed;left:0;right:0;bottom:max(var(--s4),env(safe-area-inset-bottom));z-index:1;display:flex;align-items:center;justify-content:center;gap:var(--s4);font:600 calc(11px * var(--ui-scale)) / 1 inherit;letter-spacing:.4px;color:var(--muted);pointer-events:none}.menu-footer>*{pointer-events:auto}.menu-locale{display:inline-flex;gap:2px}.menu-locale__opt{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px 6px;border-radius:var(--r-sm);font:inherit;text-transform:uppercase}.menu-locale__opt:hover{color:var(--text)}.menu-locale__opt.is-active{color:var(--accent)}.menu-locale__opt:focus-visible{outline:none;box-shadow:var(--focus-ring)}.cs-screen{display:flex;flex-direction:column;gap:var(--s4);width:min(calc(var(--hero-w) + var(--rail-w) + var(--s5)),94vw)}.cs-header{display:flex;align-items:center;gap:var(--s3)}.cs-header__brand{display:inline-flex;align-items:center;gap:var(--s2);font:700 calc(18px * var(--ui-scale)) / 1 inherit;color:var(--accent)}.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{display:grid;grid-template-columns:var(--hero-w) var(--rail-w);gap:var(--s5);align-items:start}.cs-hero{box-shadow:var(--elev-hero),var(--inset-top);display:flex;flex-direction:column;gap:var(--s4)}.cs-hero__head{display:grid;grid-template-columns:auto 1fr;gap:var(--s4);align-items:center}.cs-hero__id{display:flex;flex-direction:column;gap:2px;min-width:0}.cs-hero__name{font:700 calc(22px * var(--ui-scale)) / 1.15 inherit;letter-spacing:.3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cs-hero__class{color:var(--muted);font-size:calc(13px * var(--ui-scale))}.cs-hero__vitals{display:flex;flex-direction:column;gap:var(--s2)}.cs-hero__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s2)}.cs-stat{display:flex;align-items:baseline;justify-content:space-between;gap:var(--s1);padding:6px 10px;border-radius:var(--r-sm);background:var(--glass-2);border:1px solid var(--line)}.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{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);font-size:calc(12px * var(--ui-scale));color:var(--muted)}.cs-hero__meta b{color:#ffe066;font-weight:700;font-variant-numeric:tabular-nums}.cs-hero__actions{display:flex;gap:var(--s3);margin-top:auto}.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{align-items:center;text-align:center;justify-content:center;gap:var(--s4);min-height:320px}.cs-hero.is-empty .cs-empty-plus{font-size:calc(56px * var(--ui-scale));line-height:1;color:var(--accent);opacity:.8}.cs-rail{display:flex;flex-direction:column;gap:var(--s2);max-height:70vh;overflow-y:auto;padding-right:2px}.cs-slot{display:flex;align-items:center;gap:var(--s3);width:100%;text-align:left;padding:10px 12px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--glass-2);color:var(--text);cursor:pointer;transition:border-color var(--dur),background var(--dur),transform var(--dur),box-shadow var(--dur)}.cs-slot:hover{border-color:var(--line-strong);background:var(--glass-hi);transform:translateY(-2px);box-shadow:var(--elev-1)}.cs-slot:focus-visible{outline:none;box-shadow:var(--focus-ring)}.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{flex:0 0 auto;width:8px;height:8px;border-radius:50%;border:1px solid var(--line-strong)}.cs-slot[aria-current=true] .cs-slot__dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px #d9a441b3}.cs-slot__body{display:flex;flex-direction:column;gap:1px;min-width:0}.cs-slot__name{font:600 calc(13px * var(--ui-scale)) / 1.2 inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cs-slot__meta{font-size:calc(11px * var(--ui-scale));color:var(--muted)}.cs-slot.is-create{border-style:dashed;color:var(--muted);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{transform:none;box-shadow:none;border-color:var(--line);background:var(--glass-2)}.create-grid{display:grid;grid-template-columns:auto 1fr;gap:var(--s5);align-items:start}.create-preview{display:flex;flex-direction:column;align-items:center;gap:var(--s2)}.create-preview .menu-crest{width:88px;height:88px}.create-preview .menu-crest__glyph{font-size:40px}.create-fields{display:flex;flex-direction:column;gap:var(--s4)}.create-count{align-self:flex-end;font-size:calc(11px * var(--ui-scale));color:var(--muted);font-variant-numeric:tabular-nums}.create-stepper{display:flex;align-items:center;gap:var(--s2)}.create-stepper__btn{flex:0 0 auto;width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--glass-2);color:var(--text);cursor:pointer;font-size:16px;transition:border-color var(--dur),background var(--dur)}.create-stepper__btn:hover{border-color:var(--accent)}.create-stepper__btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.create-stepper__val{flex:1;text-align:center;font:700 calc(15px * var(--ui-scale)) / 1 inherit;font-variant-numeric:tabular-nums}.create-swatches{display:flex;flex-wrap:wrap;gap:var(--s2)}.create-swatch{position:relative;width:30px;height:30px;border-radius:50%;border:2px solid var(--line-strong);cursor:pointer;padding:0;transition:transform var(--dur),border-color var(--dur),box-shadow var(--dur)}.create-swatch:hover{transform:scale(1.08)}.create-swatch:focus-visible{outline:none;box-shadow:var(--focus-ring)}.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:"✓";position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:14px;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.9)}.delete-echo{display:flex;align-items:center;gap:var(--s3);padding:var(--s3);border-radius:var(--r-md);background:var(--glass-2);border:1px solid var(--line)}.delete-echo__body{display:flex;flex-direction:column;gap:1px;min-width:0}.delete-echo__name{font:700 calc(15px * var(--ui-scale)) / 1.2 inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delete-echo__meta{font-size:calc(12px * var(--ui-scale));color:var(--muted)}.pin-panel{width:min(340px,92vw);text-align:center}.pin-panel__icon{font-size:28px;line-height:1;color:var(--accent);margin-bottom:var(--s2)}.pin-dots{display:flex;justify-content:center;gap:var(--s4);margin:var(--s5) 0}.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--accent-line);background:transparent;transition:transform var(--dur-fast) var(--ease),background var(--dur-fast)}.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{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s2)}.pin-key{min-height:clamp(48px,9vw,56px);border-radius:var(--r-sm);border:1px solid var(--line);background:var(--glass-2);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{outline:none;box-shadow:var(--focus-ring)}.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{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:var(--s5)}.menu-overlay--fatal{z-index:60}.menu-overlay__scrim{position:absolute;inset:0;background:#080b10b8;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:menu-fade var(--dur) var(--ease) both}.menu-overlay__card{position:relative;z-index:1;width:min(360px,90vw);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--s4);background:var(--glass);backdrop-filter:blur(var(--blur)) saturate(120%);-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}.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{position:fixed;left:50%;bottom:max(var(--s5),env(safe-area-inset-bottom));transform:translate(-50%);z-index:55;display:flex;align-items:center;gap:var(--s2);padding:8px 16px;border-radius:var(--r-pill);background:var(--glass);backdrop-filter:blur(var(--blur));-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}.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-direction:row;flex-wrap:nowrap;max-height:none;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.cs-slot{flex:0 0 auto;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{animation:none;transition: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{position:fixed;bottom:12px;left:50%;transform:translate(-50%);display:flex;flex-direction:column-reverse;align-items:center;gap:4px;pointer-events:none;z-index:30}.action-bar{display:flex;flex-direction:row;gap:3px;padding:3px;border-radius:8px;background:#0a0e146b;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{top:1px;right:3px;left:auto;font-size:calc(10px * var(--ui-scale));font-weight:600;color:var(--muted);text-shadow:0 1px 1px #000}.action-bars__config{position:absolute;right:-34px;bottom:0;pointer-events:auto}.action-bar__handle{width:26px;height:26px;padding:0;border:1px solid #2c3543;border-radius:6px;background:#0a0e14d1;color:var(--muted);font-size:14px;line-height:1;cursor:pointer}.action-bar__handle:hover{color:var(--accent);border-color:var(--accent)}.action-bars__popover{position:absolute;right:0;bottom:32px;display:flex;flex-direction:column;gap:6px;padding:8px 10px;white-space:nowrap;background:#0a0e14f0;border:1px solid #2c3543;border-radius:8px;box-shadow:0 6px 18px #00000080}.action-bars__opt{display:flex;align-items:center;gap:7px;font-size:12px;color:#d6dde6;cursor:pointer}.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{position:fixed;inset:0;z-index:45;display:none;align-items:center;justify-content:center;background:#080a1099}.esc-root__panel{width:240px;display:flex;flex-direction:column;gap:8px}.esc-root__panel h1{margin:0 0 6px}.esc-root__btn{width:100%}.settings-win{position:fixed;inset:0;z-index:45;display:none;align-items:center;justify-content:center;background:#080a1099}.settings-dialog{width:600px;max-width:94vw;max-height:88vh;display:flex;flex-direction:column;gap:10px;overflow:hidden}.settings-dialog__title{margin:0}.settings-body{display:flex;gap:14px;min-height:0;flex:1}.settings-rail{display:flex;flex-direction:column;gap:4px;width:140px;flex:0 0 140px;border-right:1px solid #28303d;padding-right:10px}.settings-rail__tab{text-align:left;padding:8px 10px;font-size:13px;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--muted);cursor:pointer}.settings-rail__tab:hover{background:var(--panel-2);color:#e6e6e6}.settings-rail__tab.is-active{background:var(--panel-2);border-color:#28303d;color:var(--accent);font-weight:600}.settings-pane-host{flex:1;min-width:0;overflow-y:auto}.settings-pane{display:none;flex-direction:column;gap:10px}.settings-row{display:flex;flex-direction:column;gap:4px}.settings-row--check{flex-direction:row;align-items:center;gap:8px;font-size:12px;color:var(--muted);cursor:pointer}.settings-row__label{font-size:12px;color:var(--muted)}.settings-row__head{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}.settings-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:6px;padding-top:10px;border-top:1px solid #28303d}.settings-footer__btn{font-size:11px;padding:4px 12px;background:var(--panel-2);border:1px solid #28303d;border-radius:6px;color:var(--muted);cursor:pointer}.settings-footer__btn:hover{color:#e6e6e6}.settings-footer__btn--danger{border-color:#5a2630;color:#ff9b9b}.settings-controls{display:flex;flex-direction:column;gap:8px}.settings-controls__grid{display:grid;grid-template-columns:1fr auto;gap:4px 10px;align-items:center;font-size:12px}.settings-controls__label{color:var(--muted)}.settings-controls__key{min-width:110px;font-size:11px;padding:3px 8px;background:var(--panel-2);border:1px solid #28303d;border-radius:6px;color:#e6e6e6;cursor:pointer}.settings-controls__key.is-reassigned{box-shadow:0 0 0 2px #d9a441;transition:box-shadow .12s ease-out}.settings-controls__ref{font-size:11px;color:var(--muted);line-height:1.6;margin-top:4px}.settings-controls__ref b{color:var(--accent)}.weapon-kit-bar.is-hidden{display:none}
