.theme-icon-btn[data-v-13499c33]{display:inline-flex;align-items:center;justify-content:center;min-width:28px;min-height:28px;padding:0;border:0;border-radius:0;background:transparent;color:var(--ui-text-2);box-shadow:none;cursor:pointer}.theme-icon-btn svg[data-v-13499c33]{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.theme-icon-btn svg circle[data-v-13499c33],.theme-icon-btn svg path[data-v-13499c33]:first-child:last-child{fill:currentColor}.top-bar-right .theme-toggle-btn[data-v-72295cfd],.top-bar-right .top-link-danger[data-v-72295cfd]{border-radius:16px!important}.top-user-trigger[data-v-72295cfd]{display:inline-flex;align-items:center;padding:0;border:none;background:transparent;border-radius:16px}.top-profile-overlay[data-v-72295cfd]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:420;display:flex;align-items:flex-start;justify-content:center;padding:72px 12px 12px;background:var(--ui-overlay)}.top-profile-card[data-v-72295cfd]{width:min(100%,520px);border-radius:24px!important;padding:18px!important;background:color-mix(in srgb,var(--ui-surface-2) 96%,white 4%)!important;border-color:color-mix(in srgb,var(--ui-border) 92%,white 8%)!important}.top-profile-head[data-v-72295cfd]{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid color-mix(in srgb,var(--ui-border) 78%,transparent)}.top-profile-avatar[data-v-72295cfd]{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;font-size:18px;font-weight:800;flex-shrink:0}.top-profile-copy[data-v-72295cfd]{min-width:0;flex:1}.top-profile-name-row[data-v-72295cfd]{display:flex;align-items:baseline;gap:8px}.top-profile-name[data-v-72295cfd]{font-size:19px;font-weight:800;color:var(--ui-text)}.top-profile-level[data-v-72295cfd]{color:var(--ui-primary);font-size:13px;font-weight:800}.top-profile-meta[data-v-72295cfd]{display:flex;flex-wrap:wrap;gap:4px 10px;margin-top:5px;font-size:12px;color:var(--ui-muted)}.top-profile-grid[data-v-72295cfd]{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:14px}.top-profile-grid span[data-v-72295cfd],.top-profile-chip[data-v-72295cfd]{display:inline-flex;align-items:center;min-height:36px;padding:0 12px;border:1px solid color-mix(in srgb,var(--ui-border) 86%,transparent);border-radius:14px;background:color-mix(in srgb,var(--ui-surface-soft) 88%,white 12%);color:var(--ui-text-2);font-size:11px;line-height:1.2}.top-profile-inline-list[data-v-72295cfd]{margin-top:14px}.top-profile-inline-title[data-v-72295cfd]{margin-bottom:7px;font-size:12px;font-weight:800;color:var(--ui-muted);letter-spacing:.08em}.top-profile-inline-items[data-v-72295cfd]{display:flex;flex-wrap:wrap;gap:6px}.top-profile-chip.is-muted[data-v-72295cfd]{color:var(--ui-muted)}.top-profile-actions[data-v-72295cfd]{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid color-mix(in srgb,var(--ui-border) 78%,transparent)}@media(max-width:560px){.top-profile-grid[data-v-72295cfd]{grid-template-columns:repeat(2,minmax(0,1fr))}}.global-ticker[data-v-c8730aed]{margin:0 8px;border-bottom:1px solid var(--ui-border)}.global-ticker-inner[data-v-c8730aed]{display:flex;align-items:center;gap:3px;min-height:26px;padding:0 8px;color:var(--ui-text-2)}.global-ticker-mark[data-v-c8730aed]{display:inline-flex;align-items:center;justify-content:center;color:var(--ui-accent-strong);flex-shrink:0}.global-ticker-label[data-v-c8730aed]{flex-shrink:0;color:var(--ui-primary);font-size:11px;font-weight:800;letter-spacing:0}.global-ticker-viewport[data-v-c8730aed]{position:relative;flex:1;min-width:0;overflow:hidden}.global-ticker-track[data-v-c8730aed]{display:inline-flex;align-items:center;min-width:100%;white-space:nowrap}.global-ticker-track.is-marquee[data-v-c8730aed]{min-width:max-content;will-change:transform;animation:ticker-marquee-c8730aed 10s linear}.global-ticker-text[data-v-c8730aed]{color:var(--ui-text-2);font-size:11px}.global-ticker-text.is-honor[data-v-c8730aed]{color:#c54d4d}.global-ticker-time[data-v-c8730aed]{color:var(--ui-muted);font-size:10px;flex-shrink:0}@keyframes ticker-marquee-c8730aed{0%{transform:translate(100%)}to{transform:translate(-100%)}}.quest-float-dock[data-v-e8f305d7]{position:absolute;display:grid;gap:3px}.quest-float-entry[data-v-e8f305d7]{display:grid;gap:2px;width:74px;min-height:54px;padding:7px 6px 4px;border:1px solid var(--ui-border);border-radius:13px 13px 9px 9px;background:color-mix(in srgb,var(--ui-surface-2) 96%,white);text-align:left}.quest-float-step[data-v-e8f305d7]{color:var(--ui-primary);font-size:10px;font-weight:800}.quest-float-title[data-v-e8f305d7]{color:var(--ui-text);font-size:9px;font-weight:700;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.quest-float-quick-action[data-v-e8f305d7]{min-height:20px;padding:0 5px;border:1px solid var(--ui-primary);border-radius:10px;background:var(--ui-primary);color:#fff;font-size:12px;font-weight:800;line-height:1;white-space:nowrap}.quest-float-overlay[data-v-e8f305d7]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1600;display:flex;align-items:center;justify-content:center;padding:20px 14px 86px;background:color-mix(in srgb,black 28%,transparent)}.quest-float-modal[data-v-e8f305d7]{display:grid;gap:10px;width:min(560px,calc(100vw - 28px));max-height:min(78dvh,700px);padding:14px;border:1px solid var(--ui-border);border-radius:18px;background:var(--ui-surface-2);overflow:hidden}.quest-float-scroll[data-v-e8f305d7]{display:grid;gap:10px;min-height:0;overflow-y:auto;padding-right:2px}.quest-float-head[data-v-e8f305d7],.quest-float-focus-top[data-v-e8f305d7],.quest-float-actions[data-v-e8f305d7],.quest-float-row-main[data-v-e8f305d7],.quest-float-row-meta[data-v-e8f305d7]{display:flex;align-items:center;gap:8px}.quest-float-head[data-v-e8f305d7]{justify-content:space-between}.quest-float-head-copy-wrap[data-v-e8f305d7],.quest-float-focus[data-v-e8f305d7],.quest-float-section[data-v-e8f305d7]{display:grid;gap:8px}.quest-float-head-title[data-v-e8f305d7],.quest-float-section-title[data-v-e8f305d7]{color:var(--ui-text);font-size:14px;font-weight:700}.quest-float-head-copy[data-v-e8f305d7],.quest-float-focus-copy[data-v-e8f305d7],.quest-float-empty[data-v-e8f305d7]{color:var(--ui-muted);font-size:12px;line-height:1.55}.quest-float-close[data-v-e8f305d7]{min-height:28px;padding:0 10px;border:1px solid var(--ui-border);border-radius:10px;background:var(--ui-surface-soft);color:var(--ui-text-2);font-size:12px;font-weight:700}.quest-float-focus[data-v-e8f305d7],.quest-float-section[data-v-e8f305d7]{padding:9px 10px;border:1px solid var(--ui-border);border-radius:14px;background:var(--ui-surface-soft)}.quest-float-focus-title[data-v-e8f305d7]{color:var(--ui-text);font-size:16px;font-weight:700;line-height:1.35}.quest-float-focus-step[data-v-e8f305d7]{color:var(--ui-text-2);font-size:12px;font-weight:700}.quest-float-focus-arrive[data-v-e8f305d7]{padding:7px 8px;border:1px solid var(--ui-success-soft-border);border-radius:10px;background:var(--ui-success-soft);color:var(--ui-success);font-size:11px;line-height:1.5}.quest-float-pill[data-v-e8f305d7]{display:inline-flex;align-items:center;justify-content:center;min-height:22px;padding:0 7px;border:1px solid var(--ui-border);border-radius:999px;background:var(--ui-surface);color:var(--ui-text-2);font-size:11px;font-weight:700}.quest-float-pill.is-primary[data-v-e8f305d7]{border-color:var(--ui-primary-soft-border);background:var(--ui-primary-soft);color:var(--ui-primary)}.quest-float-list[data-v-e8f305d7]{display:grid;gap:6px;max-height:168px;overflow-y:auto}.quest-float-row[data-v-e8f305d7]{display:grid;gap:5px;padding:8px 9px;border:1px solid var(--ui-border);border-radius:10px;background:var(--ui-surface-2);text-align:left}.quest-float-row.is-available[data-v-e8f305d7]{background:color-mix(in srgb,var(--ui-primary-soft) 32%,var(--ui-surface-2))}.quest-float-row-main[data-v-e8f305d7],.quest-float-row-meta[data-v-e8f305d7]{flex-wrap:wrap}.quest-float-row strong[data-v-e8f305d7]{color:var(--ui-text);font-size:13px;line-height:1.35}.quest-float-row-meta[data-v-e8f305d7]{color:var(--ui-muted);font-size:11px}.quest-float-actions[data-v-e8f305d7]{justify-content:flex-end;padding-top:2px;border-top:1px solid color-mix(in srgb,var(--ui-border) 84%,transparent);background:var(--ui-surface-2)}@media(max-width:520px){.quest-float-dock[data-v-e8f305d7]{left:8px}.quest-float-entry[data-v-e8f305d7]{width:70px;min-height:50px;padding:6px 5px}.quest-float-modal[data-v-e8f305d7]{width:min(560px,calc(100vw - 20px));max-height:min(82dvh,700px);padding:12px;gap:8px}.quest-float-head[data-v-e8f305d7]{align-items:flex-start}.quest-float-actions[data-v-e8f305d7]{position:sticky;bottom:0;padding-top:8px;padding-bottom:2px}}@media(max-height:760px){.quest-float-modal[data-v-e8f305d7]{max-height:min(84dvh,620px);gap:8px}.quest-float-focus[data-v-e8f305d7],.quest-float-section[data-v-e8f305d7]{padding:8px 9px;gap:6px}.quest-float-list[data-v-e8f305d7]{max-height:136px}.quest-float-row[data-v-e8f305d7]{padding:7px 8px}}.bottom-link-dot[data-v-be52a792]{position:absolute;top:-4px;right:-5px;width:9px;height:9px;border:2px solid var(--ui-surface-2);border-radius:999px;background:var(--ui-danger)}.func-btn[data-v-be52a792]{position:relative}.func-btn-badge[data-v-be52a792]{position:absolute;top:6px;right:6px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--ui-danger);color:#fff;font-size:10px;font-weight:800;line-height:1;box-shadow:0 0 0 2px var(--ui-surface-2)}.battle-shell[data-v-3b119181]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:8px;background:color-mix(in srgb,var(--ui-overlay) 42%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.battle-panel[data-v-3b119181]{display:flex;flex-direction:column;gap:7px;width:min(100%,382px);max-height:min(74vh,560px);padding:8px;border:1px solid var(--ui-border);border-radius:14px;background:color-mix(in srgb,var(--ui-surface-2) 96%,var(--ui-surface));box-shadow:var(--ui-shadow);overflow:hidden}.battle-head[data-v-3b119181],.battle-status-top[data-v-3b119181],.battle-entity[data-v-3b119181],.battle-log-head[data-v-3b119181],.battle-action-row[data-v-3b119181]{display:flex;align-items:center}.battle-head[data-v-3b119181],.battle-status-top[data-v-3b119181],.battle-log-head[data-v-3b119181]{justify-content:space-between}.battle-head[data-v-3b119181]{gap:8px;padding:0 1px}.battle-head-main[data-v-3b119181],.battle-entity-copy[data-v-3b119181]{display:grid;gap:2px}.battle-head-main[data-v-3b119181]{min-width:0}.battle-head-side[data-v-3b119181]{display:inline-flex;align-items:center;gap:6px;flex:0 0 auto}.battle-head-title[data-v-3b119181],.battle-summary-title[data-v-3b119181],.battle-entity strong[data-v-3b119181]{color:var(--ui-text);font-weight:800}.battle-head-title[data-v-3b119181]{font-size:17px;line-height:1.05;letter-spacing:-.02em}.battle-head-sub[data-v-3b119181]{line-height:1.15}.battle-head-sub[data-v-3b119181],.battle-entity-copy span[data-v-3b119181],.battle-log-head[data-v-3b119181],.battle-summary-item span[data-v-3b119181]{color:var(--ui-muted);font-size:11px}.battle-log-head[data-v-3b119181]{font-size:12px;line-height:1.1}.battle-sync-pill[data-v-3b119181]{display:inline-flex;align-items:center;min-height:22px;padding:0 7px;border:1px solid var(--ui-border);border-radius:999px;background:var(--ui-surface-soft);color:var(--ui-text-2);font-size:10px;font-weight:800;white-space:nowrap}.battle-sync-pill.is-live[data-v-3b119181]{border-color:var(--ui-success-soft-border);background:var(--ui-success-soft);color:var(--ui-success)}.battle-sync-pill.is-fallback[data-v-3b119181]{border-color:var(--ui-warning-soft-border);background:var(--ui-warning-soft);color:var(--ui-warning)}.battle-head-close[data-v-3b119181],.battle-btn[data-v-3b119181],.battle-shortcut[data-v-3b119181]{border:1px solid var(--ui-border)!important;background:var(--ui-surface-soft)!important;color:var(--ui-text)!important;box-shadow:none!important}.battle-head-close[data-v-3b119181]{min-height:24px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:700}.battle-status-grid[data-v-3b119181],.battle-summary-grid[data-v-3b119181],.battle-shortcut-row[data-v-3b119181]{display:grid;gap:6px}.battle-status-grid[data-v-3b119181]{grid-template-columns:repeat(2,minmax(0,1fr))}.battle-status-grid .battle-status-top[data-v-3b119181]{align-items:flex-start;gap:4px}.battle-status-card[data-v-3b119181],.battle-summary[data-v-3b119181]{display:grid;gap:7px;padding:8px;border:1px solid var(--ui-border);border-radius:12px;background:color-mix(in srgb,var(--ui-surface-soft) 86%,var(--ui-surface-2))}.battle-status-card.is-monster.is-pirate[data-v-3b119181],.battle-entity-icon.is-monster.is-pirate[data-v-3b119181]{color:#8b5e3c}.battle-status-card.is-monster.is-bandit[data-v-3b119181],.battle-entity-icon.is-monster.is-bandit[data-v-3b119181]{color:#8a473a}.battle-status-card.is-monster.is-serpent[data-v-3b119181],.battle-entity-icon.is-monster.is-serpent[data-v-3b119181]{color:#2a7b74}.battle-status-card.is-monster.is-spirit[data-v-3b119181],.battle-entity-icon.is-monster.is-spirit[data-v-3b119181]{color:#7565a8}.battle-status-card.is-monster.is-boss[data-v-3b119181],.battle-entity-icon.is-monster.is-boss[data-v-3b119181]{color:#9c5e14}.battle-entity[data-v-3b119181]{gap:7px;min-width:0}.battle-entity-icon[data-v-3b119181]{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:7px;font-size:11px;font-weight:800}.battle-entity-icon.is-monster[data-v-3b119181]{background:var(--ui-danger-soft);color:var(--ui-danger)}.battle-entity-icon.is-player[data-v-3b119181]{background:var(--ui-primary-soft);color:var(--ui-primary)}.battle-entity-copy[data-v-3b119181],.battle-entity-copy strong[data-v-3b119181],.battle-entity-copy span[data-v-3b119181]{min-width:0}.battle-entity-copy strong[data-v-3b119181],.battle-log-line[data-v-3b119181]{word-break:break-word}.battle-entity-copy strong[data-v-3b119181]{font-size:13px;line-height:1.18;letter-spacing:-.01em}.battle-entity-copy span[data-v-3b119181]{font-size:11px;line-height:1.2}.battle-status-grid .battle-entity-copy strong[data-v-3b119181]{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.battle-entity-hp[data-v-3b119181]{color:var(--ui-text);font-size:11px;font-weight:800;line-height:1.1;letter-spacing:.01em}.battle-meter[data-v-3b119181]{height:7px;border-radius:999px;background:color-mix(in srgb,var(--ui-surface) 88%,var(--ui-border));overflow:hidden}.battle-meter-fill[data-v-3b119181]{height:100%;border-radius:inherit}.battle-meter-fill.is-monster[data-v-3b119181]{background:linear-gradient(90deg,color-mix(in srgb,var(--ui-danger) 82%,white),var(--ui-danger))}.battle-meter-fill.is-monster.is-pirate[data-v-3b119181]{background:linear-gradient(90deg,#cd8a56,#8b5e3c)}.battle-meter-fill.is-monster.is-bandit[data-v-3b119181]{background:linear-gradient(90deg,#df8b72,#8a473a)}.battle-meter-fill.is-monster.is-serpent[data-v-3b119181]{background:linear-gradient(90deg,#6fc8b8,#2a7b74)}.battle-meter-fill.is-monster.is-spirit[data-v-3b119181]{background:linear-gradient(90deg,#b7a4f0,#7565a8)}.battle-meter-fill.is-monster.is-boss[data-v-3b119181]{background:linear-gradient(90deg,#efc36d,#9c5e14)}.battle-meter-fill.is-player[data-v-3b119181]{background:linear-gradient(90deg,color-mix(in srgb,var(--ui-primary) 82%,white),var(--ui-primary))}.battle-summary-grid[data-v-3b119181]{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px}.battle-summary-head[data-v-3b119181]{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.battle-summary-title[data-v-3b119181]{min-width:0;font-size:15px;line-height:1.2;letter-spacing:-.01em}.battle-summary-rewards[data-v-3b119181]{display:inline-flex;flex-wrap:wrap;justify-content:flex-end;gap:5px;flex:0 0 auto}.battle-summary-rewards span[data-v-3b119181]{display:inline-flex;align-items:center;gap:3px;min-height:22px;padding:0 7px;border:1px solid var(--ui-success-soft-border);border-radius:999px;background:var(--ui-success-soft);color:var(--ui-success);font-size:11px;font-weight:700;line-height:1}.battle-summary-rewards strong[data-v-3b119181]{color:inherit;font-size:12px}.battle-summary-grid>.battle-summary-item[data-v-3b119181]:not(.is-wide){display:none}.battle-summary.is-win .battle-summary-title[data-v-3b119181],.battle-summary.is-capture .battle-summary-title[data-v-3b119181]{color:var(--ui-success)}.battle-summary.is-lose .battle-summary-title[data-v-3b119181]{color:var(--ui-danger)}.battle-summary.is-flee .battle-summary-title[data-v-3b119181]{color:var(--ui-primary)}.battle-summary-item[data-v-3b119181]{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:34px;padding:4px 8px;border:1px solid color-mix(in srgb,var(--ui-border) 76%,transparent);border-radius:9px;background:color-mix(in srgb,var(--ui-surface-2) 78%,transparent)}.battle-summary-item.is-wide[data-v-3b119181]{grid-column:1 / -1;min-height:30px}.battle-summary-item strong[data-v-3b119181]{color:var(--ui-text);font-size:13px;line-height:1.25;text-align:right}.battle-log-card[data-v-3b119181]{display:flex;flex:1 1 auto;flex-direction:column;gap:2px;min-height:0;padding:6px 8px;border:1px solid var(--ui-border);border-radius:12px;background:color-mix(in srgb,var(--ui-surface-soft) 92%,var(--ui-surface-2));overflow:hidden}.battle-log-box[data-v-3b119181]{display:grid;flex:1 1 auto;grid-template-columns:1fr;gap:0;min-height:92px;max-height:140px;overflow-y:auto;overscroll-behavior:contain;padding:0;background:transparent;scrollbar-color:color-mix(in srgb,var(--ui-primary) 34%,var(--ui-border)) transparent;scrollbar-width:thin}.battle-log-line[data-v-3b119181]{display:flex;align-items:center;width:100%;min-height:22px;padding:3px 2px;border:0!important;border-bottom:1px solid color-mix(in srgb,var(--ui-border) 62%,transparent)!important;border-radius:0;background:transparent!important;color:var(--ui-text-2);font-size:11px;line-height:1.28}.battle-log-line.is-attack[data-v-3b119181]{color:var(--ui-danger)}.battle-log-line.is-defend[data-v-3b119181],.battle-log-line.is-heal[data-v-3b119181],.battle-log-line.is-system[data-v-3b119181]{color:var(--ui-primary)}.battle-log-box[data-v-3b119181]::-webkit-scrollbar{width:6px}.battle-log-box[data-v-3b119181]::-webkit-scrollbar-track{background:transparent}.battle-log-box[data-v-3b119181]::-webkit-scrollbar-thumb{border-radius:999px;background:color-mix(in srgb,var(--ui-primary) 34%,var(--ui-border))}.battle-log-box[data-v-3b119181]::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--ui-primary) 48%,var(--ui-border))}.battle-action-wrap[data-v-3b119181]{display:grid;gap:6px;flex:0 0 auto}.battle-action-row[data-v-3b119181]{gap:6px}.battle-btn[data-v-3b119181],.battle-shortcut[data-v-3b119181]{min-height:30px;border-radius:10px;font-size:12px;font-weight:800}.battle-btn[data-v-3b119181]{flex:1}.battle-btn.battle-btn-primary[data-v-3b119181]{background:var(--ui-danger-soft)!important;border-color:var(--ui-danger-soft-border)!important;color:var(--ui-danger)!important}.battle-shortcut-row[data-v-3b119181]{grid-template-columns:repeat(3,minmax(0,1fr))}.battle-shortcut[data-v-3b119181]{display:grid;gap:2px;padding:4px 7px;text-align:left}.battle-shortcut span[data-v-3b119181]{color:var(--ui-muted);font-size:10px}.battle-btn[data-v-3b119181]:disabled,.battle-shortcut[data-v-3b119181]:disabled,.battle-head-close[data-v-3b119181]:disabled{opacity:.55}@media(max-width:420px){.battle-panel[data-v-3b119181]{width:min(100%,356px);max-height:min(76vh,540px);padding:7px;border-radius:14px}.battle-head-title[data-v-3b119181]{font-size:16px}.battle-entity-copy strong[data-v-3b119181]{font-size:12px}.battle-log-line[data-v-3b119181]{font-size:10px}.battle-action-row[data-v-3b119181]{flex-wrap:wrap}.battle-btn[data-v-3b119181]{min-width:calc(50% - 4px)}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;height:100vh;height:100dvh;overflow:hidden;font-family:Segoe UI,Roboto,system-ui,PingFang SC,Microsoft YaHei,sans-serif;background:#080c08;background-image:radial-gradient(circle at 20% 20%,#1c2a1a,#050805);color:#f7efdb;font-size:13px;line-height:1.4;-webkit-text-size-adjust:100%;touch-action:manipulation}html::-webkit-scrollbar,body::-webkit-scrollbar{display:none}.app-container{height:100vh;height:100dvh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;overflow:hidden;position:relative;background:#0a100cf0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #7a6848;border-radius:24px;box-shadow:0 15px 30px #000c,inset 0 0 0 1px #5e4e36}.main-content{flex:1;overflow:hidden;padding:4px 6px;min-height:0}.top-bar{background:#141e18e0;padding:0 10px;border-bottom:1px solid #c9a758;display:flex;justify-content:space-between;align-items:center;height:36px;flex-shrink:0;z-index:100;border-radius:40px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #8b784e;box-shadow:inset 0 1px 3px #00000054,0 3px 6px #0000004d}.top-bar-title{font-size:14px;font-weight:800;color:#c9a758;text-shadow:1.5px 1.5px 0 #3d2c12}.top-bar-right{font-size:11px;color:#cfc19e;display:flex;align-items:center;gap:4px}.top-link{color:#c9a758;text-decoration:none;font-size:11px}.bottom-bar{height:48px;background:#0c130ce0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid #a68750;display:flex;justify-content:space-around;align-items:center;flex-shrink:0;border-radius:40px;margin:0 4px 4px}.bottom-link{color:#f5e0b5;text-decoration:none;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;gap:0px;padding:2px 4px;flex:1;text-align:center;background:#253b21;border:1px solid #b29658;border-radius:40px;margin:0 3px;font-weight:700;box-shadow:0 2px #13200e;cursor:pointer;transition:all .05s}.bottom-link .nav-icon{font-size:18px;line-height:1.1}.bottom-link .nav-text{font-size:9px;line-height:1.1}.bottom-link:hover,.bottom-link:active{color:#f5e0b5;transform:translateY(2px);box-shadow:0 1px #13200e}.game-title{text-align:center;padding:24px 16px 12px}.game-title h1{font-size:28px;font-weight:800;color:#ecd59e;text-shadow:2px 2px 0 #2f3e1c;margin-bottom:4px;letter-spacing:4px;border-left:5px solid #c9a758;display:inline-block;padding-left:12px}.game-title .subtitle{font-size:12px;color:#cfc19e;letter-spacing:2px}.game-title .divider{width:60%;height:1px;background:#c9a7584d;margin:10px auto}.game-title .version{font-size:10px;color:#8b784e}.card{background:#0e1811e6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #9e895c;border-radius:18px;padding:6px 8px;margin-bottom:4px;box-shadow:inset 0 1px 3px #00000054}.card-title{font-size:12px;color:#ddc288;font-weight:700;margin-bottom:4px;padding-bottom:3px;border-bottom:1px solid rgba(169,119,78,.15)}.btn{display:inline-block;padding:5px 10px;border-radius:30px;text-decoration:none;font-size:12px;font-weight:700;text-align:center;cursor:pointer;border:none;transition:all .15s;margin:2px 1px;white-space:nowrap;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.btn-primary{background:#b39250;border:1px solid #c9a758;box-shadow:0 2px #7a6848,0 3px 6px #0006;color:#0f1810}.btn-primary:hover,.btn-primary:active{background:#c9a758;box-shadow:0 1px #7a6848,0 1px 3px #0006;transform:translateY(1px)}.btn-secondary{background:#2a3525;color:#f7efdb;border:1px solid #4a5e3a;box-shadow:0 2px #1a261a}.btn-secondary:hover,.btn-secondary:active{background:#3a4f2e;transform:translateY(1px);box-shadow:0 1px #1a261a}.btn-danger{background:#73281c;border:1px solid #b85a3a;box-shadow:0 2px #4a1f15,0 3px 6px #0006;color:#ffcfb0}.btn-danger:hover,.btn-danger:active{background:#843428;transform:translateY(1px);box-shadow:0 1px #4a1f15}.btn-success{border:1px solid #84a86b;box-shadow:0 2px #1f3822,0 3px 6px #0006;background:#3f6a4a;color:#e2f0b3}.btn-success:hover,.btn-success:active{background:#4a7a55;transform:translateY(1px);box-shadow:0 1px #1f3822}.btn-block{display:block;width:100%;padding:7px}.btn-small{padding:3px 8px;font-size:11px}.form-group{margin-bottom:6px}.form-group label{display:block;font-size:12px;color:#cfc19e;margin-bottom:2px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:6px 8px;border-radius:16px;border:1px solid #7f6e4a;background:#080c08;color:#f7efdb;font-size:13px;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#c9a758;box-shadow:0 0 0 1px #c9a75833}.status-bar{margin-bottom:4px}.status-bar .bar-label{display:flex;justify-content:space-between;font-size:11px;margin-bottom:1px;color:#cfc19e}.status-bar .bar-track{height:10px;background:#080c08;border-radius:5px;overflow:hidden;border:1px solid #3a4f2e}.status-bar .bar-fill{height:100%;border-radius:4px;transition:width .3s}.bar-hp .bar-fill{background:linear-gradient(90deg,#73281c,#b85a3a)}.bar-hp.bar-low .bar-fill{background:#b85a3a}.bar-exp .bar-fill{background:linear-gradient(90deg,#2e5a3b,#3f6a4a)}.nav-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto auto;gap:2px;text-align:center;margin:4px 0}.nav-grid .nav-n{grid-column:2}.nav-grid .nav-w{grid-column:1;grid-row:2}.nav-grid .nav-center{grid-column:2;grid-row:2}.nav-grid .nav-e{grid-column:3;grid-row:2}.nav-grid .nav-s{grid-column:2;grid-row:3}.nav-dir{display:inline-block;padding:4px 8px;background:#1a261ae6;border:1px solid #b39254;border-radius:30px;color:#eedbaa;text-decoration:none;font-size:12px;font-weight:700;width:60px;transition:all .05s;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);box-shadow:0 1px 3px #0000004d;cursor:pointer}.nav-dir:hover,.nav-dir:active{background:#3f5532;transform:scale(.96)}.nav-dir.disabled{color:#5f4a31;cursor:not-allowed;pointer-events:none;opacity:.5}.nav-center{font-size:11px;color:#8b784e;padding:4px}.func-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.func-grid .btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;text-align:center;padding:4px 2px;font-size:10px;margin:0;line-height:1.2;gap:1px}.func-grid .btn .func-icon{font-size:16px;line-height:1}.func-grid .btn .func-text{font-size:10px;line-height:1.1}.player-list{list-style:none}.player-list li{padding:3px 0;border-bottom:1px solid rgba(169,119,78,.06);display:flex;justify-content:space-between;align-items:center;font-size:12px}.player-list li:last-child{border-bottom:none}.player-name{color:#f7efdb;text-decoration:none;font-weight:700}.player-name:hover{color:#c9a758}.player-level{font-size:10px;color:#8b784e}.player-hp{font-size:10px;color:#eeb782}.item-list{list-style:none}.item-list li{padding:4px 0;border-bottom:1px solid rgba(169,119,78,.06)}.item-list li:last-child{border-bottom:none}.item-name{font-weight:700;color:#f7efdb;font-size:12px}.item-desc{font-size:10px;color:#8b784e;margin-top:1px;line-height:1.3}.item-price{color:#c9a758;font-size:12px}.item-actions{margin-top:2px}.battle-log{background:#080c08;border:1px solid #2a3525;border-radius:16px;padding:4px 6px;max-height:120px;overflow-y:auto;font-size:11px;line-height:1.4}.battle-log .log-line{margin-bottom:2px;padding:1px 0}.battle-log .log-attack{color:#b85a3a}.battle-log .log-defend{color:#ffcfb0}.battle-log .log-heal{color:#84a86b}.battle-log .log-info{color:#ddd0b6}.battle-log .log-system{color:#c9a758}.chat-messages{background:#080c08;border:1px solid #2a3525;border-radius:16px;padding:4px 6px;max-height:100%;overflow-y:auto;font-size:12px}.chat-msg{margin-bottom:3px;padding-bottom:3px;border-bottom:1px solid rgba(169,119,78,.03)}.chat-msg:last-child{border-bottom:none}.chat-sender{color:#c9a758;font-weight:700;font-size:11px}.chat-text{color:#f7efdb;word-break:break-all;font-size:12px}.chat-time{color:#5f4a31;font-size:9px}.npc-dialog{background:#0f181080;border-left:2px solid #c9a758;border-radius:0 16px 16px 0;padding:6px 10px;margin:4px 0;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.npc-name{font-weight:700;font-size:13px;color:#c9a758;text-shadow:1px 1px 0 #3b301c}.npc-text{font-size:12px;line-height:1.5;color:#ddd0b6;font-style:italic}.story-box{background:#1e2a1c;border:1px solid #7f6e4a;border-radius:18px;padding:10px 12px;margin:6px 0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:inset 0 1px 3px #00000054}.story-text{font-size:13px;line-height:1.7;color:#ddd0b6;text-indent:2em}.story-step{text-align:right;color:#8b784e;font-size:10px;margin-top:6px}.city-places{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;list-style:none}.city-places li a{display:flex;align-items:center;justify-content:center;padding:5px 4px;background:#1a261ae6;border:1px solid #b39254;border-radius:30px;color:#eedbaa;text-decoration:none;font-size:11px;font-weight:700;text-align:center;transition:all .05s;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);box-shadow:0 1px 3px #0000004d;cursor:pointer}.city-places li a:hover,.city-places li a:active{border-color:#c9a758;color:#c9a758;background:#3f5532;transform:scale(.96)}.msg-box{text-align:center;padding:20px 16px}.msg-box h2{color:#c9a758;font-weight:800;text-shadow:1.5px 1.5px 0 #3d2c12;margin-bottom:8px}.msg-box p{margin:4px 0}.location-bar{background:#141e18e0;border:1px solid #8b784e;border-radius:40px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:4px 8px;margin-bottom:4px;text-align:center;flex-shrink:0;box-shadow:inset 0 1px 3px #00000054,0 3px 6px #0000004d}.location-name{font-size:14px;color:#c9a758;font-weight:800;text-shadow:1.5px 1.5px 0 #3d2c12}.location-desc{font-size:11px;color:#bbaa83;margin-top:1px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.location-path{font-size:10px;color:#7b6844;margin-top:1px}.footer{text-align:center;padding:2px 0;color:#5f4a31;font-size:10px;flex-shrink:0;line-height:1.2}.text-center{text-align:center}.text-gold{color:#c9a758!important}.text-green{color:#84a86b!important}.text-red{color:#b85a3a!important}.text-muted{color:#8b784e!important}.mt-4{margin-top:4px}.mt-6{margin-top:6px}.mt-8{margin-top:8px}.mb-4{margin-bottom:4px}.clearfix:after{content:"";display:table;clear:both}a{color:#c9a758;text-decoration:none}a:hover{color:#c9a758}.divider{border-top:1px solid rgba(169,119,78,.08);margin:4px 0}.empty-state{text-align:center;color:#7b6844;padding:8px;font-size:12px}::-webkit-scrollbar{width:2px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#3f5532;border-radius:1px}.guild-badge{display:inline-block;padding:1px 4px;border-radius:16px;font-size:10px;font-weight:700}.sail-progress{height:8px;background:#080c08;border-radius:4px;overflow:hidden;border:1px solid #3a4f2e}.sail-progress-fill{height:100%;background:#3f6a4a;border-radius:4px;transition:width 1s ease}.rank-medal{font-size:14px;width:22px;text-align:center}.rank-item-me{background:#a9774e14;border-radius:16px;padding:4px!important;margin:0 -4px}table{border-collapse:collapse}table td{padding:2px 0!important;font-size:12px}.nearby-collapse{max-height:18px;overflow:hidden;position:relative}.main-content.chat-page{display:flex;flex-direction:column;padding:4px 6px}.main-content.chat-page .chat-messages{flex:1;min-height:0}.main-content.chat-page .chat-input-bar{flex-shrink:0;margin-top:4px}.main-content.battle-page{display:flex;flex-direction:column;padding:4px 6px}.main-content.battle-page .battle-log{flex:1;min-height:0}.main-content.battle-page .battle-actions{flex-shrink:0}.main-content.scroll-page{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.main-content.scroll-page::-webkit-scrollbar{display:none}.tab-bar{display:flex;margin-bottom:4px}.tab-bar .btn{flex:1;border-radius:0;margin:0;padding:5px 2px;font-size:11px}.tab-bar .btn:first-child{border-radius:16px 0 0 16px}.tab-bar .btn:last-child{border-radius:0 16px 16px 0}.compact-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;border-bottom:1px solid rgba(169,119,78,.05);font-size:12px}.compact-row:last-child{border-bottom:none}.inline-form{display:flex;gap:4px;align-items:center}.inline-form input,.inline-form select{padding:5px 6px;background:#080c08;color:#f7efdb;border:1px solid #7f6e4a;border-radius:16px;font-size:12px}.inline-form input:focus,.inline-form select:focus{border-color:#c9a758}.func-float{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:198}.func-float.open{display:block}.func-overlay-bg{position:fixed;top:0;left:0;right:0;bottom:0;z-index:199;background:#030503dd;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.func-float.open .func-overlay-bg{display:block}.func-panel{max-width:480px;margin:0 auto;display:flex;flex-direction:column;position:fixed;bottom:48px;left:0;right:0;height:50vh;height:50dvh;z-index:200;background:#141e18f2;border:1px solid #8b784e;border-radius:24px 24px 0 0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:10px 8px;animation:funcSlideUp .25s ease;box-shadow:0 -8px 30px #0009}@keyframes funcSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.func-close-bar{width:36px;height:4px;background:#a9774e4d;border-radius:2px;margin:0 auto 8px}.func-scroll{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}.func-scroll::-webkit-scrollbar{display:none}.func-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.func-grid .func-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 4px 8px;border-radius:16px;text-decoration:none;font-size:11px;color:#ddd0b6;background:#141e1899;border:1px solid rgba(139,118,78,.2);-webkit-tap-highlight-color:transparent;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.func-grid .func-btn:active{background:#a9774e1a;transform:scale(.95)}.func-grid .func-btn .func-emoji{font-size:18px}.func-grid .func-btn .func-label{font-size:11px}.func-grid .func-btn.func-highlight{background:#a9774e1a;border-color:#a9774e4d;color:#f7efdb}.func-grid .func-btn.func-danger{background:#73281c1a;border-color:#73281c4d;color:#b85a3a}.func-grid .func-btn.func-success{background:#2e5a3b1a;border-color:#2e5a3b4d;color:#84a86b}.func-grid .func-btn .func-badge{position:absolute;top:-2px;right:-2px;background:#73281c;color:#ffcfb0;font-size:8px;padding:1px 4px;border-radius:8px;font-weight:700}.quick-stats{display:flex;align-items:center;gap:8px;padding:5px 10px;background:#0005;border:1px solid rgba(169,119,78,.15);border-radius:40px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);margin-bottom:4px;flex-shrink:0}.qs-item{display:flex;align-items:center;gap:4px;font-size:11px;color:#ddd0b6}.qs-icon{font-size:12px;flex-shrink:0}.qs-bar-wrap{width:50px;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden;flex-shrink:0}.qs-bar{height:100%;border-radius:3px;transition:width .3s}.qs-hp-bar{background:linear-gradient(90deg,#73281c,#b85a3a)}.qs-exp-bar{background:linear-gradient(90deg,#2e5a3b,#3f6a4a)}.qs-val{font-size:10px;color:#f2dba5;white-space:nowrap}.qs-hp,.qs-exp{flex:1}.qs-money{margin-left:auto;color:#c9a758}.scene-panel{background:#162016d9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid #8b764e;border-radius:18px;box-shadow:inset 0 1px 3px #0003,0 2px 4px #0000004d;overflow:hidden;display:flex;flex-direction:column}.scene-header{display:flex;align-items:center;gap:8px;padding:8px 10px 6px;border-bottom:1px solid rgba(169,119,78,.08)}.scene-emoji{font-size:22px;flex-shrink:0}.scene-title{font-size:15px;font-weight:800;color:#f3e1b3;line-height:1.3;text-shadow:1px 1px 0 #3d2c12}.scene-title .city-name{color:#cfc19e;font-size:12px;font-weight:400}.scene-atmosphere{position:relative;height:36px;background:#141e1880;border-bottom:1px solid rgba(169,119,78,.06);overflow:hidden}.scene-body{padding:4px 6px 6px;display:flex;flex-direction:column}.scene-desc{font-size:12px;line-height:1.5;color:#bbaa83;margin-bottom:4px}.scene-desc .empty-hint{color:#7b6844;font-style:italic}.scene-entities{display:flex;gap:6px;min-height:0}.scene-entities>*{flex:1;min-width:0}.scene-col-divider{width:1px;background:#a9774e26;flex:none}.monster-cards{display:flex;flex-direction:column;gap:3px;overflow-y:auto;max-height:200px;scrollbar-width:none}.monster-cards::-webkit-scrollbar{display:none}.monster-card{display:flex;align-items:center;gap:6px;padding:5px 8px;background:#162016d9;border:1px solid #8b764e;border-radius:18px;text-decoration:none;box-shadow:0 2px 3px #0003;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.monster-card:active{background:#a9774e14;transform:scale(.98)}.mc-icon{font-size:14px;flex-shrink:0}.mc-info{flex:1;min-width:0}.mc-name{font-size:11px;font-weight:700;color:#ffeecd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mc-hp{font-size:9px;color:#eeb782;white-space:nowrap}.mc-action{font-size:10px;color:#f2e2c0;flex-shrink:0;padding:4px 12px;border-radius:30px;background:#73281c;border:1px solid #b85a3a;box-shadow:0 2px #4a1f15;font-weight:700;cursor:pointer;color:#ffcfb0}.mc-action:active{transform:translateY(1px);box-shadow:0 1px #4a1f15}.scene-npcs{display:flex;flex-direction:column;gap:3px;overflow-y:auto;max-height:200px;scrollbar-width:none}.scene-npcs::-webkit-scrollbar{display:none}.scene-npc-row{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 12px;background:#162016d9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid #8b764e;border-radius:18px;box-shadow:0 3px 4px #0003;text-decoration:none}.scene-npc-row:active{background:#a9774e14;transform:scale(.98)}.npc-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;background:#2a3525;border:1.5px solid #c9aa7b;box-shadow:0 2px 4px #0006}.npc-info{flex:1;min-width:0}.npc-name-text{font-size:12px;font-weight:700;color:#ffeecd}.npc-desc-text{font-size:10px;color:#8b784e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.npc-action{font-size:10px;color:#f2e2c0;flex-shrink:0;padding:4px 12px;border-radius:30px;background:#5f4a31;border:1px solid #bb9f6b;box-shadow:0 2px #2f2418;font-weight:700;cursor:pointer;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.npc-action:active{transform:translateY(1px);box-shadow:0 1px #2f2418}.scene-tags{display:flex;gap:4px;flex-wrap:wrap;padding-top:4px;border-top:1px solid rgba(169,119,78,.06)}.scene-tag{font-size:10px;padding:2px 8px;border-radius:16px;text-decoration:none;display:inline-flex;align-items:center;gap:3px}.nearby-bar{display:flex;align-items:center;gap:6px;padding:5px 10px;background:#0f181099;border:1px solid rgba(169,119,78,.08);border-radius:18px;margin-top:4px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.nearby-label{font-size:10px;color:#8b784e;flex-shrink:0;white-space:nowrap}.nearby-list{display:flex;gap:6px;overflow-x:auto;flex:1;scrollbar-width:none}.nearby-list::-webkit-scrollbar{display:none}.nearby-chip{display:flex;align-items:center;gap:3px;padding:3px 8px;border-radius:16px;background:#141e1899;border:1px solid rgba(139,118,78,.2);white-space:nowrap;flex-shrink:0;font-size:11px;color:#ddd0b6}.chip-sex{font-size:10px}.chip-name{font-size:11px;color:#ddd0b6}.chip-lv{font-size:9px;color:#8b784e}.dir-card{position:relative;background:#0e1811e6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #9e895c;border-radius:18px;box-shadow:inset 0 1px 3px #00000054,0 2px 3px #0003;padding:6px 6px 52px;margin-top:auto;flex-shrink:0}.dir-cross{display:grid;grid-template-areas:". n ." "w c e" ". s .";grid-template-columns:1fr 1fr 1fr;gap:4px;max-width:280px;margin:0 auto}.dir-cross .dir-n{grid-area:n}.dir-cross .dir-w{grid-area:w}.dir-cross .dir-center{grid-area:c}.dir-cross .dir-e{grid-area:e}.dir-cross .dir-s{grid-area:s}.dir-cross .dir-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px;border-radius:30px;text-decoration:none;font-size:12px;background:#1a261ae6;border:1px solid #b39254;color:#eedbaa;transition:all .05s;box-shadow:0 1px 3px #0000004d;font-weight:700;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);cursor:pointer}.dir-cross .dir-btn:active{background:#3f5532;transform:scale(.96)}.dir-cross .dir-btn .dir-sub{font-size:10px;color:#cfc19e;margin-top:2px}.dir-cross .dir-disabled{display:flex;align-items:center;justify-content:center;padding:10px 4px;border-radius:30px;color:#7a6848;font-size:12px}.dir-cross .dir-center-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#a9774e14;border:1px solid rgba(169,119,78,.25);color:#c9a758;font-size:16px;text-decoration:none;margin:0 auto}.no-exit-msg{text-align:center;font-size:11px;color:#73281c;margin-top:4px}.map-fab{display:inline-flex;align-items:center;justify-content:center;gap:4px;position:absolute;right:10px;bottom:10px;min-width:78px;height:32px;padding:0 12px;border:none;border-radius:999px;cursor:pointer;z-index:3}.map-fab-label{font-size:12px;font-weight:700;line-height:1}.map-fab-icon{display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.app-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;vertical-align:middle;color:currentColor}.app-icon svg{width:100%;height:100%;display:block;overflow:visible}.scene-sections{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}.scene-section{display:flex;flex-direction:column;gap:8px;min-width:0;padding:10px}.scene-section-monsters{display:none}.scene-section-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.scene-section-title{font-size:13px;font-weight:700}.scene-section-meta,.scene-section-note,.scene-empty-state{font-size:11px;line-height:1.5}.scene-empty-state{display:flex;align-items:center;gap:6px;min-height:64px}.scene-empty-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;flex:0 0 auto}.scene-section .monster-cards,.scene-section .scene-npcs{display:flex;flex-direction:column;gap:8px}.threat-panel{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:18px}.threat-panel-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.threat-panel-title{font-size:13px;font-weight:700}.threat-panel-meta,.threat-panel-note,.threat-empty-state{font-size:11px;line-height:1.5}.threat-empty-state{display:flex;align-items:center;gap:6px;min-height:64px}.city-layout-wrap,.city-mini-card,.city-focus-panel,.city-layout-placeholder{margin-top:10px;padding:10px;overflow:hidden}.city-layout-svg,.city-mini-svg{width:100%;height:auto;display:block}.city-layout-edge,.city-mini-edge{stroke:#5f63686b;stroke-width:2;stroke-linecap:round;transition:opacity .16s ease,stroke .16s ease}.city-layout-edge.is-nearby,.city-mini-edge.is-nearby{stroke:var(--ui-primary, #1a73e8);opacity:.9}.city-layout-edge.is-muted,.city-mini-edge.is-muted{opacity:.22}.city-layout-node-badge,.city-mini-node-badge{fill:#fffffff0;stroke:#5f63683d;stroke-width:1.5}.city-layout-node-halo,.city-mini-node-halo{fill:#1a73e824}.city-layout-node-icon,.city-mini-node-icon{color:var(--ui-primary, #1a73e8)}.city-layout-node-wrap.is-muted,.city-mini-node-wrap.is-muted{opacity:.38}.city-layout-label,.city-mini-label{fill:var(--ui-text-2, #3c4043);font-size:10px;font-weight:600;pointer-events:none}.city-layout-anchor-dot,.city-mini-anchor-dot{fill:var(--ui-accent, #ea8600)}.city-focus-header,.city-place-name{display:flex;align-items:center;gap:8px}.city-focus-header{margin-bottom:8px}.city-focus-title,.city-place-name-text{font-size:13px;font-weight:700}.city-focus-tip,.city-focus-meta,.city-place-meta{font-size:11px;line-height:1.5}.city-place-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}.city-place-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;padding:10px;cursor:pointer}.city-place-main{min-width:0;flex:1}.city-place-name{flex-wrap:wrap}.city-place-name-text{min-width:0;word-break:break-word}.city-place-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:8px;flex:0 0 auto}.city-current-tag,.city-anchor-tag{display:inline-flex;align-items:center;justify-content:center;min-height:18px;padding:0 6px;border-radius:999px;font-size:10px;font-weight:700}.city-mini-head,.city-mini-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.city-mini-head{margin-bottom:8px}.city-mini-foot{margin-top:8px;font-size:11px;line-height:1.4}.city-mini-title,.city-mini-link{font-size:12px;font-weight:700}.city-mini-subtitle,.city-layout-modal-note{font-size:11px;line-height:1.6}.city-mini-canvas{min-height:148px}.city-mini-canvas-modal{min-height:180px}.city-layout-modal{width:min(100%,440px)}@media(max-width:420px){.scene-sections{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#030503dd;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s}.modal-overlay.active{opacity:1;pointer-events:auto}.modal-card{background:#1f281bd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid #bc9a58;box-shadow:inset 0 1px 3px #0000004d,0 20px 30px #000c;border-radius:30px;width:100%;max-width:450px;max-height:82vh;overflow-y:auto;transform:scale(.9);transition:transform .2s}.modal-overlay.active .modal-card{transform:scale(1)}.modal-header{display:flex;align-items:center;gap:10px;padding:14px 16px 10px;border-bottom:1px solid rgba(169,119,78,.1)}.modal-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;background:#2a3525;border:1.5px solid #c9aa7b;box-shadow:0 2px 4px #0006}.modal-title{font-size:16px;font-weight:800;color:#f3e1b3;line-height:1.3;text-shadow:1px 1px 0 #3d2c12}.modal-subtitle{font-size:11px;color:#8b784e;margin-top:2px}.modal-body{padding:12px 16px}.modal-dialog{font-size:13px;line-height:1.8;color:#ddd0b6;margin-bottom:8px;padding:10px 12px;background:#ffffff08;border-radius:16px;border-left:3px solid rgba(169,119,78,.3);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px}.modal-stat{display:flex;justify-content:space-between;padding:4px 8px;background:#ffffff08;border-radius:16px;font-size:12px}.modal-stat-label{color:#8b784e}.modal-stat-val{color:#f7efdb;font-weight:700}.modal-footer{display:flex;gap:8px;padding:10px 16px 14px;border-top:1px solid rgba(169,119,78,.08)}.modal-btn{flex:1;padding:10px;border-radius:30px;font-size:14px;text-align:center;text-decoration:none;color:#f7efdb;cursor:pointer;transition:all .05s;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.modal-btn-primary{background:#b39250;border:1px solid #c9a758;color:#080c08;font-weight:700;box-shadow:0 2px #7a6848,0 3px 6px #0006}.modal-btn-primary:active{background:#c9a758;box-shadow:0 1px #7a6848;transform:translateY(1px)}.modal-btn-close{background:#6f5632;border:none;color:#f7efdb;box-shadow:0 2px #352918;font-weight:700;border-radius:60px}.modal-btn-close:active{transform:translateY(1px);box-shadow:0 1px #352918}.modal-btn-danger{background:#73281c;border:1px solid #b85a3a;color:#ffcfb0;box-shadow:0 2px #4a1f15,0 3px 6px #0006}.modal-btn-danger:active{background:#843428;box-shadow:0 1px #4a1f15;transform:translateY(1px)}.shop-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#141e1899;border:1px solid rgba(139,118,78,.2);border-radius:16px;margin-bottom:4px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.shop-item-info{flex:1;min-width:0}.shop-item-name{font-size:12px;color:#f7efdb;font-weight:700}.shop-item-name .level-req{color:#7a6848;font-size:10px}.shop-item-desc{font-size:10px;color:#8b784e;margin-top:2px}.shop-item-price{font-size:11px;color:#c9a758;font-weight:600;margin-top:2px}.shop-item-action{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.qty-control{display:inline-flex;border:1px solid rgba(169,119,78,.3);border-radius:16px;overflow:hidden}.qty-control button{background:#ffffff0d;color:#f7efdb;border:none;width:24px;height:24px;font-size:12px;cursor:pointer}.qty-control input{width:32px;height:24px;border:none;border-left:1px solid rgba(169,119,78,.3);border-right:1px solid rgba(169,119,78,.3);text-align:center;font-size:11px;background:#0003;color:#f7efdb;outline:none;-moz-appearance:textfield}.qty-control input::-webkit-inner-spin-button{-webkit-appearance:none}.btn-buy{background:#2e5a3b26;border:1px solid rgba(46,90,59,.3);color:#84a86b;padding:4px 12px;font-size:11px;border-radius:30px;cursor:pointer;font-weight:700}.btn-buy:active{transform:translateY(1px)}.bank-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;text-align:center;padding:6px 8px;background:#141e1899;border:1px solid rgba(139,118,78,.2);border-radius:16px;margin-bottom:8px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.bank-label{font-size:10px;color:#cfc19e}.bank-val{font-size:13px;font-weight:700}.bank-val.gold{color:#c9a758}.bank-val.green{color:#84a86b}.bank-val.big{font-size:14px}.bank-section{padding:6px 8px;background:#141e1899;border:1px solid rgba(139,118,78,.2);border-radius:16px;margin-bottom:6px}.bank-title{font-size:11px;font-weight:700;margin-bottom:4px;color:#c9a758}.bank-row{display:flex;gap:4px}.bank-input{flex:1;padding:6px 8px;background:#0003;border:1px solid rgba(169,119,78,.2);border-radius:16px;color:#f7efdb;font-size:12px;outline:none}.btn-bank{padding:6px 14px;font-size:12px;border-radius:30px;cursor:pointer;border:none;font-weight:700}.btn-bank.green{background:#3f6a4a;border:1px solid #84a86b;color:#e2f0b3;box-shadow:0 2px #1f3822}.btn-bank.green:active{transform:translateY(1px);box-shadow:0 1px #1f3822}.btn-bank.gold{background:#b39250;border:1px solid #c9a758;color:#080c08;box-shadow:0 2px #7a6848}.btn-bank.gold:active{transform:translateY(1px);box-shadow:0 1px #7a6848}.bank-quick{display:flex;gap:4px;margin-top:4px}.bank-quick button{flex:1;padding:4px;background:#141e1899;border:1px solid rgba(139,118,78,.2);border-radius:16px;color:#cfc19e;font-size:10px;cursor:pointer}.bank-quick button:active{transform:translateY(1px)}.battle-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c08f0;z-index:5000;display:flex;flex-direction:column;padding:8px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.battle-monster-bar{background:#162016d9;border:1px solid rgba(115,40,28,.3);border-radius:18px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:8px 12px;margin:4px 0;box-shadow:inset 0 1px 3px #0003}.battle-player-bar{background:#162016d9;border:1px solid rgba(63,106,74,.3);border-radius:18px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:8px 12px;margin:4px 0;box-shadow:inset 0 1px 3px #0003}.battle-log-box{flex:1;min-height:0;overflow-y:auto;background:#080c08;border:1px solid #2a3525;border-radius:18px;padding:6px 8px;margin:4px 0;font-size:11px;line-height:1.4;scrollbar-width:none}.battle-log-box::-webkit-scrollbar{display:none}.battle-actions-box{flex-shrink:0;padding:6px 0}.battle-actions-row{display:flex;gap:6px;margin-bottom:4px}.battle-btn{flex:1;padding:12px 8px;border:none;border-radius:30px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 2px #00000080;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.battle-btn:active{transform:translateY(1px);box-shadow:0 1px #00000080}.battle-attack-btn{background:#73281c;border:1px solid #b85a3a;color:#ffcfb0;box-shadow:0 2px #4a1f15,0 3px 6px #0006}.battle-attack-btn:active{box-shadow:0 1px #4a1f15}.battle-flee-btn{background:#3f281e4d;border:1px solid #a77b4e;color:#fad6a0;box-shadow:0 2px #1e120a}.battle-flee-btn:active{box-shadow:0 1px #1e120a}.battle-capture-btn{background:#3f6a4a;border:1px solid #84a86b;color:#e2f0b3;box-shadow:0 2px #1f3822,0 3px 6px #0006}.battle-capture-btn:active{box-shadow:0 1px #1f3822}.quest-alert{padding:6px 12px;background:#2e5a3b14;border:1px solid rgba(46,90,59,.2);border-radius:16px;font-size:12px;color:#84a86b;text-align:center;margin-bottom:4px}.quest-alert a{color:#c9a758;text-decoration:none}.chat-bubbles{max-height:45vh;overflow-y:auto;padding:4px 0;scrollbar-width:none}.chat-bubbles::-webkit-scrollbar{display:none}.chat-bubble{margin-bottom:8px;animation:bubbleIn .3s ease}@keyframes bubbleIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.npc-bubble{display:flex;flex-direction:column;align-items:flex-start}.bubble-name{font-size:10px;color:#c9a758;margin-bottom:2px;font-weight:700}.bubble-text{font-size:12px;line-height:1.7;color:#ddd0b6;padding:8px 12px;background:#141e1899;border:1px solid rgba(139,118,78,.2);border-radius:4px 16px 16px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.bubble-text.small{font-size:11px;color:#bbaa83}.chat-next-btn{background:#a9774e14;border:1px solid rgba(169,119,78,.2);color:#cfc19e;padding:6px 18px;border-radius:30px;font-size:11px;cursor:pointer;font-weight:700;transition:all .05s;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.chat-next-btn:active{background:#a9774e2e;transform:translateY(1px)}.npc-avatar.quest{background:#2e5a3b26;border:1px solid rgba(46,90,59,.3)}.npc-avatar.shop{background:#a9774e1f;border:1px solid rgba(169,119,78,.25)}.npc-avatar.craft{background:#6f56321f;border:1px solid rgba(111,86,50,.25)}.npc-avatar.talk{background:#3f6a4a1f;border:1px solid rgba(63,106,74,.25)}.npc-avatar.danger{background:#73281c1f;border:1px solid rgba(115,40,28,.25)}.npc-avatar.bank{background:#2e5a3b1f;border:1px solid rgba(46,90,59,.25)}.map-toast{position:fixed;bottom:120px;left:50%;transform:translate(-50%) translateY(20px);background:#0a100af7;border:2px solid #c9a758;border-radius:12px;padding:12px 24px;display:flex;align-items:center;z-index:99999;opacity:0;pointer-events:none;transition:all .3s ease;box-shadow:0 4px 20px #000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.map-toast.active{opacity:1;transform:translate(-50%) translateY(0)}.page{height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;box-sizing:border-box}.page::-webkit-scrollbar{display:none}.modal-overlay-2{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:10002;display:flex;align-items:center;justify-content:center;padding:20px}.modal-card .modal-body{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-card .modal-body::-webkit-scrollbar{display:none}:root,html[data-theme=light]{--ui-bg: #edf4f6;--ui-bg-grad: radial-gradient(circle at 12% 12%, rgba(255, 255, 255, .88), transparent 24%), linear-gradient(180deg, #f6fbfc 0%, #edf4f6 46%, #e4eef1 100%);--ui-grid: linear-gradient(rgba(35, 80, 94, .06) 1px, transparent 1px), linear-gradient(90deg, rgba(35, 80, 94, .06) 1px, transparent 1px);--ui-surface: rgba(249, 252, 252, .94);--ui-surface-2: #fbfdfd;--ui-surface-soft: #eef4f5;--ui-surface-strong: #dbe7ea;--ui-border: #bfd1d7;--ui-border-strong: #7c99a4;--ui-text: #122631;--ui-text-2: #26424e;--ui-muted: #5f7882;--ui-link: #16718b;--ui-primary: #0f6f7f;--ui-primary-strong: #0a5562;--ui-primary-soft: rgba(15, 111, 127, .12);--ui-primary-soft-border: rgba(15, 111, 127, .22);--ui-accent: #f28c53;--ui-accent-strong: #d96f34;--ui-accent-soft: rgba(242, 140, 83, .12);--ui-warning: #b67b1f;--ui-warning-soft: rgba(182, 123, 31, .12);--ui-warning-soft-border: rgba(182, 123, 31, .22);--ui-danger: #c85d48;--ui-danger-soft: rgba(200, 93, 72, .12);--ui-danger-soft-border: rgba(200, 93, 72, .2);--ui-success: #2e8a71;--ui-success-soft: rgba(46, 138, 113, .12);--ui-success-soft-border: rgba(46, 138, 113, .2);--ui-overlay: rgba(12, 30, 38, .36);--ui-shadow: 0 18px 48px rgba(18, 38, 49, .12);--map-scene-surface: linear-gradient(180deg, rgba(255, 255, 255, .72) 0%, rgba(238, 244, 245, .96) 100%);--map-scene-atmosphere: linear-gradient(180deg, rgba(240, 246, 248, .9) 0%, rgba(219, 231, 234, .92) 100%);--map-panel-surface: color-mix(in srgb, var(--ui-surface-2) 94%, white);--map-chip-surface: color-mix(in srgb, var(--ui-surface-soft) 84%, white);--map-node-surface: color-mix(in srgb, var(--ui-surface-soft) 84%, white);--map-node-border: rgba(124, 153, 164, .18);--map-modal-avatar-bg: linear-gradient(180deg, rgba(15, 111, 127, .14) 0%, rgba(242, 140, 83, .16) 100%);--map-modal-avatar-border: rgba(15, 111, 127, .24);--map-modal-avatar-color: var(--ui-primary);--role-dock-bg: rgba(33, 150, 243, .14);--role-dock-border: rgba(33, 150, 243, .24);--role-dock-fg: #1c78c2;--role-square-bg: rgba(15, 111, 127, .13);--role-square-border: rgba(15, 111, 127, .24);--role-square-fg: #0f6f7f;--role-tavern-bg: rgba(212, 152, 63, .14);--role-tavern-border: rgba(212, 152, 63, .24);--role-tavern-fg: #9b6a17;--role-market-bg: rgba(242, 140, 83, .16);--role-market-border: rgba(242, 140, 83, .24);--role-market-fg: #c56a34;--role-vault-bg: rgba(46, 138, 113, .14);--role-vault-border: rgba(46, 138, 113, .24);--role-vault-fg: #2e8a71;--role-forge-bg: rgba(200, 93, 72, .15);--role-forge-border: rgba(200, 93, 72, .24);--role-forge-fg: #b45d4a;--role-guild-bg: rgba(88, 121, 161, .14);--role-guild-border: rgba(88, 121, 161, .24);--role-guild-fg: #5e7695;--role-warehouse-bg: rgba(140, 112, 86, .14);--role-warehouse-border: rgba(140, 112, 86, .24);--role-warehouse-fg: #7b624c;--role-crossroad-bg: rgba(96, 125, 139, .14);--role-crossroad-border: rgba(96, 125, 139, .24);--role-crossroad-fg: #526c7a;--role-avenue-bg: rgba(55, 166, 132, .13);--role-avenue-border: rgba(55, 166, 132, .24);--role-avenue-fg: #2d8870;--role-casino-bg: rgba(184, 92, 123, .14);--role-casino-border: rgba(184, 92, 123, .24);--role-casino-fg: #a95672;--role-landmark-bg: rgba(120, 134, 199, .13);--role-landmark-border: rgba(120, 134, 199, .24);--role-landmark-fg: #5f6fb0}html[data-theme=dark]{--ui-bg: #091720;--ui-bg-grad: radial-gradient(circle at 14% 12%, rgba(36, 91, 112, .4), transparent 24%), linear-gradient(180deg, #10232d 0%, #091720 56%, #071118 100%);--ui-grid: linear-gradient(rgba(117, 177, 198, .08) 1px, transparent 1px), linear-gradient(90deg, rgba(117, 177, 198, .08) 1px, transparent 1px);--ui-surface: rgba(12, 26, 34, .94);--ui-surface-2: #10222b;--ui-surface-soft: #16303a;--ui-surface-strong: #1d3c48;--ui-border: rgba(121, 158, 170, .34);--ui-border-strong: rgba(132, 183, 199, .68);--ui-text: #edf7f8;--ui-text-2: #d7e7ea;--ui-muted: #91acb4;--ui-link: #74d3e3;--ui-primary: #69c6d7;--ui-primary-strong: #8ad8e6;--ui-primary-soft: rgba(105, 198, 215, .14);--ui-primary-soft-border: rgba(105, 198, 215, .26);--ui-accent: #ff9e63;--ui-accent-strong: #ffb181;--ui-accent-soft: rgba(255, 158, 99, .14);--ui-warning: #ffc26d;--ui-warning-soft: rgba(255, 194, 109, .16);--ui-warning-soft-border: rgba(255, 194, 109, .3);--ui-danger: #ef8d74;--ui-danger-soft: rgba(239, 141, 116, .14);--ui-danger-soft-border: rgba(239, 141, 116, .24);--ui-success: #6fd6b3;--ui-success-soft: rgba(111, 214, 179, .14);--ui-success-soft-border: rgba(111, 214, 179, .24);--ui-overlay: rgba(3, 9, 13, .56);--ui-shadow: 0 24px 56px rgba(0, 0, 0, .34);--map-scene-surface: linear-gradient(180deg, rgba(16, 34, 43, .96) 0%, rgba(11, 25, 32, .98) 100%);--map-scene-atmosphere: linear-gradient(180deg, rgba(24, 49, 60, .9) 0%, rgba(17, 35, 44, .94) 100%);--map-panel-surface: color-mix(in srgb, var(--ui-surface-2) 94%, black 6%);--map-chip-surface: color-mix(in srgb, var(--ui-surface-soft) 88%, black 12%);--map-node-surface: color-mix(in srgb, var(--ui-surface-strong) 74%, var(--ui-surface-soft));--map-node-border: rgba(132, 183, 199, .28);--map-modal-avatar-bg: linear-gradient(180deg, rgba(105, 198, 215, .18) 0%, rgba(255, 158, 99, .16) 100%);--map-modal-avatar-border: rgba(132, 183, 199, .34);--map-modal-avatar-color: var(--ui-primary-strong);--role-dock-bg: rgba(72, 175, 255, .22);--role-dock-border: rgba(114, 198, 255, .36);--role-dock-fg: #91d3ff;--role-square-bg: rgba(105, 198, 215, .2);--role-square-border: rgba(132, 183, 199, .34);--role-square-fg: #8ad8e6;--role-tavern-bg: rgba(255, 179, 71, .22);--role-tavern-border: rgba(255, 196, 108, .34);--role-tavern-fg: #ffc26d;--role-market-bg: rgba(255, 158, 99, .22);--role-market-border: rgba(255, 177, 129, .34);--role-market-fg: #ffbe8a;--role-vault-bg: rgba(111, 214, 179, .2);--role-vault-border: rgba(143, 224, 193, .34);--role-vault-fg: #8fe0c1;--role-forge-bg: rgba(239, 141, 116, .22);--role-forge-border: rgba(246, 168, 144, .34);--role-forge-fg: #f4b096;--role-guild-bg: rgba(124, 145, 205, .22);--role-guild-border: rgba(155, 174, 226, .34);--role-guild-fg: #b9c8f5;--role-warehouse-bg: rgba(180, 145, 109, .2);--role-warehouse-border: rgba(204, 170, 136, .34);--role-warehouse-fg: #d7bc9c;--role-crossroad-bg: rgba(137, 163, 174, .22);--role-crossroad-border: rgba(168, 194, 204, .34);--role-crossroad-fg: #c3d6dc;--role-avenue-bg: rgba(80, 191, 156, .2);--role-avenue-border: rgba(120, 214, 184, .34);--role-avenue-fg: #96e0c6;--role-casino-bg: rgba(213, 113, 146, .22);--role-casino-border: rgba(233, 143, 174, .34);--role-casino-fg: #f0b1c8;--role-landmark-bg: rgba(145, 159, 224, .2);--role-landmark-border: rgba(173, 186, 237, .34);--role-landmark-fg: #c6d0fb}html,body{font-family:Microsoft YaHei,Noto Sans SC,sans-serif!important;background:var(--ui-bg-grad)!important;color:var(--ui-text)!important}body{letter-spacing:.01em}a,.top-link{color:var(--ui-link)!important}.app-container{position:relative;background:var(--ui-surface)!important;border:1px solid var(--ui-border)!important;border-radius:0!important;box-shadow:var(--ui-shadow)!important}.app-container:before{display:none}.main-content{padding:8px!important}.main-content.chat-page{padding:8px 8px 6px!important}.main-content.battle-page{padding:4px 0!important}.top-bar,.bottom-bar,.card,.location-bar,.scene-panel,.dir-card,.modal-card,.func-panel,.scene-npc-row,.monster-card{background:color-mix(in srgb,var(--ui-surface-2) 94%,white)!important;border:1px solid var(--ui-border)!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.top-bar{min-height:48px!important;padding:0 14px!important;margin:0 8px!important;border:none!important;border-bottom:1px solid var(--ui-border)!important;border-radius:0!important;background:transparent!important}.top-brand{display:inline-flex;align-items:center;gap:10px;min-width:0}.top-brand-mark{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:26px;padding:0 8px;border-radius:0;background:var(--ui-accent-soft);color:var(--ui-accent-strong);font-size:10px;font-weight:800;letter-spacing:.16em}.top-bar-title{color:var(--ui-text)!important;font-family:STSong,SimSun,"Noto Serif SC",serif;font-size:18px!important;font-weight:700!important;letter-spacing:.08em;text-shadow:none!important}.top-bar-right{display:inline-flex!important;align-items:center;gap:6px;font-size:11px!important;color:var(--ui-muted)!important}.theme-toggle-btn,.theme-toggle-fab,.auth-theme-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;min-width:28px;min-height:28px;padding:0!important;border-radius:0;border:0!important;background:transparent!important;color:var(--ui-text-2)!important;box-shadow:none!important}.top-user-meta{display:inline-flex;align-items:center;gap:6px;min-height:28px}.top-user-name,.top-user-level{display:inline-flex;align-items:center;padding:0;border:none!important;background:transparent!important;color:var(--ui-text-2)!important;font-size:11px!important;font-weight:700!important}.top-user-name{cursor:pointer}.theme-toggle-btn,.theme-toggle-fab,.auth-theme-btn{padding:0!important}.top-notice-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:24px;min-height:24px;padding:0!important;border:none!important;background:transparent!important;color:var(--ui-text-2)!important}.top-user-trigger{display:inline-flex;align-items:center;padding:0;border:none;background:transparent}.top-notice-icon{width:16px;height:16px;color:var(--ui-primary)}.top-notice-icon .app-icon{width:100%!important;height:100%!important;color:inherit}.top-notice-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--ui-danger);color:#fff;font-size:9px;font-weight:800;line-height:16px}.theme-toggle-fab,.auth-theme-btn{position:absolute;top:20px;right:20px;z-index:1200}.top-link-danger{display:inline-flex;align-items:center;justify-content:center;min-width:28px;min-height:28px;padding:0 10px;border-radius:14px;border:1px solid var(--ui-danger-soft-border);background:var(--ui-danger-soft);color:var(--ui-danger)!important;text-decoration:none;font-weight:700}.page{padding-bottom:12px}.chat-page{display:flex;flex-direction:column;gap:6px;padding-bottom:6px}.chat-page .location-bar,.chat-page .channel-tabs,.chat-page .chat-target-bar,.chat-page .chat-messages,.chat-page .chat-input-bar{margin:0!important}.home-page{display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:calc(100vh - 16px);padding:22px 16px 28px!important}.home-hero{position:relative;padding:8px 2px 4px}.home-hero:after{display:none}.home-hero-head{display:flex;flex-direction:column;gap:4px}.home-kicker{color:var(--ui-muted);font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.home-hero h1{margin:0;color:var(--ui-text);font-family:STSong,SimSun,"Noto Serif SC",serif;font-size:30px;font-weight:700;letter-spacing:.08em}.home-subtitle{max-width:34em;margin-top:12px;color:var(--ui-text-2);font-size:14px;line-height:1.7;letter-spacing:.01em}.home-action-row,.home-action-stack{display:grid;gap:8px;margin-top:22px}.auth-page .form-group label,.register-page .form-group label{color:var(--ui-text-2)!important;font-size:12px;font-weight:800;letter-spacing:.04em}.auth-page .form-input,.register-page .form-input,.auth-page .captcha-image,.register-page .captcha-image{background:color-mix(in srgb,var(--ui-surface-soft) 78%,white)!important;border-color:color-mix(in srgb,var(--ui-border) 92%,var(--ui-primary-soft-border))!important}.auth-page .form-input::placeholder,.register-page .form-input::placeholder{color:color-mix(in srgb,var(--ui-muted) 76%,var(--ui-text-2))!important}.register-page .register-sex-chip{background:color-mix(in srgb,var(--ui-surface-soft) 78%,white)!important;border-color:color-mix(in srgb,var(--ui-border) 92%,var(--ui-primary-soft-border))!important;color:var(--ui-text-2)!important}.register-page .register-sex-chip.is-active{background:color-mix(in srgb,var(--ui-primary-soft) 62%,var(--ui-surface-2))!important;border-color:var(--ui-primary-soft-border)!important;color:var(--ui-primary-strong)!important}.home-action-row{grid-template-columns:repeat(3,minmax(0,1fr))}.home-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.home-info-card{padding:14px;border:1px solid var(--ui-border);border-radius:18px;background:color-mix(in srgb,var(--ui-surface-soft) 82%,white)}.home-info-label{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;background:var(--ui-primary-soft);color:var(--ui-primary);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.home-info-card strong{display:block;margin-top:10px;color:var(--ui-text);font-size:15px}.home-info-card p{margin-top:6px;color:var(--ui-muted);font-size:12px;line-height:1.6}.card{padding:14px 16px!important;margin-bottom:8px!important;border-radius:20px!important}.card-title,.location-name,.scene-title,.modal-title{color:var(--ui-text)!important;text-shadow:none!important}.card-title{margin-bottom:10px!important;padding-bottom:0!important;border-bottom:none!important;color:var(--ui-muted)!important;font-size:11px!important;font-weight:800!important;letter-spacing:.16em;text-transform:uppercase}.status-card{display:flex;flex-direction:column;gap:12px}.status-head{display:flex;justify-content:space-between;gap:12px}.status-card-title{margin-bottom:6px!important}.status-name{color:var(--ui-text);font-size:24px;font-weight:700;letter-spacing:-.02em}.status-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.status-tags span{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:var(--ui-surface-soft);border:1px solid var(--ui-border);color:var(--ui-text-2);font-size:11px;font-weight:700}.status-wallet{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.status-wallet-label{color:var(--ui-muted);font-size:11px}.status-wallet-value{color:var(--ui-accent-strong);font-size:20px;font-weight:800;letter-spacing:.03em}.status-meter{display:flex;flex-direction:column;gap:6px}.status-meter-head{display:flex;justify-content:space-between;color:var(--ui-text-2);font-size:12px;font-weight:700}.status-meter-track,.status-bar .bar-track,.qs-bar-wrap{height:10px!important;border-radius:999px!important;background:var(--ui-surface-strong)!important;border:1px solid rgba(124,153,164,.18)!important;overflow:hidden}.status-meter-fill,.status-bar .bar-fill,.qs-bar{height:100%;border-radius:999px}.status-meter-fill.hp,.bar-hp .bar-fill,.qs-hp-bar{background:linear-gradient(90deg,var(--ui-accent) 0%,var(--ui-danger) 100%)!important}.status-meter-fill.exp,.bar-exp .bar-fill,.qs-exp-bar{background:linear-gradient(90deg,var(--ui-primary) 0%,#6dcad6 100%)!important}.btn,.modal-btn{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:8px 14px!important;border-radius:14px!important;border:1px solid transparent!important;box-shadow:none!important;font-size:13px!important;font-weight:800!important;letter-spacing:.02em;text-decoration:none}.btn-primary,.modal-btn-primary,.btn-bank.gold{background:var(--ui-primary)!important;border-color:var(--ui-primary-strong)!important;color:#f4fdff!important}.modal-btn-secondary{background:color-mix(in srgb,var(--ui-accent-soft) 88%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-accent-soft-border) 86%,var(--ui-border))!important;color:var(--ui-accent-strong)!important}.btn-secondary,.modal-btn-close,.battle-flee-btn,.btn-bank.green{background:var(--ui-surface-soft)!important;border-color:var(--ui-border)!important;color:var(--ui-text-2)!important}.btn-danger,.modal-btn-danger,.battle-attack-btn{background:var(--ui-danger-soft)!important;border-color:var(--ui-danger-soft-border)!important;color:var(--ui-danger)!important}.btn-success,.battle-capture-btn,.btn-buy{background:color-mix(in srgb,var(--ui-success-soft) 92%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-success-soft-border) 90%,var(--ui-border))!important;color:var(--ui-success)!important}.form-group input,.form-group select,.form-group textarea,.inline-form textarea,.form-input,.page select,.page input[type=text],.page input[type=number],.page input[type=password],.page input[type=search],.inline-form input,.inline-form select,.bank-input,.qty-control input{background:color-mix(in srgb,var(--ui-surface-soft) 84%,white)!important;border:1px solid var(--ui-border)!important;border-radius:14px!important;color:var(--ui-text)!important;box-shadow:none!important}.form-group input,.form-group select,.form-group textarea,.inline-form textarea,.form-input,.page select,.page input[type=text],.page input[type=number],.page input[type=password],.page input[type=search],.inline-form input,.inline-form select,.bank-input,.qty-control input{min-height:40px;padding:0 12px!important;font-size:13px!important;line-height:1.2;outline:none;transition:border-color .18s ease,background-color .18s ease}.form-group textarea{min-height:92px;padding:10px 12px!important;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.inline-form textarea:focus,.form-input:focus,.page select:focus,.page input[type=text]:focus,.page input[type=number]:focus,.page input[type=password]:focus,.page input[type=search]:focus,.inline-form input:focus,.inline-form select:focus,.bank-input:focus,.qty-control input:focus{border-color:var(--ui-primary-soft-border)!important;background:color-mix(in srgb,var(--ui-surface-2) 92%,white)!important}.form-group select,.page select,.form-input[type=text],.inline-form select{-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-group select,.page select,.form-input.chat-select,.inline-form select{padding-right:36px!important;background-image:linear-gradient(45deg,transparent 50%,var(--ui-muted) 50%),linear-gradient(135deg,var(--ui-muted) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}.page select option{background:var(--ui-surface-2);color:var(--ui-text)}.bottom-bar{display:flex!important;align-items:center!important;justify-content:space-between;min-height:46px!important;margin:0 8px 1px!important;padding:2px 0!important;gap:6px;border:none!important;border-radius:0!important;background:transparent!important;box-shadow:none!important}.bottom-link{display:inline-flex!important;flex:1 1 0;align-items:center;justify-content:center;align-self:center;flex-direction:column;min-height:36px!important;margin:0!important;gap:1px!important;padding:3px 4px!important;border-radius:14px!important;border:1px solid color-mix(in srgb,var(--ui-border) 46%,transparent)!important;background:color-mix(in srgb,var(--ui-surface-2) 72%,transparent)!important;color:var(--ui-muted)!important;box-shadow:none!important}.bottom-link .nav-icon,.func-grid .func-btn .func-emoji,.map-fab-icon,.city-place-icon{color:var(--ui-primary)}.bottom-link .nav-text{font-size:11px!important;line-height:1.15!important}.bottom-link .nav-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px}.bottom-link .nav-icon .app-icon{width:100%!important;height:100%!important}.bottom-link-badge{position:absolute;top:-6px;right:-10px;display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--ui-danger);color:#fff;font-size:9px;font-weight:800;line-height:1}.bottom-link.active,.bottom-link:hover,.bottom-link:active{background:color-mix(in srgb,var(--ui-primary-soft) 56%,var(--ui-surface-2))!important;border-color:var(--ui-primary-soft-border)!important;color:var(--ui-text)!important;transform:none!important;box-shadow:none!important}.func-float.open .func-overlay-bg,.modal-overlay,.modal-overlay-2,.battle-overlay{background:var(--ui-overlay)!important}.func-panel{bottom:60px!important;height:min(338px,46vh)!important;padding:10px!important;border-radius:22px 22px 16px 16px!important}.func-close-bar{width:36px!important;height:4px!important;margin:0 auto 10px!important;border-radius:999px!important;background:var(--ui-border-strong)!important}.func-grid{display:grid!important;grid-template-columns:repeat(5,minmax(0,1fr))!important;gap:6px!important}.func-grid .func-btn{min-height:62px;gap:5px!important;padding:8px 3px!important;border-radius:12px!important;background:color-mix(in srgb,var(--ui-surface-soft) 82%,white)!important;border:1px solid rgba(124,153,164,.18)!important;color:var(--ui-text-2)!important}.func-grid .func-btn .func-emoji{width:20px;height:20px}.func-grid .func-btn .func-label{font-size:12px!important;line-height:1.1!important}.func-grid .func-btn.func-highlight{background:var(--ui-primary-soft)!important;border-color:var(--ui-primary-soft-border)!important;color:var(--ui-primary)!important}.func-grid .func-btn.func-success{background:var(--ui-success-soft)!important;border-color:var(--ui-success-soft-border)!important;color:var(--ui-success)!important}.quick-stats{background:var(--ui-surface-2)!important;border:1px solid var(--ui-border)!important;border-radius:14px!important;box-shadow:none!important}.qs-item,.qs-val,.qs-label{color:var(--ui-text-2)!important}.qs-bar-wrap{background:var(--ui-surface-soft)!important;border:1px solid var(--ui-border)!important}.quest-alert{padding:8px 12px!important;border-radius:14px!important;background:var(--ui-success-soft)!important;border:1px solid var(--ui-success-soft-border)!important;color:var(--ui-success)!important;font-size:12px!important}.location-bar{border-radius:20px!important}.scene-title{font-size:20px!important;font-weight:700!important;letter-spacing:.02em}.scene-desc,.modal-subtitle,.modal-dialog,.empty-state{color:var(--ui-text-2)!important}.city-name,.scene-section-meta,.npc-desc-text,.scene-empty-state,.location-path,.city-place-meta,.city-focus-meta,.city-focus-tip{color:var(--ui-muted)!important}.city-layout-wrap,.city-mini-card,.city-focus-panel{background:color-mix(in srgb,var(--ui-surface-soft) 80%,white)!important;border:1px solid rgba(124,153,164,.16)!important;border-radius:16px!important}.city-place-row,.shop-item,.bank-summary,.bank-section,.chat-next-btn{background:color-mix(in srgb,var(--ui-surface-soft) 90%,white)!important;border:1px solid color-mix(in srgb,var(--ui-border) 84%,transparent)!important;border-radius:14px!important}.shop-item{gap:10px!important;padding:10px 12px!important}.shop-item-name{color:var(--ui-text)!important}.shop-item-name .level-req{color:var(--ui-muted)!important}.shop-item-desc{color:var(--ui-text-2)!important;line-height:1.5}.shop-item-price{color:var(--ui-warning)!important}.shop-item-action{gap:6px!important}.qty-control{display:inline-grid;grid-template-columns:34px 48px 34px;align-items:center;border:1px solid color-mix(in srgb,var(--ui-border) 88%,transparent);border-radius:999px;overflow:hidden;background:color-mix(in srgb,var(--ui-surface) 92%,white)}.qty-control button{height:34px;border:none;background:transparent;color:var(--ui-text-2);font-size:14px;font-weight:800;cursor:pointer}.qty-control button:active{background:color-mix(in srgb,var(--ui-primary-soft) 30%,transparent)}.qty-control input{min-height:34px!important;height:34px;padding:0 6px!important;border-top:none!important;border-bottom:none!important;border-left:1px solid color-mix(in srgb,var(--ui-border) 84%,transparent)!important;border-right:1px solid color-mix(in srgb,var(--ui-border) 84%,transparent)!important;border-radius:0!important;text-align:center;background:transparent!important}.npc-preview-modal .modal-header,.npc-chat-modal .modal-header,.monster-preview-modal .modal-header{border-bottom-color:color-mix(in srgb,var(--ui-border) 72%,transparent)!important}.npc-preview-avatar,.npc-chat-avatar{background:color-mix(in srgb,var(--ui-primary-soft) 82%,var(--ui-surface-2))!important;border:2px solid color-mix(in srgb,var(--ui-primary) 42%,var(--ui-border))!important;color:var(--ui-primary)!important}.npc-preview-title,.npc-chat-title,.monster-preview-title{color:var(--ui-text)!important}.npc-preview-modal .modal-subtitle-quote{color:var(--ui-text-2)!important}.quest-list-modal .modal-header{border-bottom-color:color-mix(in srgb,var(--ui-border) 72%,transparent)!important}.quest-list-avatar{background:color-mix(in srgb,var(--ui-accent-soft) 78%,var(--ui-surface-2))!important;border:2px solid color-mix(in srgb,var(--ui-accent) 40%,var(--ui-border))!important;color:var(--ui-accent-strong)!important}.quest-list-title{color:var(--ui-text)!important}.quest-list-subtitle{color:var(--ui-text-2)!important}.quest-list-body{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.quest-list-section-title{margin-bottom:6px;font-size:12px;font-weight:700;line-height:1.2}.quest-list-section-title.has-top-gap{margin-top:10px}.quest-list-section-title.is-available{color:var(--ui-success)!important}.quest-list-section-title.is-active{color:var(--ui-warning)!important}.quest-list-item{display:grid;gap:4px;margin-bottom:6px;padding:8px 10px;border:1px solid var(--ui-border);border-radius:10px}.quest-list-item.is-available{background:color-mix(in srgb,var(--ui-success-soft) 56%,var(--ui-surface-2))!important;border-color:color-mix(in srgb,var(--ui-success-soft-border) 70%,var(--ui-border))!important}.quest-list-item.is-active{background:color-mix(in srgb,var(--ui-warning-soft) 48%,var(--ui-surface-2))!important;border-color:color-mix(in srgb,var(--ui-warning-soft-border) 64%,var(--ui-border))!important}.quest-list-item.is-ready{background:color-mix(in srgb,var(--ui-primary-soft) 52%,var(--ui-surface-2))!important;border-color:color-mix(in srgb,var(--ui-primary-soft-border) 72%,var(--ui-border))!important}.quest-list-item-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.quest-list-item-name{min-width:0;color:var(--ui-text)!important;font-size:13px;font-weight:600}.quest-list-level,.quest-list-status{display:inline-flex;align-items:center;justify-content:center;min-height:18px;padding:0 7px;border-radius:999px;font-size:10px;font-weight:700;line-height:1;white-space:nowrap}.quest-list-level{background:color-mix(in srgb,var(--ui-accent-soft) 82%,transparent);color:var(--ui-accent-strong)!important}.quest-list-status.is-progress{background:color-mix(in srgb,var(--ui-warning-soft) 84%,transparent);color:var(--ui-warning)!important}.quest-list-status.is-ready{background:color-mix(in srgb,var(--ui-primary-soft) 84%,transparent);color:var(--ui-primary)!important}.quest-list-hint{color:var(--ui-link)!important;font-size:10px;line-height:1.45}.quest-list-desc{color:var(--ui-text-2)!important;font-size:11px;line-height:1.45}.quest-list-row{display:grid;grid-template-columns:38px minmax(0,1fr);gap:8px;align-items:start}.quest-list-row-label{color:var(--ui-muted)!important;font-size:10px;font-weight:700;line-height:1.5}.quest-list-row-value{color:var(--ui-text)!important;font-size:11px;font-weight:600;line-height:1.5}.quest-list-reward{color:var(--ui-muted)!important;font-size:10px}.quest-list-progress{height:6px;overflow:hidden;border-radius:999px;background:color-mix(in srgb,var(--ui-surface-strong) 78%,var(--ui-surface))!important}.quest-list-progress-bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--ui-warning),var(--ui-accent))!important}.quest-list-action{width:100%;margin-top:6px;border:1px solid transparent;border-radius:8px;padding:7px 16px;font-size:12px;font-weight:700;line-height:1.2;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,color .18s ease}.quest-list-action.is-accept{background:color-mix(in srgb,var(--ui-success-soft) 82%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-success-soft-border) 86%,var(--ui-border))!important;color:var(--ui-success)!important}.quest-list-action.is-claim{background:color-mix(in srgb,var(--ui-primary-soft) 84%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-primary-soft-border) 88%,var(--ui-border))!important;color:var(--ui-primary)!important}.quest-list-action.is-guide{background:color-mix(in srgb,var(--ui-surface-soft) 90%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-border) 90%,transparent)!important;color:var(--ui-text-2)!important}.quest-list-empty{padding:20px;text-align:center;color:var(--ui-muted)!important}.monster-preview-modal .modal-body{display:grid;gap:10px}.monster-preview-subtitle{color:var(--ui-danger)!important;font-weight:700}.monster-preview-modal .modal-dialog{margin:0!important;padding:12px 14px;border-radius:16px;background:color-mix(in srgb,var(--ui-surface-soft) 88%,var(--ui-surface-2))!important;border:1px solid color-mix(in srgb,var(--ui-danger-soft-border) 44%,var(--ui-border))!important;color:var(--ui-text-2)!important;line-height:1.6}.monster-preview-modal .modal-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px}.monster-preview-modal .modal-stat{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;padding:10px 12px;border-radius:14px;background:color-mix(in srgb,var(--ui-surface) 92%,var(--ui-surface-soft))!important;border:1px solid color-mix(in srgb,var(--ui-border) 72%,transparent)!important}.monster-preview-modal .modal-stat-label{color:var(--ui-text-2)!important;font-size:12px;font-weight:700}.monster-preview-modal .modal-stat-val{color:var(--ui-text)!important;font-size:13px;font-weight:800}.monster-preview-modal .modal-footer{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.monster-preview-modal .modal-btn-danger{background:color-mix(in srgb,var(--ui-danger-soft) 82%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-danger-soft-border) 88%,var(--ui-border))!important;color:var(--ui-danger)!important}.monster-preview-modal .modal-btn-close{background:color-mix(in srgb,var(--ui-surface-soft) 94%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-border) 90%,transparent)!important;color:var(--ui-text)!important}.battle-shell .battle-log,.battle-shell .battle-log-box{background:transparent!important;border-color:transparent!important;box-shadow:none!important}.battle-shell .battle-log .log-line,.battle-shell .battle-log-box .log-line,.battle-shell .battle-log-box .battle-log-line{background:color-mix(in srgb,var(--ui-surface-soft) 82%,var(--ui-surface))!important}.npc-preview-meta{margin-top:8px;padding:9px 10px;border-radius:12px;background:color-mix(in srgb,var(--ui-surface-soft) 84%,var(--ui-surface-2))!important;border:1px solid color-mix(in srgb,var(--ui-border) 72%,transparent)!important}.npc-preview-meta-line{font-size:11px;color:var(--ui-muted)!important}.npc-preview-meta-copy{margin-top:4px;font-size:11px;color:var(--ui-text-2)!important;line-height:1.5}.npc-preview-quest-btn{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 14px;border-radius:12px;background:color-mix(in srgb,var(--ui-accent-soft) 86%,var(--ui-surface))!important;border:1px solid color-mix(in srgb,var(--ui-accent-soft-border) 86%,var(--ui-border))!important;color:var(--ui-accent-strong)!important;font-size:12px;font-weight:700;text-decoration:none}.npc-chat-modal .chat-bubbles{padding:2px 0 4px}.npc-chat-modal .chat-bubble{margin-bottom:10px}.npc-chat-modal .chat-story-panel{display:none}.npc-chat-modal .bubble-text{color:var(--ui-text)!important;background:color-mix(in srgb,var(--ui-surface) 92%,var(--ui-surface-soft))!important;border:1px solid color-mix(in srgb,var(--ui-border) 78%,transparent)!important;border-radius:6px 16px 16px!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;line-height:1.72}.npc-chat-modal .chat-bubble:first-child .bubble-text{background:color-mix(in srgb,var(--ui-primary-soft) 18%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-primary) 16%,var(--ui-border))!important;color:var(--ui-text)!important}.npc-chat-modal .bubble-text.small{color:var(--ui-text-2)!important}.npc-chat-modal .chat-story-panel{margin:0 0 10px;padding:10px 12px;border:1px solid color-mix(in srgb,var(--ui-border) 82%,transparent);border-radius:14px;background:color-mix(in srgb,var(--ui-surface) 92%,var(--ui-surface-soft))!important}.npc-chat-modal .chat-story-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.npc-chat-modal .chat-story-head strong{color:var(--ui-text)!important;font-size:13px;line-height:1.35}.npc-chat-modal .chat-story-head span{flex-shrink:0;color:var(--ui-link)!important;font-size:10px;font-weight:700}.npc-chat-modal .chat-story-line{display:grid;grid-template-columns:42px minmax(0,1fr);gap:8px;margin-top:4px}.npc-chat-modal .chat-quest-bridge{margin:0 0 8px;padding:8px 10px;border:1px solid color-mix(in srgb,var(--ui-primary) 12%,var(--ui-border));border-radius:14px;background:color-mix(in srgb,var(--ui-primary-soft) 12%,var(--ui-surface))}.npc-chat-modal .chat-quest-bridge-line{display:grid;grid-template-columns:42px minmax(0,1fr);gap:8px}.npc-chat-modal .chat-quest-bridge-line+.chat-quest-bridge-line{margin-top:5px}.npc-chat-modal .chat-quest-bridge-line span{color:var(--ui-muted);font-size:10px;font-weight:700;line-height:1.5}.npc-chat-modal .chat-quest-bridge-line strong{color:var(--ui-text);font-size:11px;line-height:1.5}.npc-chat-modal .chat-story-label{color:var(--ui-muted)!important;font-size:10px;font-weight:700;line-height:1.5}.npc-chat-modal .chat-story-text{color:var(--ui-text-2)!important;font-size:11px;line-height:1.5}.npc-chat-modal .chat-quest-focus{margin:0 0 8px;padding:9px 11px;border:1px solid color-mix(in srgb,var(--ui-border) 84%,transparent);border-radius:14px;background:color-mix(in srgb,var(--ui-surface-soft) 88%,var(--ui-surface))}.npc-chat-modal .chat-quest-focus.is-claim{background:color-mix(in srgb,var(--ui-primary-soft) 18%,var(--ui-surface));border-color:color-mix(in srgb,var(--ui-primary) 16%,var(--ui-border))}.npc-chat-modal .chat-quest-focus.is-accept{background:color-mix(in srgb,var(--ui-success-soft) 18%,var(--ui-surface));border-color:color-mix(in srgb,var(--ui-success) 14%,var(--ui-border))}.npc-chat-modal .chat-quest-focus-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:2px}.npc-chat-modal .chat-quest-focus-head strong{color:var(--ui-text);font-size:13px;line-height:1.35}.npc-chat-modal .chat-quest-focus-head span{flex-shrink:0;font-size:10px;font-weight:700;color:var(--ui-primary)}.npc-chat-modal .chat-quest-focus-meta{display:grid;grid-template-columns:42px minmax(0,1fr);gap:8px;margin-top:5px}.npc-chat-modal .chat-quest-focus-meta span{color:var(--ui-muted);font-size:10px;font-weight:700;line-height:1.5}.npc-chat-modal .chat-quest-focus-meta strong{color:var(--ui-text);font-size:11px;line-height:1.5}.npc-chat-modal .npc-chat-footer{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.npc-chat-modal .npc-chat-footer.has-triple{grid-template-columns:repeat(3,minmax(0,1fr))}.npc-chat-modal .npc-chat-footer .modal-btn{min-height:38px;padding-inline:8px;font-size:12px}.npc-chat-modal .chat-next-btn{min-height:38px;padding:7px 16px!important;background:color-mix(in srgb,var(--ui-primary-soft) 22%,var(--ui-surface-soft))!important;border-color:color-mix(in srgb,var(--ui-primary) 15%,var(--ui-border))!important;color:var(--ui-primary)!important}.npc-chat-modal .chat-next-btn:active{background:color-mix(in srgb,var(--ui-primary-soft) 34%,var(--ui-surface-soft))!important}.npc-chat-modal .npc-chat-footer .modal-btn-primary{background:color-mix(in srgb,var(--ui-primary-soft) 84%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-primary-soft-border) 88%,var(--ui-border))!important;color:var(--ui-primary)!important}.npc-chat-modal .npc-chat-footer .modal-btn-secondary{background:color-mix(in srgb,var(--ui-surface-soft) 92%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-border) 88%,transparent)!important;color:var(--ui-text-2)!important}.npc-chat-modal .npc-chat-footer .modal-btn-close{background:color-mix(in srgb,var(--ui-surface-soft) 94%,var(--ui-surface))!important;border-color:color-mix(in srgb,var(--ui-border) 90%,transparent)!important;color:var(--ui-text)!important}.npc-chat-empty{font-size:10px;color:var(--ui-muted)!important}.map-fab{border:1px solid var(--ui-border)!important;background:var(--ui-surface-2)!important;color:var(--ui-primary)!important;box-shadow:0 8px 18px #1226311f!important}.map-toast{background:var(--ui-surface-2)!important;border:1px solid var(--ui-border-strong)!important;box-shadow:var(--ui-shadow)!important;max-width:min(86vw,300px);padding:10px 12px!important;border-radius:16px!important}.confirm-card{border-radius:20px!important}.confirm-body{padding:22px 18px 16px!important;text-align:center}.confirm-title{color:var(--ui-text);font-size:15px;font-weight:700}.confirm-message{color:var(--ui-text-2);font-size:13px;line-height:1.65;white-space:pre-line}.confirm-actions{display:flex;gap:10px;padding:0 18px 18px!important}@media(max-width:420px){.top-bar{padding:0 10px!important}.top-bar-right{gap:6px}.top-user-name{max-width:76px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-action-row,.home-info-grid{grid-template-columns:1fr}.func-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important}.status-head{flex-direction:column}.status-wallet{align-items:flex-start}}.map-page .quick-stats{display:flex!important;align-items:center;gap:8px!important;padding:2px 10px!important}.map-page .scene-panel{--map-scene-panel-base-height: 154px;background:var(--map-scene-surface)!important;border:1px solid var(--ui-border)!important;box-shadow:none!important;border-radius:14px!important;margin:0!important;padding:0!important;flex:0 0 auto;display:flex;flex-direction:column;max-height:var(--map-scene-panel-base-height);overflow:hidden}.map-page .scene-hero{position:relative;min-height:52px}.map-page .scene-header{position:absolute;inset:0 0 auto 0;z-index:2;display:flex;align-items:flex-start;gap:8px;padding:4px 12px 2px!important;border-bottom:0!important;background:linear-gradient(180deg,color-mix(in srgb,var(--ui-surface-2) 92%,white 8%) 0%,color-mix(in srgb,var(--ui-surface-2) 68%,transparent) 72%,transparent 100%)!important}.map-page .scene-head-copy{display:flex;min-width:0;flex:1;flex-direction:column;gap:2px}.map-page .scene-market-link{display:inline-flex;align-items:center;justify-content:center;align-self:center;min-height:26px;margin-left:auto;padding:0 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--ui-primary-soft-border) 84%,var(--ui-border));background:color-mix(in srgb,var(--ui-primary-soft) 54%,var(--ui-surface));color:var(--ui-primary-strong)!important;font-size:11px;font-weight:700;line-height:1;white-space:nowrap}.map-page .scene-title-desc{color:var(--ui-text-2)!important;font-size:10px;line-height:1.2;display:flex;align-items:center;min-height:12px;overflow:hidden;white-space:nowrap}.map-page .scene-title-desc.is-scrolling{-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%)}.map-page .scene-title-marquee{display:inline-flex;align-items:center;gap:24px;min-width:max-content;animation:scene-notice-marquee 14s linear infinite}.scene-role-dock{--scene-role-bg: var(--role-dock-bg);--scene-role-border: var(--role-dock-border)}.scene-role-square{--scene-role-bg: var(--role-square-bg);--scene-role-border: var(--role-square-border)}.scene-role-tavern{--scene-role-bg: var(--role-tavern-bg);--scene-role-border: var(--role-tavern-border)}.scene-role-market{--scene-role-bg: var(--role-market-bg);--scene-role-border: var(--role-market-border)}.scene-role-vault{--scene-role-bg: var(--role-vault-bg);--scene-role-border: var(--role-vault-border)}.scene-role-forge{--scene-role-bg: var(--role-forge-bg);--scene-role-border: var(--role-forge-border)}.scene-role-guild{--scene-role-bg: var(--role-guild-bg);--scene-role-border: var(--role-guild-border)}.scene-role-warehouse{--scene-role-bg: var(--role-warehouse-bg);--scene-role-border: var(--role-warehouse-border)}.scene-role-crossroad{--scene-role-bg: var(--role-crossroad-bg);--scene-role-border: var(--role-crossroad-border)}.scene-role-avenue{--scene-role-bg: var(--role-avenue-bg);--scene-role-border: var(--role-avenue-border)}.scene-role-casino{--scene-role-bg: var(--role-casino-bg);--scene-role-border: var(--role-casino-border)}.scene-role-landmark{--scene-role-bg: var(--role-landmark-bg);--scene-role-border: var(--role-landmark-border)}.map-page .scene-panel[class*=scene-role-] .scene-header{background:linear-gradient(180deg,color-mix(in srgb,var(--ui-surface-2) 78%,var(--scene-role-bg, transparent)) 0%,color-mix(in srgb,var(--scene-role-bg, transparent) 48%,transparent) 72%,transparent 100%)!important}.map-page .scene-sections{display:flex!important;flex-direction:column;min-height:0;grid-template-columns:1fr!important}.map-page .scene-section-monsters{display:none!important}.map-page .scene-atmosphere{position:relative;overflow:hidden;isolation:isolate;min-height:56px;background:var(--map-scene-atmosphere)!important;border-bottom:1px solid rgba(124,153,164,.16)!important}.map-page .scene-atmosphere:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.98;background-repeat:no-repeat}.map-page .scene-atmosphere .atm-emoji{z-index:1;filter:saturate(.92)}.map-page .scene-atmosphere.scene-role-dock:before{background-image:linear-gradient(180deg,transparent 0 48%,color-mix(in srgb,var(--scene-role-bg) 92%,rgba(255,255,255,.18)) 48% 100%),repeating-linear-gradient(90deg,transparent 0 12%,color-mix(in srgb,var(--scene-role-border) 72%,transparent) 12% 14%,transparent 14% 34%),radial-gradient(circle at 20% 76%,color-mix(in srgb,var(--scene-role-border) 82%,transparent) 0 10px,transparent 11px),radial-gradient(circle at 58% 78%,color-mix(in srgb,var(--scene-role-border) 66%,transparent) 0 9px,transparent 10px)}.map-page .scene-atmosphere.scene-role-guild:before{background-image:linear-gradient(180deg,transparent 0 38%,color-mix(in srgb,var(--scene-role-bg) 88%,rgba(255,255,255,.16)) 38% 100%),repeating-linear-gradient(90deg,transparent 0 10%,color-mix(in srgb,var(--scene-role-border) 74%,transparent) 10% 19%,transparent 19% 34%),linear-gradient(90deg,transparent 0 24%,color-mix(in srgb,var(--scene-role-border) 62%,transparent) 24% 28%,transparent 28% 72%,color-mix(in srgb,var(--scene-role-border) 62%,transparent) 72% 76%,transparent 76% 100%)}.map-page .scene-atmosphere.scene-role-market:before{background-image:linear-gradient(180deg,transparent 0 42%,color-mix(in srgb,var(--scene-role-bg) 88%,rgba(255,255,255,.18)) 42% 100%),repeating-linear-gradient(115deg,color-mix(in srgb,var(--scene-role-border) 70%,transparent) 0 9px,transparent 9px 18px),linear-gradient(90deg,transparent 0 12%,color-mix(in srgb,var(--scene-role-border) 54%,transparent) 12% 26%,transparent 26% 40%,color-mix(in srgb,var(--scene-role-border) 54%,transparent) 40% 54%,transparent 54% 68%)}.map-page .scene-atmosphere.scene-role-vault:before{background-image:linear-gradient(180deg,transparent 0 36%,color-mix(in srgb,var(--scene-role-bg) 84%,rgba(255,255,255,.16)) 36% 100%),repeating-linear-gradient(90deg,transparent 0 14%,color-mix(in srgb,var(--scene-role-border) 62%,transparent) 14% 18%,transparent 18% 32%),linear-gradient(180deg,transparent 0 24%,color-mix(in srgb,var(--scene-role-border) 44%,transparent) 24% 28%,transparent 28% 100%)}.map-page .scene-atmosphere.scene-role-forge:before{background-image:radial-gradient(circle at 24% 66%,color-mix(in srgb,var(--scene-role-border) 82%,transparent) 0 14px,transparent 15px),radial-gradient(circle at 72% 74%,color-mix(in srgb,var(--scene-role-bg) 88%,transparent) 0 11px,transparent 12px),linear-gradient(180deg,transparent 0 44%,color-mix(in srgb,var(--scene-role-bg) 82%,rgba(255,255,255,.12)) 44% 100%)}.map-page .scene-atmosphere.scene-role-warehouse:before{background-image:linear-gradient(180deg,transparent 0 42%,color-mix(in srgb,var(--scene-role-bg) 88%,rgba(255,255,255,.14)) 42% 100%),repeating-linear-gradient(90deg,transparent 0 8%,color-mix(in srgb,var(--scene-role-border) 70%,transparent) 8% 18%,transparent 18% 28%),linear-gradient(90deg,transparent 0 18%,color-mix(in srgb,var(--scene-role-border) 44%,transparent) 18% 46%,transparent 46% 54%,color-mix(in srgb,var(--scene-role-border) 44%,transparent) 54% 82%,transparent 82% 100%)}.map-page .scene-atmosphere.scene-role-square:before{background-image:linear-gradient(180deg,transparent 0 36%,color-mix(in srgb,var(--scene-role-bg) 88%,rgba(255,255,255,.15)) 36% 100%),radial-gradient(circle at 50% 62%,color-mix(in srgb,var(--scene-role-border) 74%,transparent) 0 12px,transparent 13px),linear-gradient(90deg,transparent 0 18%,color-mix(in srgb,var(--scene-role-border) 42%,transparent) 18% 22%,transparent 22% 78%,color-mix(in srgb,var(--scene-role-border) 42%,transparent) 78% 82%,transparent 82% 100%)}.map-page .scene-atmosphere.scene-role-crossroad:before{background-image:linear-gradient(90deg,transparent 0 42%,color-mix(in srgb,var(--scene-role-border) 66%,transparent) 42% 58%,transparent 58% 100%),linear-gradient(180deg,transparent 0 34%,color-mix(in srgb,var(--scene-role-bg) 84%,rgba(255,255,255,.16)) 34% 66%,transparent 66% 100%),repeating-linear-gradient(90deg,transparent 0 10%,color-mix(in srgb,var(--scene-role-border) 36%,transparent) 10% 12%,transparent 12% 22%)}.map-page .scene-atmosphere.scene-role-avenue:before{background-image:linear-gradient(180deg,transparent 0 32%,color-mix(in srgb,var(--scene-role-bg) 86%,rgba(255,255,255,.14)) 32% 100%),repeating-linear-gradient(90deg,transparent 0 8%,color-mix(in srgb,var(--scene-role-border) 66%,transparent) 8% 12%,transparent 12% 24%),linear-gradient(90deg,transparent 0 18%,color-mix(in srgb,var(--scene-role-border) 40%,transparent) 18% 24%,transparent 24% 76%,color-mix(in srgb,var(--scene-role-border) 40%,transparent) 76% 82%,transparent 82% 100%)}.map-page .scene-atmosphere.scene-role-tavern:before{background-image:linear-gradient(180deg,transparent 0 40%,color-mix(in srgb,var(--scene-role-bg) 86%,rgba(255,255,255,.16)) 40% 100%),radial-gradient(circle at 26% 64%,color-mix(in srgb,var(--scene-role-border) 68%,transparent) 0 9px,transparent 10px),radial-gradient(circle at 50% 64%,color-mix(in srgb,var(--scene-role-border) 68%,transparent) 0 9px,transparent 10px),radial-gradient(circle at 74% 64%,color-mix(in srgb,var(--scene-role-border) 68%,transparent) 0 9px,transparent 10px)}.map-page .scene-atmosphere.scene-role-landmark:before,.map-page .scene-atmosphere.scene-role-casino:before{background-image:linear-gradient(180deg,transparent 0 38%,color-mix(in srgb,var(--scene-role-bg) 86%,rgba(255,255,255,.14)) 38% 100%),radial-gradient(circle at 50% 34%,color-mix(in srgb,var(--scene-role-border) 70%,transparent) 0 10px,transparent 11px),linear-gradient(90deg,transparent 0 22%,color-mix(in srgb,var(--scene-role-border) 42%,transparent) 22% 30%,transparent 30% 70%,color-mix(in srgb,var(--scene-role-border) 42%,transparent) 70% 78%,transparent 78% 100%)}.map-page .scene-atmosphere.scene-role-casino:before{background-image:linear-gradient(180deg,transparent 0 38%,color-mix(in srgb,var(--scene-role-bg) 84%,rgba(255,255,255,.14)) 38% 100%),radial-gradient(circle at 28% 58%,color-mix(in srgb,var(--scene-role-border) 76%,transparent) 0 9px,transparent 10px),radial-gradient(circle at 72% 58%,color-mix(in srgb,var(--scene-role-border) 76%,transparent) 0 9px,transparent 10px),linear-gradient(90deg,transparent 0 46%,color-mix(in srgb,var(--scene-role-border) 54%,transparent) 46% 54%,transparent 54% 100%)}.map-page .scene-emoji{filter:saturate(1.08)}.map-page .atm-emoji{filter:saturate(1.1)}.map-page .scene-desc{color:var(--ui-text-2)!important}.map-page .scene-body{display:flex;flex:1 1 auto;flex-direction:column;min-height:0;padding:0 8px 4px}.map-page .scene-section{background:transparent!important;border:none!important;border-radius:0!important;display:flex;flex:1 1 auto;flex-direction:column;min-width:0;min-height:0;padding:2px 0 0;overflow:hidden}.map-page .scene-section-head{flex-shrink:0;align-items:center;padding-bottom:2px;margin-bottom:2px;border-bottom:1px solid color-mix(in srgb,var(--ui-border) 74%,transparent)}.map-page .scene-npcs{flex:1 1 auto;min-height:0;max-height:none;align-content:start;overflow-y:hidden!important;overflow-x:hidden!important;padding-right:1px;padding-bottom:0}.map-page .scene-npcs.is-scrollable{overflow-y:auto!important}.map-page .threat-panel{--map-threat-panel-base-height: 102px;background:var(--map-panel-surface)!important;border:1px solid var(--ui-border)!important;border-radius:14px!important;box-shadow:none!important;margin:0!important;display:flex;gap:4px;max-height:var(--map-threat-panel-base-height);flex-direction:column;flex-shrink:0;overflow:hidden;padding:8px 10px!important}.map-page .threat-panel-head{display:flex;align-items:flex-start;gap:6px;flex-shrink:0;padding-bottom:4px;margin-bottom:4px;border-bottom:1px solid color-mix(in srgb,var(--ui-border) 74%,transparent)}.map-page .quick-stats,.map-page .quest-alert,.map-page .nearby-bar,.map-page .dir-card{flex-shrink:0}.map-page .map-bottom-stack{display:flex;flex-direction:column;gap:6px;margin-top:auto}.map-page .threat-panel-title-wrap{display:flex;flex:1;min-width:0;flex-direction:column;gap:4px}.map-page .threat-panel-title,.map-page .threat-panel-meta,.map-page .threat-empty-title{color:var(--ui-text)!important}.map-page .threat-panel-note,.map-page .threat-empty-state{color:var(--ui-muted)!important}.map-page .threat-panel-meta{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 10px;border-radius:999px;border:1px solid var(--ui-border);background:var(--ui-surface-soft);font-size:11px;font-weight:700;white-space:nowrap}.map-page .threat-panel-meta.is-safe{background:var(--ui-success-soft);border-color:var(--ui-success-soft-border);color:var(--ui-success)!important}.map-page .threat-panel-meta.is-alert{background:var(--ui-danger-soft);border-color:var(--ui-danger-soft-border);color:var(--ui-danger)!important}.map-page .threat-panel-note{margin:0!important;padding:8px 10px;border-radius:12px;background:color-mix(in srgb,var(--ui-surface-soft) 78%,white);border:1px solid var(--map-node-border);line-height:1.6}.map-page .threat-empty-state{display:flex;flex:1 1 auto;min-height:0;align-items:center;gap:8px;padding:8px 10px;border:1px dashed color-mix(in srgb,var(--ui-border) 82%,transparent);border-radius:12px;background:color-mix(in srgb,var(--ui-surface-soft) 78%,white)}.map-page .threat-panel .monster-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;flex:1 1 auto;min-height:0;max-height:none;align-content:start;overflow-y:hidden!important;overflow-x:hidden!important;padding-right:2px}.map-page .threat-panel .monster-cards.is-scrollable{overflow-y:auto!important}.map-page .threat-empty-icon{background:var(--ui-success-soft);color:var(--ui-success)}.map-page .threat-empty-copy{display:flex;flex-direction:column;gap:4px;min-width:0;line-height:1.4}.map-page .threat-empty-title{font-size:12px;font-weight:700}.map-page .nearby-bar{background:var(--map-panel-surface)!important;border:1px solid var(--ui-border)!important;border-radius:14px!important;margin:0!important;padding:4px 10px!important}.map-page .nearby-label{display:inline-flex;align-items:center;gap:7px;color:var(--ui-text-2)!important;font-weight:700}.map-page .nearby-label strong{color:var(--ui-primary-strong);font-weight:800}.map-page .nearby-online-dot{width:8px;height:8px;border-radius:50%;background:var(--ui-success);box-shadow:0 0 0 3px var(--ui-success-soft)}.map-page .nearby-list{display:flex;gap:6px;overflow-x:auto;flex-wrap:nowrap}.map-page .nearby-chip{min-height:0;padding:3px 8px!important;background:var(--map-chip-surface)!important;border:1px solid var(--map-node-border)!important;border-radius:14px!important}.map-page .nearby-empty-chip{color:var(--ui-muted)!important}.map-page .dir-card{position:relative;display:flex;align-items:center;justify-content:center;background:var(--map-panel-surface)!important;border:1px solid var(--ui-border)!important;border-radius:14px!important;box-shadow:none!important;margin-right:0!important;margin-bottom:0!important;margin-left:0!important;margin-top:0;padding:5px 58px!important;min-height:110px}.map-page .scene-npc-row,.map-page .monster-card{display:flex;background:var(--map-node-surface)!important;border:1px solid var(--map-node-border)!important;border-radius:14px!important;min-width:0;gap:6px;padding:4px 8px!important;min-height:44px}.map-page .scene-npc-row.is-focused,.map-page .monster-card.is-focused{border-color:var(--ui-primary-soft-border)!important;background:color-mix(in srgb,var(--ui-primary-soft) 28%,var(--map-node-surface))!important}.map-page .scene-npc-row{gap:7px;padding:4px 10px}.map-page .scene-panel.npc-density-crowded .scene-npc-row,.map-page .scene-panel.npc-density-overflow .scene-npc-row{padding-top:3px;padding-bottom:3px}.map-page .npc-avatar{width:24px;height:24px;font-size:12px}.map-page .npc-name-text{font-size:11px}.map-page .npc-name-line{display:flex;align-items:center;gap:6px;min-width:0;flex-wrap:wrap}.map-page .npc-inline-tag{display:inline-flex;align-items:center;min-height:18px;padding:0 7px;border-radius:999px;background:#4285f41f;color:var(--ui-primary);font-size:9px;font-weight:700;line-height:1}.map-page .npc-inline-meta{color:var(--ui-muted)!important;font-size:10px;white-space:nowrap}.map-page .npc-desc-text{font-size:9px;margin-top:2px;line-height:1.25}.modal-head-copy{min-width:0;display:flex;flex-direction:column;gap:3px}.modal-title-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.modal-role-chip{display:inline-flex;align-items:center;min-height:18px;padding:0 7px;border-radius:999px;background:color-mix(in srgb,var(--ui-primary) 12%,transparent);color:var(--ui-primary);font-size:10px;font-weight:700;line-height:1}.modal-subtitle-quote{margin-top:0!important;line-height:1.45}.map-page .monster-card{align-items:center}.map-page .monster-icon-badge,.monster-modal-avatar{display:inline-flex;align-items:center;justify-content:center;color:var(--ui-danger)}.map-page .monster-icon-badge{width:32px;height:32px;flex:0 0 auto;border-radius:10px;background:var(--ui-danger-soft);border:1px solid var(--ui-danger-soft-border)}.map-page .monster-icon-badge.is-bandit{background:color-mix(in srgb,#d88d7b 22%,var(--ui-surface-2));border-color:color-mix(in srgb,#d88d7b 45%,var(--ui-border));color:#9a4b3c}.map-page .monster-icon-badge.is-pirate{background:color-mix(in srgb,#d7a57b 24%,var(--ui-surface-2));border-color:color-mix(in srgb,#d7a57b 48%,var(--ui-border));color:#8b5e3c}.map-page .monster-icon-badge.is-serpent{background:color-mix(in srgb,#81d4c7 22%,var(--ui-surface-2));border-color:color-mix(in srgb,#81d4c7 44%,var(--ui-border));color:#2a7b74}.map-page .monster-icon-badge.is-spirit{background:color-mix(in srgb,#b8a4f3 24%,var(--ui-surface-2));border-color:color-mix(in srgb,#b8a4f3 42%,var(--ui-border));color:#7565a8}.map-page .monster-icon-badge.is-boss{background:color-mix(in srgb,#efc36d 24%,var(--ui-surface-2));border-color:color-mix(in srgb,#efc36d 46%,var(--ui-border));color:#9c5e14}.map-page .monster-icon-badge.is-beast{background:color-mix(in srgb,#c99479 20%,var(--ui-surface-2));border-color:color-mix(in srgb,#c99479 40%,var(--ui-border));color:#8c5a49}.monster-modal-avatar{background:var(--ui-danger-soft);border:2px solid var(--ui-danger-soft-border)}.monster-modal-avatar.is-bandit{background:color-mix(in srgb,#d88d7b 22%,var(--ui-surface-2));border-color:color-mix(in srgb,#d88d7b 46%,var(--ui-border));color:#9a4b3c}.monster-modal-avatar.is-pirate{background:color-mix(in srgb,#d7a57b 24%,var(--ui-surface-2));border-color:color-mix(in srgb,#d7a57b 48%,var(--ui-border));color:#8b5e3c}.monster-modal-avatar.is-serpent{background:color-mix(in srgb,#81d4c7 22%,var(--ui-surface-2));border-color:color-mix(in srgb,#81d4c7 44%,var(--ui-border));color:#2a7b74}.monster-modal-avatar.is-spirit{background:color-mix(in srgb,#b8a4f3 24%,var(--ui-surface-2));border-color:color-mix(in srgb,#b8a4f3 42%,var(--ui-border));color:#7565a8}.monster-modal-avatar.is-boss{background:color-mix(in srgb,#efc36d 24%,var(--ui-surface-2));border-color:color-mix(in srgb,#efc36d 46%,var(--ui-border));color:#9c5e14}.map-page .mc-info{display:flex;min-width:0;flex:1;flex-direction:column;gap:3px}.map-page .mc-hp{display:inline-flex;align-items:center;gap:6px;color:var(--ui-muted)!important}.map-page .npc-action{display:inline-flex;align-items:center;justify-content:center;min-width:56px;min-height:28px;padding:0 12px;border-radius:999px;border:1px solid var(--ui-primary-soft-border);background:linear-gradient(180deg,color-mix(in srgb,var(--ui-surface-2) 84%,white),color-mix(in srgb,var(--ui-primary-soft) 92%,var(--ui-surface-soft)))!important;color:var(--ui-primary-strong)!important;box-shadow:none!important;margin-left:auto;flex:0 0 auto}.map-page .npc-action:active{transform:translateY(1px)}.map-page .dir-cross{position:relative;width:fit-content;max-width:none;margin:0 auto;grid-template-columns:repeat(3,108px);padding-right:0;gap:5px;justify-content:center}.map-page .dir-cross .dir-btn{min-height:40px;min-width:102px;padding:3px 6px;border-radius:14px!important;border:1px solid var(--map-node-border)!important;background:var(--map-node-surface)!important;color:var(--ui-text)!important;box-shadow:none!important}.map-page .dir-cross .dir-btn .dir-main{display:inline-flex;align-items:center;gap:5px;justify-content:center;font-size:14px;font-weight:800;line-height:1;white-space:nowrap}.map-page .dir-cross .dir-btn .dir-icon{width:13px;height:13px;color:var(--ui-primary)}.map-page .dir-cross .dir-btn .dir-icon .app-icon,.map-page .dir-cross .dir-center-btn .app-icon{width:100%!important;height:100%!important;color:inherit}.map-page .dir-cross .dir-btn .dir-sub{color:var(--ui-muted)!important;white-space:nowrap;text-align:center;font-size:9px;line-height:1.15}.map-page .dir-cross .dir-disabled{display:inline-flex;align-items:center;justify-content:center;min-height:40px;min-width:102px;padding:3px 6px;border-radius:14px!important;border:1px solid transparent!important;background:transparent!important;color:var(--ui-muted)!important;font-size:12px;line-height:1}.map-page .dir-cross .dir-center{position:absolute;left:50%;top:50%;z-index:3;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;width:30px;height:30px;pointer-events:none}.map-page .dir-cross .dir-center-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;margin:0;border-radius:50%!important;border:none!important;background:transparent!important;color:var(--ui-primary)!important;box-shadow:none!important;pointer-events:auto}.map-page .map-fab{position:absolute;right:12px;bottom:12px;width:42px;height:30px;min-width:42px;padding:0;gap:0;flex-direction:column;border-radius:10px!important;background:color-mix(in srgb,var(--ui-surface-2) 92%,white)!important;box-shadow:none!important}.city-layout-modal-avatar{background:var(--map-modal-avatar-bg)!important;border:1.5px solid var(--map-modal-avatar-border)!important;color:var(--map-modal-avatar-color)!important;box-shadow:none!important}.map-fab-icon{width:11px;height:11px}.map-fab-icon .app-icon,.city-layout-modal-avatar .app-icon{width:100%!important;height:100%!important;color:inherit}.map-fab-label{font-size:7px;font-weight:800;line-height:1}@media(max-width:420px){.map-page .scene-panel{--map-scene-panel-base-height: 148px}.map-page .scene-hero,.map-page .scene-atmosphere{min-height:52px}.map-page .threat-panel{--map-threat-panel-base-height: 98px}.map-page .dir-card{padding:5px 54px!important;min-height:104px}.map-page .dir-cross{grid-template-columns:repeat(3,90px)}.map-page .dir-cross .dir-btn,.map-page .dir-cross .dir-disabled{min-width:90px}.map-page .map-fab{right:10px;bottom:10px}.map-page .scene-npcs{max-height:none}}@media(max-height:860px){.map-page{overflow:hidden!important}.map-page .scene-panel{--map-scene-panel-base-height: 142px}.map-page .threat-panel{--map-threat-panel-base-height: 92px}.map-page .scene-npcs,.map-page .monster-cards{max-height:none}}@keyframes scene-notice-marquee{0%,10%{transform:translate(0)}to{transform:translate(calc(-50% - 12px))}}.city-layout-modal .modal-title{color:var(--ui-text)!important}.city-layout-modal .modal-subtitle,.city-layout-modal-note,.city-mini-subtitle,.city-mini-foot{color:var(--ui-text-2)!important}.place-role-dock{--place-role-bg: var(--role-dock-bg);--place-role-border: var(--role-dock-border);--place-role-fg: var(--role-dock-fg)}.place-role-square{--place-role-bg: var(--role-square-bg);--place-role-border: var(--role-square-border);--place-role-fg: var(--role-square-fg)}.place-role-tavern{--place-role-bg: var(--role-tavern-bg);--place-role-border: var(--role-tavern-border);--place-role-fg: var(--role-tavern-fg)}.place-role-market{--place-role-bg: var(--role-market-bg);--place-role-border: var(--role-market-border);--place-role-fg: var(--role-market-fg)}.place-role-vault{--place-role-bg: var(--role-vault-bg);--place-role-border: var(--role-vault-border);--place-role-fg: var(--role-vault-fg)}.place-role-forge{--place-role-bg: var(--role-forge-bg);--place-role-border: var(--role-forge-border);--place-role-fg: var(--role-forge-fg)}.place-role-guild{--place-role-bg: var(--role-guild-bg);--place-role-border: var(--role-guild-border);--place-role-fg: var(--role-guild-fg)}.place-role-warehouse{--place-role-bg: var(--role-warehouse-bg);--place-role-border: var(--role-warehouse-border);--place-role-fg: var(--role-warehouse-fg)}.place-role-crossroad{--place-role-bg: var(--role-crossroad-bg);--place-role-border: var(--role-crossroad-border);--place-role-fg: var(--role-crossroad-fg)}.place-role-avenue{--place-role-bg: var(--role-avenue-bg);--place-role-border: var(--role-avenue-border);--place-role-fg: var(--role-avenue-fg)}.place-role-casino{--place-role-bg: var(--role-casino-bg);--place-role-border: var(--role-casino-border);--place-role-fg: var(--role-casino-fg)}.place-role-landmark{--place-role-bg: var(--role-landmark-bg);--place-role-border: var(--role-landmark-border);--place-role-fg: var(--role-landmark-fg)}.city-layout-node-badge,.city-mini-node-badge{fill:var(--place-role-bg, var(--map-chip-surface));stroke:var(--place-role-border, var(--map-node-border));transition:fill .18s ease,stroke .18s ease,opacity .18s ease}.city-layout-node-badge.is-current,.city-mini-node-badge.is-current{stroke-width:2}.city-layout-node-badge.is-selected,.city-mini-node-badge.is-selected{stroke-width:2.15}.city-layout-node-icon,.city-mini-node-icon,.city-place-icon{color:var(--place-role-fg, var(--ui-primary))}.city-place-icon{background:var(--place-role-bg, var(--map-chip-surface));border:1px solid var(--place-role-border, var(--map-node-border))}html[data-theme=dark] .city-layout-label,html[data-theme=dark] .city-mini-label{fill:var(--ui-text)!important}html[data-theme=dark] .city-layout-edge.is-muted,html[data-theme=dark] .city-mini-edge.is-muted{opacity:.16}html[data-theme=dark] .map-page .scene-title,html[data-theme=dark] .map-page .scene-section-title,html[data-theme=dark] .map-page .threat-panel-title{color:var(--ui-text)!important}html[data-theme=dark] .map-page .city-name,html[data-theme=dark] .map-page .scene-section-meta,html[data-theme=dark] .map-page .threat-panel-note,html[data-theme=dark] .map-page .threat-empty-state{color:var(--ui-muted)!important}.citymap-page .city-place-list{grid-template-columns:repeat(2,minmax(0,1fr))!important}.citymap-page .city-place-row{align-items:center;min-height:72px;padding:8px 10px;gap:10px}.citymap-page .city-place-name{align-items:center;gap:6px;line-height:1.15}.citymap-page .city-place-main{display:flex;min-width:0;flex-direction:column;justify-content:center;gap:5px}.citymap-page .city-place-icon{width:22px;height:22px}.citymap-page .city-place-name-text{font-size:12px}.citymap-page .city-place-meta{font-size:10px!important;line-height:1.2}.citymap-page .city-current-tag{min-height:16px;padding:0 5px;font-size:9px}.citymap-page .btn-small{min-height:28px!important;padding:0 10px!important;font-size:11px!important}@media(max-width:420px){.map-page .quick-stats{flex-wrap:wrap}.citymap-page .city-place-list{grid-template-columns:repeat(2,minmax(0,1fr))!important}}
