:root{--bg: #061019;--bg-glow: #10263d;--panel: rgba(9, 20, 31, .88);--panel-soft: rgba(12, 29, 46, .72);--panel-strong: rgba(4, 13, 21, .94);--line: rgba(123, 181, 219, .16);--line-strong: rgba(123, 181, 219, .28);--text: #eff7ff;--muted: #90a9c6;--accent: #7de3c2;--accent-strong: #36c89a;--accent-warm: #f3b76f;--danger: #ff7f70;--warning: #ffcf73;--shadow: 0 28px 80px rgba(0, 0, 0, .42)}:root[data-theme=red]{--bg-glow: #3b1616;--accent: #ff9d8d;--accent-strong: #e25d48;--accent-warm: #ffc178;--line: rgba(255, 157, 141, .16);--line-strong: rgba(255, 157, 141, .28)}:root[data-theme=blue]{--bg-glow: #142c45;--accent: #8bc6ff;--accent-strong: #4c93dd;--accent-warm: #7fd8ff;--line: rgba(139, 198, 255, .16);--line-strong: rgba(139, 198, 255, .28)}:root[data-theme=yellow]{--bg-glow: #433516;--accent: #ffd36f;--accent-strong: #e2a93d;--accent-warm: #fff1a6;--line: rgba(255, 211, 111, .16);--line-strong: rgba(255, 211, 111, .28)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--text);font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-feature-settings:"cv03","cv04","cv11";background:radial-gradient(circle at 12% 10%,color-mix(in srgb,var(--bg-glow) 78%,transparent),transparent 26%),radial-gradient(circle at 88% 14%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 22%),radial-gradient(circle at 50% 100%,rgba(243,183,111,.1),transparent 28%),linear-gradient(145deg,#041019,#071520 42%,#0a1d2f)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:30px 30px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.85),transparent);mask-image:linear-gradient(to bottom,rgba(0,0,0,.85),transparent)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}input,select,textarea,button,.btn{border:1px solid var(--line);border-radius:16px;color:var(--text);background:#08131ec7;padding:.85rem 1rem;transition:border-color .14s ease,transform .14s ease,background .14s ease,box-shadow .14s ease}input:focus,select:focus,textarea:focus,button:focus,.btn:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #7de3c21f}button,.btn{cursor:pointer}button:hover,.btn:hover{transform:translateY(-1px);border-color:#7de3c280}textarea{resize:vertical}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--line);background:#030b12d1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.topbar:after{content:"";position:absolute;inset:auto 1.5rem -1px;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 45%,transparent),transparent)}.topbar-brand-wrap{display:flex;flex-direction:column;gap:.55rem;min-width:0}.brand{display:inline-flex;align-items:center;gap:.9rem;min-width:0}.brand-copy{min-width:0}.brand-copy strong{display:block;font-size:1.1rem;font-weight:700;letter-spacing:-.02em;line-height:1}.brand-copy p{margin:.2rem 0 0;color:var(--muted);font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-meta{display:inline-flex;align-items:center;gap:.65rem;color:var(--muted);font-size:.82rem}.topbar-pill{padding:.35rem .65rem;border-radius:999px;border:1px solid var(--line);color:var(--text);background:#ffffff08}.topbar-divider{width:.3rem;height:.3rem;border-radius:999px;background:color-mix(in srgb,var(--accent) 55%,transparent)}.topbar-meta-text{white-space:nowrap}.brand-mark,.topbar-logo-image,.sidebar-logo-image{display:grid;place-items:center;width:2.8rem;height:2.8rem;border-radius:.95rem;flex:0 0 auto}.brand-mark{color:#041119;font-weight:800;background:linear-gradient(135deg,#7de3c2,#f3b76feb);box-shadow:inset 0 1px #ffffff40}.topbar-logo-image,.sidebar-logo-image{object-fit:cover;border:1px solid var(--line);background:#ffffff0a}.topbar-actions{display:flex;align-items:center;gap:.75rem}.topbar-user{display:flex;flex-direction:column;align-items:flex-end;min-width:0}.topbar-user strong{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-login,.topbar-badge{min-width:108px;justify-content:center}.topbar-badge{display:inline-flex;align-items:center;padding:.7rem 1rem;border:1px solid var(--line);border-radius:999px;color:var(--muted);background:#ffffff08}.app-body{width:min(1600px,calc(100vw - 2rem));margin:0 auto;padding:1.25rem 0 2.5rem}.app-body.with-sidebar{display:grid;grid-template-columns:280px minmax(0,1fr);gap:1.25rem}.route-shell{min-width:0}.sidebar{position:sticky;top:5.75rem;align-self:start;display:flex;flex-direction:column;gap:1rem;padding:1.1rem;border:1px solid var(--line);border-radius:28px;background:linear-gradient(180deg,#0b1b2afa,#050e17f5),linear-gradient(135deg,rgba(125,227,194,.08),transparent 45%);box-shadow:var(--shadow)}.sidebar-brand,.sidebar-user{padding:.9rem .95rem;border-radius:22px;border:1px solid var(--line);background:#ffffff08}.sidebar-brand{display:flex;align-items:center;gap:.85rem}.sidebar-brand strong{display:block;font-weight:700;letter-spacing:-.01em;margin-bottom:.15rem}.sidebar-brand p,.sidebar-user p{margin:0;color:var(--muted);font-size:.88rem}.sidebar-user strong{display:block;margin-bottom:.2rem}.sidebar-nav{display:flex;flex-direction:column;gap:.45rem}.sidebar-summary{padding:.95rem;border-radius:22px;border:1px solid var(--line);background:linear-gradient(180deg,#ffffff0a,#ffffff04)}.sidebar-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;margin-top:.35rem}.sidebar-summary-card{padding:.8rem;border-radius:18px;border:1px solid var(--line);background:#040c136b}.sidebar-summary-card strong,.sidebar-summary-card span{display:block}.sidebar-summary-card span{color:var(--muted);margin-top:.2rem;font-size:.82rem}.sidebar-tags{display:flex;gap:.55rem;flex-wrap:wrap;margin-top:.85rem}.sidebar-tag{display:inline-flex;align-items:center;padding:.38rem .62rem;border-radius:999px;border:1px solid var(--line);color:var(--muted);background:#ffffff08;font-size:.78rem}.sidebar-link{position:relative;display:flex;align-items:center;padding:.9rem 1rem;border:1px solid transparent;border-radius:18px;color:var(--muted);background:#ffffff05}.sidebar-link:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;border-radius:0 3px 3px 0;background:transparent;transition:background .15s ease}.sidebar-link:hover{color:var(--text);border-color:var(--line);background:#ffffff0a}.sidebar-link.active{color:var(--text);border-color:color-mix(in srgb,var(--accent) 35%,transparent);background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 12%,transparent),#ffffff05)}.sidebar-link.active:before{background:var(--accent)}.sidebar-logout{margin-top:auto}.page{display:flex;flex-direction:column;gap:1.25rem}.center{min-height:calc(100vh - 6rem);display:grid;place-items:center;padding:1rem 0}.hero-panel,.panel-card,.card{border:1px solid var(--line);border-radius:30px;background:linear-gradient(180deg,#0c1d2ef0,#07121cf5),radial-gradient(circle at top right,rgba(125,227,194,.1),transparent 32%);box-shadow:var(--shadow)}.hero-panel{padding:1.55rem;display:grid;gap:1.2rem}.page-hero{grid-template-columns:minmax(0,1.3fr) minmax(260px,.8fr);align-items:end}.hero-landing{grid-template-columns:minmax(0,1.4fr) minmax(280px,.9fr);align-items:center;overflow:hidden;position:relative}.hero-landing:after{content:"";position:absolute;inset:auto -8% -35% auto;width:320px;height:320px;border-radius:999px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 24%,transparent),transparent 68%);pointer-events:none}.hero-copy-block{position:relative;z-index:1}.hero-support-copy{max-width:60ch;color:var(--text);opacity:.82}.hero-cta-row{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:1.2rem}.hero-primary{display:inline-flex;align-items:center;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent-warm) 75%,white));color:#04101a;border-color:transparent;font-weight:700;font-size:.9rem;letter-spacing:-.01em;box-shadow:0 8px 24px color-mix(in srgb,var(--accent) 28%,transparent),0 2px 8px #0000004d}.hero-primary:hover{transform:translateY(-2px);border-color:transparent;box-shadow:0 14px 36px color-mix(in srgb,var(--accent) 38%,transparent),0 4px 12px #0006}.hero-secondary{background:#ffffff0a}.hero-visual{position:relative;min-height:260px;display:grid;place-items:center}.hero-logo-frame{width:min(100%,280px);aspect-ratio:1 / 1;display:grid;place-items:center;border-radius:32px;border:1px solid var(--line);background:linear-gradient(180deg,#ffffff14,#ffffff05),linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%,transparent),transparent 58%);box-shadow:inset 0 1px #ffffff14}.hero-logo-image{width:72%;height:72%;object-fit:contain}.hero-logo-fallback{width:72%;height:72%;display:grid;place-items:center;border-radius:28px;background:linear-gradient(135deg,var(--accent),var(--accent-warm));color:#09131c;font-size:clamp(2rem,6vw,4rem);font-weight:800;letter-spacing:-.04em}.hero-floating-card{position:absolute;right:0;bottom:.5rem;max-width:220px;padding:1rem;border-radius:22px;border:1px solid var(--line);background:#07121cdb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.hero-floating-card strong{display:block;margin-bottom:.35rem}.hero-floating-card p{margin:0;color:var(--muted);font-size:.9rem}.hero-panel h1,.panel-card h2,.card h3,.card h1{margin:0;font-weight:700;letter-spacing:-.025em;font-size:clamp(1.8rem,3.8vw,3rem);line-height:1.04}.page-hero-stat,.mini-stat-card{border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,#ffffff0f,#ffffff05),#040c1385}.page-hero-stat{padding:1.15rem;justify-self:end;max-width:280px}.page-hero-stat strong,.mini-stat-card strong{display:block;font-size:2rem;margin:.2rem 0 .3rem}.page-hero-stat p{margin:0;color:var(--muted)}.hero-copy,.empty-state,.field-label,.notice,.tiny{color:var(--muted)}.eyebrow{margin:0 0 .3rem;letter-spacing:.16em;text-transform:uppercase;font-size:.7rem;font-weight:600;color:color-mix(in srgb,var(--accent) 75%,var(--muted))}.metric-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem}.metric-row-shell{margin-top:-.35rem}.metric-card{padding:1.1rem 1.2rem;border:1px solid var(--line);border-radius:22px;background:linear-gradient(160deg,#ffffff0a,#ffffff03);position:relative;overflow:hidden;transition:border-color .18s ease,box-shadow .18s ease}.metric-card:before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 40%,transparent),transparent)}.metric-card:hover{border-color:color-mix(in srgb,var(--accent) 28%,transparent);box-shadow:0 0 20px color-mix(in srgb,var(--accent) 7%,transparent)}.metric-card span{display:block;color:var(--muted);margin-bottom:.45rem}.metric-card strong{font-size:2rem;font-weight:700;letter-spacing:-.03em;line-height:1}.hero-stat-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.mini-stat-card{padding:1rem}.mini-stat-card span{color:var(--muted)}.toolbar,.row,.action-cluster,.section-heading,.details-grid,.form-grid,.layout-grid{display:flex;gap:.85rem;flex-wrap:wrap}.toolbar input,.toolbar select{flex:1 1 220px}.manual-ban-toggle.active{border-color:#7de3c28c;background:linear-gradient(135deg,#7de3c22e,#ffffff08)}.layout-grid{align-items:flex-start}.layout-grid>*{flex:1 1 420px}.panel-stack{display:flex;flex-direction:column;gap:1.25rem;flex:1 1 420px}.panel-card,.card{padding:1.25rem;display:flex;flex-direction:column;gap:1rem;position:relative;overflow:hidden}.hero-status-stack{display:flex;flex-direction:column;gap:.75rem;align-self:start;min-width:min(100%,380px)}.section-heading{align-items:center;justify-content:space-between}.section-heading h2{font-size:clamp(1.3rem,3vw,2rem)}.notice{padding:.85rem 1rem;border-radius:16px;border:1px solid var(--line)}.notice.success{color:#cbffed;background:#36c89a21;border-color:#36c89a47}.notice.error{color:#ffd5cf;background:#ff7f701f;border-color:#ff7f7047}.table-shell{overflow:auto;border-radius:24px;border:1px solid var(--line)}table{width:100%;min-width:980px;border-collapse:collapse;background:#040c1394}th,td{padding:1rem .9rem;border-bottom:1px solid rgba(141,181,214,.08);text-align:left;vertical-align:top}th{position:sticky;top:0;z-index:1;color:var(--muted);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;background:#081320f5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}tbody tr{cursor:pointer;transition:background .12s ease}tbody tr:nth-child(2n){background:#ffffff03}tbody tr:hover{background:#7de3c20f}tbody tr.selected{background:#7de3c21a;outline:1px solid rgba(125,227,194,.22) inset}tbody tr.connected-row{box-shadow:inset 3px 0 0 var(--accent-strong)}tbody tr.row-locked{cursor:default}tbody tr.row-locked:hover{background:transparent}.cell-stack{display:flex;flex-direction:column;gap:.2rem}.cell-stack span{color:var(--muted);font-size:.86rem}.status-pill,.identifier-chip,.role-pill,.permission-chip,.ghost-button,.checkbox-row{display:inline-flex;align-items:center;gap:.45rem}.status-pill{padding:.35rem .7rem;border-radius:999px;border:1px solid var(--line);font-size:.78rem;font-weight:600;background:#ffffff08}.status-pill:before{content:"";display:inline-block;width:6px;height:6px;border-radius:999px;background:currentColor;opacity:.72;margin-right:.35rem;vertical-align:middle;flex-shrink:0}.status-pill.active{color:#d9ffef;border-color:#36c89a57;background:#36c89a24}.status-pill.revoked{color:#ffd9d2;border-color:#ff7f704d;background:#ff7f701f}.status-pill.expired{color:#ffeab4;border-color:#ffcf734d;background:#ffcf731c}.ghost-button{padding:.45rem .85rem;border-radius:999px;border:1px solid var(--line);background:#ffffff06;font-size:.85rem;font-weight:500}.ghost-button:hover{border-color:color-mix(in srgb,var(--accent) 50%,transparent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.danger-button{background:#ff6b5b1a;border-color:#ff6b5b47;color:#ffb5ad}.danger-button:hover{background:#ff6b5b2e;border-color:#ff6b5b80;box-shadow:0 0 16px #ff6b5b33}.details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.details-grid>div{padding:.9rem 1rem;border-radius:18px;border:1px solid var(--line);background:#ffffff05}.field-label{display:block;margin-bottom:.35rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}.identifier-list,.permission-grid,.role-list,.assignment-list,.editor-stack,.mapping-shell,.brand-preview-grid,.stack-list,.login-feature-list{display:flex;gap:.75rem;flex-wrap:wrap}.manual-ban-shell,.mapping-type-card,.mapping-form-card,.brand-preview-card{border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,#ffffff0a,#ffffff04),#0610198c}.manual-ban-shell{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:1rem;padding:1rem}.manual-ban-intro{padding:.25rem}.manual-ban-intro p{margin:0;color:var(--muted);line-height:1.55}.stack-list{flex-direction:column}.stack-list-card{display:flex;flex-direction:column;gap:.3rem;padding:.95rem 1rem;border-radius:18px;border:1px solid var(--line);background:#ffffff08}.stack-list-card span{color:var(--muted)}.identifier-chip{padding:.45rem .75rem;border-radius:999px;border:1px solid var(--line);color:var(--muted);background:#ffffff06;font-size:.82rem;font-family:Cascadia Code,Fira Code,Consolas,monospace}.identifier-chip.chip-discord{border-color:#5865f280;color:#a5aeff;background:#5865f214}.identifier-chip.chip-steam{border-color:#64a0dc80;color:#94c9f0;background:#64a0dc14}.identifier-chip.chip-license{border-color:#32c8a073;color:#5decc8;background:#32c8a014}.identifier-chip.chip-fivem{border-color:#a371f780;color:#c19ffa;background:#a371f714}.identifier-chip.chip-xbl{border-color:#50c85073;color:#7de87d;background:#50c85014}.identifier-chip.chip-ip{border-color:#f3b76f80;color:#f3b76f;background:#f3b76f14}.identifier-chip.chip-hwid{border-color:#ff7f7080;color:#ff9d8d;background:#ff7f7014}.monospace{font-family:Cascadia Code,Fira Code,Consolas,monospace}.chip-ip-text{color:#f3b76f}.chip-hwid-text{color:#ff9d8d}.editor-stack{flex-direction:column}.bordered-top{padding-top:1rem;border-top:1px solid var(--line)}.editor-stack label,.form-grid label{display:flex;flex-direction:column;gap:.45rem;flex:1 1 220px}.full-width{width:100%}.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.permission-grid.compact{max-height:360px;overflow:auto;padding-right:.25rem}.admin-layout>*{flex:1 1 480px}.mapping-shell{align-items:stretch}.mapping-type-card,.mapping-form-card,.brand-preview-card{padding:1rem}.mapping-type-card{flex:0 1 220px;display:flex;flex-direction:column;gap:.75rem}.mapping-form-card{flex:1 1 360px;display:flex;flex-direction:column;gap:1rem}.brand-preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.brand-preview-card{display:flex;flex-direction:column;gap:.8rem}.login-shell{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(260px,.9fr);gap:1rem;align-items:stretch}.login-copy{display:flex;flex-direction:column;gap:.8rem}.login-support{max-width:48ch;color:var(--muted);margin:0;line-height:1.6}.login-feature{display:inline-flex;align-items:center;padding:.5rem .85rem;border-radius:999px;border:1px solid var(--line);background:#ffffff08;color:var(--text)}.login-actions-panel{display:flex;flex-direction:column;gap:.85rem;padding:1.1rem;border-radius:24px;border:1px solid var(--line);background:linear-gradient(160deg,color-mix(in srgb,var(--accent) 12%,transparent),#ffffff05),#050e17db}.login-provider{width:100%;justify-content:center;text-align:center}.permission-chip,.role-pill,.assignment-row{border:1px solid var(--line);border-radius:18px;background:#ffffff05}.permission-chip{padding:.75rem .9rem}.role-list{gap:.65rem}.role-pill{padding:.9rem 1rem;min-width:160px;flex-direction:column;align-items:flex-start}.role-pill span{color:var(--muted)}.role-pill.active{border-color:#7de3c273;background:#7de3c214}.assignment-list{flex-direction:column}.assignment-row{padding:.9rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.assignment-row span{display:block;color:var(--muted);margin-top:.2rem}.assignment-row strong{overflow-wrap:anywhere}.login{width:min(620px,100%)}.empty-state{padding:1rem;border-radius:18px;border:1px dashed var(--line-strong);text-align:center}ul{margin:0;padding-left:1.2rem}@media (max-width: 1180px){.app-body.with-sidebar{grid-template-columns:1fr}.sidebar{position:static}}@media (max-width: 980px){.topbar{align-items:flex-start;flex-direction:column}.app-body{width:min(100vw - 1rem,1600px);padding-top:1rem}.metric-row,.details-grid{grid-template-columns:1fr 1fr}.hero-landing,.page-hero,.login-shell{grid-template-columns:1fr}.topbar-actions{width:100%;justify-content:space-between}.topbar-user{align-items:flex-start}.manual-ban-shell,.brand-preview-grid{grid-template-columns:1fr}}@media (max-width: 720px){.metric-row,.details-grid,.permission-grid{grid-template-columns:1fr}.hero-panel,.panel-card,.card,.sidebar{border-radius:22px}.hero-stat-row,.sidebar-summary-grid{grid-template-columns:1fr}}.player-src-badge{display:inline-flex;align-items:center;padding:.3rem .6rem;border-radius:999px;border:1px solid var(--line);background:#ffffff0a;color:var(--muted);font-size:.78rem;font-weight:600;font-family:Cascadia Code,Fira Code,Consolas,monospace;flex-shrink:0}.player-src-badge--lg{padding:.45rem .9rem;font-size:.88rem;color:var(--text);border-color:color-mix(in srgb,var(--accent) 30%,transparent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.ban-confirm-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#ffffff08;border-radius:999px}::-webkit-scrollbar-thumb{background:#78afd738;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#78afd76b}.panel-card:before,.hero-panel:before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,transparent 5%,color-mix(in srgb,var(--accent) 30%,transparent) 50%,transparent 95%);pointer-events:none}.section-heading>div{display:flex;flex-direction:column;gap:.1rem}.topbar{backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%)}.sidebar{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.page-content{padding:2rem 2.5rem;max-width:1100px}.btn-primary{padding:.55rem 1.1rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 55%,transparent);background:color-mix(in srgb,var(--accent) 16%,transparent);color:color-mix(in srgb,var(--accent) 95%,white);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform .12s ease}.btn-primary:hover{background:color-mix(in srgb,var(--accent) 26%,transparent);border-color:color-mix(in srgb,var(--accent) 75%,transparent);transform:translateY(-1px)}.btn-primary:disabled{opacity:.45;cursor:default;transform:none}.btn-secondary{padding:.45rem .85rem;border-radius:999px;border:1px solid var(--line);background:#ffffff06;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform .12s ease}.btn-secondary:hover{border-color:color-mix(in srgb,var(--accent) 50%,transparent);background:color-mix(in srgb,var(--accent) 8%,transparent);transform:translateY(-1px)}.btn-secondary:disabled{opacity:.45;cursor:default}.btn-icon{padding:.45rem .85rem;border-radius:999px;border:1px solid var(--line);background:#ffffff06;font-size:.82rem;font-weight:500;cursor:pointer}.btn-icon:hover{background:#ffffff0d;transform:translateY(-1px)}.btn-danger{padding:.45rem .85rem;border-radius:999px;border:1px solid rgba(255,107,91,.28);background:#ff6b5b1a;color:#ffb5ad;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .12s ease,border-color .12s ease}.btn-danger:hover{background:#ff6b5b2e;border-color:#ff6b5b80}.btn-danger:disabled{opacity:.45;cursor:default}.error-banner{padding:.85rem 1rem;border-radius:16px;border:1px solid rgba(255,127,112,.28);background:#ff7f701f;color:#ffd5cf;margin-bottom:.75rem}.success-banner{padding:.85rem 1rem;border-radius:16px;border:1px solid rgba(54,200,154,.28);background:#36c89a21;color:#cbffed;margin-bottom:.75rem}.panel-card-title{font-size:.92rem;font-weight:600;color:var(--text);margin-bottom:1rem;opacity:.9}.tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.tag-card{position:relative}.bg-deep{background:#040a10d9}.map-page .panel-card{padding:0;overflow:hidden;display:flex;flex-direction:column}.map-panel-card{flex:1;min-height:0}.map-web-controls{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--line);flex-shrink:0;flex-wrap:wrap}.map-web-style-switcher{display:flex;gap:6px}.map-web-style-btn{background:#ffffff0a;border:1px solid var(--line);border-radius:8px;color:var(--muted);cursor:pointer;font:500 .78rem/1 inherit;padding:6px 14px;transition:background .15s,color .15s,border-color .15s}.map-web-style-btn:hover{background:#ffffff14;color:var(--text)}.map-web-style-btn.active{background:#7de3c21a;border-color:var(--accent);color:var(--accent)}.map-web-hint{font-size:.72rem;color:var(--muted);opacity:.6;margin-left:auto}.map-web-canvas-wrap{flex:1;min-height:480px;position:relative;overflow:hidden;background:#061019}.map-web-canvas-wrap canvas{display:block;width:100%;height:100%;cursor:grab}.map-web-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.85rem;pointer-events:none}.map-web-tooltip{position:absolute;background:var(--panel-strong);border:1px solid var(--line-strong);border-radius:10px;padding:10px 14px;min-width:160px;pointer-events:auto;box-shadow:var(--shadow);z-index:10}.map-web-tooltip-close{position:absolute;top:6px;right:8px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:.75rem;padding:2px 4px}.map-web-tooltip-name{font-weight:700;font-size:.88rem;color:var(--text);margin-bottom:6px;padding-right:18px}.map-web-tooltip-row{display:flex;justify-content:space-between;gap:12px;font-size:.76rem;color:var(--muted);padding:2px 0}.map-web-tooltip-row span:last-child{color:var(--text);font-variant-numeric:tabular-nums}.map-web-legend{display:flex;align-items:center;gap:14px;padding:8px 16px;border-top:1px solid var(--line);flex-shrink:0;flex-wrap:wrap}.map-web-legend-item{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--muted);text-transform:capitalize}.map-web-legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.map-nocoords-list{display:flex;flex-direction:column;gap:4px}.map-nocoords-row{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:8px;background:#ffffff08;font-size:.82rem}.map-nocoords-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.map-nocoords-name{flex:1;color:var(--text);font-weight:500}.map-nocoords-id{color:var(--text-secondary);font-size:.74rem;font-family:monospace}.map-nocoords-role{font-size:.74rem;font-weight:500;text-transform:capitalize}
