*{scrollbar-width:thin;scrollbar-color:#333 transparent}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#555}[data-theme=light] *{scrollbar-color:#ccc transparent}[data-theme=light] ::-webkit-scrollbar-thumb{background:#ccc}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#aaa}:root{--table-bg:transparent;--table-border:#ffffff14;--filter-row-bg:#ffffff08;--filter-input-bg:#080808;--filter-input-border:#ffffff0f;--filter-input-shadow:#0006;--header-bg:#ffffff0f;--header-border:#ffffff1a;--header-text:#999;--header-hover-text:#ccc;--row-border:#ffffff0a;--row-stripe:#ffffff05;--row-text:#e0e0e0;--row-text-muted:#777;--clear-btn-border:#ffffff1f;--clear-btn-text:#888;--clear-btn-hover-text:#fff;--clear-btn-hover-bg:#ffffff0f;--sort-indicator:#555;--sort-indicator-hover:#888}*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background:#0a0a0a;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.auth-wrapper{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{text-align:center;background:#0f0f1a;border:1px solid #1a1a2e;border-radius:12px;width:100%;max-width:400px;padding:2.5rem 2rem;box-shadow:0 4px 24px #0006}.auth-logo{height:48px;margin-bottom:.5rem}.auth-title{margin-bottom:.25rem;font-size:2rem;font-weight:700}.auth-subtitle{color:#888;margin-bottom:2rem}.auth-form{flex-direction:column;gap:.75rem;display:flex}.auth-input{color:#e0e0e0;background:#111;border:1px solid #333;border-radius:8px;outline:none;height:44px;padding:0 1rem;font-size:1rem;transition:border-color .2s}.auth-input:focus{border-color:#6366f1}.auth-input::placeholder{color:#555}.auth-button{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:8px;height:44px;font-size:1rem;font-weight:600;transition:background .2s}.auth-button:hover{background:#5558e6}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:#f87171;font-size:.875rem}.auth-sent{animation:.3s fadeIn}.auth-sent-icon{color:#4ade80;margin-bottom:.75rem;font-size:2.5rem}.auth-sent-text{color:#e0e0e0;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.auth-sent-hint{color:#888;font-size:.875rem}.auth-link{color:#6366f1;margin-top:1rem;font-weight:500;text-decoration:none;display:inline-block}.auth-link:hover{text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.logout-btn{color:#e0e0e0;cursor:pointer;background:#1a1a2e;border:1px solid #333;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;transition:background .2s}.logout-btn:hover{background:#2a2a4e}.success{color:#4ade80;margin-top:1rem}.error{color:#f87171;margin-top:1rem}.impersonation-banner{color:#fff;background:#b45309;justify-content:space-between;align-items:center;padding:.5rem 1.25rem;font-size:.875rem;font-weight:500;display:flex}.impersonation-exit-btn{color:#fff;cursor:pointer;background:#fff3;border:1px solid #fff6;border-radius:4px;padding:.25rem .75rem;font-size:.8125rem;font-weight:600}.impersonation-exit-btn:hover{background:#ffffff4d}.app-layout{min-height:100vh;display:flex}.sidebar{background:#0f0f1a;border-right:1px solid #1a1a2e;flex-direction:column;flex-shrink:0;width:220px;padding:1.25rem 0;display:flex}.sidebar-logo{margin-bottom:1.5rem;padding:0 1.25rem;font-size:1.25rem;font-weight:700}.sidebar-nav{flex-direction:column;display:flex}.nav-item{color:#888;padding:.625rem 1.25rem;font-size:.9375rem;text-decoration:none;transition:color .15s,background .15s;display:block}.nav-item:hover{color:#e0e0e0;background:#ffffff0a}.nav-item.active{color:#e0e0e0;background:#6366f11f;border-left:3px solid #6366f1}.nav-separator{background:#ffffff14;height:1px;margin:.5rem 1rem}.app-content{flex-direction:column;flex:1;min-width:0;display:flex}.app-sticky-top{z-index:100;position:sticky;top:0}.app-header{background:#0a0a14;border-bottom:1px solid #1a1a2e;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}[data-theme=light] .app-header{background:#f5f5f5}.app-header-info{flex-direction:column;gap:.125rem;display:flex}.app-user-name{font-size:.875rem;font-weight:600}.app-user-meta{color:#666;font-size:.75rem}.app-main{flex:1;padding:1.5rem;overflow-y:auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.page-loading{color:#888;padding:2rem}.back-link{color:#6366f1;margin-bottom:1rem;font-size:.875rem;text-decoration:none;display:inline-block}.back-link:hover{text-decoration:underline}.btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{color:#fff;background:#6366f1}.btn-primary:hover:not(:disabled){background:#5558e6}.btn-secondary{color:#e0e0e0;background:#1a1a2e;border:1px solid #333}.btn-secondary:hover:not(:disabled){background:#2a2a4e}.btn-danger{color:#fff;background:#dc2626;border:none}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-success{color:#fff;background:#16a34a;border:none}.btn-success:hover:not(:disabled){background:#15803d}.btn-success:disabled{opacity:.5;cursor:not-allowed}.btn-danger-sm,.btn-success-sm{cursor:pointer;border:none;border-radius:4px;padding:.25rem .625rem;font-size:.75rem}.btn-danger-sm{color:#f87171;background:#f8717126}.btn-danger-sm:hover{background:#f8717140}.btn-success-sm{color:#4ade80;background:#4ade8026}.btn-success-sm:hover{background:#4ade8040}.btn-icon-danger{cursor:pointer;opacity:.4;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:1rem;transition:opacity .15s}.btn-icon-danger:hover{opacity:1}.data-table{border-collapse:collapse;border:1px solid var(--table-border);border-radius:8px;width:100%;overflow:hidden}.data-table th{text-align:left;color:var(--header-text);text-transform:uppercase;letter-spacing:.08em;background:var(--header-bg);border-bottom:1px solid var(--header-border);padding:.5rem .75rem;font-size:.7rem;font-weight:600}.data-table td{color:var(--row-text);border-bottom:1px solid var(--row-border);padding:.625rem .75rem;font-size:.875rem}.data-table tbody tr:nth-child(2n) td{background:var(--row-stripe)}.data-table tbody tr:hover td{background:#6366f10f}.data-table tbody tr:hover .table-link{text-decoration:underline}.data-table tbody tr.clickable-row{cursor:pointer}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-card{background:#0f0f1a;border:1px solid #1a1a2e;border-radius:12px;flex-direction:column;width:100%;max-width:440px;max-height:calc(100vh - 2rem);padding:1.5rem;display:flex;box-shadow:0 8px 32px #00000080}.modal-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.modal-title{margin:0;font-size:1.1rem}.modal-close-x{color:#999;cursor:pointer;background:0 0;border:none;padding:0 .25rem;font-size:1.4rem;line-height:1;transition:color .15s}.modal-close-x:hover{color:#fff}.modal-body{color:#bbb;min-height:0;margin-bottom:1.25rem;font-size:.9rem;line-height:1.5;overflow-y:auto}.modal-actions{justify-content:flex-end;gap:.5rem;display:flex}.modal-form{flex-direction:column;gap:.75rem;min-height:220px;display:flex}.modal-form .form-label{color:#aaa;flex-direction:column;gap:.25rem;font-size:.8125rem;display:flex}.modal-form .form-input{width:100%}.day-picker{gap:.25rem;display:flex}.day-picker-btn{color:#888;cursor:pointer;background:0 0;border:2px solid #444;border-radius:6px;padding:.4rem .75rem;font-size:.8125rem;font-weight:500;transition:all .15s}.day-picker-btn:hover{color:#ccc;border-color:#6366f1}.day-picker-active{color:#fff;background:#6366f1;border-color:#6366f1;font-weight:600}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.sortable-th:hover{color:var(--header-hover-text)}.sortable-label{align-items:center;gap:.25rem;display:inline-flex}.sort-indicator{color:var(--sort-indicator);letter-spacing:-.1em;font-size:.625rem}.sortable-th:hover .sort-indicator{color:var(--sort-indicator-hover)}.filter-row{background:var(--filter-row-bg);border-bottom:2px solid #6366f14d}.filter-row th{border-bottom:none;padding:.625rem .75rem;font-weight:400}.filter-input{background:var(--filter-input-bg);border:1px solid var(--filter-input-border);width:100%;color:var(--row-text);box-shadow:inset 0 1px 3px var(--filter-input-shadow);border-radius:4px;outline:none;padding:.3rem .5rem;font-size:.75rem;transition:border-color .15s,box-shadow .15s}.filter-input:focus{box-shadow:inset 0 1px 3px var(--filter-input-shadow), 0 0 0 1px #6366f14d;border-color:#6366f1}.filter-input::placeholder{color:var(--sort-indicator)}.filter-input-active{border-color:#6366f1;box-shadow:0 0 0 1px #6366f14d}.filter-clear-btn{color:#818cf8;cursor:pointer;white-space:nowrap;background:#6366f126;border:1px solid #6366f1;border-radius:4px;padding:.3rem .6rem;font-size:.75rem;font-weight:500;transition:color .15s,background .15s}.filter-clear-btn:hover{color:#fff;background:#6366f14d}[data-theme=light] .filter-input-active{border-color:#6366f1;box-shadow:0 0 0 1px #6366f133}[data-theme=light] .filter-clear-btn{color:#4f46e5;background:#6366f11a}[data-theme=light] .filter-clear-btn:hover{color:#4338ca;background:#6366f133}.table-link{color:#6366f1;font-weight:500;text-decoration:none}.table-link:hover{text-decoration:underline}.text-muted{color:var(--row-text-muted)}.badge{border-radius:9999px;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-active{color:#4ade80;background:#4ade8026}.badge-inactive{color:#f87171;background:#f8717126}.badge-trial{color:#facc15;background:#facc1526}.badge-suspended{color:#f87171;background:#f8717126}.plan-summary{gap:.5rem;margin-bottom:1.25rem;display:flex}.plan-filter-btn{color:#888;cursor:pointer;background:#1a1a2e;border:1px solid #333;border-radius:6px;padding:.375rem .875rem;font-size:.8125rem;transition:background .15s,color .15s}.plan-filter-btn:hover{color:#e0e0e0;background:#2a2a4e}.plan-filter-active{color:#6366f1;background:#6366f126;border-color:#6366f1}.form{flex-direction:column;gap:1rem;max-width:480px;margin-top:1rem;display:flex}.form-label{color:#aaa;flex-direction:column;gap:.375rem;font-size:.875rem;display:flex}.form-input{color:#e0e0e0;background:#111;border:1px solid #333;border-radius:6px;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;transition:border-color .15s}.form-input:focus{border-color:#6366f1}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-input-sm{padding:.25rem .5rem;font-size:.8125rem}.form-textarea{resize:vertical;min-height:80px}.form-actions{align-items:center;gap:.75rem;margin-top:.5rem;display:flex}.inline-form{background:#ffffff05;border:1px solid #1a1a2e;border-radius:8px;flex-flow:wrap;align-items:flex-end;gap:.5rem;max-width:100%;margin-bottom:1rem;padding:1rem}.inline-form .form-input{flex:1;min-width:150px}.section{border-top:1px solid #1a1a2e;margin-top:2rem;padding-top:1.5rem}.studio-picker-btn{background:#111;border:1px solid #333;border-radius:8px;justify-content:space-between;align-items:center;padding:.875rem 1.25rem;text-decoration:none;transition:border-color .15s,background .15s;display:flex}.studio-picker-btn:hover{background:#6366f10f;border-color:#6366f1}.studio-picker-name{color:#e0e0e0;font-size:1rem;font-weight:500}.studio-picker-role{color:#888;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.season-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.season-card{background:#0f0f1a;border:1px solid #1a1a2e;border-radius:8px;padding:1.25rem;transition:border-color .15s}.season-card:hover{border-color:#333}.season-card-archived{opacity:.6}.season-card-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.season-card-name{color:#e0e0e0;font-size:1.0625rem;font-weight:600;text-decoration:none}.season-card-name:hover{color:#6366f1}.season-card-meta{color:#666;justify-content:space-between;margin-bottom:.75rem;font-size:.8125rem;display:flex}.season-card-actions{gap:.5rem;display:flex}.btn-edit-inline{color:#666;cursor:pointer;background:0 0;border:none;margin-left:.375rem;padding:0 .375rem;font-size:.875rem}.btn-edit-inline:hover{color:#6366f1}.studio-switcher{border-top:1px solid #1a1a2e;margin-top:auto;padding:1rem 1.25rem}.studio-switcher-label{color:#666;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.6875rem;font-weight:600}.studio-switcher-btn{text-align:left;color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;width:100%;padding:.375rem .625rem;font-size:.8125rem;transition:color .15s,background .15s;display:block}.studio-switcher-btn:hover:not(:disabled){color:#e0e0e0;background:#ffffff0a}.studio-switcher-active{color:#e0e0e0;cursor:default;background:#6366f11f}.theme-toggle{cursor:pointer;background:0 0;border:1px solid #333;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.125rem;transition:border-color .15s,background .15s;display:flex}.theme-toggle:hover{background:#6366f10f;border-color:#6366f1}[data-theme=light]{--table-bg:#fff;--table-border:#0000001a;--filter-row-bg:#00000005;--filter-input-bg:#fff;--filter-input-border:#0000001f;--filter-input-shadow:#0000000f;--header-bg:#0000000a;--header-border:#0000001f;--header-text:#666;--header-hover-text:#333;--row-border:#0000000f;--row-stripe:#00000005;--row-text:#1a1a1a;--row-text-muted:#888;--clear-btn-border:#00000026;--clear-btn-text:#888;--clear-btn-hover-text:#333;--clear-btn-hover-bg:#0000000d;--sort-indicator:#aaa;--sort-indicator-hover:#666}[data-theme=light] body{color:#1a1a1a;background:#f8f8fa}[data-theme=light] .auth-card{background:#fff;border-color:#ddd;box-shadow:0 4px 24px #00000014}[data-theme=light] .auth-subtitle{color:#666}[data-theme=light] .auth-input{color:#1a1a1a;background:#f9f9f9;border-color:#ccc}[data-theme=light] .auth-input::placeholder{color:#999}[data-theme=light] .auth-sent-text{color:#1a1a1a}[data-theme=light] .auth-link{color:#4f46e5}[data-theme=light] .sidebar{background:#fff;border-right-color:#e0e0e0}[data-theme=light] .nav-separator{background:#00000014}[data-theme=light] .nav-item{color:#666}[data-theme=light] .nav-item:hover{color:#1a1a1a;background:#6366f10f}[data-theme=light] .nav-item.active{color:#1a1a1a;background:#6366f11a}[data-theme=light] .app-header{border-bottom-color:#e0e0e0}[data-theme=light] .app-user-name{color:#1a1a1a}[data-theme=light] .app-user-meta{color:#888}[data-theme=light] .logout-btn{color:#333;background:#f0f0f0;border-color:#ccc}[data-theme=light] .logout-btn:hover{background:#e0e0e0}[data-theme=light] .theme-toggle{border-color:#ccc}[data-theme=light] .theme-toggle:hover{background:#6366f10f;border-color:#6366f1}[data-theme=light] .form-label{color:#555}[data-theme=light] .form-input{color:#1a1a1a;background:#fff;border-color:#ccc}[data-theme=light] .form-input:focus{border-color:#6366f1}[data-theme=light] .btn-secondary{color:#333;background:#f0f0f0;border-color:#ccc}[data-theme=light] .btn-secondary:hover:not(:disabled){background:#e0e0e0}[data-theme=light] .plan-filter-btn{color:#666;background:#f0f0f0;border-color:#ccc}[data-theme=light] .plan-filter-btn:hover{color:#333;background:#e8e8e8}[data-theme=light] .season-card{background:#fff;border-color:#e0e0e0}[data-theme=light] .season-card:hover{border-color:#ccc}[data-theme=light] .season-card-name{color:#1a1a1a}[data-theme=light] .season-card-name:hover{color:#4f46e5}[data-theme=light] .season-card-meta{color:#888}[data-theme=light] .dash-card{background:#fff;box-shadow:0 1px 3px #00000014}[data-theme=light] .dash-card-note{color:#333}[data-theme=light] .dash-card-schedule{color:#666}[data-theme=light] .dash-card-season{color:#999}[data-theme=light] .dash-card-details{color:#777}[data-theme=light] .dash-card-song{color:#666}[data-theme=light] .comment-bubble{background:#00000008}[data-theme=light] .studio-picker-btn{background:#fff;border-color:#ccc}[data-theme=light] .studio-picker-btn:hover{background:#6366f10a;border-color:#6366f1}[data-theme=light] .studio-picker-name{color:#1a1a1a}[data-theme=light] .studio-switcher{border-top-color:#e0e0e0}[data-theme=light] .studio-switcher-btn{color:#666}[data-theme=light] .studio-switcher-btn:hover:not(:disabled){color:#1a1a1a;background:#6366f10f}[data-theme=light] .studio-switcher-active{color:#1a1a1a;background:#6366f11a}[data-theme=light] .modal-overlay{background:#00000059}[data-theme=light] .modal-card{background:#fff;border-color:#e0e0e0;box-shadow:0 8px 32px #00000026}[data-theme=light] .modal-title{color:#1a1a1a}[data-theme=light] .modal-body{color:#555}[data-theme=light] .modal-form .form-label{color:#666}[data-theme=light] .day-picker-btn{color:#666;border-color:#ccc}[data-theme=light] .day-picker-btn:hover{color:#333;border-color:#6366f1}[data-theme=light] .day-picker-active{color:#fff;background:#6366f1;border-color:#6366f1}[data-theme=light] .section{border-top-color:#e0e0e0}[data-theme=light] .inline-form{background:#6366f105;border-color:#e0e0e0}[data-theme=light] .back-link{color:#4f46e5}[data-theme=light] .page-loading{color:#888}[data-theme=light] .btn-edit-inline{color:#999}[data-theme=light] .btn-edit-inline:hover{color:#4f46e5}.filter-bar{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.filter-bar select,.filter-bar input{color:#e0e0e0;background:#111;border:1px solid #ffffff1a;border-radius:6px;padding:.5rem .75rem;font-size:.875rem}[data-theme=light] .filter-bar select,[data-theme=light] .filter-bar input{color:#333;background:#fff;border-color:#ddd}.comment-thread{border:1px solid var(--border);border-radius:8px;margin-top:2rem;padding:1rem}.comment-thread h3{margin-bottom:.75rem}.comment-list{flex-direction:column;gap:.5rem;max-height:400px;margin-bottom:.75rem;display:flex;overflow-y:auto}.comment-bubble{background:#ffffff0a;border-radius:8px;padding:.5rem .75rem}.comment-meta{justify-content:space-between;align-items:center;margin-bottom:.25rem;font-size:.75rem;display:flex}.comment-text{margin:0;font-size:.875rem;line-height:1.4}.comment-input{gap:.5rem;display:flex}.comment-input .form-input{flex:1}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1rem;font-size:.875rem;display:flex}.pagination button{color:#e0e0e0;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;padding:.375rem .75rem}.pagination button:disabled{opacity:.4;cursor:not-allowed}[data-theme=light] .pagination button{color:#333;background:#f5f5f5;border-color:#ddd}.dash-grid{grid-template-columns:repeat(3,minmax(0,320px));gap:1rem;display:grid}.dash-card{border:1px solid var(--border);border-top:3px solid var(--accent);color:inherit;background:#1e1e2e;border-radius:10px;padding:1.25rem 1.5rem;text-decoration:none;transition:border-color .15s;display:block;box-shadow:0 1px 3px #0003}.dash-card:hover{border-color:var(--accent)}.dash-card-name{margin-bottom:.25rem;font-size:1.125rem;font-weight:600}.dash-card-schedule{color:#aaa;margin-bottom:.125rem;font-size:.9375rem;line-height:1.4}.dash-card-season{color:#666;margin-bottom:.25rem;font-size:.8125rem}.dash-card-details{color:#888;margin-bottom:.5rem;font-size:.75rem}.dash-card-status{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.dash-card-note{color:#e0e0e0;font-size:1.125rem}.dash-card-song{color:#aaa;margin-top:.25rem;font-size:.8125rem}.toast-container{z-index:1000;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:1rem;right:1rem}.toast{cursor:pointer;border-radius:8px;max-width:400px;padding:.75rem 1.25rem;font-size:.875rem;animation:.2s ease-out toast-in}.toast-error{color:#fca5a5;background:#7f1d1d;border:1px solid #991b1b;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.toast-close{opacity:.7;font-size:1.2rem;line-height:1}.toast-close:hover{opacity:1}.toast-success{color:#86efac;background:#14532d;border:1px solid #166534}@keyframes toast-in{0%{opacity:0;transform:translate(1rem)}to{opacity:1;transform:translate(0)}}[data-theme=light] .toast-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}[data-theme=light] .toast-success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.upload-progress{width:100%;margin:.5rem 0}.upload-progress-bar{background:var(--border);border-radius:3px;height:5px;overflow:hidden}.upload-progress-fill{background:#6366f1;border-radius:3px;height:100%;transition:width .15s}.upload-progress-fill.error{background:#ef4444}.upload-progress-text{color:var(--text-muted);text-align:center;margin-top:.25rem;font-size:.75rem}.upload-validation-error{color:#ef4444;margin-top:.25rem;font-size:.8rem}.upload-wav-warning{color:#f59e0b;margin-top:.25rem;font-size:.8rem}[data-theme=light] .upload-validation-error{color:#dc2626}[data-theme=light] .upload-wav-warning{color:#d97706}.submit-tabs{background:#ffffff0d;border-radius:8px;gap:.35rem;margin-bottom:1rem;padding:.25rem;display:flex}.submit-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:.5rem .75rem;font-size:.875rem;font-weight:500;transition:color .15s,border-color .15s}.submit-tab:hover{color:var(--text)}.submit-tab-active{color:#fff;background:var(--primary,#6366f1)}[data-theme=light] .submit-tabs{background:#0000000a}[data-theme=light] .submit-tab-active{color:#fff;background:var(--primary,#6366f1)}.url-input-wrap{align-items:center;gap:.5rem;display:flex;position:relative}.url-input-field{text-overflow:ellipsis;flex:1;padding-right:2rem!important}.url-paste-btn{flex-shrink:0;padding:.4rem .75rem;font-size:.8rem}.link-info-card{border:1px solid var(--border);background:#ffffff08;border-radius:10px;margin-top:.75rem;display:flex;overflow:hidden}.link-info-thumb{object-fit:cover;flex-shrink:0;width:72px;height:72px}.link-info-body{flex-direction:column;justify-content:center;min-width:0;padding:.5rem .75rem;display:flex}.link-info-title{text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.link-info-artist{color:#94a3b8;margin-top:2px;font-size:.8rem}.link-info-provider{margin-top:4px;font-size:.75rem;font-weight:700}[data-theme=light] .link-info-card{background:#00000005}.url-input-status{pointer-events:none;align-items:center;display:flex;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.url-spinner{border:2px solid #fff3;border-top-color:#6366f1;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite url-spin}@keyframes url-spin{to{transform:rotate(360deg)}}.url-provider-other{color:#888;letter-spacing:.03em;border:1px solid #555;border-radius:4px;padding:1px 5px;font-size:.6rem;font-weight:700}[data-theme=light] .url-spinner{border-color:#6366f1 #0000001a #0000001a}[data-theme=light] .url-provider-other{color:#999;border-color:#ccc}.dash-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.25rem;display:flex}.dash-card-actions{flex-shrink:0;gap:.25rem;display:flex}.dash-icon-btn{color:#999;cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:8px;justify-content:center;align-items:center;width:36px;min-width:44px;height:36px;min-height:44px;font-size:1.25rem;transition:color .15s,background .15s,border-color .15s;display:flex}.dash-icon-btn:hover{color:#e0e0e0;background:#ffffff0f;border-color:#ffffff40}[data-theme=light] .dash-icon-btn{color:#666;border-color:#00000026}[data-theme=light] .dash-icon-btn:hover{color:#333;background:#0000000a;border-color:#00000040}.app-layout-no-sidebar{flex-direction:column}.app-layout-no-sidebar .app-content{width:100%;max-width:900px;margin:0 auto}.dash-card-row{align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.dash-card-icons{grid-template-columns:1fr 1fr 1fr 1fr;justify-items:center;gap:.25rem;width:100%;margin-top:.75rem;display:grid}.dash-icon-btn-active{background:#6366f114;color:var(--primary,#6366f1)!important;border-color:var(--primary,#6366f1)!important}.dash-icon-btn-info{color:#ca8a04!important;border-color:#ca8a04!important}.dash-icon-btn-info:hover{background:#ca8a041a!important;border-color:#a16207!important}.dash-icon-btn-green{color:#22c55e!important;border-color:#22c55e!important}.dash-icon-btn-green:hover{background:#22c55e1a!important}.dash-icon-btn-yellow{color:#eab308!important;border-color:#eab308!important}.dash-icon-btn-yellow:hover{background:#eab3081a!important}.dash-icon-btn-danger{color:#ef4444!important;border-color:#ef4444!important}.dash-icon-btn-danger:hover{background:#ef44441a!important}.dash-icon-btn-faint{color:#ffffff1a!important;cursor:default!important;border-color:#ffffff0f!important}.dash-icon-btn-faint:hover{background:0 0!important}[data-theme=light] .dash-icon-btn-faint{color:#0000001a!important;border-color:#0000000f!important}.dash-icon-btn-add{color:var(--primary,#6366f1)!important;border-color:var(--primary,#6366f1)!important}.dash-icon-btn-add:hover{background:#6366f11a!important;border-color:#4f46e5!important}.dash-icon-btn-play{color:#22c55e!important;border-color:#22c55e!important}.dash-icon-btn-play:hover{background:#22c55e1a!important;border-color:#16a34a!important}.dash-icon-btn-placeholder{visibility:hidden;pointer-events:none;border-color:#0000!important}.dash-icon-badge{background:var(--primary,#6366f1);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;font-weight:600;line-height:1;display:flex;position:absolute;top:-5px;right:-5px}.dash-icon-btn{position:relative}.subs-modal-body{flex-direction:column;gap:.75rem;display:flex}.subs-modal-item{border-bottom:1px solid var(--border);flex-direction:column;gap:.5rem;padding:.75rem 0;display:flex}.subs-modal-item:last-child{border-bottom:none}.subs-modal-item-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.subs-modal-item-label{font-size:.9rem;font-weight:500}.subs-modal-player{align-items:center;gap:.5rem;display:flex}.subs-modal-player audio{flex:1;height:32px}.inline-player{align-items:center;gap:.35rem;padding:.35rem 0;display:flex}.inline-player-play{color:#e0e0e0;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;transition:border-color .15s;display:flex}.inline-player-play:hover{border-color:#fff6}.inline-player-skip{color:#999;cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;padding-bottom:3px;font-size:1.2rem;transition:color .15s,border-color .15s;display:flex}.inline-player-skip:hover{color:#e0e0e0;border-color:#ffffff40}.inline-player-scrub{cursor:pointer;background:#ffffff1a;border-radius:3px;flex:1;min-width:40px;height:6px;overflow:hidden}.inline-player-scrub-fill{background:var(--primary,#6366f1);border-radius:3px;height:100%;transition:width .1s linear}.inline-player-time{color:#777;white-space:nowrap;flex-shrink:0;font-size:.65rem}[data-theme=light] .inline-player-play{color:#333;border-color:#00000026}[data-theme=light] .inline-player-skip{color:#777;border-color:#0000001a}[data-theme=light] .inline-player-scrub{background:#00000014}.subs-add-btn{border:1px solid var(--primary,#6366f1);color:var(--primary,#6366f1);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-right:.5rem;font-size:1rem;line-height:1;transition:background .15s;display:inline-flex}.subs-add-btn:hover{background:#6366f126}.subs-delete-btn{cursor:pointer;color:#ef4444;opacity:.7;background:0 0;border:none;border-radius:4px;margin-left:auto;padding:.15rem .25rem;font-size:.85rem;transition:opacity .15s}.subs-delete-btn:hover{opacity:1}.subs-modal-link{color:var(--primary,#6366f1);word-break:break-all;font-size:.85rem}.dash-card-notes{border-top:1px solid #ffffff0f;flex-direction:column;gap:.5rem;margin-top:.75rem;padding-top:.75rem;display:flex}[data-theme=light] .dash-card-notes{border-top-color:#0000000f}.dash-comment{font-size:.8125rem;line-height:1.4}.dash-comment-meta{align-items:center;gap:.5rem;margin-bottom:.125rem;font-size:.75rem;display:flex}.dash-comment-delete{color:#888;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0 .25rem;font-size:.875rem}.dash-comment-delete:hover{color:#ef4444}.dash-comment-form{gap:.5rem;margin-top:.25rem;display:flex}.dash-comment-form .form-input{flex:1;padding:.4rem .6rem;font-size:.8125rem}.dash-comment-form .btn{padding:.4rem .75rem;font-size:.8125rem}.notes-modal-body{flex-direction:column;gap:.75rem;display:flex}.notes-modal-list{flex-direction:column;gap:.5rem;max-height:min(320px,50vh);padding-right:.25rem;display:flex;overflow-y:auto}.notes-modal-item{border-bottom:1px solid #ffffff0f;padding:.5rem 0;font-size:.875rem;line-height:1.5}.notes-modal-item:last-child{border-bottom:none}[data-theme=light] .notes-modal-item{border-bottom-color:#0000000f}.notes-modal-meta{align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:.75rem;display:flex}.notes-modal-input{border-top:1px solid #ffffff14;gap:.5rem;padding-top:.75rem;display:flex}[data-theme=light] .notes-modal-input{border-top-color:#00000014}.notes-modal-input .form-input{flex:1}.stream-embed{border-radius:8px;overflow:hidden}.player-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;background:#0f0f1af2;border-top:1px solid #ffffff14;align-items:center;gap:.75rem;height:56px;padding:0 1rem;display:flex;position:sticky;bottom:0;left:0;right:0}[data-theme=light] .player-bar{background:#f5f5f5f2;border-top-color:#e0e0e0}.player-play-btn{color:#e0e0e0;cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.player-play-btn:hover{background:#ffffff14}.player-skip-btn{color:#999;cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.5rem;transition:color .15s,border-color .15s,background .15s;display:flex}.player-skip-btn:hover{color:#e0e0e0;background:#ffffff0f;border-color:#ffffff4d}[data-theme=light] .player-skip-btn{color:#888;border-color:#ccc}[data-theme=light] .player-skip-btn:hover{color:#333;background:#0000000a;border-color:#999}[data-theme=light] .player-play-btn{color:#333;border-color:#ccc}.player-info{flex-shrink:1;min-width:0}.player-title{white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:500;display:block;overflow:hidden}.player-artist{color:#888;font-weight:400}.player-scrub{cursor:pointer;background:#ffffff1a;border-radius:2px;flex:1;min-width:80px;height:4px}.player-scrub-fill{background:var(--primary,#6366f1);border-radius:2px;height:100%;transition:width .1s linear}[data-theme=light] .player-scrub{background:#0000001a}.player-time{color:#888;white-space:nowrap;flex-shrink:0;font-size:.6875rem}.player-dismiss{color:#666;cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.25rem;display:flex}.player-dismiss:hover{color:#e0e0e0}.listen-tab{flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:2rem 0;display:flex}.listen-mic-btn{cursor:pointer;background:0 0;border:2px solid #ffffff1f;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:120px;height:120px;transition:border-color .2s,background .2s;display:flex}.listen-mic-btn:hover{border-color:var(--primary,#6366f1);background:#6366f10f}.listen-mic-recording{border-color:#ef4444;animation:1.5s ease-in-out infinite listen-pulse}@keyframes listen-pulse{0%,to{box-shadow:0 0 #ef44444d}50%{box-shadow:0 0 0 12px #ef444400}}.listen-mic-icon{font-size:2rem}.listen-mic-label{color:#888;font-size:.75rem}.listen-status{flex-direction:column;align-items:center;gap:.75rem;display:flex}.listen-status p{color:#888;font-size:.875rem}.listen-result{text-align:center;flex-direction:column;gap:1rem;width:100%;display:flex}.listen-result-song{align-items:center;gap:.75rem;font-size:1.125rem;display:flex}.listen-result-art{object-fit:cover;border-radius:6px;flex-shrink:0;width:56px;height:56px}.listen-result-links{justify-content:center;gap:.5rem;display:flex}.listen-badge-spotify{text-decoration:none;color:#fff!important;background:#1db954!important}.listen-badge-apple{text-decoration:none;color:#fff!important;background:#fc3c44!important}.listen-result-actions{justify-content:center;gap:.5rem;display:flex}.listen-error{text-align:center;flex-direction:column;align-items:center;gap:1rem;display:flex}[data-theme=light] .listen-mic-btn{border-color:#0000001f}[data-theme=light] .listen-mic-btn:hover{background:#6366f10a}.mobile-nav{display:none}@media (width<=768px){.sidebar{display:none}.app-layout{flex-direction:column}.app-main{padding:1rem 1rem 140px}.dash-grid{grid-template-columns:1fr}.player-bar{height:64px;bottom:56px;left:0}.mobile-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:101;background:#0f0f1af7;border-top:1px solid #ffffff14;justify-content:space-around;align-items:center;height:56px;padding:0 .5rem;display:flex;position:fixed;bottom:0;left:0;right:0}[data-theme=light] .mobile-nav{background:#fafafaf7;border-top-color:#e0e0e0}.mobile-nav-item{color:#777;cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:.125rem;min-width:44px;min-height:44px;padding:.25rem .75rem;font-size:.6875rem;text-decoration:none;display:flex}.mobile-nav-item.active{color:var(--primary,#6366f1)}.mobile-nav-icon{font-size:1.25rem}.mobile-nav-label{font-size:.625rem}[data-theme=light] .mobile-nav-item{color:#999}[data-theme=light] .mobile-nav-item.active{color:var(--primary,#6366f1)}.modal-overlay .modal-content{border-radius:12px 12px 0 0;width:100%;max-width:100%;max-height:100%;margin-top:auto}}
