:root{--table-bg: transparent;--table-border: rgba(255, 255, 255, .08);--filter-row-bg: rgba(255, 255, 255, .03);--filter-input-bg: #080808;--filter-input-border: rgba(255, 255, 255, .06);--filter-input-shadow: rgba(0, 0, 0, .4);--header-bg: rgba(255, 255, 255, .06);--header-border: rgba(255, 255, 255, .1);--header-text: #999;--header-hover-text: #ccc;--row-border: rgba(255, 255, 255, .04);--row-stripe: rgba(255, 255, 255, .02);--row-text: #e0e0e0;--row-text-muted: #777;--clear-btn-border: rgba(255, 255, 255, .12);--clear-btn-text: #888;--clear-btn-hover-text: #fff;--clear-btn-hover-bg: rgba(255, 255, 255, .06);--sort-indicator: #555;--sort-indicator-hover: #888}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0a0a0a;color:#e0e0e0;min-height:100vh}.auth-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{background:#0f0f1a;border:1px solid #1a1a2e;border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:0 4px 24px #0006;text-align:center}.auth-logo{height:48px;margin-bottom:.5rem}.auth-title{font-size:2rem;font-weight:700;margin-bottom:.25rem}.auth-subtitle{color:#888;margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-input{background:#111;border:1px solid #333;border-radius:8px;padding:0 1rem;height:44px;font-size:1rem;color:#e0e0e0;outline:none;transition:border-color .2s}.auth-input:focus{border-color:#6366f1}.auth-input::placeholder{color:#555}.auth-button{background:#6366f1;color:#fff;border:none;border-radius:8px;height:44px;font-size:1rem;font-weight:600;cursor:pointer;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:fadeIn .3s ease}.auth-sent-icon{font-size:2.5rem;color:#4ade80;margin-bottom:.75rem}.auth-sent-text{font-size:1.25rem;font-weight:600;color:#e0e0e0;margin-bottom:.5rem}.auth-sent-hint{color:#888;font-size:.875rem}.auth-link{display:inline-block;margin-top:1rem;color:#6366f1;text-decoration:none;font-weight:500}.auth-link:hover{text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.logout-btn{background:#1a1a2e;color:#e0e0e0;border:1px solid #333;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;cursor:pointer;transition:background .2s}.logout-btn:hover{background:#2a2a4e}.success{color:#4ade80;margin-top:1rem}.error{color:#f87171;margin-top:1rem}.impersonation-banner{background:#b45309;color:#fff;padding:.5rem 1.25rem;display:flex;align-items:center;justify-content:space-between;font-size:.875rem;font-weight:500;z-index:100}.impersonation-exit-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:4px;padding:.25rem .75rem;font-size:.8125rem;font-weight:600;cursor:pointer}.impersonation-exit-btn:hover{background:#ffffff4d}.app-layout{min-height:100vh;display:flex}.sidebar{width:220px;background:#0f0f1a;border-right:1px solid #1a1a2e;display:flex;flex-direction:column;padding:1.25rem 0;flex-shrink:0}.sidebar-logo{font-size:1.25rem;font-weight:700;padding:0 1.25rem;margin-bottom:1.5rem}.sidebar-nav{display:flex;flex-direction:column}.nav-item{display:block;padding:.625rem 1.25rem;color:#888;text-decoration:none;font-size:.9375rem;transition:color .15s,background .15s}.nav-item:hover{color:#e0e0e0;background:#ffffff0a}.nav-item.active{color:#e0e0e0;background:#6366f11f;border-left:3px solid #6366f1}.nav-separator{height:1px;background:#ffffff14;margin:.5rem 1rem}.app-content{flex:1;display:flex;flex-direction:column;min-width:0}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid #1a1a2e}.app-header-info{display:flex;flex-direction:column;gap:.125rem}.app-user-name{font-weight:600;font-size:.875rem}.app-user-meta{color:#666;font-size:.75rem}.app-main{flex:1;padding:1.5rem;overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.page-loading{color:#888;padding:2rem}.back-link{display:inline-block;color:#6366f1;text-decoration:none;font-size:.875rem;margin-bottom:1rem}.back-link:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem 1rem;transition:background .15s;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#6366f1;color:#fff}.btn-primary:hover:not(:disabled){background:#5558e6}.btn-secondary{background:#1a1a2e;color:#e0e0e0;border:1px solid #333}.btn-secondary:hover:not(:disabled){background:#2a2a4e}.btn-danger{background:#dc2626;color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-success{background:#16a34a;color:#fff;border:none}.btn-success:hover:not(:disabled){background:#15803d}.btn-success:disabled{opacity:.5;cursor:not-allowed}.btn-danger-sm,.btn-success-sm{font-size:.75rem;padding:.25rem .625rem;border:none;border-radius:4px;cursor:pointer}.btn-danger-sm{background:#f8717126;color:#f87171}.btn-danger-sm:hover{background:#f8717140}.btn-success-sm{background:#4ade8026;color:#4ade80}.btn-success-sm:hover{background:#4ade8040}.data-table{width:100%;border-collapse:collapse;border:1px solid var(--table-border);border-radius:8px;overflow:hidden}.data-table th{text-align:left;padding:.5rem .75rem;font-size:.7rem;font-weight:600;color:var(--header-text);text-transform:uppercase;letter-spacing:.08em;background:var(--header-bg);border-bottom:1px solid var(--header-border)}.data-table td{padding:.625rem .75rem;font-size:.875rem;color:var(--row-text);border-bottom:1px solid var(--row-border)}.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{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-card{background:#0f0f1a;border:1px solid #1a1a2e;border-radius:12px;padding:1.5rem;width:100%;max-width:440px;box-shadow:0 8px 32px #00000080}.modal-title{margin-bottom:.75rem;font-size:1.1rem}.modal-body{color:#bbb;font-size:.9rem;line-height:1.5;margin-bottom:1.25rem}.modal-actions{display:flex;gap:.5rem;justify-content:flex-end}.modal-form{display:flex;flex-direction:column;gap:.75rem}.modal-form .form-label{display:flex;flex-direction:column;gap:.25rem;font-size:.8125rem;color:#aaa}.modal-form .form-input{width:100%}.day-picker{display:flex;gap:.25rem}.day-picker-btn{padding:.4rem .75rem;border:2px solid #444;border-radius:6px;background:transparent;color:#888;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s}.day-picker-btn:hover{border-color:#6366f1;color:#ccc}.day-picker-active{background:#6366f1;border-color:#6366f1;color:#fff;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{display:inline-flex;align-items:center;gap:.25rem}.sort-indicator{font-size:.625rem;color:var(--sort-indicator);letter-spacing:-.1em}.sortable-th:hover .sort-indicator{color:var(--sort-indicator-hover)}.filter-row{background:var(--filter-row-bg);border-bottom:2px solid rgba(99,102,241,.3)}.filter-row th{padding:.625rem .75rem;border-bottom:none;font-weight:400}.filter-input{width:100%;background:var(--filter-input-bg);border:1px solid var(--filter-input-border);border-radius:4px;padding:.3rem .5rem;font-size:.75rem;color:var(--row-text);outline:none;box-shadow:inset 0 1px 3px var(--filter-input-shadow);transition:border-color .15s,box-shadow .15s}.filter-input:focus{border-color:#6366f1;box-shadow:inset 0 1px 3px var(--filter-input-shadow),0 0 0 1px #6366f14d}.filter-input::placeholder{color:var(--sort-indicator)}.filter-clear-btn{background:none;border:1px solid var(--clear-btn-border);border-radius:4px;color:var(--clear-btn-text);font-size:.6875rem;padding:.25rem .5rem;cursor:pointer;transition:color .15s,background .15s;white-space:nowrap}.filter-clear-btn:hover{color:var(--clear-btn-hover-text);background:var(--clear-btn-hover-bg)}.table-link{color:#6366f1;text-decoration:none;font-weight:500}.table-link:hover{text-decoration:underline}.text-muted{color:var(--row-text-muted)}.badge{display:inline-block;font-size:.75rem;font-weight:500;padding:.125rem .5rem;border-radius:9999px}.badge-active{background:#4ade8026;color:#4ade80}.badge-inactive{background:#f8717126;color:#f87171}.badge-trial{background:#facc1526;color:#facc15}.badge-suspended{background:#f8717126;color:#f87171}.plan-summary{display:flex;gap:.5rem;margin-bottom:1.25rem}.plan-filter-btn{background:#1a1a2e;color:#888;border:1px solid #333;border-radius:6px;padding:.375rem .875rem;font-size:.8125rem;cursor:pointer;transition:background .15s,color .15s}.plan-filter-btn:hover{color:#e0e0e0;background:#2a2a4e}.plan-filter-active{background:#6366f126;color:#6366f1;border-color:#6366f1}.form{max-width:480px;display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.form-label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;color:#aaa}.form-input{background:#111;border:1px solid #333;border-radius:6px;padding:.5rem .75rem;font-size:.875rem;color:#e0e0e0;outline:none;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{min-height:80px;resize:vertical}.form-actions{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.inline-form{max-width:100%;flex-direction:row;flex-wrap:wrap;align-items:flex-end;gap:.5rem;margin-bottom:1rem;padding:1rem;background:#ffffff05;border:1px solid #1a1a2e;border-radius:8px}.inline-form .form-input{flex:1;min-width:150px}.section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #1a1a2e}.studio-picker-btn{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:#111;border:1px solid #333;border-radius:8px;text-decoration:none;transition:border-color .15s,background .15s}.studio-picker-btn:hover{border-color:#6366f1;background:#6366f10f}.studio-picker-name{color:#e0e0e0;font-weight:500;font-size:1rem}.studio-picker-role{color:#888;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.season-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.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{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.season-card-name{font-size:1.0625rem;font-weight:600;color:#e0e0e0;text-decoration:none}.season-card-name:hover{color:#6366f1}.season-card-meta{display:flex;justify-content:space-between;font-size:.8125rem;color:#666;margin-bottom:.75rem}.season-card-actions{display:flex;gap:.5rem}.btn-edit-inline{background:none;border:none;color:#666;font-size:.875rem;cursor:pointer;padding:0 .375rem;margin-left:.375rem}.btn-edit-inline:hover{color:#6366f1}.studio-switcher{margin-top:auto;padding:1rem 1.25rem;border-top:1px solid #1a1a2e}.studio-switcher-label{font-size:.6875rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.studio-switcher-btn{display:block;width:100%;text-align:left;padding:.375rem .625rem;background:none;border:none;border-radius:4px;color:#888;font-size:.8125rem;cursor:pointer;transition:color .15s,background .15s}.studio-switcher-btn:hover:not(:disabled){color:#e0e0e0;background:#ffffff0a}.studio-switcher-active{color:#e0e0e0;background:#6366f11f;cursor:default}.theme-toggle{background:none;border:1px solid #333;border-radius:8px;width:36px;height:36px;font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.theme-toggle:hover{border-color:#6366f1;background:#6366f10f}[data-theme=light]{--table-bg: #fff;--table-border: rgba(0, 0, 0, .1);--filter-row-bg: rgba(0, 0, 0, .02);--filter-input-bg: #fff;--filter-input-border: rgba(0, 0, 0, .12);--filter-input-shadow: rgba(0, 0, 0, .06);--header-bg: rgba(0, 0, 0, .04);--header-border: rgba(0, 0, 0, .12);--header-text: #666;--header-hover-text: #333;--row-border: rgba(0, 0, 0, .06);--row-stripe: rgba(0, 0, 0, .02);--row-text: #1a1a1a;--row-text-muted: #888;--clear-btn-border: rgba(0, 0, 0, .15);--clear-btn-text: #888;--clear-btn-hover-text: #333;--clear-btn-hover-bg: rgba(0, 0, 0, .05);--sort-indicator: #aaa;--sort-indicator-hover: #666}[data-theme=light] body{background:#f8f8fa;color:#1a1a1a}[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{background:#f9f9f9;border-color:#ccc;color:#1a1a1a}[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{background:#f0f0f0;color:#333;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{border-color:#6366f1;background:#6366f10f}[data-theme=light] .form-label{color:#555}[data-theme=light] .form-input{background:#fff;border-color:#ccc;color:#1a1a1a}[data-theme=light] .form-input:focus{border-color:#6366f1}[data-theme=light] .btn-secondary{background:#f0f0f0;color:#333;border-color:#ccc}[data-theme=light] .btn-secondary:hover:not(:disabled){background:#e0e0e0}[data-theme=light] .plan-filter-btn{background:#f0f0f0;color:#666;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-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{border-color:#6366f1;background:#6366f10a}[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{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-bar select,.filter-bar input{background:#111;border:1px solid rgba(255,255,255,.1);color:#e0e0e0;padding:.5rem .75rem;border-radius:6px;font-size:.875rem}[data-theme=light] .filter-bar select,[data-theme=light] .filter-bar input{background:#fff;border-color:#ddd;color:#333}.comment-thread{margin-top:2rem;padding:1rem;border:1px solid var(--border);border-radius:8px}.comment-thread h3{margin-bottom:.75rem}.comment-list{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto;margin-bottom:.75rem}.comment-bubble{padding:.5rem .75rem;background:#ffffff0a;border-radius:8px}.comment-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;margin-bottom:.25rem}.comment-text{font-size:.875rem;line-height:1.4;margin:0}.comment-input{display:flex;gap:.5rem}.comment-input .form-input{flex:1}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem;font-size:.875rem}.pagination button{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#e0e0e0;padding:.375rem .75rem;border-radius:6px;cursor:pointer}.pagination button:disabled{opacity:.4;cursor:not-allowed}[data-theme=light] .pagination button{background:#f5f5f5;border-color:#ddd;color:#333}.dash-grid{display:grid;grid-template-columns:repeat(3,minmax(0,320px));gap:1rem}.dash-card{display:block;padding:1.25rem 1.5rem;background:#1e1e2e;border:1px solid var(--border);border-top:3px solid var(--accent);border-radius:10px;text-decoration:none;color:inherit;transition:border-color .15s;box-shadow:0 1px 3px #0003}.dash-card:hover{border-color:var(--accent)}.dash-card-name{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.dash-card-schedule{font-size:.9375rem;color:#aaa;line-height:1.4;min-height:2.625rem;margin-bottom:.25rem}.dash-card-season{font-size:.8125rem;color:#666;margin-bottom:.75rem}.dash-card-status{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.dash-card-note{font-size:1.125rem;color:#e0e0e0}.dash-card-song{font-size:.8125rem;color:#aaa;margin-top:.25rem}
