@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@300;400;500;600;700;800;900&display=swap";:root{--primary-color: #1E3A8A;--primary-light: #EFF6FF;--primary-glow: rgba(30, 58, 138, .15);--bg-primary: #FFFFFF;--bg-secondary: #F8FAFF;--bg-tertiary: #F1F5F9;--text-primary: #0F172A;--text-secondary: #475569;--text-muted: #94A3B8;--border-color: rgba(0, 0, 0, .05);--border-hover: rgba(30, 58, 138, .1);--gradient-main: linear-gradient(135deg, #FFFFFF 0%, #EFF6FF 50%, #DBEAFE 100%);--gradient-primary: linear-gradient(135deg, #1E3A8A 0%, #172554 100%);--gradient-soft: linear-gradient(135deg, #EFF6FF 0%, #DBEAFE 100%);--shadow-sm: 0 4px 12px rgba(0, 0, 0, .08);--shadow-md: 0 8px 30px rgba(0, 0, 0, .12);--shadow-lg: 0 15px 50px rgba(0, 0, 0, .18);--shadow-purple: 0 10px 30px rgba(30, 58, 138, .2);--danger-color: #EF4444;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 1.75rem;--radius-full: 9999px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .22s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{transition:background-color .3s ease,color .2s ease,border-color .3s ease,box-shadow .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Outfit,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg-tertiary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}html,body,#root{width:100%;overflow-x:hidden}input,button,select,textarea{font-family:inherit;font-size:inherit}@media(max-width:768px){body{background-color:#f1f5f9}.role-selection-container{background:transparent!important}.role-bg{display:block!important}.role-selection-card{background:#ffffffb3!important;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.4)!important;box-shadow:0 25px 50px -12px #00000040!important}}.app-background{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--bg-tertiary);z-index:-2}@media(min-width:769px){.app-background{background-image:radial-gradient(at 0% 0%,rgba(30,58,138,.05) 0%,transparent 50%),radial-gradient(at 100% 0%,rgba(59,130,246,.05) 0%,transparent 50%),radial-gradient(at 100% 100%,rgba(37,99,235,.05) 0%,transparent 50%),radial-gradient(at 0% 100%,rgba(29,78,216,.05) 0%,transparent 50%),radial-gradient(circle,rgba(15,23,42,.04) 1px,transparent 1px);background-size:100% 100%,100% 100%,100% 100%,100% 100%,32px 32px;background-position:0 0,0 0,0 0,0 0,center center}}@media(max-width:768px){.app-background{display:none}}.app-background:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");z-index:-1}.main-content{margin-left:280px;min-height:100vh;padding:0 var(--spacing-2xl) 4rem;transition:all var(--transition-base);position:relative;z-index:1}.container{max-width:1400px;margin:0 auto}h1,h2,h3,h4{font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.card{background:#f8faff;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:0 10px 25px -5px #00000014,0 8px 10px -6px #0000000d,inset 0 1px #fff,inset 0 -1px #00000005;transition:all var(--transition-base)}.card:hover{transform:translateY(-8px);background:#fff;box-shadow:0 40px 60px -15px #0000002e;border-color:#1e3a8a40}.btn{border-radius:var(--radius-full);font-weight:700;padding:.75rem 1.75rem;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;border:none;position:relative;overflow:hidden}.btn-primary{background:var(--text-primary);color:#fff;box-shadow:0 4px 12px #00000026,inset 0 1px #ffffff1a,inset 0 -2px #0003}.btn-primary:hover{background:#0a1120;transform:translateY(-2px);box-shadow:0 8px 20px #0003,inset 0 1px #ffffff1a}.btn-primary:active,.btn-accent:active,.btn-secondary:active{transform:translateY(1px);box-shadow:inset 0 2px 4px #0003}.btn-accent{background:var(--gradient-primary);color:#fff;box-shadow:0 10px 25px -5px #1e3a8a66,inset 0 1px #fff3,inset 0 -2px #0000001a}.btn-accent:hover{transform:translateY(-2px);filter:brightness(1.15);box-shadow:0 15px 30px -5px #1e3a8a80,inset 0 1px #fff3}.btn-secondary{background:#f8faff;color:var(--text-secondary);border:1px solid rgba(0,0,0,.1);box-shadow:0 4px 6px #0000000a,inset 0 1px #fff,inset 0 -1px #0000000d}.btn-secondary:hover{background:#eff6ff;border-color:var(--primary-color);color:var(--primary-color);box-shadow:0 6px 15px #1e3a8a1f,translateY(-1px)}.badge{font-weight:700;border-radius:999px;padding:.25rem .75rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:.25rem}.badge-primary{background:#eff6ff;color:#1e3a8a;border:1px solid rgba(30,58,138,.1)}.badge-success{background:#ecfdf5;color:#10b981;border:1px solid rgba(16,185,129,.1)}.badge-danger{background:#fef2f2;color:#ef4444;border:1px solid rgba(239,68,68,.1)}.page-header{display:flex;justify-content:space-between;align-items:flex-end;margin-top:4rem;margin-bottom:3rem;gap:2rem}.page-header-content{flex:1}.page-title{font-size:2.75rem;font-weight:800;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:-.04em}.page-subtitle{font-size:1.125rem;color:var(--text-secondary);font-weight:500}.filters-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:2.5rem;background:#fff;padding:.6rem;border-radius:20px;border:1px solid rgba(0,0,0,.04);box-shadow:0 10px 25px -5px #0000000d,0 8px 10px -6px #00000005}.search-box{position:relative;flex:1}.search-box-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:#3b82f6;pointer-events:none;z-index:1;stroke-width:2.5px}.search-box .form-input{padding-left:3.5rem!important;width:100%;height:52px!important;background:#f8faff!important;border-radius:14px!important;border:1px solid transparent!important;font-weight:500;color:var(--text-primary);transition:all .2s ease}.search-box .form-input:focus{background:#fff!important;border-color:#3b82f64d!important;box-shadow:0 0 0 4px #3b82f614!important}.filters-bar .form-select{width:auto;min-width:120px;height:52px;background:#fff;border:1.5px solid #1E3A8A;border-radius:14px;color:#1e3a8a;font-weight:800;text-align:center;padding:0 1.5rem;cursor:pointer;transition:all .2s ease;appearance:none;background-image:none!important}.filters-bar .form-select:hover{background:#eff6ff;transform:translateY(-1px)}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:2rem}.page-title{font-size:2rem}.page-subtitle{font-size:1rem}.filters-bar{flex-direction:row;align-items:center;padding:.5rem;gap:.5rem;margin-bottom:1.5rem}.filters-bar .form-select{min-width:90px;padding:0 .75rem;font-size:.85rem}.search-box .form-input{height:48px!important;font-size:.85rem;padding-left:2.75rem!important}.search-box-icon{left:1rem;width:16px;height:16px}.form-input,.form-select,.btn{height:46px;padding:0 1rem;font-size:.9rem}}.drawer-overlay{position:fixed;inset:0;background:#0f172a26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.drawer{position:fixed;top:0;right:0;height:100vh;width:100%;max-width:500px;background:#fff;box-shadow:-10px 0 40px #00000014;z-index:1001;display:flex;flex-direction:column;overflow:hidden}@media(max-width:768px){.drawer{max-width:100%;width:100%;left:0;border-radius:0}.drawer-content{padding:1.25rem!important;overflow-x:hidden}}.drawer-header{padding:2.25rem 2rem 1.25rem;border-bottom:1px solid rgba(0,0,0,.04);display:flex;align-items:center;justify-content:space-between;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:10}.drawer-header h2{font-size:1.35rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.025em}.drawer-content{flex:1;padding:2rem;overflow-y:auto}.drawer-footer{padding:1.5rem 2rem;border-top:1px solid #F1F5F9;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:1rem;position:sticky;bottom:0;z-index:10}.drawer-form{display:flex!important;flex-direction:column!important;gap:1.5rem!important}.drawer-form .form-group{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:.5rem!important;width:100%!important}.drawer-form .form-label{display:block!important;font-size:.825rem!important;font-weight:700!important;color:var(--text-secondary)!important;margin:0 0 .15rem .25rem!important;text-align:left!important}.form-input,.form-select{display:block;width:100%;padding:0 1.25rem;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:14px;font-size:.95rem;font-family:inherit;color:var(--text-primary);transition:all .2s cubic-bezier(.4,0,.2,1);height:52px;outline:none;box-shadow:0 1px 2px #00000005,inset 0 1px 1px #00000008}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:1.2rem;padding-right:3rem;cursor:pointer}.form-input:hover,.form-select:hover{border-color:#1e3a8a33;background:#fff}.form-input:focus,.form-select:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px var(--primary-glow)}.drawer-form textarea{display:block!important;width:100%!important;padding:1.25rem!important;background:#f8faff!important;border:1px solid #E2E8F0!important;border-radius:14px!important;font-size:.95rem!important;font-family:inherit!important;color:var(--text-primary)!important;transition:all .2s ease!important;min-height:120px;outline:none!important}.drawer-form textarea:focus{background:#fff!important;border-color:var(--primary-color)!important;box-shadow:0 0 0 4px var(--primary-glow)!important}.drawer-grid{display:grid!important;grid-template-columns:1fr 1fr!important;gap:1.25rem!important;width:100%!important}.drawer-full{grid-column:span 2!important}.form-section-title{margin-top:2rem!important;margin-bottom:.75rem!important;font-size:.7rem!important;font-weight:800!important;text-transform:uppercase!important;letter-spacing:.1em!important;color:var(--text-muted)!important;display:flex!important;align-items:center!important;gap:.5rem!important;opacity:.8!important}.selection-list{display:flex!important;flex-direction:column!important;gap:.4rem!important;width:100%!important}.tag-input-row{display:flex!important;gap:.6rem!important;align-items:center!important;width:100%!important}.tag-input-row .form-input{flex:1!important}.tag-input-row button{height:52px!important;white-space:nowrap!important}.btn-close-drawer{color:var(--text-muted);padding:.5rem;border-radius:12px;transition:all .2s}.btn-close-drawer:hover{background:#eff6ff;color:var(--primary-color)}.modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease-out}.modal{background:#fff;border-radius:var(--radius-2xl);width:100%;max-width:600px;max-height:calc(100vh - 3rem);display:flex;flex-direction:column;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;animation:modalScaleUp .3s cubic-bezier(.34,1.56,.64,1)}.modal.full-screen{position:fixed!important;inset:0!important;max-width:none!important;max-height:none!important;border-radius:0!important;z-index:2100!important;animation:none!important}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.05);display:flex;align-items:center;justify-content:space-between;background:#fff}.modal.full-screen .modal-header{padding:calc(env(safe-area-inset-top) + 4rem) 1.5rem 1.5rem;background:var(--bg-secondary)}.modal-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin:0}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-close-btn-small{position:absolute;top:calc(env(safe-area-inset-top) + 3.5rem);right:1.5rem;z-index:2200;background:#fff;border:1px solid var(--border-color);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:var(--text-muted);box-shadow:var(--shadow-sm)}.modal-close-btn-small:hover{background:var(--bg-secondary);color:var(--danger-color);transform:rotate(90deg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleUp{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(max-width:768px){.modal-overlay{padding:1.5rem;background:#0f172a80}.modal:not(.full-screen){max-height:80vh;border-radius:var(--radius-2xl);margin:auto;width:100%;transform:translateY(-40px)}}.modal.full-screen .modal-body{padding:2rem;display:flex;flex-direction:column;align-items:center}.modal.full-screen .song-detail-modal{width:100%;max-width:900px;margin:0 auto}.toast-container{position:fixed;bottom:2rem;right:2rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;pointer-events:none}@media(max-width:768px){.toast-container{top:1rem;bottom:auto;left:1rem;right:1rem;align-items:center}.toast{min-width:0;width:100%;max-width:none}}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--card-bg, #1e1e24);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 8px 32px #0006;color:#fff;min-width:300px;max-width:400px;pointer-events:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-success{border-left:4px solid #10b981}.toast-error{border-left:4px solid #ef4444}.toast-info{border-left:4px solid #3b82f6}.toast-icon{display:flex;align-items:center;justify-content:center}.toast-success .toast-icon{color:#10b981}.toast-error .toast-icon{color:#ef4444}.toast-info .toast-icon{color:#3b82f6}.toast-message{flex:1;font-size:.9375rem;font-weight:500}.toast-close{background:transparent;border:none;color:#ffffff80;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.toast-close:hover{background:#ffffff1a;color:#fff}.animate-slide-in{animation:slideIn .3s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.home-page{display:flex;flex-direction:column;gap:2.5rem;padding-bottom:4rem}.home-header-image-container{position:relative;width:calc(100% + var(--spacing-2xl) * 2);margin-left:calc(var(--spacing-2xl) * -1);margin-right:calc(var(--spacing-2xl) * -1);margin-top:0;height:400px;overflow:visible;margin-bottom:2rem}.home-header-image{width:100%;height:100%;object-fit:cover;object-position:center 30%}.home-header-overlay{position:absolute;bottom:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#fff0,#ffffff1a 40%,#ffffffe6 85%,#fff);pointer-events:none}.edit-header-image-btn{position:absolute;top:1.5rem;right:1.5rem;width:36px;height:36px;border-radius:50%;background:#fff3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:10}.leader-photo-wrapper{position:absolute;left:3rem;bottom:-1.5rem;display:flex;align-items:flex-end;gap:.6rem;z-index:20}.leader-photo{width:90px;height:90px;border-radius:24px;background:#fff;padding:4px;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--primary-color);overflow:hidden;box-shadow:0 10px 25px #0000001a}.leader-photo-editable{cursor:pointer}.leader-photo-editable:focus{outline:2px solid rgba(255,255,255,.7);outline-offset:2px}.leader-photo img{width:100%;height:100%;object-fit:cover}.leader-photo-edit{width:30px;height:30px;border-radius:10px;border:1px solid rgba(255,255,255,.4);background:#0f172aa6;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,background .2s ease}.leader-photo-edit:hover{background:#0f172acc;transform:translateY(-1px)}.edit-header-image-btn:hover{background:#ffffff59;transform:scale(1.1);box-shadow:0 4px 12px #00000026}.edit-header-image-btn:active{transform:scale(.95)}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.mobile-header-logout{position:absolute;right:1.5rem;bottom:-1rem;z-index:30}.home-hero{padding:1rem 1.5rem 2.5rem;position:relative;z-index:1}@media(max-width:1024px){.home-header-image-container{width:calc(100% + 2rem);margin-left:-1rem;margin-right:-1rem;margin-top:0;height:250px;margin-bottom:3.5rem}.leader-photo-wrapper{left:2rem;bottom:-2rem}.leader-photo{width:80px;height:80px}}.home-hero-title{font-size:3rem;font-weight:800;margin-bottom:.75rem;color:var(--text-primary)}.home-hero-title span{color:var(--primary-color)}.home-hero-subtitle{font-size:1.15rem;color:var(--text-secondary);max-width:600px;font-weight:500}.quick-start-section{margin-bottom:3rem;padding:0 1.5rem}.quick-start-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin-bottom:1.5rem;letter-spacing:-.02em}.quick-start-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.quick-start-card{background:#fff;padding:1.25rem;border-radius:1.5rem;display:flex;align-items:center;gap:1rem;text-decoration:none;color:var(--text-primary);font-weight:700;border:1px solid rgba(15,23,42,.04);box-shadow:0 12px 28px #0000001f,0 4px 10px #0000000f,inset 0 1px #fff;transition:all .25s cubic-bezier(.4,0,.2,1)}.quick-start-card:hover{transform:translateY(-8px);border-color:var(--primary-color);box-shadow:0 20px 40px #1e3a8a26,0 0 0 1px #1e3a8a0d}.quick-start-card:active{transform:translateY(-2px) scale(.98);box-shadow:0 5px 15px #1e3a8a33;transition:all .1s ease}.quick-start-card:hover .quick-icon-box{transform:scale(1.1) rotate(5deg);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.quick-icon-box{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-icon-box.repertoires{background:#eff6ff;color:#1e3a8a}.quick-icon-box.songs{background:#ecfdf5;color:#10b981}.quick-icon-box.pads{background:#eff6ff;color:#3b82f6}.quick-icon-box.dashboard{background:#f8fafc;color:var(--primary-color)}.quick-start-card span{flex:1;font-size:1rem}.quick-start-card svg:last-child{color:#cbd5e1}.quick-start-card:hover svg:last-child{color:var(--primary-color);transform:translate(3px);transition:all .2s}.home-section-title{font-size:1.4rem;font-weight:800;margin-bottom:1.75rem}.home-info-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;padding:0 1.5rem}.recent-repertoires-card,.active-team-card{background:#fff;padding:1.25rem!important}.repertoire-list{display:flex;flex-direction:column;gap:.5rem}.repertoire-item{padding:.5rem .75rem;background:#f8faff;border:1px solid rgba(0,0,0,.02);border-radius:1rem;display:flex;align-items:center;gap:.75rem;transition:all var(--transition-base)}.repertoire-item:hover{background:#fff;transform:translate(12px);box-shadow:0 15px 35px #00000047;border-color:var(--primary-color)}.repertoire-date-box{width:42px;height:42px;background:#fff;border:1px solid #E2E8F0;border-radius:.65rem;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:800}@media(max-width:1200px){.home-info-grid{grid-template-columns:1fr}}@media(max-width:768px){.home-hero-title{font-size:2.25rem}}.dashboard-page{padding:2rem;max-width:1200px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem}.dashboard-title{font-size:2.2rem;font-weight:800;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:-.02em}.dashboard-subtitle{color:var(--text-secondary);font-size:1.1rem}.last-sync{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;background:#f1f5f9;padding:.5rem 1rem;border-radius:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;padding:1.5rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:1.25rem;border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.stat-card.interactive{cursor:pointer}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.stat-card.primary:hover{filter:brightness(1.1)}.stat-card.primary{background:var(--gradient-primary);color:#fff;border:none}.stat-card.primary .stat-label{color:#fffc}.stat-card.primary .stat-value{color:#fff}.stat-icon-wrapper{width:56px;height:56px;border-radius:16px;background:var(--primary-light);color:var(--primary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card.primary .stat-icon-wrapper{background:#fff3;color:#fff}.stat-icon-wrapper.songs{background:#ecfdf5;color:#10b981}.stat-icon-wrapper.people{background:#eff6ff;color:#3b82f6}.stat-icon-wrapper.genre{background:#fff7ed;color:#f59e0b}.stat-details{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:.85rem;font-weight:700;color:var(--text-secondary);margin-top:.35rem;text-transform:uppercase;letter-spacing:.02em}.dashboard-main-content{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem}.dashboard-section{background:#fff;padding:2rem;border-radius:var(--radius-xl);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;color:var(--text-primary)}.section-header h3{font-size:1.2rem;font-weight:800}.usage-list{display:flex;flex-direction:column;gap:1.5rem}.usage-item{display:flex;flex-direction:column;gap:.75rem}.usage-info{display:flex;justify-content:space-between;align-items:flex-end}.usage-title{font-weight:700;color:var(--text-primary);font-size:1rem}.usage-artist{font-size:.8rem;color:var(--text-muted)}.usage-bar-container{height:32px;background:#f1f5f9;border-radius:8px;position:relative;overflow:hidden;display:flex;align-items:center;padding:0 1rem}.usage-bar-fill{position:absolute;left:0;top:0;bottom:0;background:var(--primary-color);background:linear-gradient(90deg,var(--primary-color),var(--accent-color));border-radius:8px;opacity:.15;transition:width 1s ease-out}.usage-count{position:relative;font-size:.85rem;font-weight:800;color:var(--primary-color)}.members-activity-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.member-activity-card{display:flex;align-items:center;gap:1rem;background:#f8fafc;padding:1rem;border-radius:16px;transition:background .2s}.member-activity-card:hover{background:#f1f5f9}.member-avatar{position:relative;width:48px;height:48px;flex-shrink:0}.member-avatar img,.avatar-placeholder{width:100%;height:100%;border-radius:12px;object-fit:cover}.avatar-placeholder{background:var(--primary-light);color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-weight:800}.activity-badge{position:absolute;top:-6px;right:-6px;background:var(--accent-color);color:#fff;font-size:.7rem;font-weight:800;padding:2px 6px;border-radius:10px;border:2px solid white}.member-meta{display:flex;flex-direction:column}.member-name{font-weight:700;color:var(--text-primary);font-size:.85rem}.member-role{font-size:.7rem;color:var(--text-muted)}.empty-state{text-align:center;padding:2rem;color:var(--text-muted);font-style:italic}.detail-list{display:flex;flex-direction:column;gap:.75rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8fafc;border-radius:12px;border:1px solid #f1f5f9}.detail-info{display:flex;flex-direction:column}.detail-primary{font-weight:700;color:var(--text-primary);font-size:.95rem}.detail-secondary{font-size:.75rem;color:var(--text-muted)}.detail-value-badge{padding:.35rem .75rem;background:var(--primary-light);color:var(--primary-color);border-radius:20px;font-size:.8rem;font-weight:800}.detail-value-badge.secondary{background:#ecfdf5;color:#10b981}.team-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem}.team-section h4{font-size:.85rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-bottom:1rem;border-bottom:2px solid #f1f5f9;padding-bottom:.5rem}.team-list{display:flex;flex-direction:column;gap:.5rem}.team-item{display:flex;flex-direction:column;padding:.75rem;background:#fff;border:1px solid #f1f5f9;border-radius:10px}.team-name{font-weight:700;color:var(--text-primary);font-size:.9rem}.team-role{font-size:.7rem;color:var(--primary-color);font-weight:600}@media(max-width:1024px){.dashboard-main-content{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-page{padding:1rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-title{font-size:1.8rem}.members-activity-grid{grid-template-columns:1fr}}.musicians-page{display:flex;flex-direction:column}.musicians-list-container{display:grid!important;grid-template-columns:repeat(auto-fill,140px)!important;gap:1.5rem!important;padding:1.5rem!important}.musician-card{width:140px!important;height:140px!important;background:#fff!important;border:1px solid rgba(0,0,0,.08)!important;transition:all .3s ease!important;cursor:pointer!important;overflow:hidden;padding:0;border-radius:20px!important;box-shadow:0 4px 10px #0000000d!important}.musician-card.expanded{width:100%!important;height:auto!important;grid-column:1 / -1!important;border-color:#000!important}.musician-card:not(.expanded) .member-mini-actions,.musician-card:not(.expanded) .musician-meta-premium,.musician-card:not(.expanded) .musician-expand-icon{display:none!important}.musician-card-header-premium{position:relative;height:100%;display:flex;flex-direction:column}.musician-card.expanded .musician-card-header-premium{height:110px}.musician-expand-icon{position:absolute;bottom:.75rem;right:.75rem;opacity:.4;transition:all .2s ease}.musician-card:hover .musician-expand-icon{opacity:1;transform:translateY(-2px)}.musician-card:not(.expanded) .musician-card-background{display:none!important}.musician-card-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:0}.musician-bg-img{width:100%;height:100%;object-fit:cover;filter:blur(15px) brightness(.8);transform:scale(1.1)}.musician-bg-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent 0%,rgba(248,250,255,.95) 100%)}.musician-card-profile-section{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:.75rem .4rem;gap:.4rem;height:100%}.musician-card.expanded .musician-card-profile-section{flex-direction:row;align-items:flex-end;justify-content:flex-start;text-align:left;padding:1rem 1.5rem}.avatar-premium{width:50px;height:50px;border-radius:14px;background:#fff;padding:2px;border:1px solid rgba(0,0,0,.08);box-shadow:0 4px 10px #00000014;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;font-weight:800;color:#000;transition:all .3s ease}.musician-card.expanded .avatar-premium{width:50px;height:50px;border-radius:12px}.musician-info-premium{flex:1;width:100%}.name-with-actions-row{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%}.musician-card.expanded .name-with-actions-row{flex-direction:row;align-items:center}.mini-action-btn{width:22px;height:22px;border-radius:5px;border:1px solid rgba(0,0,0,.05);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.mini-action-btn.edit:hover{color:#000;background:#f4f4f5;border-color:#000}.musician-meta-premium{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.5rem}.musician-card.expanded .musician-meta-premium{flex-direction:row;margin-top:.25rem}.badge-premium.active{background:#000;color:#fff}.musician-name-premium{font-size:.95rem;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.musician-instrument-label{font-size:.75rem;color:var(--text-secondary);font-weight:600;display:flex;align-items:center;justify-content:center;gap:.25rem}.photo-preview-premium{width:90px;height:90px;border-radius:24px;background:#f8faff;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#000;position:relative;overflow:visible}.avatar-editable:hover:after{content:"📷";position:absolute;bottom:-4px;right:-4px;font-size:10px;background:#000;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 6px #0003}@media(max-width:768px){.musician-card-header-premium{height:110px}.avatar-premium{width:54px;height:54px;border-radius:14px}.avatar-premium img{border-radius:12px}.musician-name-premium{font-size:1.1rem}.musician-card-profile-section{padding:1rem;gap:.75rem}}.musician-expanded-content{background:#f8faff;border-top:1px solid var(--border-color)}.musician-expanded-inner{padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1.75rem}.musician-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.item-card-actions{display:flex;flex-wrap:wrap;gap:.75rem;border-top:1px solid rgba(0,0,0,.05);padding-top:1.25rem}.avatar{width:60px;height:60px;border-radius:20px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--primary-color);font-size:1.25rem}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:20px}.photo-edit-badge{position:absolute;bottom:0;right:0;background:#000;color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 8px #00000026;z-index:2}.photo-preview{position:relative;width:64px;height:64px;border-radius:18px;background:var(--bg-secondary);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:800;color:#000;flex-shrink:0}@media(max-width:768px){.musician-card-header{padding:.75rem 1rem;gap:.75rem}.avatar.compact{width:34px;height:34px;border-radius:8px;font-size:.8rem}.musician-name{font-size:1rem}.musician-expanded-inner{padding:1rem 1.25rem;gap:1.25rem}.musician-details-grid{grid-template-columns:1fr;gap:1rem}.photo-preview{width:52px;height:52px;border-radius:14px}.photo-edit-badge{width:22px;height:22px}.item-card-actions{padding-top:1rem;gap:.5rem}.item-card-actions .btn{padding:.5rem 1rem;font-size:.8rem}}.drawer-form .form-input:focus,.drawer-form .form-select:focus,.drawer-form textarea:focus{border-color:#000!important;box-shadow:0 0 0 4px #0000000d!important}.drawer-header h2{color:#000}.drawer-footer .btn-accent{background:#000!important;color:#fff!important;box-shadow:0 4px 12px #00000026!important}.drawer-footer .btn-accent:hover{background:#27272a!important;transform:translateY(-2px);box-shadow:0 8px 20px #0003!important}.drawer-footer .btn-secondary{color:#666;border-color:#0000001a}.drawer-footer .btn-secondary:hover{background:#f4f4f5;color:#000;border-color:#0003!important}.photo-edit-badge{background:#000!important}.form-checkbox input:checked{background-color:#000!important;border-color:#000!important;accent-color:#000000}.voices-page{display:flex;flex-direction:column}.voices-list-container{display:grid!important;grid-template-columns:repeat(auto-fill,140px)!important;gap:1.5rem!important;padding:1.5rem!important}.voice-card{width:140px!important;height:140px!important;background:#fff!important;border:1px solid rgba(0,0,0,.08)!important;transition:all .3s ease!important;cursor:pointer!important;overflow:hidden;padding:0;border-radius:20px!important;box-shadow:0 4px 10px #0000000d!important}.voice-card.expanded{width:100%!important;height:auto!important;grid-column:1 / -1!important;border-color:#000!important}.voice-card:not(.expanded) .member-mini-actions,.voice-card:not(.expanded) .voice-meta-premium,.voice-card:not(.expanded) .voice-expand-icon{display:none!important}.voice-card-header-premium{position:relative;height:100%;display:flex;flex-direction:column}.voice-card.expanded .voice-card-header-premium{height:110px}.voice-card:not(.expanded) .voice-card-background{display:none!important}.voice-card-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:0}.voice-bg-img{width:100%;height:100%;object-fit:cover;filter:blur(15px) brightness(.8);transform:scale(1.1)}.voice-bg-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent 0%,rgba(248,250,255,.95) 100%)}.voice-card-profile-section{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:.75rem .4rem;gap:.4rem;height:100%}.voice-card.expanded .voice-card-profile-section{flex-direction:row;align-items:flex-end;justify-content:flex-start;text-align:left;padding:1rem 1.5rem}.avatar-premium{width:70px;height:70px;border-radius:20px;background:#fff;padding:3px;border:1px solid rgba(0,0,0,.08);box-shadow:0 8px 20px #0000001a;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;font-weight:800}.avatar-premium img{width:100%;height:100%;object-fit:cover;border-radius:17px}.voice-info-premium{flex:1;padding-bottom:5px}.name-with-actions-row{display:flex;align-items:center;gap:.75rem}.member-mini-actions{display:flex;gap:.35rem}.mini-action-btn{width:26px;height:26px;border-radius:6px;border:1px solid rgba(0,0,0,.05);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.mini-action-btn:hover{transform:scale(1.1)}.mini-action-btn.edit:hover{color:var(--primary-color);background:var(--primary-light);border-color:var(--primary-color)}.mini-action-btn.delete:hover{color:#ef4444;background:#fef2f2;border-color:#ef4444}.voice-meta-premium{display:flex;align-items:center;gap:.75rem;margin-top:.25rem}.badge-premium{font-size:.7rem;font-weight:800;padding:.2rem .6rem;border-radius:8px;text-transform:uppercase;letter-spacing:.05em}.badge-premium.active{background:#ecfdf5;color:#10b981}.badge-premium.inactive{background:#fef2f2;color:#ef4444}.voice-type-label{font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.35rem}.voice-expand-icon{color:var(--text-muted);padding-bottom:1rem}.photo-input-premium-row{display:flex;align-items:center;gap:1.5rem;background:#fff;padding:1rem;border-radius:1.25rem;border:1px solid var(--border-color)}.photo-preview-premium{width:90px;height:90px;border-radius:24px;background:#f8faff;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--primary-color);position:relative;overflow:visible}.photo-preview-premium img{width:100%;height:100%;object-fit:cover;border-radius:22px}.avatar-editable{cursor:pointer;position:relative;transition:all .2s ease}.avatar-editable:hover{transform:scale(1.05);box-shadow:0 4px 12px #1e3a8a33}.avatar-editable:hover:after{content:"📷";position:absolute;bottom:-4px;right:-4px;font-size:10px;background:var(--primary-color);border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 6px #0003}@media(max-width:768px){.voice-card-header-premium{height:110px}.avatar-premium{width:54px;height:54px;border-radius:14px}.avatar-premium img{border-radius:12px}.voice-name-premium{font-size:1.1rem}.voice-card-profile-section{padding:1rem;gap:.75rem}}.voice-expanded-content{background:#f8faff;border-top:1px solid var(--border-color)}.voice-expanded-inner{padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1.75rem}.voice-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.4rem}.detail-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:800}.detail-value{font-size:.95rem;color:var(--text-primary);font-weight:700}.item-card-actions{display:flex;gap:.75rem;border-top:1px solid rgba(0,0,0,.05);padding-top:1.25rem}.photo-input-row{display:flex;align-items:center;gap:1rem}.photo-preview{width:64px;height:64px;border-radius:18px;background:var(--bg-secondary);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:800;overflow:hidden;flex-shrink:0}.photo-preview img{width:100%;height:100%;object-fit:cover}.photo-input-actions{display:flex;flex-direction:column;gap:.35rem;width:100%}.photo-file-input{padding:.6rem 1rem;height:auto}.photo-hint{font-size:.75rem;color:var(--text-muted)}.songs-page{display:flex;flex-direction:column}.songs-list-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem;padding:.5rem}.song-card{background:#fff;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;overflow:hidden;padding:0;width:100%;border-radius:16px;border:1px solid rgba(0,0,0,.06);box-shadow:0 2px 8px #00000008;height:100%;display:flex;flex-direction:column}.song-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #00000014;border-color:#0000001a}.song-card.expanded{grid-column:1 / -1;box-shadow:0 10px 30px #0000001f;border-color:#000}.song-card-header{display:flex;align-items:center;padding:1.15rem;gap:.85rem;flex:1;min-height:80px}.song-icon{width:44px;height:44px;border-radius:12px;background:#f8faff;display:flex;align-items:center;justify-content:center;color:var(--primary-color);flex-shrink:0}.song-info-compact{flex:1;display:flex;flex-direction:column;justify-content:center}.song-title{font-size:.85rem;font-weight:800;color:#000;margin:0;line-height:1.3;text-transform:uppercase;letter-spacing:.01em}.song-artist{font-size:.7rem;color:var(--text-muted);font-weight:500;margin:0;margin-top:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-header-meta{display:flex;align-items:center;gap:.65rem;flex-shrink:0}.song-header-meta .badge{font-size:.65rem;padding:.25rem .6rem;letter-spacing:.04em;font-weight:800;border-radius:8px}.song-expanded-content{background:#f8faff;border-top:1px solid var(--border-color)}.song-expanded-inner{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.song-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem}.song-detail-item{display:flex;flex-direction:column;gap:.25rem}.song-detail-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:800}.song-detail-value{font-size:.9rem;color:var(--text-primary);font-weight:700}.song-tags{display:flex;flex-wrap:wrap;gap:.5rem}.item-card-actions{display:flex;flex-wrap:wrap;gap:.75rem;border-top:1px solid rgba(0,0,0,.05);padding-top:1.25rem;margin-top:.5rem}.text-muted{color:var(--text-muted);transition:transform .2s}.song-card.expanded .text-muted{color:var(--primary-color)}.song-lyrics{background:#f8faff;padding:2rem;border-radius:1.25rem;font-family:SF Mono,Fira Code,monospace;font-size:1rem;line-height:1.8;white-space:pre-wrap;color:var(--text-primary);border:1px solid var(--border-color)}@media(max-width:640px){.song-details-grid{grid-template-columns:1fr 1fr}}.song-detail-section h4{font-size:.8rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:.75rem;font-weight:800;letter-spacing:.05em}@media(max-width:768px){.song-detail-modal{grid-template-columns:1fr;gap:1.5rem}.song-card-header{padding:.75rem 1rem;gap:.75rem}.song-icon{width:36px;height:36px;border-radius:10px}.song-icon svg{width:16px;height:16px}.song-title{font-size:.88rem}.song-artist{font-size:.7rem}.song-header-meta .badge{font-size:.55rem;padding:.18rem .45rem;letter-spacing:.03em}.song-expanded-inner{padding:1rem;gap:1rem}.song-details-grid{gap:1rem;grid-template-columns:1fr 1fr}.item-card-actions{padding-top:1rem;gap:.5rem}.item-card-actions .btn{padding:.5rem 1rem;font-size:.8rem}.song-lyrics{padding:.85rem;font-size:.7rem;line-height:1.5}.modal.full-screen .song-lyrics{padding:1rem;font-size:.75rem;line-height:1.55}.modal.full-screen .lyrics-header{padding-top:4.5rem;margin-bottom:1.25rem}.transpose-btn{width:24px;height:24px;font-size:.9rem}.transpose-value{min-width:20px;font-size:.8rem}.lyrics-header h4{font-size:.75rem}}.custom-datepicker{position:relative;width:100%}.datepicker-input-wrapper{position:relative;cursor:pointer}.datepicker-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color .3s ease}.datepicker-input{padding-left:40px!important;cursor:pointer;caret-color:transparent}.datepicker-input-wrapper:hover .datepicker-icon{color:var(--primary-color)}.calendar-popup{position:absolute;top:calc(100% + 8px);left:0;width:310px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026;z-index:1000;overflow:hidden;border:1px solid rgba(0,0,0,.05);padding:1rem}[data-theme=dark] .calendar-popup{background:#1a1a1a;border-color:#ffffff1a;box-shadow:0 10px 40px #0006}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:0 .5rem}.current-month{font-weight:700;color:var(--text-primary);font-size:1rem;text-transform:capitalize}.nav-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:5px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.nav-btn:hover{background:#0000000d;color:var(--primary-color)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.5rem}.weekday{text-align:center;font-size:.75rem;font-weight:600;color:var(--text-muted);padding:5px 0}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;font-size:.875rem;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);color:var(--text-primary)}.calendar-day:hover:not(.empty):not(.selected){background:#1e3a8a14;transform:scale(1.1)}.calendar-day.today{color:var(--primary-color);font-weight:800;position:relative}.calendar-day.today:after{content:"";position:absolute;bottom:6px;width:4px;height:4px;background:var(--primary-color);border-radius:50%}.calendar-day.selected{background:var(--primary-color);color:#fff!important;font-weight:600;box-shadow:0 4px 12px #1e3a8a4d}.calendar-day.empty{cursor:default}.calendar-footer{display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.05)}.footer-btn{background:none;border:none;font-size:.85rem;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:8px;transition:all .2s ease}.today-btn{color:var(--primary-color)}.today-btn:hover{background:#1e3a8a14}.close-btn{color:var(--text-muted)}.close-btn:hover{background:#0000000d}@media(max-width:480px){.calendar-popup{width:calc(100vw - 40px);max-width:340px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)!important}}.key-picker-container{position:relative;height:96px;width:60px;background:#f1f5f9;border-radius:12px;overflow:hidden;-webkit-user-select:none;user-select:none;border:1px solid #E2E8F0;margin-left:auto}.key-picker-wheel{height:100%;overflow-y:scroll;scroll-snap-type:y mandatory;scrollbar-width:none;-ms-overflow-style:none;display:flex;flex-direction:column}.key-picker-wheel::-webkit-scrollbar{display:none}.key-picker-padding{height:32px;flex-shrink:0}.key-picker-item{height:32px;min-height:32px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--text-muted);scroll-snap-align:center;cursor:pointer;transition:all .2s}.key-picker-item.active{color:var(--primary-color);font-size:1rem;transform:scale(1.1)}.key-picker-highlight{position:absolute;top:50%;left:0;right:0;height:32px;transform:translateY(-50%);background:#1e3a8a14;pointer-events:none;border-top:1px solid rgba(30,58,138,.1);border-bottom:1px solid rgba(30,58,138,.1)}.key-picker-container:before,.key-picker-container:after{content:"";position:absolute;left:0;right:0;height:32px;z-index:1;pointer-events:none}.key-picker-container:before{top:0;background:linear-gradient(to bottom,#F1F5F9,transparent)}.key-picker-container:after{bottom:0;background:linear-gradient(to top,#F1F5F9,transparent)}.live-session-page{position:fixed;top:0;left:0;width:100%;height:100%;background:#fff;z-index:5000;display:flex;flex-direction:column;padding:env(safe-area-inset-top) 1.5rem 2rem;overflow-y:auto;animation:slideUp .4s cubic-bezier(.165,.84,.44,1)}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.live-session-page:before{content:"";position:fixed;top:0;left:50%;transform:translate(-50%);width:40px;height:4px;background:#e2e8f0;border-radius:2px;margin-top:8px;opacity:.6}.live-session-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1.5rem;color:var(--text-secondary)}.live-pulse-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;align-items:center;justify-content:center;color:#fff;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #1e3a8a4d}50%{box-shadow:0 0 0 20px #1e3a8a00}}.loading-code-show{margin-top:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-code-show .code-label{font-size:.75rem;letter-spacing:.1em;opacity:.6;font-weight:800}.loading-code-show .code-value{font-size:2.2rem;font-weight:900;color:var(--primary-color);letter-spacing:.15em;font-family:SF Mono,monospace;text-shadow:0 4px 12px rgba(30,58,138,.15)}.live-waiting-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 0}.live-waiting-splash{width:100%;max-width:600px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:3rem 1.5rem;margin:auto;transform:translate(18px)}.live-pulse-icon.large{width:96px;height:96px;margin-bottom:2rem}.live-waiting-title{font-size:1.75rem;font-weight:900;margin-bottom:.6rem;color:var(--text-primary);letter-spacing:-.02em}.live-waiting-subtitle{font-size:.95rem;color:var(--text-muted);margin-bottom:2.5rem;max-width:300px;line-height:1.5;font-weight:500}.live-waiting-code-card{background:linear-gradient(135deg,#0f172a,#1e40af);width:100%;border-radius:2rem;padding:2.5rem 1rem;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);margin-bottom:2rem;box-shadow:0 20px 45px #1e3a8a40;position:relative}.live-waiting-code-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 25px 55px #1e3a8a59}.card-label{font-size:.75rem;font-weight:800;letter-spacing:.2em;opacity:.5;margin-bottom:1.5rem;display:block;text-transform:uppercase}.card-code{display:flex;justify-content:center;gap:.6rem;margin-bottom:1.5rem}.card-char{width:46px;height:56px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:900;font-family:SF Mono,Fira Code,monospace;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card-copy-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.8rem;font-weight:700;background:#ffffff26;padding:.4rem 1rem;border-radius:20px;width:fit-content;margin:0 auto}.live-waiting-stats{display:flex;justify-content:center;gap:2rem}.stat-item{display:flex;align-items:center;gap:.6rem;color:var(--primary-color);font-weight:800;font-size:.9rem;background:#f0f7ff;padding:.6rem 1.25rem;border-radius:15px}.members-mini-list{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin:1.5rem 0 2.5rem;max-width:400px;width:100%}.member-mini-item{display:flex;align-items:center;gap:.5rem;background:#f8fafc;padding:.4rem .75rem;border-radius:10px;border:1px solid rgba(0,0,0,.04)}.member-avatar-small{width:20px;height:20px;border-radius:6px;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800}.member-name-small{font-size:.75rem;font-weight:700;color:var(--text-primary)}.member-role-badge{font-size:.6rem;font-weight:800;text-transform:uppercase;padding:.15rem .35rem;border-radius:4px}.member-role-badge.host{background:#eff6ff;color:var(--primary-color)}.member-role-badge.controller{background:#fdf2f8;color:#db2777}.member-role-badge.musician{background:#f1f5f9;color:#475569}.minimal-code-ref{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background:#f1f5f9;border-radius:10px;color:var(--text-muted);font-size:.7rem;font-weight:700;cursor:pointer;transition:all .2s;opacity:.8}.minimal-code-ref:hover{opacity:1;background:#e2e8f0}.minimal-code-ref .ref-value{color:var(--primary-color);font-family:SF Mono,monospace;font-weight:800}.live-top-bar{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0;margin-bottom:2rem;position:sticky;top:0;background:transparent;z-index:10}.live-status-badge{display:flex;align-items:center;gap:.6rem;padding:.6rem 1.25rem;background:#f8faff;border:1px solid rgba(0,0,0,.04);border-radius:999px;font-size:.8rem;font-weight:800;color:var(--primary-color);text-transform:uppercase;letter-spacing:.06em}.live-top-actions{display:flex;gap:.75rem}.live-icon-btn{width:44px;height:44px;border-radius:50%;background:#f8faff;border:1px solid rgba(0,0,0,.04);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s;cursor:pointer}.live-icon-btn:hover{background:#fff;box-shadow:0 4px 12px #00000014;transform:translateY(-2px);color:var(--primary-color)}.live-icon-btn--danger:hover{color:#ef4444}.live-top-left{display:flex;align-items:center;gap:.75rem}.live-indicator{display:flex;align-items:center;gap:.4rem;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#dc2626;background:#fef2f2;padding:.35rem .75rem;border-radius:20px;border:1px solid rgba(220,38,38,.15)}.live-dot{width:8px;height:8px;border-radius:50%;background:#dc2626;animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.live-session-name{font-weight:700;font-size:.9rem;color:var(--text-primary);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-top-right{display:flex;align-items:center;gap:.5rem}.live-icon-btn{width:38px;height:38px;border-radius:12px;border:1px solid rgba(0,0,0,.06);background:#f8faff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s}.live-icon-btn:hover{background:#eff6ff;color:var(--primary-color);border-color:#1e3a8a26}.live-icon-btn--danger:hover{background:#fef2f2;color:#dc2626;border-color:#dc262626}.live-join-banner{background:linear-gradient(135deg,#0f172a,#1e3a8a);border-radius:1.5rem;padding:2rem;color:#fff;text-align:center}.live-join-code-section{margin-bottom:1.25rem}.live-join-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;opacity:.7;display:block;margin-bottom:.75rem}.live-join-code-display{display:flex;justify-content:center;gap:.5rem;margin-bottom:1rem}.live-code-char{width:48px;height:56px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;font-family:SF Mono,Fira Code,monospace;letter-spacing:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.live-copy-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.25rem;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:20px;color:#fff;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.live-copy-btn:hover{background:#ffffff40}.live-join-members{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;font-weight:600;opacity:.8}.live-voting-section{background:#fff;border-radius:1.5rem;padding:1.75rem;box-shadow:0 8px 30px #0000000f;border:1px solid rgba(30,58,138,.08)}.voting-header{display:flex;align-items:center;gap:.5rem;color:var(--primary-color);margin-bottom:.75rem}.voting-header h3{flex:1;font-size:1.1rem;font-weight:800;margin:0}.voting-timer{display:flex;align-items:center;gap:.3rem;font-size:.85rem;font-weight:800;color:#dc2626;background:#fef2f2;padding:.3rem .75rem;border-radius:20px}.voting-timer-bar{height:4px;background:#f1f5f9;border-radius:2px;overflow:hidden;margin-bottom:1rem}.voting-timer-fill{height:100%;background:linear-gradient(90deg,#1e3a8a,#3b82f6);border-radius:2px}.voting-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}.voting-candidates{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.voting-candidate{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:#f8faff;border:2px solid transparent;border-radius:14px;cursor:pointer;transition:all .2s;position:relative}.voting-candidate:hover:not(:disabled){background:#fff;box-shadow:0 4px 12px #0000000f}.voting-candidate.voted{border-color:var(--primary-color);background:#eff6ff}.voting-candidate:disabled{opacity:.5;cursor:default}.candidate-info{display:flex;align-items:center;gap:.75rem}.candidate-avatar{width:36px;height:36px;border-radius:10px;background:var(--primary-light);color:var(--primary-color);display:flex;align-items:center;justify-content:center}.candidate-name{display:block;font-weight:700;font-size:.9rem;color:var(--text-primary)}.candidate-role{display:block;font-size:.72rem;color:var(--text-muted);font-weight:600;text-transform:capitalize}.candidate-votes{font-size:.75rem;font-weight:700;color:var(--text-secondary);background:#f1f5f9;padding:.25rem .65rem;border-radius:20px}.vote-check{position:absolute;top:-6px;right:-6px;width:24px;height:24px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center}.voting-close-btn{width:100%;padding:.75rem;background:#f1f5f9;border:none;border-radius:12px;font-weight:700;font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:all .2s}.voting-close-btn:hover{background:#e2e8f0;color:var(--text-primary)}.live-now-playing{background:#fff;border-radius:2rem;padding:4rem 2rem;color:var(--text-primary);text-align:center;position:relative;overflow:hidden;margin-top:1rem}.live-now-playing:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;background:radial-gradient(circle,rgba(37,99,235,.05) 0%,transparent 70%);pointer-events:none}.now-playing-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--primary-color);margin-bottom:2rem;position:relative}.now-playing-tone-selector{position:relative;margin-bottom:2rem;display:flex;justify-content:center}.now-playing-label-button{border:1px solid rgba(37,99,235,.2);border-radius:999px;background:#f0f7ff;padding:.5rem 1rem;margin-bottom:0;cursor:pointer}.now-playing-label-button:hover{background:#e3f0ff}.now-playing-tone-menu{position:absolute;top:calc(100% + .6rem);left:50%;transform:translate(-50%);width:min(320px,90vw);max-height:220px;overflow-y:auto;padding:.75rem;border-radius:1rem;background:#fff;border:1px solid #DDE8F6;box-shadow:0 16px 30px #0f172a1f;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem;z-index:4}.now-playing-tone-item{border:1px solid #E2E8F0;border-radius:.6rem;background:#f8fafc;color:#0f172a;font-size:.82rem;font-weight:800;padding:.45rem .25rem;cursor:pointer}.now-playing-tone-item:hover{border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}.now-playing-tone-item.active{border-color:#1d4ed8;background:#1d4ed8;color:#fff}.live-active-song-view{display:flex;flex-direction:column;width:100%;animation:fadeIn .4s ease-out}.live-song-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:flex-end}.header-main-info{display:flex;flex-direction:column;gap:.5rem}.live-active-song-view .now-playing-title{font-size:2.2rem;font-weight:900;margin:0;color:#0f172a;letter-spacing:-.03em;text-align:left}.live-active-song-view .now-playing-meta{display:flex;align-items:center;gap:1rem;margin:0;justify-content:flex-start}.artist-name{font-size:1.1rem;color:var(--text-secondary);font-weight:500}.song-badges{display:flex;gap:.5rem}.live-active-song-view .now-playing-key{background:var(--primary-color);color:#fff;padding:.2rem .75rem;border-radius:6px;font-weight:800;font-size:.8rem}.now-playing-tempo{background:#f1f5f9;color:var(--text-secondary);padding:.2rem .75rem;border-radius:6px;font-weight:700;font-size:.8rem}.live-active-song-view .now-playing-progress{font-size:.8rem;font-weight:700;color:var(--text-muted);background:transparent;padding:0}.live-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:.75rem}.live-nav-btn{flex:1;max-width:180px;padding:1rem 1.25rem;border:2px solid rgba(0,0,0,.08);border-radius:1rem;background:#fff;display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:700;font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:all .2s;position:relative;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:manipulation}.live-nav-btn:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color);box-shadow:0 4px 16px #1e3a8a1f}.live-nav-btn:disabled{opacity:.35;cursor:not-allowed}.live-nav-btn--next{background:var(--text-primary);color:#fff;border-color:transparent}.live-nav-btn--next:hover:not(:disabled){background:#0a1120;color:#fff;box-shadow:0 8px 24px #0f172a33}.live-nav-btn.pressing{transform:scale(.96)}.long-press-ring{position:absolute;inset:0;border-radius:inherit;-webkit-mask:linear-gradient(white 0 0) content-box,linear-gradient(white 0 0);mask:linear-gradient(white 0 0) content-box,linear-gradient(white 0 0);mask-composite:exclude;-webkit-mask-composite:xor;padding:3px;pointer-events:none}.live-song-counter{font-size:.85rem;font-weight:800;color:var(--text-muted);min-width:50px;text-align:center}.live-next-song{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 2rem;background:#fff;border:2px solid #F1F5F9;border-radius:1.5rem;transition:all .3s ease;width:100%;max-width:550px;margin:2rem auto 0}.live-next-song.clickable{cursor:pointer;border-color:#e2e8f0}.live-next-song.clickable:hover{border-color:var(--primary-color);background:#f8faff;transform:translateY(-4px);box-shadow:0 12px 24px #1e3a8a0f}.next-play-icon-wrapper{width:48px;height:48px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #1e3a8a33}.next-label{font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);display:block;margin-bottom:.25rem}.next-title{flex:1;font-weight:900;font-size:1.15rem;color:var(--text-primary);line-height:1.3}.next-key{font-size:.75rem;font-weight:800;color:var(--primary-color);background:#f0f7ff;padding:.6rem 1.25rem;border-radius:15px}.live-waiting-actions-main{margin:1rem 0 2rem;width:100%}.btn-start-session{width:100%;padding:1.4rem;border:none;border-radius:1.5rem;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;font-size:1.2rem;font-weight:900;display:flex;align-items:center;justify-content:center;gap:.85rem;cursor:pointer;box-shadow:0 15px 35px #1e3a8a40;transition:all .4s cubic-bezier(.34,1.56,.64,1);margin-top:1rem}.btn-start-session:hover{box-shadow:0 20px 45px #1e3a8a59;transform:translateY(-4px) scale(1.02)}.live-controller-bar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border-radius:12px;font-size:.82rem;color:var(--text-secondary);border:1px solid rgba(0,0,0,.04)}.live-controller-bar strong{color:var(--primary-color)}.live-members-count{margin-left:auto;display:flex;align-items:center;gap:.3rem;font-weight:700;color:var(--text-muted)}.live-waiting-actions{display:flex;gap:1rem;margin:1rem auto 2rem;max-width:550px;width:100%}.live-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:none;border-radius:14px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s}.live-action-btn--vote{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;box-shadow:0 8px 24px #1e3a8a40}.live-action-btn--vote:hover{transform:translateY(-2px);box-shadow:0 12px 32px #1e3a8a59}.live-action-btn--skip{background:#f8faff;color:var(--text-secondary);border:1px solid rgba(0,0,0,.08)}.live-action-btn--skip:hover{background:#fff;border-color:var(--border-hover)}.live-action-btn--end{background:#fef2f2;color:#dc2626;border:1px solid rgba(220,38,38,.15);width:100%}.live-action-btn--end:hover{background:#fee2e2}.live-action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.live-members-section,.live-audit-section{background:#fff;border-radius:1.25rem;padding:1.25rem;box-shadow:0 4px 12px #00000008}.live-section-title{display:flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.85rem}.live-members-grid{display:flex;flex-wrap:wrap;gap:.5rem}.now-playing-progress{display:inline-flex;padding:.5rem 1rem;background:#f1f5f9;border-radius:99px;font-size:.85rem;font-weight:800;color:var(--text-secondary);margin-top:1rem}.live-lyrics-container{width:100%;max-width:none;margin:0;text-align:left;background:transparent;border-radius:0;padding:0;border:none}.lyrics-content.practice-style{background:#f8faff;padding:2rem;border-radius:1.5rem;border:1px solid rgba(0,0,0,.03);min-height:400px;box-shadow:inset 0 2px 4px #00000003}.lyrics-content{font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.8}.lyrics-line{white-space:pre-wrap;min-height:1.5em;font-size:1.25rem;color:#334155}.lyrics-line.chord-line{font-family:SF Mono,Roboto Mono,Menlo,monospace;font-weight:700;font-size:1.35rem;color:#e11d48;margin-bottom:-.2rem;margin-top:1.2rem;letter-spacing:.02em}.lyrics-line.lyric-line{color:#0f172a;font-weight:500}.lyrics-line.empty-line{height:1.5rem}.lyrics-empty{padding:2.5rem 2rem;color:var(--text-muted);text-align:center}.lyrics-hint{display:block;font-size:.85rem;margin-top:.5rem;opacity:.7}.live-member-chip{display:flex;align-items:center;gap:.4rem;padding:.45rem .85rem;background:#f8faff;border-radius:20px;font-size:.8rem;font-weight:600;color:var(--text-primary);border:1px solid rgba(0,0,0,.04)}.member-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.member-status.online{background:#10b981;box-shadow:0 0 6px #10b98166}.member-status.offline{background:#cbd5e1}.member-chip-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.host-badge-icon{color:#f59e0b}.controller-badge-icon{color:var(--primary-color)}.live-audit-list{display:flex;flex-direction:column;gap:.4rem;max-height:200px;overflow-y:auto}.audit-entry{padding:.5rem .75rem;background:#f8faff;border-radius:10px;font-size:.78rem;color:var(--text-secondary);line-height:1.4}.audit-detail{font-weight:600}.live-overlay{position:fixed;inset:0;background:#0f172a4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500}.live-drawer{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:1.5rem 1.5rem 0 0;z-index:1501;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 -20px 60px #00000026}.live-drawer-handle{width:40px;height:4px;background:#cbd5e1;border-radius:2px;margin:.75rem auto}.live-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem 1rem;border-bottom:1px solid rgba(0,0,0,.04)}.live-drawer-header h3{font-size:1.15rem;font-weight:800;margin:0}.live-drawer-header button{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:.5rem;border-radius:10px;transition:all .2s}.live-drawer-header button:hover{background:#f1f5f9;color:var(--text-primary)}.live-drawer-body{flex:1;overflow-y:auto;padding:1rem 1.5rem 2rem}.setlist-item{display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;border-radius:12px;transition:all .2s;position:relative}.setlist-item.current{background:var(--primary-light);border:1px solid rgba(30,58,138,.15)}.setlist-item.clickable{cursor:pointer}.setlist-item.clickable:hover{background:#f8faff}.setlist-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:8px;font-size:.75rem;font-weight:800;color:var(--text-muted);flex-shrink:0}.setlist-item.current .setlist-number{background:var(--primary-color);color:#fff}.setlist-info{flex:1;min-width:0}.setlist-title{display:block;font-weight:700;font-size:.88rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setlist-meta{display:block;font-size:.72rem;color:var(--text-muted);font-weight:600}.setlist-playing{width:24px;height:24px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;animation:pulse-glow 2s ease-in-out infinite}.host-panel-section{padding:1rem 0;border-bottom:1px solid rgba(0,0,0,.04)}.host-panel-section:last-child{border-bottom:none}.host-panel-section h4{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.75rem}.host-code-display{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;background:#f8faff;border-radius:12px}.host-code{font-size:1.5rem;font-weight:800;letter-spacing:.25em;font-family:SF Mono,Fira Code,monospace;color:var(--primary-color)}.host-code-display button{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:.4rem;border-radius:8px;transition:all .2s}.host-code-display button:hover{background:#fff;color:var(--primary-color)}.host-member-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem .85rem;background:#f8faff;border-radius:10px;margin-bottom:.4rem}.host-member-info{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:.85rem}.host-member-role-tag{font-size:.72rem;color:var(--text-muted)}.host-force-btn{display:flex;align-items:center;gap:.3rem;padding:.35rem .75rem;background:transparent;border:1px solid rgba(0,0,0,.08);border-radius:8px;font-size:.72rem;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .2s}.host-force-btn:hover{background:var(--primary-light);color:var(--primary-color);border-color:#1e3a8a33}.host-panel-danger{padding-top:1.5rem}.waiting-song-preview{margin:2rem 0;padding:1.5rem 2rem;background:#f8faff;border:1px solid rgba(0,0,0,.04);border-radius:1.5rem;width:100%;max-width:400px}.preview-label{display:block;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.5rem}.preview-title{font-size:1.5rem;font-weight:950;color:#0f172a;line-height:1.2;margin-bottom:.5rem}.preview-key{display:inline-block;padding:.4rem 1rem;background:#fff;border:1.5px solid var(--primary-color);border-radius:99px;color:var(--primary-color);font-weight:800;font-size:.9rem}@media(max-width:768px){.live-session-page{gap:1rem;padding-bottom:8rem}.live-top-bar{border-radius:1rem;padding:.85rem 1rem}.live-session-name{max-width:100px;font-size:.8rem}.live-waiting-splash{transform:translate(8px)}.live-join-banner{padding:1.5rem;border-radius:1.25rem}.live-code-char{width:40px;height:48px;font-size:1.25rem;border-radius:10px}.live-now-playing{padding:2rem 1.5rem;border-radius:1.5rem}.now-playing-title{font-size:1.5rem}.now-playing-meta{font-size:.8rem;gap:.5rem}.live-controls{gap:.75rem}.live-nav-btn{padding:.85rem 1rem;font-size:.82rem;border-radius:14px}.live-waiting-actions{flex-direction:column}.live-action-btn{font-size:.85rem}.live-members-section,.live-audit-section{border-radius:1rem;padding:1rem}}.live-floating-next-btn{position:fixed;bottom:2rem;right:2rem;padding:.75rem 1.5rem;background:var(--text-primary);color:#fff;border:none;border-radius:99px;box-shadow:0 10px 25px #0f172a40;z-index:100;cursor:pointer;display:flex;align-items:center;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.live-floating-next-btn .btn-content{display:flex;align-items:center;gap:.75rem}.live-floating-next-btn .btn-label{font-size:.9rem;font-weight:700}.live-floating-next-btn.clickable:hover{transform:translateY(-4px);background:#2d3748;box-shadow:0 15px 35px #0f172a59}@media(max-width:640px){.live-active-song-view .now-playing-title{font-size:1.75rem}.live-song-header{flex-direction:column;align-items:flex-start;gap:1rem;padding-bottom:1rem}.live-floating-next-btn{bottom:1.5rem;right:1.5rem;padding:.6rem 1rem}.live-floating-next-btn .btn-label{font-size:.8rem}}@media(max-width:480px){.live-code-char{width:36px;height:44px;font-size:1.1rem;border-radius:8px}.now-playing-title{font-size:1.3rem}}.join-session-page{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:2rem}.join-session-card{background:#fff;border-radius:1.75rem;padding:2.5rem;max-width:420px;width:100%;box-shadow:0 20px 60px #00000014,0 8px 20px #0000000a;text-align:center;position:relative}.join-back-btn{position:absolute;top:1.5rem;left:1.5rem;display:flex;align-items:center;gap:.4rem;background:none;border:none;color:var(--text-muted);font-weight:600;font-size:.85rem;cursor:pointer;padding:.4rem .75rem;border-radius:10px;transition:all .2s}.join-back-btn:hover{background:#f1f5f9;color:var(--text-primary)}.join-session-icon{margin:.5rem auto 1.5rem}.join-session-icon-ring{width:64px;height:64px;margin:0 auto;border-radius:50%;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 24px #1e3a8a40}.join-session-title{font-size:1.6rem;font-weight:800;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:-.02em}.join-session-subtitle{font-size:.9rem;color:var(--text-muted);margin-bottom:2rem;line-height:1.5}.join-code-input-wrapper{position:relative;margin-bottom:1.5rem}.join-code-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.join-code-input{width:100%;padding:1rem 3.5rem 1rem 3.25rem;font-size:1.5rem;font-weight:800;letter-spacing:.35em;text-align:center;color:var(--text-primary);background:#f8faff;border:2px solid transparent;border-radius:16px;outline:none;transition:all .2s ease;font-family:SF Mono,Fira Code,monospace;text-transform:uppercase}.join-code-input:focus{border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 4px #1e3a8a1a}.join-code-input::placeholder{color:#cbd5e1;letter-spacing:.25em;font-weight:600}.join-code-counter{position:absolute;right:1.25rem;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:700;color:var(--text-muted)}.join-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid rgba(239,68,68,.15);border-radius:12px;color:#dc2626;font-size:.85rem;font-weight:600;margin-bottom:1.5rem}.join-submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#1e3a8a,#172554);color:#fff;border:none;border-radius:var(--radius-full);font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease;box-shadow:0 8px 24px #1e3a8a4d}.join-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #1e3a8a66}.join-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.join-session-page{padding:1rem;min-height:60vh}.join-session-card{padding:2rem 1.5rem}.join-code-input{font-size:1.25rem}.join-session-title{font-size:1.4rem}}.repertoires-page{display:flex;flex-direction:column}.repertoires-list{display:flex;flex-direction:column;gap:1.5rem}.repertoire-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.repertoire-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.repertoire-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.75rem;cursor:pointer;transition:all var(--transition-fast)}.repertoire-header:hover{background:#f8faff}.repertoire-header-main{display:flex;align-items:center;gap:1.5rem}.repertoire-header-name{font-weight:700;font-size:1.05rem;color:var(--text-primary)}.history-badge{font-size:.7rem;font-weight:800;text-transform:uppercase;background:#f1f5f9;color:var(--text-muted);padding:.35rem .8rem;border-radius:20px;letter-spacing:.05em}.repertoire-date-badge{display:flex;align-items:center;gap:.75rem;padding:.6rem 1.5rem;background:var(--text-primary);border-radius:12px;font-size:.95rem;font-weight:800;color:#fff;box-shadow:0 4px 12px #0000001a}.header-toggle{color:var(--text-muted);display:flex;align-items:center;transition:transform .3s ease}.repertoire-card.expanded .header-toggle{color:var(--primary-color)}.repertoire-content{padding:0 1.75rem 1.75rem;overflow:hidden}.repertoire-expanded-top{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.5rem;margin-bottom:1.5rem;border-bottom:1px solid #F1F5F9;padding-top:.5rem}.repertoire-info{flex:1}.repertoire-name{font-size:1.4rem;font-weight:800;color:var(--text-primary);margin-bottom:.35rem;letter-spacing:-.02em}.repertoire-stats{display:flex;gap:1.5rem;font-size:.85rem;color:var(--text-secondary);font-weight:700}.repertoire-actions{display:flex;gap:.75rem;align-items:center}.repertoire-sections-wrapper{display:flex;flex-direction:column;gap:.5rem}.repertoire-section{padding:1.5rem 0;border-bottom:1px solid #F8FAFF}.repertoire-section:last-child{border-bottom:none;padding-bottom:0}.repertoire-section h4{display:flex;align-items:center;gap:.5rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1rem;font-weight:800}.repertoire-songs-list{display:flex;flex-direction:column;gap:.75rem}.repertoire-song-item{display:flex;flex-direction:column;gap:0;padding:0;background:#f8faff;border-radius:12px;border:1px solid transparent;transition:all .2s ease;cursor:pointer;overflow:hidden}.repertoire-song-item:hover{background:#fff;box-shadow:0 4px 12px #0000000d}.repertoire-song-item.expanded{background:#fff;border-color:#1e3a8a1a;box-shadow:0 4px 15px #00000014}.song-item-main{padding:.85rem 1rem;display:flex;align-items:center}.song-item-expanded{overflow:hidden}.song-expanded-content{padding:.75rem 1rem 1rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(0,0,0,.02)}.song-item-actions{display:flex;gap:.5rem}.btn-xs{width:28px;height:28px;padding:0;border-radius:8px}.song-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary-color);border-radius:50%;font-size:.7rem;font-weight:800;flex-shrink:0}.repertoire-team-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.team-member{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8faff;border-radius:12px}.member-name{font-weight:700;color:var(--text-primary);font-size:.9rem}.member-role{font-size:.75rem;color:var(--primary-color);font-weight:800;text-transform:uppercase;letter-spacing:.05em}.repertoire-notes{padding:1.25rem;background:#f8faff;border-radius:12px;color:var(--text-secondary);font-size:.95rem;line-height:1.6;white-space:pre-wrap;border:1px solid #F1F5F9}.selection-list{max-height:250px;overflow-y:auto;background:#f8faff;border:1px solid #E2E8F0;border-radius:1rem;padding:.5rem}.selection-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:12px;cursor:pointer;transition:all .2s}.selection-item:hover{background:#fff;box-shadow:var(--shadow-sm)}.selection-item input{width:20px;height:20px;accent-color:var(--primary-color)}.selection-info{display:flex;flex-direction:column}.selection-name{font-size:.82rem;font-weight:700;color:var(--text-primary)}.selection-meta{font-size:.72rem;color:var(--text-muted);font-weight:600}@media(max-width:768px){.repertoire-header{flex-wrap:wrap}.repertoire-date-badge{order:-1;width:100%;justify-content:center}.repertoire-team-list{grid-template-columns:1fr}.selection-name{font-size:.74rem}.selection-meta{font-size:.66rem}}.song-detail-modal{display:grid;grid-template-columns:1fr 1.6fr;gap:2rem;align-items:start}.song-detail-left{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:0}.song-detail-right{min-width:0}.song-detail-header{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.song-detail-title{font-size:1.75rem;font-weight:800;margin:0;line-height:1.2;color:var(--text-primary)}.song-detail-artist{font-size:1.1rem;color:var(--text-secondary);margin:.25rem 0 0;font-weight:500}.song-detail-badges{display:flex;gap:.5rem;flex-wrap:wrap}.lyrics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.transpose-btn.reset:hover{color:var(--danger-color);background:#ef44441a}.song-lyrics{background:#f8faff;padding:2rem;border-radius:1.25rem;font-family:SF Mono,Fira Code,monospace;font-size:1rem;line-height:1.8;white-space:pre-wrap;color:var(--text-primary);border:1px solid rgba(0,0,0,.04)}.modal.full-screen .song-lyrics{background:#fff;padding:2rem;border:none;max-height:none;overflow-y:visible;font-size:1.1rem}@media(max-width:768px){.repertoire-header{padding:1rem}.repertoire-date-badge{padding:.5rem 1rem;font-size:.85rem}.repertoire-content{padding:0 1rem 1rem}.repertoire-expanded-top{flex-direction:column;align-items:flex-start;gap:1rem;padding-bottom:1rem}.repertoire-name{font-size:1.25rem}.repertoire-actions{width:100%;justify-content:flex-start;gap:.5rem}.repertoire-song-item,.team-member{padding:.75rem}.song-detail-modal{grid-template-columns:1fr;gap:1.5rem}.song-lyrics{padding:.85rem;font-size:.72rem;line-height:1.5}.modal.full-screen .song-lyrics{padding:1rem;font-size:.76rem;line-height:1.55}.modal.full-screen .lyrics-header{padding-top:4.5rem;margin-bottom:1.25rem}.transpose-btn{width:24px;height:24px;font-size:.9rem}.transpose-value{min-width:20px;font-size:.8rem}.lyrics-header h4{font-size:.75rem}}.key-selector{padding:.35rem .75rem;border-radius:8px;border:1px solid #E2E8F0;font-size:.85rem;font-weight:700;color:var(--primary-color);background:#fff;cursor:pointer;outline:none;transition:all .2s;margin-left:auto}.key-selector:hover{border-color:var(--primary-color);background:#f8faff}.key-selector:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #1e3a8a1a}.repertoire-tabs{display:flex;gap:.5rem;background:#f1f5f9;padding:.4rem;border-radius:14px;margin-right:1.5rem}.tab-btn{padding:.6rem 1.25rem;border:none;background:transparent;border-radius:10px;font-size:.85rem;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.tab-btn span{font-size:.75rem;opacity:.6;font-weight:600}.tab-btn:hover{color:var(--primary-color);background:#ffffff80}.tab-btn.active{background:#fff;color:var(--primary-color);box-shadow:0 4px 10px #0000000d}@media(max-width:768px){.repertoire-tabs{width:100%;margin-right:0;margin-bottom:1rem;overflow-x:auto}.tab-btn{flex:1;justify-content:center}}.schedule-page{padding-bottom:2rem}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;background:#fff;border-radius:20px;padding:.75rem 1.25rem;border:1px solid rgba(0,0,0,.04);box-shadow:0 10px 25px -5px #0000000d,0 8px 10px -6px #00000005}.calendar-nav-btn{background:none;border:1px solid rgba(0,0,0,.08);width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:all .2s ease}.calendar-nav-btn:hover{background:#f4f4f5;border-color:#00000026}.calendar-month-label{font-size:1.3rem;font-weight:800;color:var(--text-primary);text-transform:capitalize;letter-spacing:-.02em}.calendar-today-btn{background:#000;color:#fff;border:none;padding:.4rem 1rem;border-radius:999px;font-size:.75rem;font-weight:800;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em}.calendar-today-btn:hover{background:#27272a;transform:translateY(-1px)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:2rem}.calendar-day-header{text-align:center;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:.75rem 0}.calendar-day{aspect-ratio:1;background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.04);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.calendar-day:hover{border-color:#00000026;transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.calendar-day.empty{background:transparent;border:none;cursor:default;pointer-events:none}.calendar-day.today{border-color:#000;border-width:2px}.calendar-day.has-schedule{background:#000;border-color:#000}.calendar-day.has-schedule .calendar-day-number{color:#fff}.calendar-day.has-schedule:hover{background:#27272a;border-color:#27272a}.calendar-day.past{opacity:.45}.calendar-day-number{font-size:.95rem;font-weight:700;color:var(--text-primary);line-height:1}.calendar-day-count{font-size:.55rem;font-weight:800;color:#ffffffd9;text-transform:uppercase;letter-spacing:.03em}.schedule-detail-card{background:#fff;border-radius:20px;border:1px solid rgba(0,0,0,.04);padding:1.5rem;box-shadow:0 10px 25px -5px #0000000d,0 8px 10px -6px #00000005;margin-bottom:1.5rem}.schedule-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.schedule-detail-date{display:flex;align-items:center;gap:.75rem}.schedule-date-box{width:52px;height:52px;background:#000;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.schedule-date-box .date-num{font-size:1.25rem;font-weight:800;line-height:1.1}.schedule-date-box .date-month{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.schedule-detail-title{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin:0}.schedule-detail-weekday{font-size:.8rem;color:var(--text-muted);font-weight:600;text-transform:capitalize}.schedule-detail-actions{display:flex;gap:.5rem}.schedule-detail-actions .btn-icon{width:36px;height:36px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.schedule-detail-actions .btn-icon:hover{background:#f4f4f5;color:#000}.schedule-detail-actions .btn-icon.delete:hover{background:#fef2f2;color:#ef4444;border-color:#ef444433}.schedule-members-section{margin-top:1rem}.schedule-members-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.schedule-member-chips{display:flex;flex-wrap:wrap;gap:.5rem}.schedule-member-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;background:#f4f4f5;border-radius:999px;font-size:.8rem;font-weight:600;color:var(--text-primary);border:1px solid rgba(0,0,0,.04)}.schedule-member-chip .chip-icon{width:18px;height:18px;border-radius:50%;background:#000;color:#fff;display:flex;align-items:center;justify-content:center}.schedule-member-chip.voice-chip{background:#fafafa}.schedule-notes{margin-top:1rem;padding:.75rem 1rem;background:#fafafa;border-radius:12px;font-size:.85rem;color:var(--text-secondary);line-height:1.5;border:1px solid rgba(0,0,0,.03)}.schedule-empty-state{text-align:center;padding:3rem 2rem;background:#fff;border-radius:20px;border:1px solid rgba(0,0,0,.04);box-shadow:0 4px 12px #00000008}.schedule-empty-icon{width:64px;height:64px;border-radius:20px;background:#f4f4f5;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:var(--text-muted)}.schedule-empty-state h3{font-size:1.1rem;font-weight:800;margin-bottom:.5rem}.schedule-empty-state p{color:var(--text-muted);font-size:.9rem;max-width:300px;margin:0 auto}.schedule-drawer .member-select-section{margin-bottom:.5rem}.member-select-title{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.member-select-list{display:flex;flex-direction:column;gap:.35rem;max-height:220px;overflow-y:auto;padding-right:.25rem}.member-select-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:14px;cursor:pointer;transition:all .2s ease;border:1px solid transparent;background:#fafafa}.member-select-item:hover{background:#f4f4f5;border-color:#0000000f}.member-select-item.selected{background:#000;color:#fff;border-color:#000}.member-select-item.selected .member-select-detail{color:#ffffffb3}.member-select-checkbox{width:20px;height:20px;border-radius:6px;border:2px solid rgba(0,0,0,.15);background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.member-select-item.selected .member-select-checkbox{background:#fff;border-color:#fff;color:#000}.member-select-name{font-weight:700;font-size:.88rem}.member-select-detail{font-size:.72rem;color:var(--text-muted);font-weight:600}.upcoming-schedule-section{margin-bottom:1.5rem}.upcoming-schedule-title{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:800;margin-bottom:1rem;color:var(--text-primary)}.upcoming-schedule-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.04);margin-bottom:.75rem;transition:all .2s ease;box-shadow:0 2px 8px #00000008}.upcoming-schedule-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000000f}.upcoming-date-box{width:48px;height:48px;background:#000;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.upcoming-date-box .date-num{font-size:1.15rem;font-weight:800;line-height:1.1}.upcoming-date-box .date-month{font-size:.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.upcoming-info{flex:1;min-width:0}.upcoming-info .upcoming-title{font-weight:700;font-size:.88rem;color:var(--text-primary);display:block;margin-bottom:.15rem}.upcoming-info .upcoming-meta{font-size:.72rem;color:var(--text-muted);font-weight:600}.upcoming-days-badge{font-size:.65rem;font-weight:800;padding:.25rem .6rem;border-radius:999px;background:#f4f4f5;color:var(--text-secondary);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.upcoming-days-badge.today{background:#000;color:#fff}.upcoming-empty{text-align:center;padding:1.5rem;background:#fafafa;border-radius:14px;color:var(--text-muted);font-size:.85rem;font-weight:600}@media(max-width:768px){.calendar-grid{gap:3px}.calendar-day{border-radius:10px;aspect-ratio:1}.calendar-day-number{font-size:.8rem}.calendar-nav{padding:.6rem 1rem}.calendar-month-label{font-size:1rem}.schedule-detail-card{padding:1.25rem}.schedule-date-box{width:44px;height:44px}.schedule-date-box .date-num{font-size:1.1rem}.schedule-member-chip{font-size:.75rem;padding:.35rem .65rem}}.pads-page{display:flex;flex-direction:column}.pads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:.65rem;margin-bottom:1.5rem}.pad-card{background:#f8faff;border:1px solid rgba(0,0,0,.08);border-radius:.85rem;aspect-ratio:1 / 1;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -2px #00000026,0 4px 10px -3px #0000001a,inset 0 1px #fff,inset 0 -2px #0000000d;overflow:hidden}.pad-card:active{transform:scale(.96) translateY(2px);box-shadow:0 2px 4px #0000000d,inset 0 3px 6px #0000001a}.pad-card:hover{transform:translateY(-5px);background:#fff;border-color:#1e3a8a40;box-shadow:0 20px 30px -10px #00000026,0 10px 15px -5px #0000000d,inset 0 1px #fff}.pad-card.active{background:var(--gradient-primary);border-color:transparent;color:#fff;box-shadow:0 18px 35px -5px #1e3a8a73,0 12px 15px -5px #1e3a8a40,inset 0 1px #ffffff40,inset 0 -3px #0003}.pad-card-body{display:flex;flex-direction:column;gap:.75rem}.pad-card-key{font-weight:900;font-size:1.25rem;color:var(--primary-color);transition:all .3s ease;letter-spacing:-.02em}.pad-card.active .pad-card-key{color:#fff;transform:scale(1.1)}.pad-card:hover .pad-card-actions{opacity:1}.pad-card-info{display:flex;flex-direction:column}.pad-card-name{font-size:.65rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pad-card-category{font-size:.5rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;opacity:.6}.pad-card-footer{display:flex;align-items:center;margin-top:.25rem;gap:.25rem}.youtube-indicator{color:red}.pad-card.active .youtube-indicator{color:#fff;opacity:.8}.spacer{flex:1}.pad-action-btn{background:#0000000a;border:none;color:var(--text-muted);width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.pad-card.active .pad-action-btn{background:#ffffff26;color:#fff}.pad-action-btn.edit:hover{background:var(--primary-light);color:var(--primary-color)}.pad-action-btn.delete:hover{background:#fef2f2;color:#ef4444}.pad-card-actions{position:absolute;top:.25rem;right:.25rem;display:flex;gap:.2rem;opacity:0;transition:opacity .2s ease}.playing-indicator{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;align-items:flex-end;gap:2px;height:12px}.playing-indicator span{width:3px;background:#fff;border-radius:3px;animation:bounce .8s ease-in-out infinite alternate}.playing-indicator span:nth-child(2){animation-delay:.2s}.playing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%{height:4px}to{height:12px}}.floating-player{position:fixed;bottom:24px;right:24px;width:320px;background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000040,0 0 0 1px #0000000d;overflow:hidden;z-index:1000;cursor:grab}.floating-player:active{cursor:grabbing}.floating-player-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#0f172a;color:#fff}.floating-player-title{font-size:.85rem;font-weight:700;text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-close-floating{width:28px!important;height:28px!important;min-width:28px!important;padding:0!important;border-radius:8px!important;background:#ffffff1a!important;color:#fff!important;border:none!important}.btn-close-floating:hover{background:#fff3!important}.floating-player-video{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;background:#000}.floating-player-video iframe{position:absolute;top:0;left:0;width:100%;height:100%}.floating-player-drag-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;background:#f1f5f9;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.form-hint{display:block;margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.dropzone{border:2px dashed #E2E8F0;border-radius:1.25rem;padding:2rem 1.5rem;text-align:center;transition:all var(--transition-base);background:#f8faff;cursor:pointer}.dropzone:hover{border-color:var(--primary-color);background:#fff}.dropzone.dragging{border-color:var(--primary-color);background:#1e3a8a0d}.dropzone-icon{width:60px;height:60px;border-radius:50%;background:#1e3a8a1a;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:var(--primary-color)}.dropzone-text p{font-weight:700;margin:0 0 .25rem}.dropzone-text span{display:block;font-size:.85rem;color:var(--text-muted)}.file-note{margin-top:.5rem;font-size:.75rem;color:var(--primary-color);font-weight:700}@media(max-width:768px){.floating-player{width:calc(100% - 32px);max-width:300px;bottom:110px;right:16px;left:16px;margin:0 auto}.pad-list-item{padding:.875rem 1rem}.pad-list-icon{width:40px;height:40px}}.metronome-panel{background:#fff!important;width:400px!important;max-width:90vw!important;border-left:1px solid rgba(0,0,0,.05)!important;box-shadow:-20px 0 60px #0000000d!important}.metronome-premium-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem!important;border-bottom:none!important}.metronome-logo{display:flex;align-items:center;gap:.6rem;font-size:.65rem;font-weight:900;letter-spacing:.2em;color:var(--text-muted)}.logo-wave{width:2px;height:12px;background:var(--primary-color);border-radius:2px}.btn-close-minimal{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;transition:all .2s}.btn-close-minimal:hover{color:var(--text-primary);transform:rotate(90deg)}.metronome-premium-content{display:flex;flex-direction:column;align-items:center;padding:1rem 2rem 3rem!important;overflow-x:hidden}.metronome-signature-display{font-size:1.5rem;font-weight:800;color:var(--text-primary);margin-bottom:2rem;opacity:.8}.metronome-dots-visualizer{display:flex;gap:1.5rem;margin-bottom:3rem;align-items:center}.beat-group{display:flex;align-items:center;gap:.5rem}.sub-dots{display:flex;gap:.4rem}.metronome-dot-lite{width:6px;height:6px;background:#e2e8f0;border-radius:50%;transition:all .15s cubic-bezier(.175,.885,.32,1.275)}.sub-dot{width:3px;height:3px;background:#e2e8f0;border-radius:50%;transition:all .1s ease}.metronome-dot-lite.active{background:var(--primary-color);transform:scale(1.6);box-shadow:0 0 15px #1e3a8a66}.sub-dot.active{background:var(--primary-color);transform:scale(1.8)}.metronome-dot-lite.accent{border:1px solid rgba(30,58,138,.3)}.metronome-gear-wrapper{margin-bottom:2rem}.gear-circle{width:40px;height:40px;border:1px solid rgba(0,0,0,.05);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:all .2s}.gear-circle:hover{background:#f8faff;color:var(--primary-color);transform:rotate(45deg)}.metronome-main-bpm{display:flex;align-items:center;gap:2.5rem;margin-bottom:3rem}.bpm-step-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;transition:all .2s}.bpm-step-btn:hover{color:var(--text-primary);transform:scale(1.2)}.bpm-number-group{display:flex;flex-direction:column;align-items:center}.bpm-value{font-size:5rem;font-weight:900;line-height:1;color:#1e293b;letter-spacing:-.05em;text-shadow:0 10px 20px rgba(30,41,59,.08)}.bpm-unit{font-size:.75rem;font-weight:800;color:var(--text-muted);letter-spacing:.15em;margin-top:.25rem}.metronome-dial-area{margin-bottom:4rem;position:relative}.dial-outer{width:240px;height:240px;border-radius:50%;background:#fff;box-shadow:0 15px 45px #00000026;border:1px solid rgba(0,0,0,.05);display:flex;align-items:center;justify-content:center;position:relative;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;transition:border-color .2s,box-shadow .2s}.dial-outer:active,.dial-outer.dragging{cursor:grabbing;border-color:var(--primary-color)!important;box-shadow:0 15px 50px #1e3a8a1a!important}.dial-ticks{position:absolute;width:100%;height:100%;pointer-events:none}.dial-tick{position:absolute;top:10px;left:50%;width:1px;height:6px;background:#e2e8f0;transform-origin:50% 110px}.dial-tap-btn{width:160px;height:160px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.05);box-shadow:0 10px 35px #0000001f,0 4px 8px #0000000f,inset 0 2px 5px #ffffffe6;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:900;font-size:.9rem;letter-spacing:.1em;color:var(--text-muted);z-index:2;transition:all .2s cubic-bezier(.4,0,.2,1)}.dial-tap-btn:hover{color:var(--primary-color);border-color:#1e3a8a26;box-shadow:0 15px 45px #0000002e,0 6px 12px #00000014}.metronome-bottom-controls-wrapper{width:100%;display:flex;flex-direction:column;gap:2rem;align-items:center}.metronome-selectors-stack{display:flex;flex-direction:column;gap:1rem;align-items:center}.metronome-subdivision-selector,.metronome-signature-selector{display:flex;gap:.5rem;background:#f8faff;padding:.35rem;border-radius:999px;border:1px solid rgba(0,0,0,.04);box-shadow:inset 0 2px 4px #00000005}.sig-opt{background:transparent;border:none;padding:.4rem 1rem;border-radius:999px;font-size:.85rem;font-weight:800;color:var(--text-muted);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:48px}.metronome-subdivision-selector .sig-opt{font-size:1.1rem;padding:.3rem .8rem}.sig-opt.active{background:#fff;color:var(--primary-color);box-shadow:0 4px 12px #00000014,0 2px 4px #00000005}.metronome-bottom-main{width:100%;display:flex;align-items:center;justify-content:space-between}.main-play-btn{width:72px;height:72px;background:#1e293b;color:#fff;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 15px 35px #1e293b4d}.main-play-btn:hover{background:#000}.metronome-close-btn{width:44px;height:44px;border-radius:50%;background:#f8faff;border:1px solid rgba(0,0,0,.04);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.metronome-close-btn:hover{background:#fef2f2;color:#e11d48;border-color:#e11d481a}@media(max-width:480px){.metronome-panel{width:100vw!important}.bpm-value{font-size:4rem}.dial-outer{width:200px;height:200px}.dial-tap-btn{width:130px;height:130px}}.practice-page{display:flex;flex-direction:column;align-items:center}.page-header{width:100%;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:2.5rem}.header-actions{display:flex;gap:1rem;align-items:center}.practice-tools-section{width:100%;margin-bottom:0;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.tool-card{background:#fff;border:1px solid rgba(0,0,0,.05);border-radius:1.5rem;padding:1.5rem 2rem;display:flex;align-items:center;gap:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 25px #0000000d,0 2px 8px #00000008;width:100%;max-width:480px;margin:0 auto;position:relative;overflow:hidden}.tool-card:hover{transform:translateY(-4px);border-color:var(--primary-color);box-shadow:0 12px 30px #1e3a8a1f}.tool-card-icon{width:52px;height:52px;background:linear-gradient(135deg,#f0f7ff,#e0efff);border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--primary-color);flex-shrink:0;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 4px #fff}.tool-card:hover .tool-card-icon{background:var(--primary-color);color:#fff}.tool-card-info h3{font-size:1.15rem;font-weight:850;margin:0;color:var(--text-primary);letter-spacing:-.02em}.tool-card-info p{font-size:.85rem;color:var(--text-secondary);margin:.25rem 0 0;font-weight:500}.tool-card-arrow{margin-left:auto;color:#cbd5e1;transition:all .2s}.tool-card:hover .tool-card-arrow{color:var(--primary-color);transform:translate(4px)}@media(max-width:640px){.practice-tools-section{flex-direction:column;gap:1rem}.tool-card{min-width:100%}}@media(max-width:640px){.header-actions{width:100%;justify-content:space-between}.header-actions .btn{flex:1;font-size:.85rem;padding:.6rem 1rem}}.practice-compact-cta{background:#fff;border:1px solid rgba(0,0,0,.05);border-radius:1.5rem;padding:1.5rem 2rem;display:flex;align-items:center;gap:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 25px #0000000d,0 2px 8px #00000008;width:100%;max-width:480px;margin:1.5rem auto 2rem}.practice-compact-cta:hover{transform:translateY(-4px);border-color:var(--primary-color);box-shadow:0 12px 30px #1e3a8a1f}.cta-icon-box{width:52px;height:52px;background:linear-gradient(135deg,#f0f7ff,#e0efff);border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--primary-color);flex-shrink:0;box-shadow:inset 0 2px 4px #fff}.cta-content{flex:1;text-align:left}.cta-content h2{font-size:1.15rem;font-weight:850;margin:0;color:var(--text-primary);letter-spacing:-.02em}.cta-content p{font-size:.85rem;color:var(--text-secondary);margin:.25rem 0 0;font-weight:500}.cta-arrow{color:#cbd5e1;transition:all .2s}.practice-compact-cta:hover .cta-arrow{color:var(--primary-color);transform:translate(4px)}.practice-player-container{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:start}.practice-video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--radius-xl);background:#000;box-shadow:var(--shadow-lg)}.practice-iframe{position:absolute;top:0;left:0;width:100%;height:100%}.no-video-state{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:1rem;text-align:center;padding:2rem}.practice-song-details{padding:2rem}.practice-song-details h2{font-size:1.75rem;margin-bottom:.25rem}.song-artist{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1.5rem;font-weight:500}.song-meta-tags{display:flex;gap:.75rem;margin-bottom:2rem}.song-notes-preview{background:var(--bg-secondary);padding:1.25rem;border-radius:12px}.song-notes-preview h4{font-size:.8rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem}.song-notes-preview p{font-size:.95rem;color:var(--text-primary);line-height:1.6}.songs-selection-list{display:flex;flex-direction:column;gap:.5rem}.empty-search-state{padding:2rem;text-align:center;color:var(--text-muted);background:var(--bg-secondary);border-radius:12px}@media(max-width:1024px){.practice-player-container{grid-template-columns:1fr}}.song-lyrics-practice{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.05)}.song-lyrics-practice h4{font-size:.8rem;text-transform:uppercase;color:var(--text-muted);font-weight:800}.lyrics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.lyrics-display{font-family:SF Mono,Fira Code,monospace;font-size:.9rem;line-height:1.7;color:var(--text-primary);white-space:pre-wrap;background:#f8faff;padding:1.5rem;border-radius:1rem;border:1px solid rgba(0,0,0,.03);max-height:500px;overflow-y:auto}.transpose-controls{display:flex;align-items:center;gap:.5rem;background:#f1f5f9;padding:2px;border-radius:8px}.transpose-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:#fff;border-radius:6px;color:var(--text-primary);font-weight:700;cursor:pointer;box-shadow:0 1px 2px #0000000d;font-size:1.1rem;line-height:1}.transpose-btn:hover{background:#f8fafc;color:var(--primary-color)}.transpose-btn:active{transform:scale(.95)}.transpose-btn.reset{background:transparent;box-shadow:none;color:var(--text-muted);font-size:1rem}.transpose-btn.reset:hover{color:#e11d48;background:#e11d481a}.transpose-btn:disabled{opacity:.3;pointer-events:none}.transpose-value{min-width:24px;text-align:center;font-size:.9rem;font-weight:700;color:var(--primary-color);font-variant-numeric:tabular-nums}.chord-line{color:#e11d48;font-weight:700}.lyric-line{color:var(--text-primary)}@media(max-width:640px){.lyrics-header{flex-direction:column;align-items:flex-start;gap:1rem}.transpose-controls{width:100%;justify-content:space-between}.transpose-btn{flex:1}}.sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;background:#fff;border-right:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-hidden{transform:translate(-100%)!important}.toggle-hidden{opacity:0!important;pointer-events:none!important;transform:scale(.9)!important}.sidebar-toggle{display:none;position:fixed;top:var(--spacing-md);left:var(--spacing-md);z-index:101;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.sidebar-toggle:hover{background:var(--bg-card-hover)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:99}.sidebar-header{padding:2.5rem 1.5rem;margin-bottom:1rem}.sidebar-logo{display:flex;align-items:center;gap:.5rem}.sidebar-logo-img{height:52px;width:auto;object-fit:contain;animation:logoFloat 3s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15));transition:all .3s ease}.sidebar-logo-img:hover{animation:logoPulse .6s ease-in-out;filter:drop-shadow(0 8px 24px rgba(0,0,0,.25));transform:scale(1.08)}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes logoPulse{0%{transform:scale(1)}50%{transform:scale(1.12)}to{transform:scale(1.08)}}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-title{font-size:1.4rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.sidebar-logo-subtitle{font-size:.7rem;color:#000;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.sidebar-nav{flex:1;padding:0 1rem;display:flex;flex-direction:column;gap:.5rem}.sidebar-nav-item{display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;color:var(--text-secondary);text-decoration:none;border-radius:999px;transition:all .22s ease-out;font-weight:600;font-size:.95rem;border:1px solid transparent;position:relative;isolation:isolate}.sidebar-nav-item:hover{background:#f4f4f5;color:#000}.sidebar-nav-item.active{background:transparent;color:#fff;border:1px solid transparent}.sidebar-nav-item.active:hover{background:transparent;border:1px solid transparent}.sidebar-active-bg{position:absolute;inset:0;background:#000;border-radius:999px;z-index:-1;box-shadow:0 4px 12px #00000026}.sidebar-nav-icon,.sidebar-nav-text{position:relative;z-index:1;display:flex;align-items:center}.sidebar-nav-item svg{width:20px;height:20px;opacity:.7}.sidebar-nav-item-button{width:100%;background:transparent;border:none;text-align:left;cursor:pointer}.sidebar-nav-item.active svg{opacity:1;color:#fff;filter:drop-shadow(0 0 4px rgba(255,255,255,.3))}.sidebar-nav-indicator{position:absolute;right:12px;width:6px;height:6px;border-radius:50%;background:#fff;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.sidebar-footer{padding:1.5rem;border-top:1px solid rgba(0,0,0,.03);display:flex;flex-direction:column;gap:1.25rem}.sidebar-logout-btn{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;width:100%;background:#f8faff;border:1px solid rgba(0,0,0,.08);border-radius:999px;color:#64748b;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0000000a,inset 0 1px #fff,inset 0 -1px #0000000d}.sidebar-logout-btn:hover{background:#fff1f2;color:#e11d48;border-color:#e11d4833;box-shadow:0 6px 15px #e11d481a,inset 0 1px #fff;transform:translateY(-1px)}.logout-icon-wrapper{display:flex;align-items:center;justify-content:center}.sidebar-footer-info p{font-size:.7rem;color:var(--text-muted);font-weight:500;margin:0}.sidebar-footer-version{color:var(--primary-color)!important;opacity:.6;margin-top:.2rem!important}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar-open{transform:translate(0)}.sidebar-toggle{display:none!important}.sidebar-overlay{display:block}}[data-theme=dark] .sidebar{background:var(--bg-primary);border-right-color:var(--border-color)}[data-theme=dark] .sidebar-nav-item:hover{background:var(--bg-secondary)}[data-theme=dark] .sidebar-nav-item.active{background:linear-gradient(135deg,#60a5fa1a,#3b82f626);border-color:#60a5fa33;color:var(--primary-color)}[data-theme=dark] .sidebar-logout-btn{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-muted)}[data-theme=dark] .sidebar-logout-btn:hover{background:#f871711a;color:#f87171;border-color:#f8717133}[data-theme=dark] .sidebar-footer{border-top-color:var(--border-color)}.role-selection-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100vh;padding:10vh 2rem 2rem;position:relative;overflow:hidden;background:#fff}.role-selection-container:before{display:none}.role-bg{z-index:-1}.role-branding{display:flex;flex-direction:column;align-items:center;gap:0rem;margin-bottom:1rem}.branding-logo{width:260px;height:auto;object-fit:contain;margin-bottom:.25rem;mix-blend-mode:multiply}.role-header{text-align:center}.role-title{font-size:1.5rem;font-weight:900;color:#000;margin:0 0 .5rem;letter-spacing:-.04em;line-height:1.2}.role-subtitle{color:#475569;font-size:.9rem;font-weight:500;opacity:.9}.role-options{display:flex;flex-direction:column;gap:1rem}.role-option{display:flex;align-items:center;padding:1.25rem 1.5rem;background:#f8faff;border:1px solid rgba(0,0,0,.08);border-radius:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 4px 6px -1px #0000000a,inset 0 1px #fff,inset 0 -1px #00000005}.role-option:hover{background:#fff;border-color:#1e3a8a40;transform:translateY(-4px);box-shadow:0 15px 30px -10px #0000001a,inset 0 1px #fff}.role-option.selected{background:#fff;border-color:var(--primary-color);box-shadow:0 12px 30px #1e3a8a1f}.role-icon-box{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-right:1.25rem;flex-shrink:0;transition:all .2s ease}.admin-icon{background:#eff6ff;color:#1e3a8a}.musician-icon{background:#ecfdf5;color:#10b981}.role-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.role-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.role-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .5rem;border-radius:6px;width:fit-content}.admin-badge{background:#eff6ff;color:#1e3a8a}.musician-badge{background:#ecfdf5;color:#059669}.role-check{width:24px;color:var(--primary-color);margin-left:.5rem}.role-confirm-btn{background:#f8faff;color:#000;border:1px solid rgba(0,0,0,.15);padding:.85rem;border-radius:1.15rem;font-size:.9rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:not-allowed;transition:all .3s cubic-bezier(.4,0,.2,1)}.role-confirm-btn.active{background:#000;color:#fff;border:none;cursor:pointer;pointer-events:auto;box-shadow:0 10px 25px #0000001a;font-size:.85rem;font-weight:700;letter-spacing:.05em;padding:.8rem 2.2rem;border-radius:9999px;transition:all .4s cubic-bezier(.22,1,.36,1);text-transform:uppercase;margin-bottom:1rem}.role-confirm-btn.active:hover{background:#18181b;transform:translateY(-2px);box-shadow:0 15px 35px #00000026}.role-confirm-btn:active{transform:scale(.98)}.role-login{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem;border-radius:1.5rem;background:#f8faff;border:1px solid rgba(30,58,138,.1);box-shadow:inset 0 2px 4px #00000005;overflow:hidden}.role-login-field{display:flex;flex-direction:column;gap:.5rem}.role-login-label{font-size:.95rem;font-weight:800;color:#000}.role-login-field .form-input{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:.85rem;padding:.85rem 1rem;font-size:.95rem;font-weight:500;color:var(--text-primary);transition:all .2s ease;width:100%;outline:none}.role-login-field .form-input:hover{border-color:#1e3a8a4d}.role-login-field .form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #1e3a8a1a;background:#fff}.password-input-wrapper{position:relative;width:100%}.password-toggle-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.5rem;transition:color .2s}.password-toggle-btn:hover{color:var(--primary-color)}.password-input-wrapper .form-input{padding-right:3rem}.role-login-field .form-input::placeholder{color:#111827;font-weight:600}.role-login-error{margin-top:.25rem;color:#e11d48;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.role-login-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.role-link-btn{background:transparent;border:none;color:var(--primary-color);font-weight:700;cursor:pointer;padding:.25rem .5rem}.role-link-btn:disabled{opacity:.5;cursor:not-allowed}.role-special-entry{display:none}.admin-special-btn{width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.05);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 25px #0000000d;transition:all .3s ease}.admin-special-btn:hover{color:var(--primary-color);border-color:#1e3a8a33;box-shadow:0 10px 30px #1e3a8a26;transform:translateY(-2px)}.admin-special-btn.selected{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 0 20px #1e3a8a66}@media(max-width:480px){.role-selection-card{padding:2rem}}.role-selection-dialog{max-width:340px!important;padding:1.25rem!important;border-radius:1.5rem!important}.role-selection-dialog .dialog-header{margin-bottom:1rem}.role-selection-dialog .dialog-title{font-size:1.15rem}.role-selection-dialog .dialog-description{font-size:.8rem}.role-selection-dialog .dialog-role-selector{margin-bottom:1rem;padding:.25rem}.role-selection-dialog .dialog-role-tab{padding:.5rem .75rem;font-size:.8rem}.role-selection-dialog .dialog-field{gap:.25rem}.role-selection-dialog .dialog-label{font-size:.75rem}.role-selection-dialog .form-input{padding:.65rem .75rem;font-size:.8rem}.role-selection-dialog .dialog-submit-btn{padding:.75rem 1rem;font-size:.85rem;border-radius:.75rem}.role-selection-dialog .dialog-link{font-size:.75rem}.role-selection-dialog .dialog-form{gap:1rem}.dialog-role-selector{display:flex;gap:.5rem;background:#f8faff;padding:.5rem;border-radius:1rem;margin-bottom:1.5rem}.dialog-role-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:transparent;border:none;border-radius:.75rem;font-size:.9rem;font-weight:700;color:#64748b;cursor:pointer;transition:all .2s ease}.dialog-role-tab:hover{color:#000}.dialog-role-tab.active{background:#fff;color:#000;box-shadow:0 4px 12px #00000014}.dialog-form{display:flex;flex-direction:column;gap:1.25rem}.dialog-field{display:flex;flex-direction:column;gap:.5rem}.dialog-label{font-size:.9rem;font-weight:700;color:#0f172a}.dialog-error{color:#e11d48;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.dialog-link{background:transparent;border:none;color:#1a1a1a;font-size:.85rem;font-weight:700;cursor:pointer;padding:0;text-align:left}.dialog-link:hover{text-decoration:underline}.dialog-actions{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}.dialog-submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.5rem;background:#1e293b;color:#fff;border:none;border-radius:1rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 10px 30px #00000026}.dialog-submit-btn:hover:not(:disabled){background:#0f172a;transform:translateY(-2px);box-shadow:0 15px 40px #00000040}.dialog-submit-btn:disabled{opacity:.5;cursor:not-allowed}.dialog-submit-btn.small{width:auto;padding:.75rem 1.5rem}.dialog-section-title{font-size:1rem;font-weight:800;color:#0f172a;margin-bottom:.5rem}.register-leader-link-relative{display:flex;justify-content:center;width:100%;margin-top:.5rem}.register-leader-link{display:none}.register-btn{display:inline-flex;align-items:center;gap:.6rem;background:#fff;border:1px solid rgba(0,0,0,.06);color:#18181b;font-weight:600;font-size:.75rem;padding:.6rem 1.4rem;border-radius:9999px;cursor:pointer;transition:all .4s cubic-bezier(.22,1,.36,1);letter-spacing:.01em;box-shadow:0 2px 8px #00000005}.register-btn:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 5px 15px #0000000d}.dialog-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialog-content{position:fixed;left:50%;top:50%;z-index:1001;width:calc(100% - 2rem);max-width:480px;max-height:calc(100vh - 4rem);overflow-y:auto;transform:translate(-50%,-50%);background:#fff;border-radius:1.75rem;padding:2rem;box-shadow:0 25px 80px #00000026;margin:0 auto}.dialog-close-btn{position:absolute;right:1rem;top:1rem;width:36px;height:36px;border-radius:50%;border:none;background:#f8faff;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.dialog-close-btn:hover{background:#1e3a8a;color:#fff}.dialog-header{display:flex;flex-direction:column;gap:.5rem;text-align:center;margin-bottom:1.5rem}.dialog-title{font-size:1.5rem;font-weight:800;color:#0f172a;letter-spacing:-.02em}.dialog-description{font-size:1rem;color:#64748b;font-weight:500}.dialog-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(max-width:520px){.dialog-content{width:calc(100% - 2rem);max-width:calc(100% - 2rem);padding:1.5rem;border-radius:1.5rem;top:50%;left:50%;transform:translate(-50%,-50%)}}.register-card-modern{width:100%;max-width:600px;padding:2.5rem;display:flex;flex-direction:column;position:relative;z-index:2;background:transparent}.register-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.register-logo-mini img{height:32px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.register-back-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:#64748b;font-weight:700;font-size:.9rem;cursor:pointer;padding:.5rem .75rem;margin-left:-.75rem;border-radius:8px;transition:all .2s}.register-back-btn:hover{background:#e2e8f080;color:#000}.modern-form-grid{display:flex;flex-direction:column;gap:1.5rem}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:640px){.form-grid-2{grid-template-columns:1fr}}.modern-input{width:100%;padding:.875rem 1.25rem;background:#fff;border:1.5px solid #E2E8F0;border-radius:12px;font-size:1rem;color:#1e293b;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000d}.modern-input:focus{outline:none;border-color:#000;background:#fff;box-shadow:0 0 0 4px #0000000d,0 4px 6px -1px #0000000d}.modern-input::placeholder{color:#94a3b8}.password-modern-wrapper{position:relative;display:flex;align-items:center}.password-reveal-btn{position:absolute;right:1rem;background:transparent;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:6px;transition:all .2s}.password-reveal-btn:hover{color:#000;background:#f4f4f5}.modern-error-msg{display:flex;align-items:center;gap:.5rem;color:#ef4444;font-size:.9rem;font-weight:600;background:#fef2f2;padding:.75rem 1rem;border-radius:10px;border:1px solid #FEE2E2}.form-submit-row{margin-top:1rem;display:flex;flex-direction:column;gap:1.25rem}.premium-submit-btn{width:100%;padding:1rem 1.5rem;background:#000;color:#fff;border:none;border-radius:14px;font-size:1.1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #00000026}.premium-submit-btn:hover:not(:disabled){background:#27272a;transform:translateY(-2px);box-shadow:0 8px 20px #0003}.premium-submit-btn:active:not(:disabled){transform:translateY(0)}.premium-submit-btn:disabled{background:#cbd5e1;cursor:not-allowed;box-shadow:none}.terms-hint{font-size:.8rem;color:#94a3b8;text-align:center;line-height:1.4}.premium-title{font-size:2.5rem;font-weight:900;color:#0f172a;letter-spacing:-.04em;margin-bottom:.5rem}.register-success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.5rem}.success-icon-box{width:80px;height:80px;border-radius:24px;background:#000;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 40px #00000026;margin-bottom:1rem}.success-hint{background:#f8fafc;padding:1rem;border-radius:12px;border-left:4px solid #3B82F6;color:#64748b!important;text-align:left;font-size:.85rem!important}.terms-checkbox-container{margin:.5rem 0}.terms-label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.terms-label input[type=checkbox]{width:20px;height:20px;margin-top:.1rem;cursor:pointer}.checkmark-text{font-size:.9rem;color:#64748b;line-height:1.4}.inline-link{background:transparent;border:none;padding:0;color:#000;font-weight:700;text-decoration:underline;cursor:pointer;font-size:inherit;display:inline}.inline-link:hover{color:#333}.terms-modal-content{max-width:600px!important;max-height:80vh;display:flex;flex-direction:column}.terms-scroll-area{margin:1.5rem 0;padding-right:1rem;overflow-y:auto;max-height:50vh;scrollbar-width:thin}.terms-scroll-area::-webkit-scrollbar{width:4px}.terms-scroll-area::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:10px}.terms-scroll-area h3{font-size:1.1rem;font-weight:800;color:#1e293b;margin:1.5rem 0 .5rem}.terms-scroll-area h3:first-child{margin-top:0}.terms-scroll-area p{font-size:.95rem;color:#475569;line-height:1.6;margin-bottom:1rem}.terms-footer{display:flex;justify-content:flex-end;border-top:1px solid #E2E8F0;padding-top:1.25rem}.premium-submit-btn.small{width:auto;padding:.75rem 2rem;font-size:1rem}.onboarding-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#fff;padding:1.5rem}.onboarding-card-wrapper{background:#fff;border-radius:1.75rem;padding:2.25rem;width:100%;max-width:400px;box-shadow:0 25px 70px #00000014,0 0 0 1px #00000005;min-height:480px;display:flex;flex-direction:column}.onboarding-slide{display:flex;flex-direction:column;flex:1}.slide-header{text-align:center;margin-bottom:1.5rem}.slide-icon-box{width:64px;height:64px;background:#f4f4f5;border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:#000}.slide-icon-main{width:32px;height:32px}.slide-title{font-size:1.5rem;font-weight:900;color:var(--text-primary);margin:0 0 .5rem;line-height:1.2}.slide-description{color:var(--text-muted);font-size:.95rem;font-weight:500}.slide-bullets{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:1rem}.slide-bullets li{display:flex;align-items:center;gap:.75rem;font-size:.9rem;font-weight:600;color:var(--text-secondary)}.bullet-check{color:#000;width:16px;height:16px;flex-shrink:0}.slide-footer{margin-top:auto;display:flex;flex-direction:column;gap:1.5rem}.slide-dots{display:flex;justify-content:center;gap:.5rem}.slide-dot{width:8px;height:8px;border-radius:50%;background:#e2e8f0;transition:all .3s ease}.slide-dot.active{width:24px;border-radius:4px;background:#000}.slide-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem}.btn-skip{background:transparent;border:none;color:var(--text-muted);font-weight:700;font-size:1rem;cursor:pointer;padding:.5rem 1rem;transition:all .2s}.btn-skip:hover{color:var(--text-primary)}.onboarding-btn-next{flex:1;background:#000;color:#fff;border:none;padding:.85rem 1.5rem;border-radius:1rem;font-size:1rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:.6rem;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1);box-shadow:0 10px 25px #00000026}.onboarding-btn-next:hover{background:#27272a;transform:translateY(-2px);box-shadow:0 15px 35px #00000040}.onboarding-btn-next:active{transform:scale(.98)}.floating-chat-container{position:fixed;z-index:2000}.floating-chat-trigger{position:fixed;right:24px;bottom:100px;width:50px;height:50px;border-radius:50%;background:#111;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;box-shadow:0 10px 20px #0003,0 4px 6px #0000001a;z-index:2001;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}@media(min-width:1025px){.floating-chat-trigger{bottom:30px}}.floating-chat-trigger:hover{transform:scale(1.1);box-shadow:0 15px 35px #1e3a8a59}.floating-chat-trigger.active{background:#000}@keyframes pulse-dot{0%{box-shadow:0 0 #00d2d3b3}70%{box-shadow:0 0 0 6px #00d2d300}to{box-shadow:0 0 #00d2d300}}.chat-notification-dot{position:absolute;top:10px;right:10px;width:10px;height:10px;background:#00d2d3;border:2px solid #111111;border-radius:50%;animation:pulse-dot 2s infinite}.chat-modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1999}.chat-modal{position:fixed;top:50%;left:50%;width:90%;max-width:400px;height:600px;max-height:80vh;background:#fffffff2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:2rem;display:flex;flex-direction:column;overflow:hidden;z-index:2000;box-shadow:0 30px 60px #00000040,0 0 0 1px #ffffff80;border:1px solid rgba(255,255,255,.2)}@media(max-width:480px){.chat-modal{height:70vh}}.chat-modal-header{padding:1.25rem 1.5rem;background:#fffc;border-bottom:1px solid rgba(0,0,0,.05);display:flex;align-items:center;justify-content:space-between}.chat-header-main{display:flex;align-items:center;gap:.75rem}.header-icon{color:var(--primary-color)}.header-text h3{font-size:1rem;font-weight:850;margin:0;color:var(--text-primary)}.header-text p{font-size:.65rem;font-weight:700;color:var(--text-muted);margin:0;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:3px}.chat-close-btn{background:#0000000d;border:none;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s}.chat-close-btn:hover{background:#0000001a;transform:rotate(90deg)}.chat-modal-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth;background:linear-gradient(to bottom,#f8faff,#fff)}.empty-chat-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center}.empty-icon-box{width:64px;height:64px;background:#1e3a8a0d;border-radius:20px;display:flex;align-items:center;justify-content:center;color:var(--primary-color);margin-bottom:1rem}.empty-chat-state p{font-weight:800;margin:0;color:var(--text-primary)}.empty-chat-state span{font-size:.8rem}.chat-bubble-row{display:flex;align-items:flex-end;gap:.6rem;max-width:85%}.chat-bubble-row.me{align-self:flex-end;flex-direction:row-reverse}.chat-avatar-small{width:28px;height:28px;background:var(--gradient-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;flex-shrink:0}.chat-bubble{padding:.75rem 1rem;border-radius:1.25rem;position:relative;box-shadow:0 4px 12px #00000008}.chat-bubble-row.me .chat-bubble{background:var(--primary-color);color:#fff;border-radius:1.25rem 1.25rem 0;box-shadow:0 8px 20px #1e3a8a33}.chat-bubble-row.other .chat-bubble{background:#fff;color:var(--text-primary);border:1px solid rgba(0,0,0,.04);border-radius:1.25rem 1.25rem 1.25rem 0}.chat-sender-info{font-size:.65rem;font-weight:800;margin-bottom:.25rem;color:var(--primary-color)}.chat-sender-info .role{opacity:.6;font-weight:600}.chat-bubble p{margin:0;font-size:.9rem;line-height:1.4;font-weight:500}.time{font-size:.6rem;opacity:.6;display:block;margin-top:.3rem;text-align:right}.chat-bubble-row.me .time{color:#fffc}.chat-bubble-row.system{align-self:center;max-width:95%;margin:.5rem 0;justify-content:center}.chat-bubble.system{background:linear-gradient(135deg,#1e3a8af2,#3b82f6f2);color:#fff;border-radius:1rem;padding:.85rem 1.25rem;text-align:center;box-shadow:0 10px 25px #1e3a8a40;border:1px solid rgba(255,255,255,.15)}.chat-bubble.system p{font-size:.85rem;font-weight:750;line-height:1.5}.chat-bubble.system .time{color:#fff9;text-align:center;margin-top:.4rem}.chat-modal-input{padding:1.25rem;background:#fff;border-top:1px solid rgba(0,0,0,.05);display:flex;gap:.75rem}.modal-input-field{flex:1;background:#f8faff;border:1px solid rgba(0,0,0,.06);border-radius:1.25rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;outline:none;transition:all .2s}.modal-input-field:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 3px #1e3a8a0d}.modal-send-btn{width:44px;height:44px;border-radius:14px;background:var(--primary-color);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.modal-send-btn:hover:not(:disabled){transform:scale(1.05);filter:brightness(1.1)}.modal-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-modal-messages::-webkit-scrollbar{width:6px}.chat-modal-messages::-webkit-scrollbar-track{background:transparent}.chat-modal-messages::-webkit-scrollbar-thumb{background:#0000001a;border-radius:10px}.app{display:flex;min-height:100vh;position:relative;background:#fff}.main-content{flex:1;margin-left:280px;padding:0 0 3rem;min-height:100vh;position:relative;z-index:1}@media(max-width:1024px){.main-content{margin-left:0;padding:0 1rem 160px}}.splash-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:radial-gradient(circle at center,#fff,#f8fafc);display:flex;align-items:center;justify-content:center;z-index:9999}.splash-content{display:flex;flex-direction:column;align-items:center;gap:2rem;width:100%;max-width:400px;padding:0 2rem}.splash-logo-container{perspective:1000px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.05))}.splash-logo{height:320px;width:auto;object-fit:contain}.splash-text-container{text-align:center;display:flex;flex-direction:column;gap:.5rem;margin-top:-1rem}.splash-title{font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:800;color:#000;letter-spacing:-.02em}.splash-subtitle{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.25em}.splash-loader-container{width:140px;display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:1rem}.splash-loader-bar{width:100%;height:1px;background:#e2e8f0;border-radius:99px;overflow:hidden}.loader-fill{height:100%;background:#000}.loading-status{font-size:.7rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.1em}.mobile-nav-wrapper{display:none}@media(max-width:1024px){.mobile-nav-wrapper{display:block}}.bottom-tab-bar{position:fixed;bottom:20px;left:20px;right:20px;height:64px;background:#ffffffb3;backdrop-filter:blur(35px) saturate(200%);-webkit-backdrop-filter:blur(35px) saturate(200%);border:1px solid rgba(255,255,255,.6);display:flex;justify-content:space-around;align-items:center;padding:0 4px;border-radius:32px;z-index:1000;box-shadow:0 25px 50px #0003,0 10px 20px #0000001a,inset 0 1px #ffffff80}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;height:48px;color:#71717a;transition:all .4s cubic-bezier(.23,1,.32,1);position:relative;cursor:pointer;border-radius:24px;z-index:1}.tab-item.active{color:#000}.tab-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;position:relative;z-index:2}.tab-label{font-size:.52rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;position:relative;z-index:2}.more-menu-drawer{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:32px 32px 0 0;padding:24px;padding-bottom:calc(100px + env(safe-area-inset-bottom));z-index:1001;box-shadow:0 -10px 40px #0000001a}.more-menu-drawer.crystal-drawer{background:#fffc;backdrop-filter:blur(25px) saturate(180%);-webkit-backdrop-filter:blur(25px) saturate(180%);border-top:1px solid rgba(255,255,255,.6);border-radius:40px 40px 0 0;padding:30px;box-shadow:0 -15px 40px #0000001a}.drawer-handle{width:36px;height:5px;background:#0000001a;border-radius:10px;margin:-15px auto 25px}.menu-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.menu-profile-section{display:flex;align-items:center;gap:12px;background:#fff6;border-radius:20px;padding:16px;margin-bottom:24px;border:1px solid rgba(255,255,255,.5)}.menu-profile-avatar{width:44px;height:44px;background:#000;color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center}.menu-profile-avatar img{width:100%;height:100%;object-fit:cover;border-radius:12px}.profile-info{display:flex;flex-direction:column}.profile-name{font-weight:800;font-size:1rem;color:var(--text-primary)}.profile-role{font-size:.7rem;font-weight:700;color:#000;text-transform:uppercase;letter-spacing:.05em}.menu-items-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:30px}.menu-grid-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#ffffff73;border:1px solid rgba(255,255,255,.7);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;height:90px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;box-shadow:0 4px 10px #0000000a,inset 0 1px #ffffff80}.menu-grid-item:hover{background:#fff;transform:translateY(-4px);box-shadow:0 12px 25px #0000001a;border-color:#0003}.menu-grid-item.active{background:#000;border-color:#000;color:#fff;box-shadow:0 10px 20px #00000040,inset 0 1px #fff3}.menu-item-icon{color:#000;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.menu-grid-item.active .menu-item-icon,.menu-grid-item.active .menu-item-label{color:#fff;filter:none}.menu-item-label{font-size:.75rem;font-weight:800;color:var(--text-primary)}.menu-logout-btn{width:100%;padding:14px;background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.15);border-radius:20px;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:800;font-size:.9rem;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);height:56px;transition:all .3s ease}.menu-logout-btn:active{background:#ef4444;color:#fff}.top-header{position:fixed;top:0;left:400px;right:0;height:90px;padding-top:20px;background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-bottom:none!important;z-index:900;transition:all var(--transition-base);pointer-events:none}.top-header-inner{max-width:1400px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:flex-start;padding:0 var(--spacing-2xl)}.top-header-left{display:flex;align-items:center;gap:var(--spacing-md)}.logo-container{display:none;align-items:center;pointer-events:auto}.logo-img{width:80px;height:auto;object-fit:contain;filter:drop-shadow(0 4px 10px rgba(0,0,0,.1))}.logo-text{font-family:Montserrat,sans-serif;font-weight:850;font-size:1.15rem;color:var(--text-primary);letter-spacing:.12em}.top-header-right{display:flex;align-items:center;gap:1rem}.header-action-btn{width:40px;height:40px;border-radius:12px;border:none;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.header-action-btn:hover{background:var(--bg-secondary);color:var(--primary-color)}.notification-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;background:#ef4444;border:2px solid white;border-radius:50%}.user-avatar-small{width:36px;height:36px;border-radius:50%;background:var(--primary-light);color:var(--primary-color);display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 4px 12px #0000000d}.search-overlay-mobile{position:absolute;inset:0;background:#fff;z-index:1000;display:flex;align-items:center;padding:0 1.5rem}.search-input-wrapper{width:100%;display:flex;align-items:center;gap:1rem;background:var(--bg-secondary);padding:.75rem 1.25rem;border-radius:16px}.search-input-wrapper input{flex:1;border:none;background:transparent;outline:none;font-size:1rem;font-family:inherit;color:var(--text-primary)}.search-icon-inner{color:var(--text-muted)}.search-input-wrapper button{background:transparent;border:none;color:var(--text-muted);cursor:pointer}@media(max-width:1024px){.top-header{left:0;height:64px}.top-header-inner{padding:0 1.25rem}.logo-container{display:flex}.logo-img{width:38px}}.live-notification{position:fixed;bottom:100px;left:50%;transform:translate(-50%);width:calc(100% - 2rem);max-width:420px;background:#0f172a;border-radius:1.5rem;padding:1.5rem;color:#fff;z-index:2000;box-shadow:0 25px 60px #0f172a80,0 10px 30px #0f172a4d,0 0 0 1px #ffffff14;overflow:hidden}.live-notification-glow{position:absolute;top:-60px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.25) 0%,transparent 70%);pointer-events:none;animation:notification-glow-pulse 3s ease-in-out infinite}@keyframes notification-glow-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.live-notification-close{position:absolute;top:.85rem;right:.85rem;width:28px;height:28px;border-radius:50%;background:#ffffff1a;border:none;color:#ffffff80;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:2}.live-notification-close:hover{background:#fff3;color:#fff}.live-notification-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;position:relative}.live-notification-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.live-notification-pulse-ring{position:absolute;width:100%;height:100%;border-radius:14px;border:2px solid rgba(59,130,246,.5);animation:notification-pulse 2s ease-out infinite}.live-notification-pulse-ring.delay{animation-delay:.5s}@keyframes notification-pulse{0%{transform:scale(1);opacity:.8}to{transform:scale(1.6);opacity:0}}.live-notification-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.6rem;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:#ef4444;background:#ef444426;padding:.3rem .65rem;border-radius:20px;border:1px solid rgba(239,68,68,.25);animation:badge-pulse 1.5s ease-in-out infinite}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.6}}.live-notification-content{margin-bottom:1.25rem;position:relative}.live-notification-title{font-size:1.1rem;font-weight:800;margin:0 0 .4rem;letter-spacing:-.01em}.live-notification-description{font-size:.82rem;color:#ffffffa6;margin:0 0 .65rem;line-height:1.4}.live-notification-description strong{color:#ffffffe6}.live-notification-repertoire{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:.82rem;font-weight:700;color:#ffffffe6;margin-bottom:.5rem}.live-notification-meta{display:flex;align-items:center;gap:.75rem;font-size:.72rem;color:#fff6;font-weight:600}.live-notification-songs{display:flex;align-items:center;gap:.3rem}.live-notification-actions{display:flex;gap:.5rem;position:relative}.live-notification-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.85rem;border:none;border-radius:14px;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s ease}.live-notification-btn--accept{background:linear-gradient(135deg,#10b981,#059669);color:#fff;flex:2;box-shadow:0 8px 24px #10b9814d}.live-notification-btn--accept:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #10b98166}.live-notification-btn--accept:disabled{opacity:.7;cursor:wait;transform:none}.live-notification-btn--dismiss{background:#ffffff14;color:#fff9;border:1px solid rgba(255,255,255,.1)}.live-notification-btn--dismiss:hover{background:#ffffff1f;color:#fffc}.live-notification-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:notif-spin .8s linear infinite}@keyframes notif-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.live-notification{bottom:85px;padding:1.25rem;border-radius:1.25rem}.live-notification-title{font-size:1rem}.live-notification-icon{width:42px;height:42px;border-radius:12px}.live-notification-actions{flex-direction:column}.live-notification-btn--accept{flex:1}}@media(max-width:480px){.live-notification{bottom:75px;width:calc(100% - 1.5rem);padding:1rem}.live-notification-title{font-size:.95rem}}
