:root{--bk-surface-0:#0b0d12;--bk-surface-1:#12151e;--bk-surface-2:#1a1d28;--bk-surface-3:#222636;--bk-surface-4:#2a3040;--bk-accent:#c9a227;--bk-accent-bright:#e8b830;--bk-accent-muted:#c9a22726;--bk-accent-glow:#c9a22740;--bk-text-1:#ede8e0;--bk-text-2:#c4bfb4;--bk-text-3:#7c8290;--bk-text-4:#505668;--bk-border-subtle:#ffffff0f;--bk-border-default:#2a2f3a;--bk-border-strong:#3d4455;--bk-success:#22c55e;--bk-success-muted:#22c55e26;--bk-danger:#ef4444;--bk-danger-muted:#ef444426;--bk-warning:#f59e0b;--bk-warning-muted:#f59e0b26;--bk-info:#3b82f6;--bk-info-muted:#3b82f626;--bk-class-feca:#8b6914;--bk-class-osamodas:#3c8c2e;--bk-class-enutrof:#c9a227;--bk-class-sram:#4a4a4a;--bk-class-xelor:#2980b9;--bk-class-ecaflip:#9b59b6;--bk-class-eniripsa:#e74c8b;--bk-class-iop:#e74c3c;--bk-class-cra:#27ae60;--bk-class-sadida:#2ecc71;--bk-class-sacrieur:#c0392b;--bk-class-pandawa:#1abc9c;--bk-space-1:4px;--bk-space-2:8px;--bk-space-3:12px;--bk-space-4:16px;--bk-space-5:20px;--bk-space-6:24px;--bk-space-8:32px;--bk-space-10:40px;--bk-space-12:48px;--bk-font-display:"Cinzel", Georgia, serif;--bk-font-body:"Inter", system-ui, -apple-system, sans-serif;--bk-font-mono:"JetBrains Mono", "Fira Code", monospace;--bk-text-xs:.6875rem;--bk-text-sm:.8125rem;--bk-text-base:.9375rem;--bk-text-lg:1.125rem;--bk-text-xl:1.375rem;--bk-text-2xl:1.75rem;--bk-shadow-sm:0 1px 3px #0000004d;--bk-shadow-md:0 4px 12px #0006;--bk-shadow-lg:0 8px 24px #00000080;--bk-shadow-accent:0 0 16px var(--bk-accent-glow);--bk-duration-fast:.12s;--bk-duration-normal:.25s;--bk-duration-slow:.4s;--bk-ease-out:cubic-bezier(.16, 1, .3, 1);--bk-ease-spring:cubic-bezier(.34, 1.56, .64, 1);--bk-radius-sm:4px;--bk-radius-base:8px;--bk-radius-lg:12px;--bk-radius-pill:9999px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--bk-font-body);background:var(--bk-surface-0);color:var(--bk-text-1);font-size:var(--bk-text-base);min-height:100vh;line-height:1.5}h1,h2,h3{font-family:var(--bk-font-display);letter-spacing:.02em}.app-layout{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.app-content{padding:var(--bk-space-6);width:100%;max-width:1100px}.sidenav{background:var(--bk-surface-1);border-right:1px solid var(--bk-border-subtle);height:100vh;padding:var(--bk-space-6) 0;flex-direction:column;display:flex;position:sticky;top:0;overflow-y:auto}.sidenav-header{padding:0 var(--bk-space-5);margin-bottom:var(--bk-space-8)}.sidenav-title{font-family:var(--bk-font-display);font-size:var(--bk-text-2xl);color:var(--bk-accent);letter-spacing:.03em;font-weight:700}.sidenav-subtitle{font-size:var(--bk-text-xs);color:var(--bk-text-3);margin-top:var(--bk-space-1);display:block}.sidenav-links{margin:0;padding:0;list-style:none}.sidenav-link{align-items:center;gap:var(--bk-space-3);padding:var(--bk-space-3) var(--bk-space-5);color:var(--bk-text-2);font-size:var(--bk-text-base);transition:background var(--bk-duration-fast) var(--bk-ease-out), color var(--bk-duration-fast) var(--bk-ease-out);font-weight:500;text-decoration:none;display:flex}.sidenav-link:hover{background:var(--bk-surface-2);color:var(--bk-text-1)}.sidenav-active{color:var(--bk-accent);background:var(--bk-accent-muted);border-right:3px solid var(--bk-accent)}.sidenav-icon{color:currentColor;justify-content:center;align-items:center;width:1.5rem;display:flex}.sidenav-icon svg{fill:currentColor}.sidenav-subtabs{margin:0;padding:0;list-style:none}.sidenav-sublink{padding:var(--bk-space-2) var(--bk-space-5) var(--bk-space-2) calc(var(--bk-space-5) + 2.25rem);color:var(--bk-text-3);font-size:var(--bk-text-sm);transition:color var(--bk-duration-fast) var(--bk-ease-out);text-decoration:none;display:block}.sidenav-sublink:hover{color:var(--bk-text-1)}.sidenav-subactive{color:var(--bk-accent)}.bottom-bar{background:var(--bk-surface-1);border-top:1px solid var(--bk-border-subtle);z-index:100;padding:var(--bk-space-2) 0;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-bar-link{color:var(--bk-text-3);font-size:var(--bk-text-xs);padding:var(--bk-space-1);flex-direction:column;align-items:center;gap:2px;text-decoration:none;display:flex}.bottom-bar-icon{color:currentColor;justify-content:center;align-items:center;display:flex}.bottom-bar-icon svg{fill:currentColor}.bottom-bar-active{color:var(--bk-accent)}@media (width<=767px){.app-layout{grid-template-columns:1fr}.sidenav{display:none}.bottom-bar{justify-content:space-around;display:flex}.app-content{padding:var(--bk-space-4);padding-bottom:72px}}.card{background:var(--bk-surface-2);border:1px solid var(--bk-border-subtle);border-radius:var(--bk-radius-base);box-shadow:var(--bk-shadow-sm);padding:var(--bk-space-4)}.card--interactive{cursor:pointer;transition:transform var(--bk-duration-fast) var(--bk-ease-out), box-shadow var(--bk-duration-fast) var(--bk-ease-out), background var(--bk-duration-fast) var(--bk-ease-out), border-color var(--bk-duration-fast) var(--bk-ease-out)}.card--interactive:hover{background:var(--bk-surface-3);border-color:var(--bk-border-strong);box-shadow:var(--bk-shadow-md);transform:translateY(-1px)}.card--accent{border-left:4px solid var(--bk-accent);box-shadow:var(--bk-shadow-sm), inset 0 0 8px var(--bk-accent-glow)}[data-class=Feca]{--card-accent:var(--bk-class-feca)}[data-class=Osamodas]{--card-accent:var(--bk-class-osamodas)}[data-class=Enutrof]{--card-accent:var(--bk-class-enutrof)}[data-class=Sram]{--card-accent:var(--bk-class-sram)}[data-class=Xelor]{--card-accent:var(--bk-class-xelor)}[data-class=Ecaflip]{--card-accent:var(--bk-class-ecaflip)}[data-class=Eniripsa]{--card-accent:var(--bk-class-eniripsa)}[data-class=Iop]{--card-accent:var(--bk-class-iop)}[data-class=Cra]{--card-accent:var(--bk-class-cra)}[data-class=Sadida]{--card-accent:var(--bk-class-sadida)}[data-class=Sacrieur]{--card-accent:var(--bk-class-sacrieur)}[data-class=Pandawa]{--card-accent:var(--bk-class-pandawa)}.player-card[data-class]{border-left:4px solid var(--card-accent,var(--bk-border-default))}.badge{align-items:center;gap:var(--bk-space-1);border-radius:var(--bk-radius-pill);font-size:var(--bk-text-xs);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;cursor:pointer;border:none;padding:2px 10px;font-weight:600;line-height:1.5;display:inline-flex}.badge--todo{border:1px solid var(--bk-border-default);color:var(--bk-text-3);background:0 0}.badge--in-progress{background:var(--bk-accent-muted);color:var(--bk-accent-bright)}.badge--done{background:var(--bk-success-muted);color:var(--bk-success)}.badge--active{background:var(--bk-accent-muted);color:var(--bk-accent-bright)}.badge--ended{background:var(--bk-surface-4);color:var(--bk-text-3)}button{cursor:pointer;border-radius:var(--bk-radius-base);font-family:var(--bk-font-body);font-size:var(--bk-text-sm);padding:var(--bk-space-2) var(--bk-space-4);transition:background var(--bk-duration-fast) var(--bk-ease-out), border-color var(--bk-duration-fast) var(--bk-ease-out), color var(--bk-duration-fast) var(--bk-ease-out), box-shadow var(--bk-duration-fast) var(--bk-ease-out);border:none}.btn-primary{background:var(--bk-accent);color:var(--bk-surface-0);font-weight:600}.btn-primary:hover{background:var(--bk-accent-bright);box-shadow:0 0 12px var(--bk-accent-glow)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-secondary{background:var(--bk-surface-3);color:var(--bk-text-1);border:1px solid var(--bk-border-default)}.btn-secondary:hover{background:var(--bk-surface-4);border-color:var(--bk-border-strong)}.btn-danger{color:var(--bk-danger);border:1px solid var(--bk-danger);background:0 0}.btn-danger:hover{background:var(--bk-danger);color:#fff}.btn-small{padding:var(--bk-space-1) 10px;font-size:var(--bk-text-xs)}.team-list{flex-direction:column;gap:12px;display:flex}.team-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);cursor:pointer;color:var(--bk-text-1);text-align:left;width:100%;font:inherit;padding:16px;transition:border-color .15s}.team-card:hover{border-color:var(--bk-accent)}.team-card h3{color:var(--bk-text-1);margin-bottom:4px;font-size:16px}.team-card .meta{color:var(--bk-text-2);font-size:13px}.team-detail-header{align-items:center;gap:12px;margin-bottom:24px;display:flex}.team-detail-header h2{flex:1;font-size:20px}.player-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:16px;display:grid}.player-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);padding:16px}.player-card .player-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.player-card .player-name{font-size:15px;font-weight:600}.player-card .player-class{color:var(--bk-accent);font-size:13px;font-weight:600}.player-card .player-info{color:var(--bk-text-2);font-size:13px}.player-card .player-actions{gap:8px;margin-top:12px;display:flex}.form-overlay{z-index:10;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.form-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);width:100%;max-width:420px;padding:24px}.form-card h3{margin-bottom:16px;font-size:18px}.form-field{margin-bottom:12px}.form-field label{color:var(--bk-text-2);margin-bottom:4px;font-size:13px;display:block}.form-field input,.form-field select{width:100%}.form-field input:focus,.form-field select:focus{border-color:var(--bk-accent);box-shadow:0 0 0 2px var(--bk-accent-muted)}.form-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}input,select,textarea{font-family:var(--bk-font-body);font-size:var(--bk-text-sm);color:var(--bk-text-1);background:var(--bk-surface-0);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);padding:var(--bk-space-2) var(--bk-space-3);transition:border-color var(--bk-duration-fast) var(--bk-ease-out), box-shadow var(--bk-duration-fast) var(--bk-ease-out)}input:focus,select:focus,textarea:focus{border-color:var(--bk-accent);box-shadow:0 0 0 2px var(--bk-accent-muted);outline:none}input::placeholder{color:var(--bk-text-4)}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%237c8290'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}select option{background:var(--bk-surface-2);color:var(--bk-text-1)}.empty-state{text-align:center;padding:var(--bk-space-12) var(--bk-space-4);color:var(--bk-text-3)}.empty-state:before{content:"📦";margin-bottom:var(--bk-space-4);opacity:.5;font-size:2.5rem;display:block}.empty-state p{margin-bottom:var(--bk-space-4);font-size:var(--bk-text-base);line-height:1.6}.empty-state .btn-primary{display:inline-flex}.loading{text-align:center;color:var(--bk-text-2);padding:32px}.error{border:1px solid var(--bk-danger);border-radius:var(--bk-radius-base);color:var(--bk-danger);background:#ef44441a;margin-bottom:16px;padding:12px 16px}.section-header{margin-bottom:var(--bk-space-4);justify-content:space-between;align-items:center;display:flex}.section-header h3{font-size:var(--bk-text-base);color:var(--bk-text-2)}.resource-player-selector{align-items:center;gap:var(--bk-space-3);margin-bottom:var(--bk-space-5);padding:var(--bk-space-3) var(--bk-space-4);background:var(--bk-surface-2);border:1px solid var(--bk-border-subtle);border-radius:var(--bk-radius-base);display:flex}.resource-player-selector label{color:var(--bk-accent);font-size:var(--bk-text-sm);white-space:nowrap;font-weight:600;font-family:var(--bk-font-display)}.resource-player-selector select{background:var(--bk-surface-3);border-color:var(--bk-border-default);min-width:240px;padding:var(--bk-space-2) var(--bk-space-4);font-size:var(--bk-text-base);padding-right:32px;font-weight:500}.resource-page>h2,.app-content>div>h2,.app-content h2:first-child{font-family:var(--bk-font-display);font-size:var(--bk-text-xl);color:var(--bk-text-1);padding-bottom:var(--bk-space-3);margin-bottom:var(--bk-space-5);border-bottom:1px solid var(--bk-border-subtle)}.inventory-table,.gear-table,.craft-delta-table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--bk-text-sm)}.inventory-table thead th,.gear-table thead th,.craft-delta-table thead th{text-align:left;color:var(--bk-text-3);font-weight:600;font-size:var(--bk-text-xs);text-transform:uppercase;letter-spacing:.05em;padding:var(--bk-space-2) var(--bk-space-3);border-bottom:2px solid var(--bk-border-default);background:var(--bk-surface-1);position:sticky;top:0}.inventory-table tbody td,.gear-table tbody td,.craft-delta-table tbody td{padding:var(--bk-space-2) var(--bk-space-3);border-bottom:1px solid var(--bk-border-subtle);vertical-align:middle}.inventory-table tbody tr:nth-child(2n),.gear-table tbody tr:nth-child(2n),.craft-delta-table tbody tr:nth-child(2n){background:#ffffff05}.inventory-table tbody tr:hover,.gear-table tbody tr:hover,.craft-delta-table tbody tr:hover{background:var(--bk-surface-2)}.inventory-table tbody td:last-child{gap:var(--bk-space-1);display:flex}.craft-plan-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);overflow:hidden}.craft-plan-header{padding:var(--bk-space-2) var(--bk-space-3);background:var(--bk-surface-3);justify-content:space-between;align-items:center;display:flex}.craft-plans{gap:var(--bk-space-3);flex-direction:column;display:flex}.craft-complete td{color:var(--bk-success)}.craft-missing td:last-child{color:var(--bk-warning);font-weight:600}.item-icon{object-fit:contain;vertical-align:middle;border-radius:4px;flex-shrink:0}.td-item-name{align-items:center;gap:var(--bk-space-2);display:flex}.text-muted{color:var(--bk-text-3);font-size:var(--bk-text-xs)}.session-toolbar{align-items:flex-end;gap:12px;margin-bottom:20px;display:flex}.session-list{flex-direction:column;gap:12px;display:flex}.session-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);cursor:pointer;padding:16px;transition:border-color .15s;position:relative}.session-card:hover{border-color:var(--bk-accent)}.session-card-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.session-date{font-size:14px;font-weight:600}.session-status{border-radius:4px;padding:2px 8px;font-size:12px;font-weight:600}.session-active{color:var(--bk-success);background:#22c55e26}.session-ended{color:var(--bk-text-2);background:#9ca3af26}.session-notes{color:var(--bk-text-2);margin-bottom:6px;font-size:13px}.session-meta{color:var(--bk-text-3);gap:12px;font-size:12px;display:flex}.session-delete{opacity:0;transition:opacity .15s;position:absolute;bottom:12px;right:12px}.session-card:hover .session-delete{opacity:1}.session-section{margin-bottom:24px}.session-section h3{color:var(--bk-text-2);margin-bottom:8px;font-size:15px}.session-inline-form{align-items:center;gap:8px;display:flex}.session-input{flex:1}.session-actions{border-top:1px solid var(--bk-border-default);gap:12px;margin-top:32px;padding-top:16px;display:flex}.objective-list{flex-direction:column;gap:6px;display:flex}.objective-row{align-items:center;gap:8px;display:flex}.objective-item{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);flex:1;align-items:center;gap:10px;padding:8px 12px;display:flex}.objective-status-btn{text-align:center;border-radius:4px;min-width:70px;padding:2px 8px;font-size:11px;font-weight:600}.objective-todo .objective-status-btn{color:var(--bk-text-2);background:#9ca3af26}.objective-in_progress .objective-status-btn{color:var(--bk-accent);background:#d4a01726}.objective-done .objective-status-btn{color:var(--bk-success);background:#22c55e26}.objective-desc{font-size:14px}.objective-done .objective-desc{color:var(--bk-text-3);text-decoration:line-through}.drop-list{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.drop-row{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);align-items:center;gap:8px;padding:6px 10px;display:flex}.drop-name{flex:1;font-size:14px}.drop-qty{color:var(--bk-accent);font-size:13px;font-weight:600}.drop-add-form{align-items:flex-start;gap:8px;margin-top:8px;display:flex}.drop-search-wrapper{flex:1;position:relative}.drop-clear{color:var(--bk-text-3);background:0 0;padding:0 4px;font-size:16px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.drop-suggestions{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);z-index:5;max-height:200px;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.drop-suggestions li button{align-items:center;gap:var(--bk-space-2);text-align:left;width:100%;color:var(--bk-text-1);background:0 0;border-radius:0;padding:8px 12px;font-size:13px;display:flex}.drop-suggestions li button:hover{background:var(--bk-surface-3)}.drop-qty-input{flex:none;width:70px}.tracker-toolbar{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:20px;display:flex}.tracker-list{flex-direction:column;gap:4px;display:flex}.tracker-row{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);align-items:center;gap:10px;padding:8px 12px;display:flex}.tracker-name{flex:1;font-size:14px}.tracker-level{color:var(--bk-text-3);font-size:12px}.tracker-row-clickable{cursor:pointer}.tracker-row-clickable:hover{border-color:var(--bk-accent)}.tracker-expand{color:var(--bk-text-3);margin-left:4px;font-size:10px}.tracker-detail-wrapper{flex-direction:column;display:flex}.tracker-details{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:0 0 var(--bk-radius-base) var(--bk-radius-base);border-top:none;margin-top:-4px;padding:12px 16px}.tracker-detail-section{margin-bottom:8px}.tracker-detail-section:last-child{margin-bottom:0}.tracker-detail-label{color:var(--bk-accent);margin-bottom:2px;font-size:12px;font-weight:600;display:block}.tracker-details p{color:var(--bk-text-2);margin:0;font-size:13px}.tracker-details ul{color:var(--bk-text-2);font-size:13px;list-style:none}.tracker-details li{padding:1px 0}.tracker-details li:before{content:"• ";color:var(--bk-accent)}.status-badge{text-align:center;border-radius:4px;min-width:70px;padding:2px 8px;font-size:11px;font-weight:600}.status-todo{color:var(--bk-text-2);background:#9ca3af26}.status-in_progress{color:var(--bk-accent);background:#d4a01726}.status-done{color:var(--bk-success);background:#22c55e26}.level-filter{flex-direction:column;gap:4px;display:flex}.level-filter label{color:var(--bk-text-2);font-size:13px}.level-filter-input{width:80px}.synergy-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);margin-bottom:20px;padding:16px}.synergy-card h3{color:var(--bk-accent);margin-bottom:12px;font-size:16px}.synergy-roles{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.synergy-role{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);padding:8px 12px;font-size:13px}.synergy-role-icon{margin-right:4px;font-size:16px}.synergy-role-name{margin-right:6px;font-weight:600}.synergy-players{color:var(--bk-text-2)}.synergy-missing{color:var(--bk-text-3);flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;font-size:13px;display:flex}.synergy-missing-role{font-weight:600}.enrichment-panel{border-top:1px solid var(--bk-border-default);margin-top:8px;padding-top:8px}.enrichment-groups{flex-direction:column;gap:8px;margin-top:8px;display:flex}.enrichment-group h4{color:var(--bk-accent);margin-bottom:4px;font-size:13px}.enrichment-group ul{color:var(--bk-text-1);font-size:13px;list-style:none}.enrichment-group li{padding:2px 0}.save-indicator{color:var(--bk-success);white-space:nowrap;font-size:13px;font-weight:600}.build-selector{flex-wrap:wrap;gap:6px;display:flex}.build-chip{border:1.5px solid var(--bk-border-default);background:var(--bk-surface-2);color:var(--bk-text-1);cursor:pointer;border-radius:16px;align-items:center;gap:4px;padding:4px 10px;font-size:13px;transition:border-color .15s,background .15s;display:flex}.build-chip:hover{border-color:var(--bk-accent)}.build-chip-active{font-weight:600}.build-chip-icon{font-size:15px}.build-chip-label{font-size:12px}.build-badges{vertical-align:middle;gap:3px;display:inline-flex}.build-badge{border:1.5px solid;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;display:inline-flex}.resource-tabs{gap:var(--bk-space-2);margin-bottom:var(--bk-space-5);padding:var(--bk-space-1);background:var(--bk-surface-1);border-radius:var(--bk-radius-lg);border:1px solid var(--bk-border-subtle);display:flex}.resource-tab{align-items:center;gap:var(--bk-space-2);color:var(--bk-text-3);font-size:var(--bk-text-sm);cursor:pointer;border-radius:var(--bk-radius-base);transition:background var(--bk-duration-fast) var(--bk-ease-out), color var(--bk-duration-fast) var(--bk-ease-out), box-shadow var(--bk-duration-fast) var(--bk-ease-out);background:0 0;border:none;padding:10px 18px;font-weight:500;display:inline-flex}.resource-tab svg{fill:currentColor;flex-shrink:0;width:16px;height:16px}.resource-tab:hover{color:var(--bk-text-1);background:var(--bk-surface-2)}.resource-tab-active{color:var(--bk-accent-bright);background:var(--bk-accent-muted);box-shadow:0 0 0 1px var(--bk-accent-glow), var(--bk-shadow-sm);font-weight:600}.inventory-filters{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.inventory-filter-btn{border:1px solid var(--bk-border-default);background:var(--bk-surface-2);color:var(--bk-text-2);cursor:pointer;border-radius:14px;padding:4px 12px;font-size:12px;transition:border-color .15s,background .15s}.inventory-filter-btn:hover{border-color:var(--bk-accent)}.inventory-filter-active{border-color:var(--bk-accent);color:var(--bk-accent);background:#d4a0171f;font-weight:600}.tracker-description-paragraphs{flex-direction:column;gap:8px;display:flex}.tracker-description-paragraphs p{color:var(--bk-text-2);margin:0;font-size:13px;line-height:1.5}.scroll-tracker{flex-direction:column;gap:12px;display:flex}.scroll-info{margin:0;font-size:12px}.scroll-stats-grid{flex-direction:column;gap:8px;display:flex}.scroll-stat-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:var(--bk-radius-base);padding:10px 14px}.scroll-stat-header{align-items:center;gap:8px;display:flex}.scroll-stat-toggle{color:var(--bk-text-1);cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:8px;padding:0;font-size:14px;display:flex}.scroll-stat-toggle:hover{color:var(--bk-accent)}.scroll-stat-icon{font-size:18px}.scroll-stat-label{min-width:90px;font-weight:600}.scroll-stat-level{color:var(--bk-text-2);font-size:13px;font-weight:500}.scroll-stat-chevron{color:var(--bk-text-3);margin-left:auto;font-size:10px}.scroll-edit-inline{align-items:center;gap:4px;display:flex}.scroll-level-input{text-align:center;width:60px}.scroll-progress-bar{background:var(--bk-surface-4);border-radius:var(--bk-radius-pill);height:10px;margin-top:8px;overflow:hidden}.scroll-progress-fill{border-radius:var(--bk-radius-pill);background:linear-gradient(90deg, #9e7a1a, var(--bk-accent-bright));height:100%;transition:width var(--bk-duration-slow) var(--bk-ease-out);animation:bar-fill var(--bk-duration-slow) var(--bk-ease-out)}@keyframes bar-fill{0%{transform-origin:0;transform:scaleX(0)}to{transform-origin:0;transform:scaleX(1)}}.scroll-delta-section{border-top:1px solid var(--bk-border-default);margin-top:10px;padding-top:10px}.text-success{color:var(--bk-success);font-weight:600}.spell-tree h3,.gear-progression h3,.next-milestones h3{margin:0 0 1rem}.spell-priority-section{margin-bottom:1.5rem}.spell-priority-section h4,.spell-all-section h4{color:var(--bk-text-2);margin:0 0 .5rem;font-size:.9rem}.spell-priority-list{margin:0;padding:0;list-style:none}.spell-priority-item{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);cursor:grab;border-radius:6px;align-items:center;gap:.75rem;margin-bottom:.25rem;padding:.5rem .75rem;display:flex}.spell-priority-item:active{cursor:grabbing}.spell-priority-rank{color:var(--bk-accent);min-width:1.5rem;font-weight:700}.spell-name{flex:1}.spell-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.5rem;display:grid}.spell-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:6px;padding:.5rem .75rem}.spell-card-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.spell-description{color:var(--bk-text-2);margin:.25rem 0 0;font-size:.8rem}.btn-icon{color:var(--bk-text-3);cursor:pointer;background:0 0;border:none;padding:.2rem;font-size:.9rem}.btn-icon:hover{color:var(--bk-danger)}.gear-brackets{flex-direction:column;gap:.25rem;display:flex}.gear-bracket{border:1px solid var(--bk-border-default);border-radius:6px;overflow:hidden}.gear-bracket-current{border-color:var(--bk-accent)}.gear-bracket-header{background:var(--bk-surface-2);width:100%;color:var(--bk-text-1);cursor:pointer;border:none;justify-content:space-between;padding:.5rem .75rem;font-size:.9rem;display:flex}.gear-bracket-header:hover{background:var(--bk-surface-2)}.gear-bracket-items{padding:.5rem .75rem}.gear-table{border-collapse:collapse;width:100%;font-size:.85rem}.gear-table th{text-align:left;color:var(--bk-text-2);border-bottom:1px solid var(--bk-border-default);padding:.3rem .5rem}.gear-table td{padding:.3rem .5rem}.gear-slots{gap:var(--bk-space-4);flex-direction:column;display:flex}.gear-slot-group{border-left:3px solid var(--bk-accent-muted);padding-left:var(--bk-space-3)}.gear-slot-title{font-size:var(--bk-text-sm);color:var(--bk-accent);margin-bottom:var(--bk-space-2);font-weight:600;font-family:var(--bk-font-display)}.gear-score{background:var(--bk-accent-muted);color:var(--bk-accent-bright);border-radius:var(--bk-radius-pill);font-size:var(--bk-text-xs);font-weight:600;font-family:var(--bk-font-mono);padding:1px 8px;display:inline-block}.gear-bracket-count{color:var(--bk-text-3);font-weight:400}.milestone-list{margin:0;padding:0;list-style:none}.milestone-item{border-bottom:1px solid var(--bk-border-default);align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.milestone-item:last-child{border-bottom:none}.job-tracker h3{margin:0}.job-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.job-add-form{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.job-list{flex-direction:column;gap:.5rem;display:flex}.job-item{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);border-radius:6px;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.job-name{min-width:10rem;font-weight:500}.job-level-bar{background:var(--bk-surface-4);border-radius:var(--bk-radius-pill);flex:1;height:10px;overflow:hidden}.job-level-fill{background:linear-gradient(90deg, #9e7a1a, var(--bk-accent-bright));border-radius:var(--bk-radius-pill);height:100%;transition:width var(--bk-duration-slow) var(--bk-ease-out);animation:bar-fill var(--bk-duration-slow) var(--bk-ease-out)}.job-level-btn{border:1px solid var(--bk-border-default);color:var(--bk-text-1);cursor:pointer;text-align:center;background:0 0;border-radius:4px;min-width:4rem;padding:.2rem .5rem;font-size:.85rem}.job-level-btn:hover{border-color:var(--bk-accent)}.job-edit{align-items:center;gap:.25rem;display:flex}.job-level-input{text-align:center;width:4rem}.milestone-icon{font-size:1.2rem}.milestone-level{color:var(--bk-accent);min-width:4rem;font-weight:600}.milestone-desc{color:var(--bk-text-1)}.player-info,.job-level-btn,.scroll-stat-value,.milestone-level{font-family:var(--bk-font-mono);font-variant-numeric:tabular-nums}@media (width<=767px){.player-grid,.scroll-stats-grid{grid-template-columns:1fr}.resource-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.resource-tab{white-space:nowrap;min-height:44px;padding:10px 14px}.session-input,select.session-input{width:100%;min-height:44px}.btn-small{min-width:44px;min-height:44px;padding:10px 16px}.btn-icon{justify-content:center;align-items:center;min-width:44px;min-height:44px;display:inline-flex}.bottom-bar-link{min-width:44px;min-height:44px;padding:var(--bk-space-2)}.player-actions{gap:var(--bk-space-3)}}@media (width>=768px){.player-grid{grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr))}}@media (width>=1024px){.app-content{max-width:1100px}}@media (width>=1440px){.app-content{max-width:1200px}}.dashboard-title{font-family:var(--bk-font-display);color:var(--bk-text-1);margin-bottom:var(--bk-space-6)}.dashboard-grid{gap:var(--bk-space-4);grid-template-columns:1fr;display:grid}@media (width>=768px){.dashboard-grid{grid-template-columns:1fr 1fr}}.dashboard-card{gap:var(--bk-space-3);flex-direction:column;display:flex}.dashboard-card-header{align-items:center;gap:var(--bk-space-2);color:var(--bk-accent);display:flex}.dashboard-card-header h3{font-size:var(--bk-text-lg);font-family:var(--bk-font-display);color:var(--bk-text-1)}.dashboard-card-header svg{fill:var(--bk-accent)}.dashboard-empty{color:var(--bk-text-3);font-size:var(--bk-text-sm)}.dashboard-list{gap:var(--bk-space-2);flex-direction:column;list-style:none;display:flex}.dashboard-list-btn{background:var(--bk-surface-3);border:1px solid var(--bk-border-subtle);border-radius:var(--bk-radius-sm);width:100%;padding:var(--bk-space-3) var(--bk-space-4);color:var(--bk-text-1);cursor:pointer;text-align:left;transition:background var(--bk-duration-fast) var(--bk-ease-out), border-color var(--bk-duration-fast) var(--bk-ease-out);justify-content:space-between;align-items:center;display:flex}.dashboard-list-btn:hover{background:var(--bk-surface-4);border-color:var(--bk-border-default)}.dashboard-team-name{font-weight:600}.dashboard-session{align-items:flex-start;gap:var(--bk-space-2);flex-direction:column}.dashboard-session-info{align-items:center;gap:var(--bk-space-3);display:flex}.dashboard-session-date{font-weight:600}.dashboard-session-stats{font-size:var(--bk-text-sm);color:var(--bk-text-2)}.dashboard-milestone{flex-direction:column;gap:2px;display:flex}.dashboard-milestone-player{font-weight:600;font-size:var(--bk-text-sm);color:var(--bk-accent)}.dashboard-milestone-desc{font-size:var(--bk-text-sm);color:var(--bk-text-2)}.dashboard-actions{gap:var(--bk-space-3);flex-wrap:wrap;display:flex}.dashboard-actions button{align-items:center;gap:var(--bk-space-2);display:inline-flex}.dashboard-actions button svg{fill:currentColor}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.app-content>div{animation:fade-in var(--bk-duration-normal) var(--bk-ease-out)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--bk-surface-2) 25%, var(--bk-surface-3) 50%, var(--bk-surface-2) 75%);border-radius:var(--bk-radius-base);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton-text{width:80%;height:1rem;margin-bottom:var(--bk-space-2)}.skeleton-card{width:100%;height:120px}.skeleton-list-item{width:100%;height:48px;margin-bottom:var(--bk-space-2)}.skeleton-grid{gap:var(--bk-space-4);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));display:grid}.skeleton-list{gap:var(--bk-space-2);flex-direction:column;display:flex}.skeleton-stack{gap:var(--bk-space-2);flex-direction:column;max-width:400px;display:flex}:focus-visible{outline:2px solid var(--bk-accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){:root{--bk-duration-fast:0s;--bk-duration-normal:0s;--bk-duration-slow:0s}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.overlay-root{width:100vw;height:100vh;color:var(--bk-text-1);border:1px solid var(--bk-border-default);background:#0b0d12eb;border-radius:10px;flex-direction:column;font-family:Inter,system-ui,sans-serif;font-size:13px;display:flex;overflow:hidden;box-shadow:0 8px 32px #0009}.overlay-header{background:var(--bk-surface-2);border-bottom:1px solid var(--bk-border-subtle);-webkit-app-region:drag;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.overlay-title{color:var(--bk-accent);text-transform:uppercase;letter-spacing:1px;font-family:Cinzel,serif;font-size:14px;font-weight:700}.overlay-hint{color:var(--bk-text-4);background:var(--bk-surface-3);border-radius:4px;padding:2px 6px;font-size:10px}.overlay-tabs{background:var(--bk-surface-1);border-bottom:1px solid var(--bk-border-subtle);gap:0;display:flex}.overlay-tab{color:var(--bk-text-3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:6px 0;font-size:12px;font-weight:500;transition:color .15s,border-color .15s}.overlay-tab:hover{color:var(--bk-text-2)}.overlay-tab--active{color:var(--bk-accent);border-bottom-color:var(--bk-accent)}.overlay-panel{flex:1;padding:10px 12px;overflow-y:auto}.overlay-empty{color:var(--bk-text-4);text-align:center;margin:0;padding:20px 0;font-style:italic}.overlay-section-title{color:var(--bk-text-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px;font-weight:600}.overlay-xp{text-align:right;color:var(--bk-success);margin-top:8px;font-size:12px;font-weight:600}.overlay-objectives{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.overlay-obj{border-radius:4px;align-items:flex-start;gap:6px;padding:4px 6px;font-size:12px;line-height:1.4;display:flex}.overlay-obj:hover{background:var(--bk-surface-2)}.overlay-obj--done{color:var(--bk-text-4);text-decoration:line-through}.overlay-obj-icon{text-align:center;width:14px;color:var(--bk-accent);flex-shrink:0}.overlay-obj--done .overlay-obj-icon{color:var(--bk-success)}.overlay-characters{flex-direction:column;gap:8px;display:flex}.overlay-char-card{background:var(--bk-surface-2);border:1px solid var(--bk-border-subtle);border-radius:6px;padding:8px 10px}.overlay-char-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.overlay-char-name{color:var(--bk-text-1);font-size:13px;font-weight:600}.overlay-char-class{color:var(--bk-accent);font-size:11px;font-weight:500}.overlay-milestones{margin:0;padding:0;list-style:none}.overlay-milestones li{color:var(--bk-text-3);padding:1px 0;font-size:11px}.overlay-milestone-level{color:var(--bk-accent-bright);font-weight:600}.overlay-search{background:var(--bk-surface-2);border:1px solid var(--bk-border-default);width:100%;color:var(--bk-text-1);box-sizing:border-box;border-radius:6px;outline:none;margin-bottom:8px;padding:6px 10px;font-size:12px}.overlay-search:focus{border-color:var(--bk-accent)}.overlay-search::placeholder{color:var(--bk-text-4)}.overlay-inv-results{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.overlay-inv-row{border-radius:4px;align-items:center;gap:6px;padding:4px 6px;font-size:12px;display:flex}.overlay-inv-row:hover{background:var(--bk-surface-2)}.overlay-inv-name{text-overflow:ellipsis;white-space:nowrap;color:var(--bk-text-1);flex:1;overflow:hidden}.overlay-inv-qty{color:var(--bk-accent);text-align:right;min-width:28px;font-weight:600}.overlay-inv-loc{color:var(--bk-text-4);text-align:right;min-width:45px;font-size:10px}.overlay-loading{height:100%;color:var(--bk-text-3);justify-content:center;align-items:center;font-style:italic;display:flex}
