:root{--bg: #101214;--bg-elevated: #14171a;--surface: #161a1d;--surface-hover: #1e2226;--surface-inset: #121518;--border: #2a2d31;--border-strong: #363a3f;--text: #f3f4f6;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--accent: #e53935;--accent-hover: #ef5350;--accent-muted: rgba(229, 57, 53, .1);--accent-ring: rgba(229, 57, 53, .32);--success: #00c853;--success-muted: rgba(0, 200, 83, .1);--danger: #e53935;--danger-muted: rgba(229, 57, 53, .1);--info: #2196f3;--info-muted: rgba(33, 150, 243, .1);--warning: #e0b050;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .25);--shadow: 0 8px 32px rgba(0, 0, 0, .28);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .35);--sidebar-w: 252px;--font: "Inter", system-ui, -apple-system, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace;--ease: cubic-bezier(.22, 1, .36, 1)}*,*:before,*:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.5;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 65% 42% at 12% -8%,rgba(33,150,243,.05),transparent),radial-gradient(ellipse 55% 38% at 88% 102%,rgba(229,57,53,.04),transparent);pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;opacity:.028;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:180px 180px}#root{position:relative;z-index:1;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color .15s var(--ease)}a:hover{color:var(--accent-hover)}.app-shell{display:flex;min-height:100vh}.content-area{flex:1;min-width:0;display:flex;flex-direction:column}.site-footer{margin-top:auto;padding:1.5rem 3.25rem 2rem;text-align:center}.site-footer p{margin:0;font-size:.78rem;color:var(--text-tertiary);letter-spacing:.02em}.main{flex:1;padding:2.75rem 3.25rem 4rem;max-width:1240px;width:100%;animation:page-in .35s var(--ease)}.page{display:flex;flex-direction:column;gap:1.35rem}@keyframes page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.page-header-actions .toolbar{justify-content:flex-end}.sidebar{width:var(--sidebar-w);background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.5rem .75rem 1.25rem;position:sticky;top:0;height:100vh;flex-shrink:0}.brand{display:flex;align-items:center;gap:.75rem;padding:.25rem .75rem 1.5rem;margin-bottom:.125rem}.brand-mark{width:36px;height:36px;border-radius:var(--radius-sm);background:linear-gradient(145deg,#c7505029,#c750500f);border:1px solid var(--accent-ring);color:#e08080;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.brand-mark-lg{width:52px;height:52px;font-size:1.35rem;border-radius:var(--radius-lg)}.brand-name{font-weight:700;font-size:1.05rem;letter-spacing:-.02em;line-height:1.2}.brand-tag{font-size:.72rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-top:.1rem}.sidebar-nav{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.125rem;padding:0 .25rem}.nav-group{margin-bottom:1rem}.nav-group-label{display:block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);padding:.35rem .75rem .4rem}.nav-item{position:relative;display:flex;align-items:center;gap:.7rem;padding:.5rem .75rem .5rem .875rem;margin-left:.25rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;font-size:.875rem;transition:background .15s var(--ease),color .15s var(--ease);text-decoration:none}.nav-item:hover{background:#ffffff0a;color:var(--text)}.nav-item.active{background:var(--accent-muted);color:var(--text)}.nav-item.active:before{content:"";position:absolute;left:-.25rem;top:50%;transform:translateY(-50%);width:2px;height:55%;min-height:14px;max-height:22px;background:var(--accent);border-radius:2px}.nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.65;display:flex;align-items:center;justify-content:center}.nav-label{line-height:1.25}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1;color:var(--accent)}.nav-icon svg{width:100%;height:100%;display:block}.user-panel{margin-top:auto;padding:.875rem .5rem 0;border-top:1px solid var(--border)}.user-panel-row{display:flex;align-items:center;gap:.65rem}.user-panel-text{flex:1;min-width:0}.user-panel-text .user-name-nick{font-size:.84rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.user-panel-text .user-name-global{display:none}.user-panel-avatar{flex-shrink:0;border:2px solid var(--border-strong);box-shadow:0 0 0 1px #0003}.user-role{display:block;font-size:.68rem;color:var(--text-tertiary);margin-top:.05rem;letter-spacing:.01em}.btn-logout{flex-shrink:0;width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease)}.btn-logout svg{width:17px;height:17px}.btn-logout:hover{color:var(--text);background:#ffffff0d;border-color:var(--border)}.btn-logout:active{transform:scale(.96)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;margin-bottom:.5rem}.page-header h1,h2.page-title{margin:0;font-family:var(--font);font-size:2.125rem;font-weight:700;letter-spacing:-.04em;line-height:1.15}h2{margin:0 0 1rem;font-size:1.35rem;font-weight:600;letter-spacing:-.02em}h3{margin:0 0 .75rem;font-size:1rem;font-weight:600}.page-subtitle{margin:.5rem 0 0;color:var(--text-secondary);font-size:.9375rem;max-width:58ch;line-height:1.6}.page-header-actions{flex-shrink:0}.card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.35rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.panel{margin-bottom:0}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.85rem;border-bottom:1px solid var(--border)}.panel-head h2{margin:0;font-size:1rem;font-weight:600}.stat-grid,.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.875rem;margin-bottom:0}.stat-card,.card.stat,.stat-glow{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .18s var(--ease),background .18s var(--ease),color .18s var(--ease)}.stat-card:hover,.stat-glow:hover{border-color:var(--border-strong);background:#ececef}.stat-card:hover .stat-label,.stat-card:hover .stat .label,.stat-glow:hover .stat-label,.stat-glow:hover .stat .label{color:#52525b}.stat-card:hover .stat-value,.stat-card:hover .stat .value,.stat-glow:hover .stat-value,.stat-glow:hover .stat .value{color:#0c0c0e}.stat-card:hover .value.capture-win,.stat-glow:hover .value.capture-win{color:#1a7a52}.stat-card:hover .value.capture-loss,.stat-glow:hover .value.capture-loss{color:#b83a3a}.stat-label,.stat .label{font-size:.78rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.stat-value,.stat .value{font-size:1.85rem;font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1.1}.stat .value{color:var(--accent)}label{display:block;margin-bottom:.4rem;color:var(--text-secondary);font-size:.82rem;font-weight:500}input,select,textarea{width:100%;padding:.6rem .8rem;background:var(--surface-inset);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:.92rem;margin-bottom:1rem;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-ring);box-shadow:0 0 0 3px var(--accent-muted)}input::placeholder{color:var(--text-tertiary)}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:none;padding:.55rem 1.1rem;border-radius:var(--radius);font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit;transition:background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease),transform .1s var(--ease);text-decoration:none}button[type=submit],button.btn-primary,.btn-primary,button:not(.secondary):not(.danger):not(.btn-ghost):not(.filter-chip):not(.perm-mode-btn):not(.perm-role-chip):not(.access-tile):not(.access-mode-btn):not(.drp-role):not(.drp-selected-chip):not(.cap-battle-row):not(.cap-detail-copy):not(.cap-detail-player-btn):not(.cap-modal-close):not(.btn-sm):not(.btn-logout):not(.error-state-retry):not(.spots-tab):not(.spots-map-btn):not(.spots-tool-btn):not(.spots-size-btn):not(.spots-color-btn):not(.spots-layer-item):not(.spots-dialog-btn):not(.spots-dialog-tab):not(.spots-layers-clear):not(.spots-climb-marker):not(.spots-climb-close):not(.spots-zoom-btn):not(.spots-tactic-item):not(.spots-layer-delete),a.btn:not(.secondary):not(.btn-ghost):not(.btn-discord):not(.btn-sm){background:linear-gradient(180deg,#d05a5a,#b84848);color:#fff;border:1px solid rgba(255,255,255,.1);box-shadow:0 1px #ffffff14 inset,0 2px 12px #c7505038}button[type=submit]:hover,button.btn-primary:hover,.btn-primary:hover,button:not(.secondary):not(.danger):not(.btn-ghost):not(.filter-chip):not(.perm-mode-btn):not(.perm-role-chip):not(.access-tile):not(.access-mode-btn):not(.drp-role):not(.drp-selected-chip):not(.cap-battle-row):not(.cap-detail-copy):not(.cap-detail-player-btn):not(.cap-modal-close):not(.btn-sm):not(.btn-logout):not(.error-state-retry):not(.spots-tab):not(.spots-map-btn):not(.spots-tool-btn):not(.spots-size-btn):not(.spots-color-btn):not(.spots-layer-item):not(.spots-dialog-btn):not(.spots-dialog-tab):not(.spots-layers-clear):not(.spots-climb-marker):not(.spots-climb-close):not(.spots-zoom-btn):not(.spots-tactic-item):not(.spots-layer-delete):hover,a.btn:not(.secondary):not(.btn-ghost):not(.btn-discord):not(.btn-sm):hover{background:linear-gradient(180deg,#da6565,#c04f4f);color:#fff;box-shadow:0 1px #ffffff1f inset,0 4px 16px #c750504d;transform:translateY(-1px)}button.secondary,.btn-secondary,a.btn.secondary{background:#ffffff08;color:var(--text);border:1px solid var(--border-strong);box-shadow:none}button.secondary:hover,.btn-secondary:hover,a.btn.secondary:hover{background:#ececef;color:#18181b;border-color:#d4d4d8;transform:translateY(-1px)}button.danger,.btn-danger{background:linear-gradient(180deg,#ef5f5f,#c93c3c);color:#fff;border:1px solid rgba(255,255,255,.08);box-shadow:0 2px 8px #e85d5d33}button.danger:hover,.btn-danger:hover{background:linear-gradient(180deg,#f56e6e,#d94848);color:#fff;transform:translateY(-1px)}.btn-sm,button.btn-sm,a.btn.btn-sm{padding:.42rem .85rem;font-size:.82rem;border-radius:var(--radius-sm)}.btn-sm.btn-primary,.btn-sm:not(.secondary):not(.danger):not(.btn-ghost){background:linear-gradient(180deg,#d05a5a,#b84848);color:#fff;border:1px solid rgba(255,255,255,.1);box-shadow:0 1px #ffffff14 inset,0 2px 10px #c7505033}.btn-sm.btn-primary:hover,.btn-sm:not(.secondary):not(.danger):not(.btn-ghost):hover{background:linear-gradient(180deg,#da6565,#c04f4f);color:#fff;box-shadow:0 1px #ffffff1f inset,0 4px 14px #c7505047;transform:translateY(-1px)}.btn-sm.secondary{background:#ffffff08;color:var(--text);border:1px solid var(--border-strong);box-shadow:none}.btn-sm.secondary:hover{background:#ececef;color:#18181b;border-color:#d4d4d8;transform:translateY(-1px)}.btn-sm.danger{background:linear-gradient(180deg,#ef5f5f,#c93c3c);color:#fff;border:1px solid rgba(255,255,255,.08);box-shadow:0 2px 8px #e85d5d33}.btn-sm.danger:hover{background:linear-gradient(180deg,#f56e6e,#d94848);color:#fff;transform:translateY(-1px)}.btn-sm.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border);box-shadow:none}.btn-sm.btn-ghost:hover{background:#ffffff0d;color:var(--text);border-color:var(--border-strong);transform:none}.error-state{display:flex;align-items:center;justify-content:center;min-height:min(52vh,420px);padding:2rem 1rem}.error-state-card{max-width:400px;width:100%;text-align:center;padding:2.25rem 2rem 2rem;background:#222228b8;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg)}.error-state-icon{width:52px;height:52px;margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#e0b0501a;color:var(--warning)}.error-state-icon svg{width:26px;height:26px}.error-state-title{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;letter-spacing:-.02em;color:var(--text)}.error-state-message{margin:0;font-size:.9rem;line-height:1.55;color:var(--text-secondary)}.error-state-retry{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;margin-top:1.5rem;padding:.5rem 1.1rem;font-size:.84rem;font-weight:600;font-family:inherit;color:var(--text);background:#ffffff0d;border:1px solid var(--border-strong);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease),transform .15s var(--ease),box-shadow .2s var(--ease)}.error-state-retry svg{width:15px;height:15px;transition:transform .35s var(--ease)}.error-state-retry:hover{background:#ffffff17;border-color:#ffffff2e;box-shadow:0 4px 16px #0003;transform:translateY(-1px)}.error-state-retry:hover svg{transform:rotate(-180deg)}.error-state-retry:active{transform:scale(.97) translateY(0)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:min(40vh,320px);color:var(--text-tertiary);font-size:.9rem}.loading-state-spinner{width:28px;height:28px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:.5rem .85rem;font-size:.85rem;box-shadow:none}.btn-ghost:hover{background:#ffffff0d;color:var(--text);border-color:var(--border-strong);transform:none}button:active,.btn:active{transform:scale(.98) translateY(0)}button:disabled,.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn-full{width:100%}.btn-discord{background:#5865f2;color:#fff;width:100%;padding:.75rem 1.25rem;font-size:.95rem}.btn-discord:hover{background:#4752c4;color:#fff}.btn-row{display:flex;flex-wrap:wrap;gap:.5rem}.btn-row .btn,.btn-row button{padding:.4rem .8rem;font-size:.85rem}.table-wrap{overflow-x:auto;margin:0 -.25rem}table,.data-table{width:100%;border-collapse:collapse;font-size:.88rem}th,td{text-align:left;padding:.7rem .65rem;border-bottom:1px solid var(--border)}th{color:var(--text-tertiary);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;background:#ffffff05}tbody tr{transition:background .15s var(--ease),color .15s var(--ease)}tbody tr:hover{background:#ececef;color:#0c0c0e}tbody tr:hover .muted,tbody tr:hover .cell-mono{color:#52525b}tbody tr:hover .badge{filter:saturate(1.1)}tbody tr:hover .chip,tbody tr:hover .user-chip{background:#d4d4d8;border-color:#a1a1aa;color:#3f3f46}tbody tr:last-child td{border-bottom:none}.cell-strong{font-weight:600}.cell-mono{font-family:var(--mono);font-size:.82rem;color:var(--text-secondary)}.badge{display:inline-flex;align-items:center;padding:.18rem .5rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:1px solid transparent}.badge.scheduled{background:var(--info-muted);color:var(--info);border-color:#6eb5ff33}.badge.active{background:var(--success-muted);color:var(--success);border-color:#3ecf8e33}.badge.completed,.badge-muted{background:#ffffff0a;color:var(--text-tertiary);border-color:var(--border)}.badge.cancelled{background:var(--danger-muted);color:var(--danger);border-color:#e85d5d33}.badge.capture-result.win{background:var(--success-muted);color:var(--success);border-color:#3ecf8e33}.badge.capture-result.loss{background:var(--danger-muted);color:var(--danger);border-color:#e85d5d33}.badge.capture-role.attack{background:var(--info-muted);color:var(--info);border-color:#6eb5ff33}.badge.capture-role.defense{background:var(--accent-muted);color:var(--accent);border-color:var(--accent-ring)}.chip-list{display:flex;flex-wrap:wrap;gap:.35rem}.chip{background:var(--surface-inset);border:1px solid var(--border);padding:.15rem .5rem;border-radius:var(--radius-sm);font-size:.78rem;font-family:var(--mono);color:var(--text-secondary)}.avatar{border-radius:50%;object-fit:cover;vertical-align:middle}.avatar-fallback{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-muted);border:1px solid var(--accent-ring);color:var(--accent);font-weight:600}.user-chip{display:inline-flex;align-items:center;gap:.45rem;background:var(--surface-inset);border:1px solid var(--border);padding:.2rem .6rem .2rem .25rem;border-radius:999px;font-size:.82rem}.user-name{display:inline-flex;flex-direction:column;line-height:1.25;min-width:0}.user-name-lg .user-name-nick{font-size:1.2rem;font-weight:700;letter-spacing:-.02em}.user-name-nick{font-weight:600;font-size:.88rem}.user-name-global{font-size:.75em;color:var(--text-tertiary);font-weight:400}.profile-header{display:flex;align-items:center;gap:1.1rem}.muted{color:var(--text-secondary)}.error,.alert-error{color:#fca5a5;background:var(--danger-muted);border:1px solid rgba(232,93,93,.25);border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:0;font-size:.9rem;line-height:1.45}.alert-success{color:#6ee7b7;background:var(--success-muted);border:1px solid rgba(62,207,142,.25);border-radius:var(--radius);padding:.75rem 1rem;font-size:.9rem}.alert-warn{color:#fcd34d;background:#fcd34d14;border:1px solid rgba(252,211,77,.22);border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:0;font-size:.9rem;line-height:1.45}.field-hint{margin:-.65rem 0 1rem;font-size:.8rem;color:var(--text-tertiary);line-height:1.45}code{font-family:var(--mono);font-size:.84em;background:var(--surface-inset);border:1px solid var(--border);padding:.1rem .35rem;border-radius:4px;color:var(--text-secondary)}.form-panel{max-width:520px}.settings-form{max-width:640px}.fake-stats-panel{max-width:640px;margin-bottom:1rem}.fake-stats-toggle{display:flex;align-items:flex-start;gap:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none}.fake-stats-toggle input{position:absolute;opacity:0;width:0;height:0}.fake-stats-toggle-ui{flex-shrink:0;width:2.5rem;height:1.45rem;border-radius:999px;border:1px solid var(--border-strong);background:var(--surface-inset);position:relative;transition:background .18s var(--ease),border-color .18s var(--ease);margin-top:.1rem}.fake-stats-toggle-ui:after{content:"";position:absolute;top:2px;left:2px;width:1.05rem;height:1.05rem;border-radius:50%;background:var(--text-secondary);transition:transform .18s var(--ease),background .18s var(--ease)}.fake-stats-toggle input:checked+.fake-stats-toggle-ui{background:var(--accent-muted);border-color:var(--accent-ring)}.fake-stats-toggle input:checked+.fake-stats-toggle-ui:after{transform:translate(1.05rem);background:var(--accent)}.fake-stats-toggle-text{display:flex;flex-direction:column;gap:.3rem;font-size:.88rem;color:var(--text-secondary);line-height:1.45}.fake-stats-toggle-text strong{color:var(--text);font-size:.95rem}.fake-stats-hint{margin:.85rem 0 0;padding:.65rem .75rem;border-radius:var(--radius-sm);border:1px solid rgba(224,176,80,.25);background:#e0b05014;color:#e0c878;font-size:.82rem;line-height:1.45}.fake-stats-banner{display:flex;align-items:center;gap:.55rem;margin:0 0 .65rem;padding:.55rem .85rem;border-radius:var(--radius-sm);border:1px solid rgba(224,176,80,.28);background:#e0b0501a;color:#e8d49a;font-size:.82rem;font-weight:600;line-height:1.35}.fake-stats-banner-dot{width:.5rem;height:.5rem;border-radius:50%;background:#e0b050;box-shadow:0 0 10px #e0b050a6;flex-shrink:0;animation:fake-stats-pulse 1.6s ease-in-out infinite}@keyframes fake-stats-pulse{0%,to{opacity:1}50%{opacity:.45}}.admins-form-row{display:flex;gap:.75rem;align-items:flex-start;flex-wrap:wrap}.admin-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.admin-list-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.admin-list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.settings-section{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}.settings-section-head{margin-bottom:.85rem;padding-bottom:0;border-bottom:none}.settings-section-head h2{margin:0;font-size:1rem}.role-panel{margin-top:1.25rem;padding:1.1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-inset)}.role-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.role-panel-title h2{margin:0;font-size:1rem;font-weight:600}.role-panel-desc{margin:.35rem 0 0;font-size:.82rem;color:var(--text-secondary);line-height:1.45;max-width:36rem}.role-panel-count{flex-shrink:0;display:inline-flex;align-items:center;padding:.3rem .7rem;border-radius:999px;font-size:.78rem;font-weight:600;background:var(--surface);border:1px solid var(--border);color:var(--text-tertiary);transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease)}.role-panel-count.has-selection{background:var(--success-muted);border-color:#00c85347;color:var(--success)}.role-panel-state{padding:1.5rem .5rem;text-align:center}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.45rem;max-height:400px;overflow-y:auto;padding:.15rem;margin-bottom:.85rem}.role-grid::-webkit-scrollbar{width:6px}.role-grid::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.role-card{--role-accent: #6b7280;display:flex;align-items:center;gap:.55rem;padding:.55rem .7rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-tertiary);font-size:.84rem;font-weight:500;font-family:inherit;text-align:left;cursor:pointer;transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease),box-shadow .15s var(--ease),transform .1s var(--ease)}.role-card:hover{background:var(--surface-hover);color:var(--text-secondary);border-color:var(--border-strong)}.role-card:active{transform:scale(.98)}.role-card.active{color:var(--text);border-color:color-mix(in srgb,var(--role-accent) 55%,var(--border));background:color-mix(in srgb,var(--role-accent) 12%,var(--surface));box-shadow:inset 3px 0 0 var(--role-accent),0 0 0 1px color-mix(in srgb,var(--role-accent) 18%,transparent)}.role-card.active:hover{background:color-mix(in srgb,var(--role-accent) 18%,var(--surface));border-color:color-mix(in srgb,var(--role-accent) 65%,var(--border))}.role-card-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;opacity:.55;transition:opacity .15s var(--ease)}.role-card.active .role-card-dot{opacity:1;box-shadow:0 0 10px color-mix(in srgb,var(--role-accent) 60%,transparent)}.role-card-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-card-check{flex-shrink:0;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;line-height:1;color:transparent;transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease)}.role-card.active .role-card-check{background:var(--role-accent);border-color:var(--role-accent);color:#fff}.role-panel-hint{margin:0;padding-top:.85rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--text-tertiary);line-height:1.5}.main:has(.settings-page){max-width:none;width:100%}.settings-page .settings-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:none}.settings-page .fake-stats-panel{max-width:640px}.settings-server-panel{margin:0;min-width:0;height:100%}.settings-body-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem;align-items:stretch;width:100%}.settings-fields-grid{display:grid;grid-template-columns:1fr;gap:.85rem}.settings-mp-toggle{margin-top:.15rem}.settings-save-bar{display:flex;justify-content:flex-end;padding:0 .15rem}.discord-workspace{display:contents}.tracked-roles-panel,.access-panel{min-width:0;width:100%;height:100%}.tracked-roles-panel{margin:0;display:flex;flex-direction:column;gap:0}.access-panel{margin:0;padding:1.15rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);display:flex;flex-direction:column;gap:0}.tracked-roles-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.tracked-roles-head h2{margin:0;font-size:1rem;font-weight:600}.tracked-roles-head p{margin:.3rem 0 0;font-size:.8rem;color:var(--text-secondary);line-height:1.4}.tracked-roles-count{flex-shrink:0;padding:.28rem .65rem;border-radius:999px;font-size:.76rem;font-weight:600;border:1px solid var(--border);background:var(--surface-inset);color:var(--text-tertiary)}.tracked-roles-count.has-selection{background:var(--success-muted);border-color:#00c85347;color:var(--success)}.discord-workspace-hint{margin:1rem 0 0;padding-top:.85rem;border-top:1px solid var(--border);font-size:.76rem;color:var(--text-tertiary);line-height:1.45}.drp{display:flex;flex-direction:column;gap:0;min-width:0}.drp-state{margin:0;padding:1.25rem .5rem;text-align:center;font-size:.84rem}.drp-toolbar{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.drp-search{flex:1;display:flex;align-items:center;gap:.45rem;padding:.45rem .65rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-inset);color:var(--text-tertiary)}.drp-search input{flex:1;min-width:0;border:none;background:transparent;color:var(--text);font:inherit;font-size:.84rem;outline:none}.drp-actions{display:flex;gap:.25rem;flex-shrink:0}.drp-selected{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem;padding:.65rem;border-radius:var(--radius-sm);background:#0000002e;border:1px solid var(--border);max-height:none}.drp-selected-chip{--role-accent: #6b7280;display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .45rem .22rem .35rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--role-accent) 40%,var(--border));background:color-mix(in srgb,var(--role-accent) 12%,var(--surface));color:var(--text);font:inherit;font-size:.72rem;font-weight:500;cursor:pointer}.drp-selected-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.drp-selected-x{opacity:.55;font-size:.9rem;line-height:1}.drp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:.45rem;max-height:280px;overflow-y:auto;padding:.15rem}.drp--compact .drp-grid{max-height:220px}.drp-grid::-webkit-scrollbar,.drp-selected::-webkit-scrollbar{width:5px}.drp-grid::-webkit-scrollbar-thumb,.drp-selected::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.drp-role{--role-accent: #6b7280;display:flex;align-items:center;gap:.45rem;padding:.48rem .55rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-tertiary);font:inherit;font-size:.8rem;font-weight:500;text-align:left;cursor:pointer;transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease)}.drp-role:hover{background:var(--surface-hover);color:var(--text-secondary);border-color:var(--border-strong)}.drp-role.active{color:var(--text);border-color:color-mix(in srgb,var(--role-accent) 50%,var(--border));background:color-mix(in srgb,var(--role-accent) 10%,var(--surface))}.drp-role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;opacity:.6}.drp-role.active .drp-role-dot{opacity:1;box-shadow:0 0 8px color-mix(in srgb,var(--role-accent) 50%,transparent)}.drp-role-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drp-role-check{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--border-strong);display:grid;place-items:center;font-size:.58rem;font-weight:700;color:transparent;flex-shrink:0}.drp-role.active .drp-role-check{background:var(--role-accent);border-color:var(--role-accent);color:#fff}.access-panel-head{margin-bottom:1rem}.access-panel-head h2{margin:0;font-size:1rem;font-weight:600}.access-panel-head p{margin:.35rem 0 0;font-size:.8rem;color:var(--text-secondary);line-height:1.45}.access-layout{display:flex;flex-direction:column;gap:1rem;min-width:0}.access-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:.5rem;width:100%}.access-tile{display:flex;flex-direction:row;align-items:center;gap:.55rem;padding:.6rem .7rem;min-height:3.25rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-inset);color:var(--text-secondary);font:inherit;text-align:left;cursor:pointer;transition:border-color .15s var(--ease),background .15s var(--ease),box-shadow .15s var(--ease)}.access-tile:hover{border-color:var(--border-strong);background:var(--surface-hover)}.access-tile.active{border-color:color-mix(in srgb,var(--accent) 45%,var(--border));background:color-mix(in srgb,var(--accent) 8%,var(--surface-inset));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 15%,transparent);color:var(--text)}.access-tile-icon{display:grid;place-items:center;width:1.85rem;height:1.85rem;border-radius:6px;background:#ffffff0a;border:1px solid var(--border);color:var(--text-tertiary);flex-shrink:0}.access-tile.active .access-tile-icon{color:var(--accent-hover);border-color:color-mix(in srgb,var(--accent) 30%,var(--border))}.access-tile-icon svg{width:.95rem;height:.95rem}.access-tile-body{display:flex;flex-direction:column;gap:.08rem;min-width:0;flex:1}.access-tile-body strong{font-size:.8rem;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.access-tile-body span{font-size:.66rem;color:var(--text-tertiary);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.access-tile-badge{flex-shrink:0;padding:.14rem .38rem;border-radius:999px;font-size:.58rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.access-tile-badge--all{background:var(--success-muted);color:var(--success)}.access-tile-badge--admins{background:#ffffff0d;color:var(--text-tertiary)}.access-tile-badge--roles{background:var(--accent-muted);color:var(--accent-hover)}.access-detail{display:flex;flex-direction:column;gap:.85rem;width:100%;padding:1rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-inset);min-height:0}.access-detail-head{display:flex;flex-direction:column;gap:.75rem}@media(min-width:520px){.access-detail-head{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:1rem}}.access-detail-title{display:flex;align-items:center;gap:.6rem}.access-detail-icon{display:grid;place-items:center;width:2.1rem;height:2.1rem;border-radius:var(--radius-sm);background:#ffffff0a;border:1px solid var(--border);color:var(--accent-hover);flex-shrink:0}.access-detail-icon svg{width:1rem;height:1rem}.access-detail-title h3{margin:0;font-size:.92rem;font-weight:600}.access-detail-title p{margin:.12rem 0 0;font-size:.74rem;color:var(--text-tertiary)}.access-mode-group{display:inline-flex;align-self:flex-start;padding:3px;border-radius:999px;background:var(--surface);border:1px solid var(--border)}.access-mode-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--text-tertiary);font:inherit;font-size:.74rem;font-weight:600;padding:.38rem .75rem;border-radius:999px;cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease)}.access-mode-btn:hover{color:var(--text-secondary)}.access-mode-btn.active{color:var(--text);background:var(--surface-hover);box-shadow:var(--shadow-sm)}.access-mode-btn--all.active{background:var(--success-muted);color:var(--success)}.access-mode-btn--roles.active{background:var(--accent-muted);color:var(--accent-hover)}.access-detail-note{padding:.75rem .85rem;border-radius:var(--radius-sm);font-size:.8rem;line-height:1.4;border:1px dashed var(--border)}.access-detail-note--all{color:var(--success);background:var(--success-muted);border-color:#00c85333}.access-detail-note--admins{color:var(--text-secondary);background:#00000026}@media(max-width:1180px){.settings-body-grid{grid-template-columns:1fr}.discord-workspace{display:flex;flex-direction:column;gap:1.25rem}.settings-fields-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.settings-fields-grid,.access-tiles{grid-template-columns:1fr}.access-detail-head{flex-direction:column}.access-mode-group{width:100%;justify-content:space-between}.access-mode-btn{flex:1;text-align:center}.drp-grid{grid-template-columns:1fr}}.member-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.member-list-item{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;background:var(--surface);color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);transition:background .15s var(--ease)}.member-list-item:last-child{border-bottom:none}.member-list-item:hover,.member-list-item.active{background:var(--surface-hover)}.member-list-info{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:1rem}.member-list-nick{font-weight:500;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-list-role{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-secondary);flex-shrink:0}.member-list-role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.member-id-fallback{padding:0}.member-id-fallback summary{padding:1rem 1.25rem;cursor:pointer;color:var(--text-secondary);font-size:.88rem;font-weight:500;list-style:none}.member-id-fallback summary::-webkit-details-marker{display:none}.member-id-form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem;padding:0 1.25rem 1.25rem;border-top:1px solid var(--border)}.member-id-form .field{flex:1;min-width:200px;margin:0}.member-id-form .field input{margin-bottom:0}.form-panel .field:last-child input,.form-panel .field:last-child select{margin-bottom:.5rem}.field{margin-bottom:.25rem}.state-loading,.state-empty{color:var(--text-tertiary);font-size:.9rem;padding:1.5rem 0;text-align:center}.login-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem}.login-screen .login-card{margin:auto}.login-screen .site-footer{padding:0 0 .5rem;width:100%}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.25rem 2rem;box-shadow:var(--shadow-lg)}.login-brand{text-align:center;margin-bottom:2rem}.login-brand .brand-mark{margin:0 auto 1rem}.login-brand h1{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.03em}.login-brand p{margin:.5rem 0 0;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.login-note{margin:1.25rem 0 0;text-align:center;font-size:.78rem;color:var(--text-tertiary)}.splash{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--text-tertiary);font-size:.85rem}.splash-mark{width:44px;height:44px;border-radius:var(--radius);background:var(--accent-muted);border:1px solid var(--accent-ring);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;animation:pulse 1.5s ease infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row .field input{margin-bottom:0}.form-row+button{margin-top:.25rem}.snapshot-list{display:flex;flex-direction:column;gap:.65rem}.snapshot-item{padding:.85rem 1rem;background:var(--surface-inset);border:1px solid var(--border);border-radius:var(--radius);transition:background .15s var(--ease),border-color .15s var(--ease)}.snapshot-item:hover{background:#ececef;border-color:#d4d4d8;color:#18181b}.snapshot-item:hover .muted,.snapshot-item:hover .cell-mono{color:#52525b}.snapshot-item-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.snapshot-item-head strong{font-size:.95rem}.snapshot-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.snapshot-row input{margin-bottom:0;flex:1}.snapshot-inputs{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.form-section{margin-top:.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}.form-section>label{margin-bottom:.25rem;color:var(--text);font-size:.88rem;font-weight:600}.form-section .field-hint{margin:0 0 .85rem}.form-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}.btn-icon{width:2.25rem;height:2.25rem;padding:0;flex-shrink:0;border-radius:var(--radius-sm);font-size:.85rem;line-height:1}.btn-add{margin-top:.15rem}button:focus-visible,.btn:focus-visible,.nav-item:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--accent-ring);outline-offset:2px}.analytics-dashboard,.stats-bento{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:1.5rem}.stats-bento--wide,.dash-card--wide{grid-column:1 / -1}.analytics-row,.analytics-row--top,.analytics-row--bottom{display:contents}.dash-card{position:relative;background:#1215188c;border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-lg);padding:1.1rem 1.15rem 1rem;overflow:hidden}.dash-card:after,.dash-card:before{display:none}.dash-card-head{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.dash-card-titles h3{margin:0;font-size:.86rem;font-weight:600;letter-spacing:-.01em;color:var(--text)}.dash-card-titles p{margin:.12rem 0 0;font-size:.72rem;color:var(--text-tertiary);line-height:1.4}.dash-card-body{position:relative;z-index:1}.stat-semi-row{display:flex;justify-content:space-around;align-items:flex-end;gap:.25rem}.stat-semi{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center}.stat-semi-chart{width:100%;background:transparent!important}.stat-semi-meta{display:flex;flex-direction:column;align-items:center;gap:.08rem;margin-top:-.5rem;text-align:center}.stat-semi-meta span{font-size:.68rem;color:var(--text-tertiary);max-width:76px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-semi-meta strong{font-size:.82rem;font-weight:700;color:var(--text)}.stat-vbars{display:flex;align-items:flex-end;justify-content:space-between;gap:.35rem;padding-top:.25rem}.stat-vbar{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:.3rem}.stat-vbar-col{width:100%;max-width:28px;height:100%;min-height:120px;display:flex;align-items:flex-end;justify-content:center;position:relative}.stat-vbar-col:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:100%;border-radius:6px;background:#ffffff0a}.stat-vbar-fill{position:relative;width:100%;border-radius:6px;min-height:4px;transition:height .55s var(--ease);box-shadow:0 0 14px #2196f340}.stat-vbar-val{font-size:.72rem;font-weight:700;color:var(--text)}.stat-vbar-label{font-size:.62rem;color:var(--text-tertiary);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-hbars{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.stat-hbar{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;align-items:center;gap:.25rem .55rem}.stat-hbar-dot{grid-row:1 / 3;width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 10px #e5393559}.stat-hbar-name{font-size:.78rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-hbar-line{grid-column:2;grid-row:2;height:5px;border-radius:999px;background:#ffffff0d;overflow:hidden}.stat-hbar-fill{height:100%;border-radius:999px;transition:width .55s var(--ease)}.stat-hbar-val{grid-column:3;grid-row:1 / 3;font-size:.82rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.stat-area-chart{position:relative}.stat-area-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem 1.1rem;margin-top:.5rem}.stat-area-legend-item{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--text-secondary)}.stat-area-legend-dot{width:7px;height:7px;border-radius:50%}.dash-donut{display:flex;flex-direction:column}.dash-donut-chart{flex-shrink:0}.dash-donut-legend{list-style:none;margin:.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.35rem}.dash-donut-legend li{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--text-secondary)}.dash-donut-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dash-donut-legend-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-donut-legend-value{font-variant-numeric:tabular-nums;color:var(--text);font-weight:600}.dash-minibar-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.dash-minibar-item{display:flex;flex-direction:column;gap:.3rem}.dash-minibar-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.8rem}.dash-minibar-name{color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-minibar-value{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0}.dash-minibar-track{height:4px;border-radius:999px;background:var(--border);overflow:hidden}.dash-minibar-fill{height:100%;border-radius:999px;background:var(--text-secondary);transition:width .4s var(--ease)}.dash-pills{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;margin-top:.65rem}.dash-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:999px;font-size:.76rem;font-weight:600;border:1px solid var(--border);background:#ffffff08;color:var(--text-secondary);transition:background .15s ease,border-color .15s ease,transform .1s ease;cursor:default}.dash-pill-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:currentColor;box-shadow:0 0 8px currentColor}.dash-pill--win{color:#00c853;border-color:#00c85347;background:#00c85314}.dash-pill--loss{color:#ef9a9a;border-color:#e5393538;background:#e5393514}.dash-pill--attack{color:#64b5f6;border-color:#2196f347;background:#2196f314}.dash-pill--defense{color:#ef5350;border-color:#e5393547;background:#e5393514}.dash-pill--neutral{color:var(--text-secondary)}.dash-leaderboard-list--compact{margin-top:0;padding-top:0;border-top:none}.dash-donut-glow .apexcharts-series path,.dash-donut-glow--1 .apexcharts-series path:nth-child(1),.dash-donut-glow--1 .apexcharts-series path:nth-child(2){filter:none}.dash-leaderboard-list{list-style:none;margin:.85rem 0 0;padding:.75rem 0 0;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.dash-leaderboard-item{display:flex;align-items:center;gap:.55rem;padding:.4rem .5rem;border-radius:10px;transition:background .15s ease}.dash-leaderboard-item:hover{background:#ffffff08}.dash-leaderboard-rank{width:1.25rem;font-size:.72rem;font-weight:700;color:var(--text-tertiary);text-align:center;font-family:var(--mono)}.dash-leaderboard-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:2px solid var(--border-strong);flex-shrink:0}.dash-leaderboard-avatar--fallback{display:inline-flex;align-items:center;justify-content:center;background:#f472b626;color:#f472b6;font-size:.78rem;font-weight:700}.dash-leaderboard-name{flex:1;min-width:0;font-size:.84rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-leaderboard-value{font-size:.88rem;font-weight:700;font-family:var(--mono);color:#f472b6;text-shadow:0 0 16px rgba(244,114,182,.35)}.dash-combined-chart .apexcharts-bar-area:hover{filter:brightness(1.08)}.apex-custom-tooltip{padding:.65rem .85rem;background:#101214eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--border-strong);border-radius:10px;box-shadow:0 12px 40px #00000073;font-family:Inter,system-ui,sans-serif;font-size:12px;min-width:130px}.apex-custom-tooltip-title{font-weight:600;color:var(--text);margin-bottom:.4rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}.apex-custom-tooltip-row{display:flex;align-items:center;gap:.4rem;padding:.15rem 0;color:var(--text-secondary)}.apex-custom-tooltip-row strong{margin-left:auto;color:var(--text);font-family:var(--mono);font-size:11px}.apex-custom-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:.875rem;margin-bottom:1.5rem}.charts-grid-premium{gap:.875rem}.chart-card{min-height:300px}.chart-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.2rem 1.3rem 1rem;position:relative;box-shadow:var(--shadow-sm)}.chart-panel-wide{grid-column:1 / -1}.chart-panel-head{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.chart-panel-head h3{margin:0;font-size:.95rem;font-weight:600}.chart-panel-head p{margin:.2rem 0 0;font-size:.8rem;color:var(--text-tertiary)}.chart-panel-body{position:relative}.chart-apex-wrap{width:100%;position:relative;background:transparent!important}.chart-apex-wrap .apexcharts-canvas{margin:0 auto;background:transparent!important}.chart-apex-wrap .apexcharts-svg{overflow:visible;background:transparent!important}.apexcharts-tooltip{background:#1c1c21e0!important;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1)!important;box-shadow:0 10px 40px #00000073!important;border-radius:10px!important}.apexcharts-tooltip-title{background:transparent!important;border-bottom:1px solid rgba(255,255,255,.08)!important;font-family:Inter,system-ui,sans-serif!important;font-weight:600!important;font-size:12px!important;padding:8px 12px 6px!important;margin-bottom:0!important}.apexcharts-tooltip-series-group{padding:4px 12px 8px!important;font-family:Inter,system-ui,sans-serif!important}.apexcharts-tooltip-text-y-value{font-weight:700!important;font-family:IBM Plex Mono,ui-monospace,monospace!important}.apexcharts-xaxistooltip,.apexcharts-yaxistooltip{background:#1c1c21eb!important;border:1px solid rgba(255,255,255,.1)!important;color:#f0f0f2!important;border-radius:8px!important;font-family:Inter,system-ui,sans-serif!important}.apexcharts-legend-text{font-family:Inter,system-ui,sans-serif!important;font-size:12px!important}.apexcharts-gridline{stroke:#ffffff0d!important}.apexcharts-radialbar-track path{stroke:#ffffff0f!important}.apexcharts-canvas,.apexcharts-svg,.apexcharts-inner{background:transparent!important}.chart-empty{text-align:center;padding:2rem 1rem;color:var(--text-tertiary);font-size:.85rem}.chart-tooltip{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius);padding:.6rem .8rem;box-shadow:var(--shadow);min-width:110px}.chart-tooltip-label{color:var(--text-tertiary);font-size:.72rem;margin-bottom:.35rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}.chart-tooltip-row{display:flex;align-items:center;gap:.4rem;font-size:.82rem;padding:.1rem 0}.chart-tooltip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.chart-tooltip-name{flex:1;color:var(--text-secondary)}.chart-tooltip-value{font-weight:600;font-family:var(--mono);font-size:.8rem}.chart-legend-pills{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-top:.25rem}.chart-pill{font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-inset)}.chart-pill.win{color:var(--success);border-color:#3ecf8e40;background:var(--success-muted)}.chart-pill.loss{color:var(--danger);border-color:#e85d5d40;background:var(--danger-muted)}.chart-pill.attack{color:var(--info);border-color:#6eb5ff40;background:var(--info-muted)}.chart-pill.defense{color:var(--accent);border-color:var(--accent-ring);background:var(--accent-muted)}.chart-avatar-legend{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.3rem}.chart-avatar-legend-row{display:flex;align-items:center;gap:.5rem;font-size:.84rem;padding:.3rem .45rem;border-radius:var(--radius-sm);transition:background .15s var(--ease),color .15s var(--ease)}.chart-avatar-legend-row:hover{background:#ececef;color:#0c0c0e}.chart-avatar-legend-row:hover .rank{color:#52525b}.chart-avatar-legend-row:hover strong{color:#9e2e2e}.chart-avatar-legend-row .rank{width:1.2rem;color:var(--text-tertiary);font-weight:600;font-family:var(--mono);font-size:.78rem}.chart-avatar-legend-row .name{flex:1}.chart-avatar-legend-row strong{color:var(--accent);font-family:var(--mono);font-size:.85rem}.top-users-list{display:flex;flex-direction:column;gap:.25rem}.top-user-row{display:flex;align-items:center;gap:.65rem;padding:.4rem .5rem;border-bottom:1px solid var(--border);border-radius:var(--radius-sm);transition:background .15s var(--ease),color .15s var(--ease)}.top-user-row:hover{background:#ececef;color:#0c0c0e}.top-user-row:hover .rank,.top-user-row:hover .muted{color:#52525b}.top-user-row:hover .count{color:#9e2e2e}.top-user-row .rank{width:1.25rem;color:var(--text-tertiary);font-weight:600;font-family:var(--mono);font-size:.8rem}.top-user-row .name{flex:1}.top-user-row .count{font-weight:700;font-family:var(--mono);color:var(--accent)}.captures-page{--cap-win: #00ff9d;--cap-win-dim: rgba(0, 255, 157, .12);--cap-win-border: rgba(0, 255, 157, .45);--cap-loss: #ff6b6b;--cap-loss-dim: rgba(255, 107, 107, .1);--cap-teal: #5eead4;--cap-gold: #f0c14b;display:flex;flex-direction:column;gap:1.25rem;max-width:1100px}.cap-page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.cap-page-kicker{display:flex;align-items:center;gap:.5rem;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.35rem}.cap-page-kicker-line{width:1.25rem;height:2px;background:var(--accent);border-radius:1px}.cap-page-title{margin:0;font-size:1.75rem;font-weight:800;letter-spacing:-.03em}.cap-page-sub{margin:.35rem 0 0;color:var(--text-secondary);font-size:.88rem}.cap-page-meta{margin:.35rem 0 0;color:var(--text-secondary);font-size:.78rem}.cap-page-meta--muted{color:var(--text-tertiary)}.cap-page-actions{display:flex;flex-direction:column;align-items:stretch;gap:.4rem;flex-shrink:0}.cap-page-guide{white-space:nowrap}.cap-page-refresh:disabled{opacity:.55;cursor:not-allowed}.cap-guide-modal{position:relative;width:min(100%,26rem);padding:1.25rem 1.35rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);box-shadow:var(--shadow-lg)}.cap-guide-title{margin:0 0 .5rem;font-size:1.05rem;font-weight:700}.cap-guide-lead{margin:0 0 .85rem;color:var(--text-secondary);font-size:.82rem;line-height:1.45}.cap-guide-list{margin:0;padding:0 0 0 1rem;color:var(--text-secondary);font-size:.8rem;line-height:1.5}.cap-guide-list li+li{margin-top:.45rem}.cap-guide-list strong{color:var(--text);font-weight:600}.cap-guide-foot{margin:.85rem 0 0;font-size:.72rem;text-align:center}.game-nicks-panel{margin:0}.game-nicks-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.85rem;margin-bottom:1rem;padding-bottom:.85rem;border-bottom:1px solid var(--border)}.game-nicks-panel-head h2{margin:0;font-size:1rem;font-weight:600}.game-nicks-count{flex-shrink:0;min-width:2rem;padding:.28rem .6rem;border-radius:999px;font-size:.76rem;font-weight:600;text-align:center;border:1px solid var(--border);background:var(--surface-inset);color:var(--text-tertiary)}.game-nicks-count.has-items{background:var(--accent-muted);border-color:color-mix(in srgb,var(--accent) 35%,var(--border));color:var(--accent-hover)}.nickname-setup-card{max-width:28rem;text-align:left}.nickname-setup-card .dialog-title,.nickname-setup-card .dialog-message{text-align:center}.nickname-setup-card .dialog-icon{margin-left:auto;margin-right:auto}.nickname-setup-skip{display:block;width:100%;margin-top:.75rem;padding:.35rem;border:none;background:none;color:var(--text-tertiary);font-size:.82rem;cursor:pointer;text-align:center}.nickname-setup-skip:hover{color:var(--text-secondary)}.game-nicks-form{display:flex;flex-direction:column;gap:.65rem;margin-top:.5rem}.game-nicks-hint{margin:0;color:var(--text-secondary);font-size:.82rem;line-height:1.45}.game-nicks-fields{display:flex;flex-direction:column;gap:.45rem}.game-nicks-row{display:flex;align-items:center;gap:.4rem}.game-nicks-input{flex:1;min-width:0;padding:.55rem .7rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-inset);color:var(--text);font:inherit;font-size:.88rem}.game-nicks-input:focus{outline:none;border-color:var(--accent-ring);box-shadow:0 0 0 2px var(--accent-muted)}.game-nicks-remove{flex-shrink:0;width:2rem;height:2rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);font-size:1.1rem;line-height:1;cursor:pointer}.game-nicks-remove:hover{color:var(--danger);border-color:#e5393559}.game-nicks-add{align-self:flex-start}.game-nicks-panel-hint{margin:.35rem 0 0;color:var(--text-secondary);font-size:.8rem;line-height:1.45}.game-nicks-list{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.5rem}.game-nicks-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.7rem .8rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-inset);transition:border-color .15s var(--ease),background .15s var(--ease)}.game-nicks-item:hover{border-color:var(--border-strong);background:#ffffff05}.game-nicks-item-main{display:flex;align-items:center;gap:.65rem;min-width:0;flex:1}.game-nicks-avatar{display:grid;place-items:center;width:2rem;height:2rem;border-radius:8px;background:var(--accent-muted);border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));color:var(--accent-hover);font-size:.82rem;font-weight:700;flex-shrink:0}.game-nicks-name{font-weight:600;font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-nicks-actions{display:flex;gap:.35rem;flex-shrink:0}.game-nicks-edit-row{display:flex;flex-direction:column;gap:.55rem;width:100%}.game-nicks-edit-actions{display:flex;gap:.35rem;justify-content:flex-end}.game-nicks-add-form{display:flex;gap:.5rem;align-items:stretch;padding-top:.15rem;border-top:1px solid var(--border)}.game-nicks-add-field{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem;padding:.45rem .65rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-inset);color:var(--text-tertiary)}.game-nicks-add-field:focus-within{border-color:var(--accent-ring);box-shadow:0 0 0 2px var(--accent-muted)}.game-nicks-add-field svg{width:1rem;height:1rem;flex-shrink:0}.game-nicks-add-field .game-nicks-input{border:none;background:transparent;padding:0;box-shadow:none}.game-nicks-add-field .game-nicks-input:focus{box-shadow:none}.game-nicks-empty{color:var(--text-tertiary);font-size:.86rem;padding:1rem;text-align:center;border:1px dashed var(--border);border-radius:var(--radius-sm);background:#0000001f}@media(max-width:640px){.game-nicks-item{flex-direction:column;align-items:stretch}.game-nicks-actions,.game-nicks-edit-actions{justify-content:flex-end}.game-nicks-add-form{flex-direction:column}}.capture-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(7rem,1fr));gap:.55rem;margin-bottom:.85rem}.capture-stats-card{padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:#0003}.capture-stats-card span{display:block;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:.3rem}.capture-stats-card strong{font-size:1.35rem;font-weight:800}.capture-stats-win{color:var(--success)}.capture-stats-kills{color:#ff5c8a}.panel-head-meta{font-size:.75rem;color:var(--text-tertiary);font-weight:500}.cap-empty{padding:3rem 1rem;text-align:center;color:var(--text-tertiary);border:1px dashed var(--border);border-radius:var(--radius)}.cap-battle-list{display:flex;flex-direction:column;gap:.65rem}.cap-battle-row{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:grid;grid-template-columns:auto 1fr auto 1fr auto;align-items:stretch;gap:0;width:100%;padding:0;border:1px solid rgba(255,255,255,.07);border-radius:10px;background:#0c0e12d9;cursor:pointer;overflow:hidden;box-shadow:none;transform:none;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.cap-battle-row:hover{border-color:#ffffff24;box-shadow:0 8px 32px #00000059;transform:none}.cap-battle-icon{display:grid;place-items:center;width:2.25rem;color:#ffffff59;background:#00000040}.cap-battle-icon svg{width:1rem;height:1rem}.cap-battle-side{position:relative;min-width:0;padding:.85rem 1rem}.cap-battle-side--left{text-align:left}.cap-battle-side--right{text-align:right}.cap-battle-side-glow{position:absolute;top:0;bottom:0;width:3px;opacity:0;transition:opacity .18s var(--ease),box-shadow .18s var(--ease)}.cap-battle-side--left .cap-battle-side-glow{left:0}.cap-battle-side--right .cap-battle-side-glow{right:0}.cap-battle-side--win .cap-battle-side-glow{opacity:1;background:var(--cap-win);box-shadow:0 0 18px var(--cap-win),0 0 40px #00ff9d59}.cap-battle-side-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:.45rem}.cap-battle-side--right .cap-battle-side-inner{align-items:flex-end}.cap-battle-side--win .cap-battle-side-inner{padding:.55rem .75rem;border-radius:8px;border:1px solid var(--cap-win-border);background:linear-gradient(135deg,var(--cap-win-dim),transparent)}.cap-battle-result{font-size:.62rem;font-weight:800;letter-spacing:.12em}.cap-battle-result.win{color:var(--cap-win);text-shadow:0 0 12px rgba(0,255,157,.45)}.cap-battle-result.loss{color:#9f4f4f}.cap-battle-team{display:flex;align-items:center;gap:.55rem}.cap-battle-side--right .cap-battle-team{flex-direction:row-reverse}.cap-battle-logo{width:1.65rem;height:1.65rem;border-radius:50%;display:grid;place-items:center;font-size:.62rem;font-weight:800;color:#fff;flex-shrink:0}.cap-battle-name{font-size:.92rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:9rem}.cap-battle-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.5rem 1.1rem;border-left:1px solid rgba(255,255,255,.06);border-right:1px solid rgba(255,255,255,.06);min-width:6.5rem}.cap-battle-duration{font-size:1.35rem;font-weight:800;font-variant-numeric:tabular-nums;color:var(--text);line-height:1}.cap-battle-when{font-size:.72rem;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.cap-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000c7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;padding:1rem;overflow-y:auto}.cap-detail-modal,.cap-player-modal{position:relative;width:min(100%,920px);max-height:min(92vh,900px);overflow-y:auto;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:linear-gradient(180deg,#12141a,#0c0e12);box-shadow:0 24px 80px #000000a6;padding:1.35rem 1.35rem 1rem}.cap-player-modal{width:min(100%,420px);padding:1.25rem}.cap-modal-close{position:absolute;top:.85rem;right:.85rem;z-index:2;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:2rem;height:2rem;border:none;border-radius:8px;background:#ffffff0d;color:var(--text-secondary);font-size:1.35rem;line-height:1;cursor:pointer;box-shadow:none;transform:none}.cap-modal-close:hover{color:var(--text);background:#ffffff1a;transform:none}.cap-detail-kicker,.cap-player-label{display:flex;align-items:center;gap:.45rem;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}.cap-detail-kicker-line{width:1rem;height:2px;background:var(--accent)}.cap-detail-head h2,.cap-player-head h2{margin:.35rem 0 0;font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.cap-detail-meta{display:flex;align-items:center;gap:.4rem;margin:.45rem 0 0;color:var(--text-tertiary);font-size:.82rem}.cap-detail-search{display:flex;align-items:center;gap:.55rem;margin:1rem 0;padding:.55rem .75rem;border:1px solid var(--border);border-radius:10px;background:#00000040;color:var(--text-tertiary)}.cap-detail-search input{flex:1;border:none;background:transparent;color:var(--text);padding:0;margin:0;font-size:.88rem}.cap-detail-search input:focus{outline:none;box-shadow:none}.cap-detail-hero{position:relative;height:140px;border-radius:10px;overflow:hidden;margin-bottom:1rem;background:linear-gradient(135deg,var(--map-accent-2),var(--map-accent)),repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 24px)}.cap-detail-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1rem;background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,.75) 100%)}.cap-detail-hero-label{display:flex;align-items:center;gap:.35rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cap-teal);margin-bottom:.25rem}.cap-detail-hero-overlay strong{font-size:1.35rem;font-weight:800}.cap-detail-teams{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.cap-detail-team{border:1px solid var(--border);border-radius:10px;background:#0003;overflow:hidden;min-width:0}.cap-detail-team-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.65rem .75rem;border-bottom:1px solid rgba(255,255,255,.06)}.cap-detail-team-title{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;min-width:0}.cap-detail-team-name{font-weight:800;font-size:.92rem}.cap-detail-badge{font-size:.58rem;font-weight:800;letter-spacing:.08em;padding:.2rem .45rem;border-radius:999px}.cap-detail-badge.win{background:#00ff9d26;color:var(--cap-win);border:1px solid var(--cap-win-border)}.cap-detail-badge.loss{background:var(--cap-loss-dim);color:var(--cap-loss);border:1px solid rgba(255,107,107,.25)}.cap-detail-copy{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;gap:.3rem;border:none;background:transparent;color:var(--text-tertiary);font:inherit;font-size:.72rem;font-weight:600;cursor:pointer;padding:.2rem;box-shadow:none;transform:none;flex-shrink:0}.cap-detail-copy:hover{color:var(--text-secondary);transform:none}.cap-detail-table-wrap{max-height:280px;overflow:auto}.cap-detail-table{width:100%;border-collapse:collapse;font-size:.8rem}.cap-detail-table th{position:sticky;top:0;z-index:1;padding:.45rem .65rem;text-align:left;font-size:.62rem;font-weight:700;letter-spacing:.08em;color:var(--text-tertiary);background:#101218;border-bottom:1px solid rgba(255,255,255,.06)}.cap-detail-table td{padding:.5rem .65rem;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.cap-detail-table tbody tr:hover{background:#ffffff08}.cap-detail-player-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;border:none;background:transparent;color:var(--text);font:inherit;font-weight:600;cursor:pointer;padding:0;text-align:left;box-shadow:none;transform:none}.cap-detail-player-btn small{color:var(--text-tertiary);font-size:.68rem;font-weight:500}.cap-detail-player-btn:hover{color:var(--cap-teal);transform:none}.cap-kills{color:#ff6b7a;font-weight:700}.cap-damage{color:var(--cap-gold);font-weight:700}.cap-detail-empty{text-align:center;color:var(--text-tertiary);padding:1.5rem!important}.cap-detail-foot{margin:.85rem 0 0;font-size:.75rem;text-align:center}.cap-player-head p{margin:.2rem 0 0;color:var(--text-tertiary);font-size:.88rem}.cap-player-section-title{display:flex;align-items:center;gap:.4rem;margin:1.25rem 0 .5rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;color:var(--text-tertiary)}.cap-player-radar{margin:0 -.5rem}.cap-player-stats{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin-top:.5rem}.cap-player-stat{padding:.85rem;border:1px solid var(--border);border-radius:10px;background:#00000040}.cap-player-stat span{display:block;font-size:.62rem;font-weight:700;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:.35rem}.cap-player-stat strong{font-size:1.5rem;font-weight:800}.cap-stat-kills{color:#ff5c8a}.cap-stat-damage{color:var(--cap-gold)}.cap-player-foot{margin:.85rem 0 0;font-size:.72rem;color:var(--text-tertiary);text-align:center;line-height:1.4}.capture-win{color:var(--success)}.capture-loss{color:var(--danger)}@media(max-width:860px){.cap-battle-row{grid-template-columns:1fr;grid-template-rows:auto auto auto}.cap-battle-icon{display:none}.cap-battle-center{border:none;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);flex-direction:row;justify-content:center;gap:.75rem;padding:.55rem}.cap-battle-side--right .cap-battle-side-inner,.cap-battle-side--right .cap-battle-team{align-items:flex-start;flex-direction:row}.cap-detail-teams{grid-template-columns:1fr}}.user-bar{display:none}.user-bar-profile{display:flex;align-items:center;gap:.5rem}.layout{display:flex;min-height:100vh}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#080a0cb8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:dialog-overlay-in .2s var(--ease)}@keyframes dialog-overlay-in{0%{opacity:0}to{opacity:1}}.dialog-card{width:100%;max-width:400px;padding:1.75rem 1.75rem 1.5rem;background:linear-gradient(160deg,#161a1df7,#101214f2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 1px #ffffff0d inset,0 24px 64px #0000008c;text-align:center;animation:dialog-card-in .28s var(--ease)}@keyframes dialog-card-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}.dialog-icon{width:52px;height:52px;margin:0 auto 1.1rem;display:flex;align-items:center;justify-content:center;border-radius:50%}.dialog-icon svg{width:26px;height:26px}.dialog-icon--danger{background:#e539351f;color:#ef5350;box-shadow:0 0 24px #e5393533}.dialog-icon--default{background:#2196f31f;color:#64b5f6;box-shadow:0 0 24px #2196f326}.dialog-icon--info{background:#00c8531a;color:#00c853;box-shadow:0 0 24px #00c85326}.dialog-title{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;letter-spacing:-.02em;color:var(--text);line-height:1.35}.dialog-message{margin:0 0 1.5rem;font-size:.88rem;line-height:1.55;color:var(--text-secondary)}.dialog-actions{display:flex;gap:.65rem}.dialog-actions--single{justify-content:center}.dialog-btn{flex:1;padding:.6rem 1rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;font-family:inherit;cursor:pointer;border:1px solid transparent;transition:background .15s var(--ease),border-color .15s var(--ease),transform .1s var(--ease),box-shadow .15s var(--ease)}.dialog-btn:active{transform:scale(.98)}.dialog-btn--cancel{background:#ffffff08;border-color:var(--border-strong);color:var(--text)}.dialog-btn--cancel:hover{background:#ececef;color:#18181b;border-color:#d4d4d8;transform:translateY(-1px)}.dialog-btn--confirm{background:linear-gradient(180deg,#d05a5a,#b84848);color:#fff;border-color:#ffffff1a;box-shadow:0 1px #ffffff14 inset,0 2px 12px #c7505040}.dialog-btn--confirm:hover{background:linear-gradient(180deg,#da6565,#c04f4f);box-shadow:0 1px #ffffff1f inset,0 4px 16px #c7505052;transform:translateY(-1px)}.dialog-btn--danger{background:linear-gradient(180deg,#ef5f5f,#c93c3c);border-color:#ffffff14;box-shadow:0 2px 12px #e85d5d47}.dialog-btn--danger:hover{background:linear-gradient(180deg,#f56e6e,#d94848);box-shadow:0 4px 16px #e85d5d61;transform:translateY(-1px)}.dialog-actions--single .dialog-btn--confirm{flex:0 1 auto;min-width:140px}.main:has(.spots-page){max-width:none;padding:.65rem .85rem .85rem;display:flex;flex-direction:column;min-height:0}.spots-page{--mh-bg: var(--bg);--mh-panel: var(--surface);--mh-border: var(--border);--mh-border-strong: var(--border-strong);--mh-text: var(--text);--mh-muted: var(--text-secondary);--mh-dim: var(--text-tertiary);--mh-accent: var(--accent);--mh-accent-dim: var(--accent-hover);--mh-accent-border: var(--accent-ring);--mh-accent-bg: var(--accent-muted);--mh-tool-active: #fff;--mh-tool-active-bg: var(--accent-muted);display:flex;flex-direction:column;gap:.55rem;flex:1;min-height:0;height:calc(100vh - 1.5rem);color:var(--mh-text);background:var(--mh-bg);border:1px solid var(--mh-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden}.spots-tabs{display:flex;gap:.15rem;flex-shrink:0;padding:.35rem .65rem 0;border-bottom:1px solid var(--mh-border);background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 100%)}.spots-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--mh-muted);font:inherit;font-size:.82rem;font-weight:600;padding:.55rem 1rem .65rem;margin-bottom:-1px;border-radius:0;cursor:pointer;box-shadow:none;transform:none;transition:color .15s var(--ease),border-color .15s var(--ease),background .15s var(--ease)}.spots-tab:hover{color:var(--mh-text);background:#ffffff08;transform:none;box-shadow:none}.spots-tab.active{color:var(--mh-text);border-bottom-color:var(--mh-accent);background:transparent;box-shadow:none;transform:none}.spots-panel{flex:1;min-height:0;display:flex;padding:0 .65rem .65rem}.spots-workspace{display:flex;gap:.65rem;width:100%;min-height:0}.spots-map-list{width:9rem;flex-shrink:0;display:flex;flex-direction:column;min-height:0}.spots-map-list-label{margin:0 0 .35rem;padding:.35rem .4rem;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mh-dim)}.spots-map-list-items{display:flex;flex-direction:column;gap:.25rem;overflow-y:auto;padding-right:.15rem}.spots-map-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--mh-border);border-left:3px solid transparent;background:var(--surface-inset);color:var(--mh-muted);font:inherit;font-size:.82rem;font-weight:500;text-align:left;padding:.55rem .7rem;border-radius:var(--radius-sm);cursor:pointer;box-shadow:none;transform:none;transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spots-map-btn:hover{color:var(--mh-text);border-color:var(--mh-border-strong);border-left-color:#e5393559;background:var(--surface-hover);transform:none;box-shadow:none}.spots-map-btn.active{color:var(--mh-text);border-color:var(--mh-accent-border);border-left-color:var(--mh-accent);background:var(--mh-accent-bg);box-shadow:inset 0 1px #ffffff0a}.spots-toolbar{width:2.85rem;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.45rem .35rem;border:1px solid var(--mh-border);border-radius:var(--radius-sm);background:linear-gradient(180deg,var(--mh-panel) 0%,var(--surface-inset) 100%);box-shadow:inset 0 1px #ffffff0a;overflow-y:auto}.spots-toolbar-sep{width:1.5rem;height:1px;background:#ffffff14;margin:.15rem 0}.spots-tool-btn,.spots-size-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:2rem;height:2rem;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-secondary);display:grid;place-items:center;cursor:pointer;box-shadow:none;transform:none;padding:0;transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease)}.spots-tool-btn svg,.spots-size-btn svg{width:1rem;height:1rem}.spots-tool-btn:hover:not(:disabled),.spots-size-btn:hover:not(:disabled){color:var(--text);background:#ffffff0f;border-color:#ffffff1a;transform:none;box-shadow:none}.spots-tool-btn.active{color:var(--mh-tool-active);background:var(--mh-tool-active-bg);border-color:var(--mh-accent-border);box-shadow:0 0 12px var(--accent-ring)}.spots-tool-btn.danger:hover:not(:disabled){color:#f87171;background:#e539351f;border-color:#e539354d}.spots-tool-btn:disabled,.spots-size-btn:disabled{opacity:.35;cursor:not-allowed}.spots-size-btn span{display:block;border-radius:50%;background:#52525b}.spots-size-btn.active span{background:var(--mh-accent)}.spots-size-btn.active{border-color:var(--mh-accent-border);background:var(--mh-accent-bg)}.spots-color-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:1.2rem;height:1.2rem;border-radius:50%;border:2px solid rgba(255,255,255,.18);background:var(--swatch)!important;background-image:none!important;cursor:pointer;padding:0;box-shadow:none;transform:none;transition:transform .12s var(--ease),box-shadow .12s var(--ease),border-color .12s var(--ease)}.spots-color-btn.active{transform:scale(1.15);box-shadow:0 0 0 2px var(--mh-accent-border),0 0 10px var(--accent-ring);border-color:#ffffffe6}.spots-color-btn:disabled{opacity:.35;cursor:not-allowed}.spots-marker-count{margin-top:auto;padding:.35rem .15rem;font-size:.58rem;font-weight:700;text-align:center;color:var(--text-tertiary);line-height:1.3}.spots-tip-wrap{position:relative}.spots-tip{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%) scale(.96);opacity:0;pointer-events:none;z-index:30;display:flex;align-items:center;gap:.45rem;padding:.4rem .55rem;border-radius:6px;border:1px solid rgba(255,255,255,.09);background:#16161af5;box-shadow:0 8px 28px #00000080;white-space:nowrap;font-size:.72rem;color:var(--text-secondary);transition:opacity .15s var(--ease),transform .15s var(--ease)}.spots-tip-wrap:hover .spots-tip{opacity:1;transform:translateY(-50%) scale(1)}.spots-tip-keys{display:flex;gap:.2rem}.spots-tip kbd{font-family:var(--mono);font-size:.62rem;padding:.15rem .35rem;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:var(--text-tertiary)}.spots-canvas-wrap{position:relative;flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;border:1px solid var(--mh-border);border-radius:var(--radius-sm);background:radial-gradient(ellipse at center,#1e222680,#0000008c);overflow:hidden;box-shadow:inset 0 1px #ffffff08}.spots-canvas{flex:1;width:100%;min-height:480px}.spots-canvas-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--mh-muted);font-size:.88rem;z-index:2;pointer-events:none}.spots-canvas-error{color:#f87171}.spots-zoom-controls{position:absolute;top:.55rem;right:.55rem;z-index:5;display:flex;flex-direction:column;gap:.25rem}.spots-zoom-controls button,.spots-zoom-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:2rem;height:2rem;border:1px solid var(--mh-border-strong);border-radius:50%;background:#161a1deb;color:var(--text);font-size:1rem;font-weight:600;line-height:1;cursor:pointer;display:grid;place-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm);transform:none;padding:0;transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease)}.spots-zoom-controls button:hover,.spots-zoom-btn:hover{background:var(--surface-hover);border-color:var(--mh-accent-border);color:var(--mh-accent-dim);transform:none;box-shadow:0 0 12px var(--accent-ring)}.spots-zoom-controls button svg{width:.95rem;height:.95rem}.spots-map-pill{position:absolute;left:.55rem;bottom:.55rem;z-index:5;padding:.35rem .75rem;border-radius:999px;border:1px solid var(--mh-accent-border);background:#161a1de6;color:var(--mh-accent-dim);font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #00000059}.spots-zoom-label{position:absolute;right:.55rem;bottom:.55rem;z-index:5;padding:.25rem .5rem;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:#101214e0;color:var(--text-secondary);font-size:.68rem;font-weight:600;font-variant-numeric:tabular-nums;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.spots-layers{width:11.5rem;flex-shrink:0;display:flex;flex-direction:column;min-height:0;border:1px solid var(--mh-border);border-radius:var(--radius-sm);background:linear-gradient(180deg,var(--mh-panel) 0%,var(--surface-inset) 100%);overflow:hidden;box-shadow:inset 0 1px #ffffff0a}.spots-layers-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .75rem;border-bottom:1px solid rgba(255,255,255,.07);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary)}.spots-layers-meta{display:flex;align-items:center;gap:.35rem}.spots-layers-count{font-family:var(--mono);font-size:.58rem;color:var(--text-tertiary)}.spots-layers-clear{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--text-tertiary);width:1.25rem;height:1.25rem;display:grid;place-items:center;border-radius:4px;cursor:pointer}.spots-layers-clear:hover:not(:disabled){color:#f87171;background:#e539351f}.spots-layers-clear:disabled{opacity:.25;cursor:not-allowed}.spots-layers-clear svg{width:.75rem;height:.75rem}.spots-layers-body{flex:1;overflow-y:auto;display:flex;flex-direction:column}.spots-layers-empty{flex:1;display:grid;place-items:center;color:var(--text-tertiary);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:1.5rem .5rem}.spots-layer-row{display:flex;align-items:stretch;border-bottom:1px solid rgba(255,255,255,.04)}.spots-layer-row:hover{background:#ffffff0a}.spots-layer-row.active{background:var(--mh-accent-bg);border-left:2px solid var(--mh-accent)}.spots-layer-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;min-width:0;border:none;background:transparent;color:var(--text-secondary);font:inherit;font-size:.78rem;font-weight:600;text-align:left;padding:.55rem .45rem .55rem .7rem;display:flex;align-items:center;gap:.45rem;cursor:pointer;box-shadow:none;transform:none}.spots-layer-row:hover .spots-layer-item,.spots-layer-row.active .spots-layer-item{color:var(--mh-text)}.spots-layer-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spots-layer-delete{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex-shrink:0;width:2rem;align-self:stretch;border:none;border-left:1px solid rgba(255,255,255,.04);background:transparent;color:var(--text-tertiary);display:grid;place-items:center;cursor:pointer;padding:0;box-shadow:none;transform:none;transition:color .12s var(--ease),background .12s var(--ease)}.spots-layer-row:hover .spots-layer-delete,.spots-layer-row.active .spots-layer-delete{color:var(--text-secondary)}.spots-layer-delete:hover{color:#f87171;background:#e539351f;border-left-color:#ffffff0f;transform:none;box-shadow:none}.spots-layer-delete svg{width:.75rem;height:.75rem}.spots-layer-dot{width:.55rem;height:.55rem;border-radius:50%;flex-shrink:0}.spots-empty{padding:2rem;color:var(--text-secondary);text-align:center}.spots-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000a6;display:grid;place-items:center;padding:1rem}.spots-dialog{width:min(100%,360px);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:1.1rem;box-shadow:var(--shadow-lg)}.spots-dialog h3{margin:0 0 .25rem;font-size:1rem}.spots-dialog p{margin:0 0 1rem;font-size:.82rem;color:var(--text-secondary)}.spots-dialog-row{margin-bottom:.85rem}.spots-dialog-row label{display:block;margin-bottom:.35rem;font-size:.78rem;font-weight:600;color:var(--text-secondary)}.spots-dialog-tabs{display:flex;gap:.35rem}.spots-dialog-tabs button,.spots-dialog-tab{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--surface-inset);color:var(--text-secondary);font:inherit;font-size:.8rem;font-weight:600;padding:.45rem;border-radius:6px;cursor:pointer;box-shadow:none;transform:none}.spots-dialog-tabs button.active,.spots-dialog-tab.active{border-color:var(--accent-ring);background:var(--accent-muted);color:var(--text);box-shadow:none;transform:none}.spots-dialog-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.spots-dialog-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--surface-hover);color:var(--text);font:inherit;font-size:.82rem;font-weight:600;padding:.45rem .85rem;border-radius:6px;cursor:pointer}.spots-dialog-btn-primary{border-color:var(--accent-ring);background:var(--accent);color:#fff;box-shadow:0 2px 12px var(--accent-ring)}.spots-tactic-list{display:flex;flex-direction:column;gap:.35rem;max-height:200px;overflow-y:auto;margin-bottom:.5rem}.spots-tactic-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;border:1px solid var(--border);border-radius:8px;background:var(--surface-inset);color:var(--text);font:inherit;font-size:.8rem;font-weight:600;padding:.5rem .65rem;cursor:pointer;box-shadow:none;transform:none;text-align:left;transition:border-color .15s var(--ease),background .15s var(--ease)}.spots-tactic-item:hover{border-color:var(--accent-ring);background:var(--accent-muted);transform:none;box-shadow:none}.spots-tactic-item span{color:var(--text-secondary);font-weight:500;font-size:.72rem}.spots-tactic-empty{padding:1rem .5rem;text-align:center;color:var(--text-tertiary);font-size:.8rem}@media(max-width:1100px){.analytics-dashboard,.stats-bento{grid-template-columns:1fr 1fr}}@media(max-width:860px){.app-shell{flex-direction:column}.sidebar{width:100%;height:auto;position:static;padding:1rem}.sidebar-nav{flex-direction:row;flex-wrap:wrap;gap:.25rem}.nav-group{display:contents}.nav-group-label{display:none}.nav-item{padding:.45rem .65rem;font-size:.82rem}.nav-label,.user-panel{display:none}.main{padding:1.25rem 1rem 2rem}.form-row{grid-template-columns:1fr}.page-header{flex-direction:column}.analytics-dashboard,.stats-bento{grid-template-columns:1fr}.maps-layout,.spots-workspace{display:flex;flex-direction:column;min-height:auto}.spots-page{height:auto;min-height:0}.spots-map-list,.spots-layers{width:100%}.spots-map-list-items{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden}.spots-map-btn{flex-shrink:0}.spots-toolbar{width:100%;flex-direction:row;flex-wrap:wrap;justify-content:center;max-height:none;padding:.5rem}.spots-toolbar-sep{width:1px;height:1.5rem;margin:0 .15rem}.spots-tip{display:none}.spots-canvas{min-height:320px}}
