:root{--bg-color:#0f0f11;--surface-color:#18181b;--surface-hover:#27272a;--text-primary:#e2e8f0;--text-secondary:#a1a1aa;--accent-primary:#38bdf8;--accent-glow:#38bdf833;--success-color:#34d399;--success-glow:#34d39933;--font-primary:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-secondary:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-12:48px;--space-16:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-glow:0 0 15px var(--accent-glow);--shadow-success:0 0 15px var(--success-glow)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-secondary);background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;min-height:100vh;line-height:1.5;display:flex}#root{flex-direction:column;flex:1;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);letter-spacing:-.02em;font-weight:600}button{cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit}input,textarea{border:none;outline:none;font-family:inherit}.glass-panel{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);background:#18181bb3;border:1px solid #ffffff0d}::-webkit-scrollbar{background:0 0;width:0}.error-fallback{padding:var(--space-6);background:var(--bg-color);z-index:9999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.error-fallback-card{text-align:center;width:100%;max-width:380px;padding:var(--space-8);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);background:#18181bb3;border:1px solid #ffffff0d}.error-fallback-card h1{margin-bottom:var(--space-3);font-size:1.5rem}.error-fallback-card p{color:var(--text-secondary);margin-bottom:var(--space-6);font-size:.95rem}.error-fallback-actions{gap:var(--space-3);justify-content:center;display:flex}.error-fallback-btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-full);font-family:var(--font-primary);color:var(--text-secondary);border:1px solid #ffffff1a;font-size:.9rem;font-weight:600;transition:transform .18s cubic-bezier(.16,1,.3,1),background .2s;display:inline-flex}.error-fallback-btn.primary{color:#06141d;background:var(--accent-primary);border-color:#0000}.error-fallback-btn:active{transform:scale(.95)}.context-menu-content{z-index:1000;-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);min-width:180px;padding:var(--space-2);gap:var(--space-1);transform-origin:var(--radix-context-menu-content-transform-origin);background:#141417f2;border:1px solid #ffffff1a;flex-direction:column;animation:.15s ease-out contextMenuFadeIn;display:flex;box-shadow:0 10px 40px #00000080}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{text-align:left;width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;align-items:center;gap:var(--space-2);background:0 0;border:none;font-size:.9rem;font-weight:500;transition:background .2s;display:flex}.context-menu-item:hover,.context-menu-item:focus,.context-menu-item[data-highlighted]{background:#ffffff1a;outline:none}.context-menu-item[data-disabled]{opacity:.35;pointer-events:none}.context-menu-item.danger{color:var(--error-color)}.context-menu-item.danger:hover,.context-menu-item.danger:focus,.context-menu-item.danger[data-highlighted]{background:#ef44441a;outline:none}.task-row{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--surface-color);border-radius:var(--radius-lg);cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:var(--space-3);border:1px solid #ffffff08;transition:transform .2s cubic-bezier(.16,1,.3,1),background .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.task-row:hover{background:var(--surface-hover);border-color:#ffffff14}.task-row:active{transform:scale(.98)}.task-checkbox{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:relative}.check-bg{background-color:var(--success-color);box-shadow:var(--shadow-success);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.uncheck-icon{transition:color .2s}.task-row:hover .uncheck-icon{color:var(--text-primary)}.task-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.task-header{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.task-title{font-family:var(--font-primary);color:var(--text-primary);word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:1.05rem;font-weight:500;transition:color .3s}.task-duration{color:var(--accent-primary);background:var(--accent-glow);border-radius:var(--radius-full);padding:2px 8px;font-size:.8rem;font-weight:600}.task-desc{color:var(--text-secondary);word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:.9rem;line-height:1.4;transition:color .3s}.task-row.completed{background:#18181b66;border-color:#0000}.task-row.completed .task-title{color:var(--text-secondary);opacity:.7;text-decoration:line-through}.task-row.completed .task-desc{opacity:.5;text-decoration:line-through}.task-row.completed .task-duration{opacity:.5;background:0 0;border:1px solid #ffffff1a}.task-row.editing{background:var(--surface-hover);border-color:var(--accent-primary);cursor:default}.task-edit-form{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.task-edit-input,.task-edit-textarea{color:var(--text-primary);padding:var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-primary);background:#0003;border:1px solid #ffffff1a;outline:none;width:100%;font-size:.95rem;transition:border-color .2s}.task-edit-input:focus,.task-edit-textarea:focus{border-color:var(--accent-primary)}.task-edit-textarea{resize:none;color:var(--text-secondary);font-size:.85rem}.task-edit-actions{justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-1);display:flex}.task-aside{align-items:flex-end;gap:var(--space-2);flex-direction:column;flex-shrink:0;display:flex}.task-meta{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.task-drill-result{letter-spacing:.02em;color:var(--success-color);font-size:.75rem;font-weight:600}.task-row.completed .task-drill-result{opacity:.55}.task-drill-btn{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-family:var(--font-primary);letter-spacing:.01em;color:var(--accent-primary);background:var(--accent-glow);border:1px solid #0000;flex-shrink:0;font-size:.78rem;font-weight:600;transition:transform .18s cubic-bezier(.16,1,.3,1),background .2s,border-color .2s;display:inline-flex}.task-drill-btn:hover{background:#38bdf838;border-color:#38bdf866}.task-drill-btn:active{transform:scale(.94)}.task-duration-field{align-items:center;width:100%;display:flex;position:relative}.task-duration-field input{padding-right:3.4rem}.task-duration-suffix{right:var(--space-3);font-family:var(--font-primary);color:var(--text-secondary);pointer-events:none;font-size:.9rem;position:absolute}.drill-edit{gap:var(--space-2);padding-top:var(--space-1);flex-direction:column;display:flex}.drill-edit-label{letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);font-size:.72rem;font-weight:600}.drill-segment{gap:var(--space-1);border-radius:var(--radius-md);background:#00000040;border:1px solid #ffffff0f;padding:3px;display:flex}.drill-segment-btn{padding:var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-primary);color:var(--text-secondary);flex:1;font-size:.78rem;font-weight:600;transition:color .2s,background .2s}.drill-segment-btn:hover{color:var(--text-primary)}.drill-segment-btn.active{color:#06141d;background:var(--accent-primary)}.drill-chords{align-items:center;gap:var(--space-3);display:flex}.drill-select{appearance:none;text-align:center;color:var(--text-primary);padding:var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-primary);cursor:pointer;background:#00000040;border:1px solid #ffffff1a;flex:1;font-size:.95rem;font-weight:600;transition:border-color .2s}.drill-select:focus{border-color:var(--accent-primary)}.drill-segment-btn{font-size:.72rem}.drill-hint{color:var(--text-secondary);font-size:.75rem}.drill-chip-grid{gap:var(--space-2);flex-wrap:wrap;display:flex}.drill-chip{min-width:44px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-primary);background:#00000040;border:1px solid #ffffff1a;font-size:.9rem;font-weight:600;transition:color .2s,background .2s,border-color .2s}.drill-chip.active{color:var(--accent-primary);background:var(--accent-glow);border-color:#38bdf866}.drill-song-select{cursor:pointer}.drill-song-select option{color:var(--text-primary);background:#1a1a1d}.drill-blocks{gap:var(--space-2);flex-direction:column;display:flex}.drill-block-row{align-items:center;gap:var(--space-2);display:flex}.drill-block-row .task-input{min-width:0}.drill-block-mins{flex:0 0 92px;align-items:center;display:flex;position:relative}.drill-block-mins input{text-align:center;padding-right:2.6rem}.drill-block-mins .task-duration-suffix{right:var(--space-2);position:absolute}.drill-block-remove{padding:var(--space-2);border-radius:var(--radius-sm);color:var(--text-secondary);flex:none;justify-content:center;align-items:center;transition:color .2s,background .2s;display:inline-flex}.drill-block-remove:hover{color:#f87171;background:#f871711a}.drill-block-add{justify-content:center;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-primary);border:1px dashed #ffffff2e;align-self:flex-start;font-size:.78rem;font-weight:600;transition:color .2s,border-color .2s;display:inline-flex}.drill-block-add:hover{color:var(--accent-primary);border-color:#38bdf866}.drill-block{gap:var(--space-1);padding:var(--space-2);border-radius:var(--radius-sm);background:#0000002e;flex-direction:column;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0006;position:fixed;inset:0}.modal-wrapper{z-index:101;pointer-events:none;display:flex;position:fixed;inset:0}.modal-wrapper>*{pointer-events:auto}.position-center{padding:var(--space-6);justify-content:center;align-items:center}.position-bottom{padding-bottom:var(--space-8);justify-content:center;align-items:flex-end}.position-top-right{padding-top:80px;padding-right:var(--space-4);justify-content:flex-end;align-items:flex-start}.position-top-right .modal-content{max-width:320px;padding:var(--space-4)}.modal-content{border-radius:var(--radius-2xl);width:100%;max-width:400px;max-height:90vh;padding:var(--space-6);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#18181bf2;border:1px solid #ffffff0d;position:relative;overflow-y:auto;box-shadow:0 25px 50px -12px #00000080}.position-bottom .modal-content{max-width:500px}.modal-header{margin-bottom:var(--space-4);padding-right:var(--space-6);justify-content:flex-start;align-items:center;display:flex}.modal-title{color:var(--text-primary);font-size:1.1rem;font-weight:500}.modal-close{top:var(--space-4);right:var(--space-4);color:var(--text-secondary);padding:var(--space-2);border-radius:var(--radius-full);z-index:10;background:0 0;border:none;justify-content:center;align-items:center;transition:color .2s,background .2s;display:flex;position:absolute}.modal-close:hover{color:var(--text-primary);background:#ffffff0d}.app-loader{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-8);flex-direction:column;display:flex}.app-loader.is-overlay{z-index:200;-webkit-backdrop-filter:blur(12px);background:#0a0a0cdb;position:fixed;inset:0}.app-loader-strings{flex-direction:column;gap:8px;width:120px;display:flex}.app-loader-string{background:#ffffff1a;border-radius:2px;height:2px;position:relative;overflow:hidden}.app-loader-string:first-child{height:3px}.app-loader-string:nth-child(2){height:2.5px}.app-loader-string:nth-child(3){height:2px}.app-loader-string:nth-child(4){height:1.5px}.app-loader-string:nth-child(5){height:1.2px}.app-loader-string:nth-child(6){height:1px}.app-loader-string:after{content:"";background:linear-gradient(90deg,#0000,#38bdf8cc,#0000);width:100%;height:100%;animation:1.5s ease-in-out infinite app-loader-strum;position:absolute;top:0;left:-100%}.app-loader-string:first-child:after{animation-delay:0s}.app-loader-string:nth-child(2):after{animation-delay:.1s}.app-loader-string:nth-child(3):after{animation-delay:.2s}.app-loader-string:nth-child(4):after{animation-delay:.3s}.app-loader-string:nth-child(5):after{animation-delay:.4s}.app-loader-string:nth-child(6):after{animation-delay:.5s}@keyframes app-loader-strum{0%{left:-100%}to{left:100%}}.app-loader-label{font-family:var(--font-secondary);letter-spacing:.08em;color:var(--text-secondary);font-size:.8rem}.task-creator-content{gap:var(--space-4);flex-direction:column;display:flex}.task-creator-header{justify-content:space-between;align-items:center;display:flex}.task-creator-title{font-family:var(--font-primary);color:var(--text-primary);margin-bottom:0;font-size:1.25rem;font-weight:600}.task-creator-close{color:var(--text-secondary);border-radius:var(--radius-full);padding:var(--space-1);background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.task-creator-close:hover{color:var(--text-primary);background:#ffffff1a}.task-creator-form{gap:var(--space-4);flex-direction:column;display:flex}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-group label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.task-input{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--text-primary);background:#ffffff0d;border:1px solid #ffffff1a;outline:none;font-size:1rem;transition:all .2s}.task-input:focus{background:#ffffff14;border-color:#38bdf880}.task-textarea{resize:none;min-height:80px}.task-submit-btn{justify-content:center;align-items:center;gap:var(--space-2);background:var(--text-primary);color:var(--bg-color);padding:var(--space-3);border-radius:var(--radius-lg);margin-top:var(--space-2);border:none;font-weight:600;transition:transform .2s,opacity .2s;display:flex}.task-submit-btn:disabled{opacity:.5;cursor:not-allowed}.task-submit-btn:not(:disabled):hover{opacity:.9}.task-submit-btn:not(:disabled):active{transform:scale(.98)}.routine-manager-content{gap:var(--space-4);flex-direction:column;display:flex}.routine-vocab{gap:var(--space-2);margin-top:var(--space-2);flex-direction:column;display:flex}.routine-vocab-label{font-family:var(--font-secondary);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:.68rem}.routine-vocab-chips{gap:var(--space-2);flex-wrap:wrap;display:flex}.routine-vocab-chip{min-width:40px;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-primary);background:#ffffff0a;border:1px solid #ffffff14;font-size:.85rem;font-weight:600;transition:color .2s,background .2s,border-color .2s}.routine-vocab-chip.is-on{color:var(--accent-primary);background:var(--accent-glow);border-color:#38bdf866}.routine-manager-header{justify-content:space-between;align-items:center;display:flex}.header-title-row{align-items:center;gap:var(--space-2);display:flex}.routine-manager-title{font-family:var(--font-primary);color:var(--text-primary);margin-bottom:0;font-size:1.25rem;font-weight:600}.routine-manager-close{color:var(--text-secondary);border-radius:var(--radius-full);padding:var(--space-1);background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.routine-manager-close:hover{color:var(--text-primary);background:#ffffff1a}.routines-list{gap:var(--space-2);padding-right:var(--space-2);flex-direction:column;display:flex}.routine-edit-item{border-radius:var(--radius-lg);padding:var(--space-3);background:#ffffff08;border:1px solid #ffffff0d;transition:background .2s}.routine-edit-item:hover{background:#ffffff0d}.routine-edit-display-row,.routine-edit-input-row{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.routine-edit-name{color:var(--text-primary);cursor:text;padding:var(--space-1);border-radius:var(--radius-sm);flex:1;font-weight:500}.routine-edit-name:hover{background:#ffffff0d}.routine-edit-input{border:1px solid var(--accent-primary);color:var(--text-primary);padding:var(--space-2);border-radius:var(--radius-sm);background:#0003;outline:none;flex:1;font-size:1rem}.routine-actions{gap:var(--space-2);display:flex}.icon-btn{padding:var(--space-1);border-radius:var(--radius-md);color:var(--text-secondary);background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.icon-btn:disabled{opacity:.3;cursor:not-allowed}.icon-btn.danger:not(:disabled):hover{color:#ef4444;background:#ef44441a}.icon-btn.success:hover{color:var(--success-color);background:#34d3991a}.routine-manager-actions{gap:var(--space-3);padding-top:var(--space-2);display:flex}.create-routine-btn{color:var(--text-primary);padding:var(--space-2);border-radius:var(--radius-lg);background:#ffffff0d;border:1px dashed #fff3;flex:1;font-weight:500;transition:all .2s}.create-routine-btn:hover{background:#ffffff1a;border-color:#ffffff4d}.import-json-btn{align-items:center;gap:var(--space-2);color:var(--text-secondary);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);background:0 0;border:none;font-size:.9rem;transition:color .2s;display:flex}.import-json-btn:hover{color:var(--text-primary);background:#ffffff0d}.json-import-box{border-radius:var(--radius-lg);padding:var(--space-3);gap:var(--space-3);margin-top:var(--space-2);background:#0003;border:1px solid #ffffff0d;flex-direction:column;animation:.2s ease-out forwards slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.json-hint{color:var(--text-secondary);font-size:.85rem}.json-error{color:#ef4444;padding:var(--space-2);border-radius:var(--radius-sm);background:#ef44441a;font-size:.85rem}.json-textarea{border-radius:var(--radius-md);width:100%;height:120px;padding:var(--space-3);color:var(--text-primary);resize:none;background:#18181b80;border:1px solid #ffffff1a;font-family:monospace;font-size:.85rem}.json-textarea:focus{border-color:var(--accent-primary);outline:none}.json-submit-btn{justify-content:center;align-items:center;gap:var(--space-2);background:var(--text-primary);color:var(--bg-color);padding:var(--space-2);border-radius:var(--radius-md);border:none;align-self:flex-end;font-weight:500;display:flex}.json-submit-btn:disabled{opacity:.5;cursor:not-allowed}.slate-view{gap:var(--space-4);flex-direction:column;animation:.2s ease-out fade-in;display:flex}@keyframes fade-in{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.slate-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.back-btn{color:var(--text-primary);border-radius:var(--radius-full);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.back-btn:hover{background:#ffffff1a}.slate-title{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:600}.slate-form{gap:var(--space-4);flex-direction:column;display:flex}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-group label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.input-group input{color:var(--text-primary);padding:var(--space-3);border-radius:var(--radius-lg);background:#0003;border:1px solid #ffffff1a;outline:none;font-size:1rem;transition:border-color .2s}.input-group input:focus{border-color:var(--accent-primary)}.slate-submit-btn{background:var(--accent-primary);color:var(--bg-color);padding:var(--space-3);border-radius:var(--radius-lg);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-2);border:none;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.slate-submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #38bdf833}.slate-submit-btn:disabled{opacity:.5;cursor:not-allowed;color:var(--text-secondary);box-shadow:none;background:#ffffff1a}.progress-empty{color:var(--text-secondary);text-align:center;padding:var(--space-6) var(--space-2);font-size:.95rem;line-height:1.6}.progress-root{gap:var(--space-4);flex-direction:column;display:flex}.progress-reco{align-items:center;gap:var(--space-3);text-align:left;width:100%;padding:var(--space-4);border-radius:var(--radius-lg);background:var(--accent-glow);color:var(--text-primary);cursor:pointer;border:1px solid #38bdf840;transition:transform .18s cubic-bezier(.16,1,.3,1),background .2s,border-color .2s;display:flex}.progress-reco:hover{background:#38bdf838;border-color:#38bdf873}.progress-reco:active{transform:scale(.99)}.progress-reco-icon{color:var(--accent-primary);flex-shrink:0}.progress-reco-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.progress-reco-label{font-family:var(--font-secondary);letter-spacing:.1em;text-transform:uppercase;color:var(--accent-primary);font-size:.68rem}.progress-reco-pair{font-family:var(--font-primary);font-size:1.05rem;font-weight:600}.progress-reco-reason{font-family:var(--font-secondary);color:var(--text-secondary);font-size:.8rem;font-weight:500}.progress-reco-go{border-radius:var(--radius-full);background:var(--accent-primary);color:#06141d;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.progress-summary{gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-lg);background:#ffffff08;border:1px solid #ffffff0f;grid-template-columns:repeat(3,1fr);display:grid}.progress-stat{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.progress-stat+.progress-stat{border-left:1px solid #ffffff0f}.progress-stat-value{font-family:var(--font-primary);color:var(--text-primary);font-size:1.8rem;font-weight:700;line-height:1}.progress-stat-streak{color:#fb923c;align-items:center;gap:4px;display:inline-flex}.progress-stat-label{font-family:var(--font-secondary);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:.7rem}.progress-chart-card{padding:var(--space-4);border-radius:var(--radius-lg);background:#ffffff08;border:1px solid #ffffff0f}.progress-chart-head{margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-start;display:flex}.progress-chart-titles{flex-direction:column;gap:2px;display:flex}.progress-chart-pair{font-family:var(--font-primary);color:var(--text-primary);font-size:1.1rem;font-weight:700}.progress-chart-sub{font-family:var(--font-secondary);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:.7rem}.progress-chart-best{font-family:var(--font-primary);color:var(--accent-primary);font-size:1.8rem;font-weight:700;line-height:1}.progress-chart{width:100%;height:auto;display:block}.chart-axis{fill:var(--text-secondary);font-size:11px;font-family:var(--font-secondary);opacity:.7}.chart-empty{color:var(--text-secondary);text-align:center;padding:var(--space-8) 0}.progress-pairs{gap:var(--space-2);flex-direction:column;display:flex}.progress-pair-row{align-items:center;gap:var(--space-3);text-align:left;width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);cursor:pointer;background:#ffffff08;border:1px solid #ffffff0f;transition:background .2s,border-color .2s;display:flex}.progress-pair-row:hover{background:#ffffff0d}.progress-pair-row.is-active{background:var(--accent-glow);border-color:#38bdf859}.progress-pair-name{font-family:var(--font-primary);color:var(--text-primary);flex:1;font-size:1rem;font-weight:600}.progress-pair-best{font-family:var(--font-primary);color:var(--text-primary);align-items:baseline;gap:3px;font-size:1.1rem;font-weight:700;display:inline-flex}.progress-pair-unit{color:var(--text-secondary);text-transform:uppercase;font-size:.65rem;font-weight:600}.progress-trend{padding:2px var(--space-2);border-radius:var(--radius-full);font-family:var(--font-secondary);justify-content:center;align-items:center;gap:3px;min-width:52px;font-size:.72rem;font-weight:700;display:inline-flex}.progress-trend.is-up{color:var(--success-color);background:var(--success-glow)}.progress-trend.is-down{color:#f87171;background:#f871711f}.progress-trend.is-flat{color:var(--text-secondary);background:#ffffff0d}@media (width<=600px){.progress-stat-value,.progress-chart-best{font-size:1.5rem}.progress-summary,.progress-chart-card{padding:var(--space-3)}}.daily-path{align-items:center;gap:var(--space-6);flex-direction:column;width:100%;display:flex}.path-header-center{justify-content:center;align-items:center;gap:var(--space-3);width:100%;padding:0 var(--space-3);z-index:30;flex-wrap:wrap;display:flex}@media (width<=600px){.path-header-center{gap:var(--space-2)}.routine-selector,.progress-launch{padding:var(--space-2) var(--space-4);font-size:.85rem}.routine-name{max-width:120px}.progress-launch-icon{font-size:1rem}}.routine-selector-container{position:relative}.progress-launch{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-primary);background:#14141666;border:1px solid #ffffff0d;font-size:.95rem;font-weight:600;transition:transform .18s cubic-bezier(.16,1,.3,1),color .2s,background .2s,border-color .2s;display:inline-flex;box-shadow:0 4px 20px #0000001a}.progress-launch:hover{color:var(--text-primary);background:#ffffff14;border-color:#ffffff1a}.progress-launch:active{transform:scale(.95)}.progress-launch-icon{font-size:1.15rem}.routine-selector{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;background:#14141666;border:1px solid #ffffff0d;max-width:100vw;font-weight:500;transition:all .2s;display:flex;box-shadow:0 4px 20px #0000001a}.routine-name{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.routine-selector:hover{background:#ffffff14;border-color:#ffffff1a}.manage-routines-btn{padding:var(--space-2);border-radius:var(--radius-full);cursor:pointer;background:#ffffff08;border:1px solid #ffffff0d;justify-content:center;align-items:center;transition:all .2s;display:flex}.manage-routines-btn:hover{background:#ffffff14;border-color:#ffffff1a}.routine-dropdown{top:calc(100% + var(--space-2));-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);width:250px;padding:var(--space-2);gap:var(--space-1);z-index:100;background:#141417f2;border:1px solid #ffffff1a;flex-direction:column;display:flex;position:absolute;left:0;box-shadow:0 10px 40px #00000080}.dropdown-item{text-align:left;width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;align-items:center;gap:var(--space-2);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;font-size:.95rem;font-weight:500;transition:all .2s;display:flex;overflow:hidden}.dropdown-item:hover{color:var(--text-primary);background:#ffffff0d}.dropdown-item.active{color:var(--accent-primary);background:#38bdf81a}.dropdown-divider{height:1px;margin:var(--space-1) 0;background:#ffffff0d}.dropdown-item.manage-action{color:var(--text-secondary);font-size:.9rem}.dropdown-item.manage-action:hover{color:var(--text-primary)}.task-container-wrapper{width:100%;max-width:800px;padding:0 var(--space-4)}.task-container{border-radius:var(--radius-2xl);background:0 0;border:none;flex-direction:column;width:100%;max-height:calc(100dvh - 10rem);display:flex;overflow:hidden}.task-list-scrollable{min-height:0;padding:var(--space-4);gap:var(--space-2);scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex-direction:column;flex:1;display:flex;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0%,#000 5% 95%,#0000 100%);mask-image:linear-gradient(#0000 0%,#000 5% 95%,#0000 100%)}.task-list-scrollable::-webkit-scrollbar{width:6px}.task-list-scrollable::-webkit-scrollbar-thumb{background-color:#ffffff1a;border-radius:10px}.task-container-footer{padding:var(--space-4) 0;flex-shrink:0;justify-content:flex-start;display:flex}.add-task-btn{align-items:center;gap:var(--space-2);color:var(--text-secondary);background:0 0;border:none;font-size:.95rem;transition:color .2s;display:flex}.add-task-btn:hover{color:var(--text-primary)}.empty-state-placeholder{cursor:text;opacity:.4;padding:0;transition:opacity .2s}.empty-state-placeholder:hover{opacity:.8;background:0 0}.placeholder-text{color:var(--text-secondary);font-size:1.5rem;font-style:normal}.inline-task-creator{background:0 0;border:none;flex-direction:column;align-items:flex-start;padding:0;display:flex}.inline-tooltip{color:var(--accent-primary);margin-bottom:var(--space-2);opacity:.8;font-size:.85rem;font-weight:500}.inline-input-wrapper{align-items:center;width:100%;display:flex}.inline-input.fluid-input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;padding:0;font-size:1.5rem}.inline-input.fluid-input::placeholder{color:#fff3}.jotter-content{gap:var(--space-4);flex-direction:column;display:flex}.jotter-title{font-family:var(--font-primary);color:var(--text-primary);font-size:1.5rem;font-weight:600}.jotter-subtitle{color:var(--text-secondary)}.jotter-input{border-radius:var(--radius-xl);width:100%;min-height:120px;padding:var(--space-4);color:var(--text-primary);resize:none;background:#0003;border:1px solid #ffffff1a;font-size:1rem}.jotter-input:focus{background:#0000004d;border-color:#fff3;outline:none}.jotter-done-btn{background:var(--text-primary);color:var(--bg-color);padding:var(--space-2) var(--space-6);border-radius:var(--radius-full);border:none;align-self:flex-end;font-weight:500;transition:transform .2s,opacity .2s}.jotter-done-btn:hover{opacity:.9}.jotter-done-btn:active{transform:scale(.95)}.app-footer{padding:var(--space-4) var(--space-6);opacity:.5;z-index:50;transition:opacity .3s;display:flex;position:absolute;bottom:0;left:0}.footer-content{align-items:center;gap:var(--space-2);display:flex}.app-footer:hover{opacity:1}.footer-quote{color:var(--text-secondary);letter-spacing:.02em;font-size:.75rem;font-style:italic;font-weight:400}.footer-link{color:var(--text-secondary);transition:color .2s}.footer-link:hover{color:var(--text-primary)}.signal-meter{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-family:var(--font-secondary);letter-spacing:.04em;color:var(--text-secondary);background:#ffffff0a;font-size:.72rem;transition:color .25s,background .25s;display:inline-flex}.signal-mic{opacity:.7;flex-shrink:0}.signal-bars{align-items:flex-end;gap:2px;height:12px;display:inline-flex}.signal-bar{background:#ffffff2e;border-radius:2px;width:3px}.signal-bar:first-child{height:5px}.signal-bar:nth-child(2){height:8px}.signal-bar:nth-child(3){height:12px}.signal-label{white-space:nowrap}.signal-meter.is-good{color:var(--success-color)}.signal-meter.is-good .signal-bar.is-on{background:var(--success-color)}.signal-meter.is-weak{color:#fbbf24}.signal-meter.is-weak .signal-bar.is-on{background:#fbbf24}.signal-meter.is-loud{color:#fbbf24}.signal-meter.is-loud .signal-bar.is-on{background:#fbbf24}.signal-meter.is-silent{color:#f87171}.signal-meter.is-silent .signal-bar.is-on{background:#f87171}.practice-overlay{z-index:100;-webkit-backdrop-filter:blur(20px);background:#0a0a0cdb;flex-direction:column;display:flex;position:fixed;inset:0}.practice-topbar{padding:var(--space-6);justify-content:space-between;align-items:center;display:flex}.practice-eyebrow{font-family:var(--font-secondary);letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary);font-size:.75rem}.practice-topbar-actions{align-items:center;gap:var(--space-2);display:flex}.practice-close{border-radius:var(--radius-full);width:40px;height:40px;color:var(--text-secondary);background:#ffffff0a;justify-content:center;align-items:center;transition:color .2s,background .2s;display:inline-flex}.practice-close:hover{color:var(--text-primary);background:#ffffff14}.practice-close.is-off{color:var(--text-secondary);opacity:.5}.practice-close.is-off:hover{opacity:.8}.practice-body{justify-content:safe center;align-items:center;gap:var(--space-8);min-height:0;padding:var(--space-6) var(--space-6) var(--space-16);text-align:center;flex-direction:column;flex:1;display:flex;overflow-y:auto}@media (width<=600px){.practice-topbar{padding:var(--space-4)}.practice-body{padding:var(--space-4) var(--space-4) var(--space-12);gap:var(--space-6)}.om-selects{gap:var(--space-2)}.om-select{padding:var(--space-2) var(--space-4);font-size:1.25rem}.ct-stats{gap:var(--space-4)}}.practice-mode{letter-spacing:.22em;text-transform:uppercase;color:var(--text-secondary);font-size:.8rem;transition:color .3s}.practice-mode.is-chord{color:var(--accent-primary)}.practice-hero{font-family:var(--font-primary);letter-spacing:-.04em;color:var(--text-primary);will-change:transform;backface-visibility:hidden;contain:layout paint;font-size:clamp(5rem,22vw,12rem);font-weight:600;line-height:1;transition:transform .28s cubic-bezier(.16,1,.3,1),opacity .28s;transform:translateZ(0)}.practice-hero.is-idle{color:var(--text-secondary);opacity:.4}.practice-hero.is-active{transform:translateZ(0)scale(1.06)}.chroma-viz{align-items:flex-end;gap:var(--space-2);width:min(560px,90vw);height:120px;display:flex}.chroma-bar-wrap{align-items:center;gap:var(--space-2);flex-direction:column;flex:1;height:100%;display:flex}.chroma-bar-track{border-radius:var(--radius-sm);background:#ffffff0a;flex:1;align-items:flex-end;width:100%;display:flex;overflow:hidden}.chroma-bar-fill{background:linear-gradient(180deg, var(--accent-primary), #38bdf859);border-radius:var(--radius-sm);width:100%;height:0%;transition:height 90ms linear}.chroma-bar-label{font-family:var(--font-secondary);color:var(--text-secondary);font-size:.7rem}.mic-gate{align-items:center;gap:var(--space-4);flex-direction:column;max-width:420px;display:flex}.mic-gate p{color:var(--text-secondary);font-size:.95rem}.practice-btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);border-radius:var(--radius-full);font-family:var(--font-primary);font-size:1rem;font-weight:600;transition:transform .15s,background .2s,opacity .2s;display:inline-flex}.practice-btn:active{transform:scale(.97)}.practice-btn.primary{background:var(--accent-primary);color:#06141d;box-shadow:var(--shadow-glow)}.practice-btn.ghost{color:var(--text-primary);background:#ffffff0d}.practice-btn:disabled{opacity:.4;cursor:not-allowed}.om-setup{align-items:center;gap:var(--space-8);flex-direction:column;width:min(460px,92vw);display:flex}.om-selects{justify-content:center;align-items:center;gap:var(--space-4);display:flex}.om-select{appearance:none;background:var(--surface-color);color:var(--text-primary);border-radius:var(--radius-md);padding:var(--space-3) var(--space-6);font-family:var(--font-primary);text-align:center;cursor:pointer;border:1px solid #ffffff14;font-size:1.5rem;font-weight:600}.om-arrow{color:var(--text-secondary)}.om-pair{letter-spacing:.16em;text-transform:uppercase;color:var(--text-secondary);align-items:center;gap:var(--space-2);font-size:.85rem;display:flex}.om-pair .target{color:var(--accent-primary)}.om-count{font-family:var(--font-primary);color:var(--text-primary);font-size:clamp(5rem,20vw,10rem);font-weight:700;line-height:1}.om-count.pop{animation:.3s om-pop}@keyframes om-pop{0%{transform:scale(1)}40%{color:var(--accent-primary);transform:scale(1.12)}to{transform:scale(1)}}.om-caption{letter-spacing:.2em;text-transform:uppercase;color:var(--text-secondary);font-size:.8rem}.om-timer{align-items:center;gap:var(--space-2);font-family:var(--font-primary);color:var(--text-secondary);font-size:2rem;display:flex}.om-detected{letter-spacing:.16em;text-transform:uppercase;color:var(--text-secondary);min-height:1.2em;font-size:.8rem}.om-results{align-items:center;gap:var(--space-5);flex-direction:column;width:min(420px,92vw);display:flex;position:relative}.om-saved-hint{font-family:var(--font-secondary);letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);opacity:.6;font-size:.72rem}.om-actions{gap:var(--space-4);width:100%;display:flex}.om-actions .practice-btn{flex:1}.coach-intro{align-items:center;gap:var(--space-3);text-align:center;flex-direction:column;width:min(420px,92vw);display:flex}.coach-intro .om-actions{margin-top:var(--space-2)}.coach-up-next{font-family:var(--font-secondary);letter-spacing:.2em;text-transform:uppercase;color:var(--accent-primary);font-size:.75rem}.coach-intro-title{font-family:var(--font-primary);letter-spacing:-.02em;color:var(--text-primary);font-size:clamp(2rem,7vw,3rem);font-weight:700}.coach-countdown{margin-top:var(--space-4);font-family:var(--font-primary);color:var(--accent-primary);font-size:clamp(4rem,16vw,7rem);font-weight:700;line-height:1}.coach-countdown-ready{margin-top:var(--space-4);font-family:var(--font-primary);color:var(--accent-primary);opacity:.85;font-size:clamp(1.6rem,6vw,2.4rem);font-weight:700;line-height:1.1}.coach-advance{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.coach-advance-label{font-family:var(--font-secondary);letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary);font-size:.72rem}.coach-advance-count{font-family:var(--font-primary);color:var(--accent-primary);font-size:2.4rem;font-weight:700;line-height:1;animation:1s ease-in-out infinite coach-advance-pulse}@keyframes coach-advance-pulse{0%,to{opacity:.65;transform:scale(.96)}50%{opacity:1;transform:scale(1)}}.timed-desc{text-align:center;max-width:min(440px,90vw);color:var(--text-secondary);font-size:.95rem}.coach-summary{align-items:center;gap:var(--space-5);flex-direction:column;width:min(440px,92vw);min-height:0;max-height:100%;display:flex}.coach-summary-head{align-items:center;gap:var(--space-2);flex-direction:column;flex:none;display:flex}.coach-summary-trophy{color:#fbbf24}.coach-summary-title{font-family:var(--font-primary);color:var(--text-primary);font-size:1.6rem;font-weight:700;line-height:1.1}.coach-summary-sub{font-family:var(--font-secondary);color:var(--text-secondary);font-size:.85rem}.coach-summary-list{gap:var(--space-2);flex-direction:column;flex:auto;width:100%;min-height:0;padding:2px 0;display:flex;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000,#000 12px calc(100% - 12px),#0000);mask-image:linear-gradient(#0000,#000 12px calc(100% - 12px),#0000)}.coach-summary-done{flex:none}.coach-summary-row{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:#ffffff08;border:1px solid #ffffff0f;display:flex}.coach-summary-check{color:var(--success-color);flex-shrink:0}.coach-summary-name{text-align:left;min-width:0;font-family:var(--font-primary);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:600;overflow:hidden}.coach-summary-val{font-family:var(--font-primary);color:var(--text-primary);font-weight:700}.coach-summary-unit{color:var(--text-secondary);font-size:.7rem;font-weight:600}.ct-chip-grid{justify-content:center;gap:var(--space-2);flex-wrap:wrap;max-width:min(420px,92vw);display:flex}.ct-chip{min-width:52px;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-primary);background:#ffffff0d;border:1px solid #ffffff14;font-size:1.05rem;font-weight:600;transition:transform .15s,background .2s,color .2s,border-color .2s}.ct-chip:active{transform:scale(.95)}.ct-chip.is-on{background:var(--accent-glow);color:var(--accent-primary);border-color:#38bdf866}.practice-hero.ct-target.is-hit{color:var(--success-color);transform:translateZ(0)scale(1.08)}.ct-stats{align-items:center;gap:var(--space-6);display:flex}.ct-score{font-family:var(--font-primary);color:var(--text-primary);font-size:1.4rem;font-weight:700}.om-best-badge{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);color:#fbbf24;font-family:var(--font-secondary);background:#fbbf241a;border:1px solid #fbbf2438;font-size:.85rem;font-weight:600;display:inline-flex}.om-best-spark{color:#fbbf24;opacity:.9}.om-ring{color:var(--accent-primary)}.om-ring.is-pr{color:#fbbf24}.om-ring-value{font-family:var(--font-primary);color:var(--text-primary);font-size:clamp(3.5rem,14vw,5rem);font-weight:700;line-height:1}.om-context{align-items:center;gap:var(--space-2);font-family:var(--font-secondary);color:var(--text-secondary);font-size:.9rem;display:inline-flex}.om-context.is-pr{color:#fbbf24;font-weight:600}.om-result-meta{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.om-result-spark{color:var(--accent-primary)}.om-sparkles{pointer-events:none;width:0;height:0;position:absolute;top:110px;left:50%}.om-sparkle{border-radius:var(--radius-full);background:#fbbf24;width:8px;height:8px;position:absolute;box-shadow:0 0 12px #fbbf24b3}.song-intro-head{align-items:center;gap:var(--space-3);color:var(--accent-primary);display:inline-flex}.song-intro-title{font-family:var(--font-primary);color:var(--text-primary);text-align:left;font-size:1.25rem;font-weight:700}.song-chip-row{justify-content:center;gap:var(--space-2);flex-wrap:wrap;display:inline-flex}.song-chip{min-width:40px;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent-primary);font-family:var(--font-primary);border:1px solid #38bdf84d;font-size:.85rem;font-weight:600}.song-stage{justify-content:center;align-items:center;gap:clamp(var(--space-3), 4vh, var(--space-6));flex-direction:column;width:100%;max-width:720px;margin:0 auto;display:flex}.song-topline{align-items:center;gap:var(--space-3);display:flex}.song-pass{font-family:var(--font-secondary);letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:#ffffff0a;font-size:.7rem;font-weight:600}.song-pass.is-play{color:var(--accent-primary);background:var(--accent-glow)}.song-section-tag{font-family:var(--font-secondary);color:var(--text-secondary);font-size:.78rem}.song-lane{width:100%;height:116px;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 16% 84%,#0000);mask-image:linear-gradient(90deg,#0000,#000 16% 84%,#0000)}.song-now-marker{border-radius:var(--radius-md);pointer-events:none;z-index:0;background:#38bdf80f;border:1.5px solid #38bdf873;width:76px;position:absolute;top:6px;bottom:6px;left:50%;transform:translate(-50%)}.song-track{will-change:transform;align-items:center;gap:16px;height:100%;display:flex;position:absolute;top:0;left:50%}.song-cell{justify-content:center;align-items:center;gap:var(--space-2);opacity:.4;transform-origin:50%;flex-direction:column;flex:0 0 76px;transition:opacity .25s,transform .25s;display:flex}.song-cell.is-past{opacity:.18}.song-cell.is-now{opacity:1;transform:scale(1.12)}.song-cell-chord{font-family:var(--font-primary);color:var(--text-primary);font-size:1.7rem;font-weight:700;line-height:1}.song-cell.is-now .song-cell-chord{color:var(--accent-primary)}.strum-row{align-items:center;gap:2px;height:18px;display:inline-flex}.strum-arrow{color:var(--text-secondary);justify-content:center;align-items:center;display:inline-flex}.song-cell.is-now .strum-arrow{color:var(--text-primary)}.strum-arrow.is-rest{color:#ffffff40}.strum-rest-dot{border-radius:var(--radius-full);background:currentColor;width:4px;height:4px}.song-lyric-line{text-align:center;min-height:1.6em;font-family:var(--font-secondary);color:var(--text-secondary);max-width:90%;font-size:.95rem}.song-parts{border-radius:var(--radius-sm);background:#ffffff0a;width:100%;height:22px;display:flex;position:relative;overflow:hidden}.song-part{border-right:1px solid #0000004d;justify-content:center;align-items:center;min-width:0;display:flex;overflow:hidden}.song-part:last-child{border-right:none}.song-part-label{font-family:var(--font-secondary);letter-spacing:.02em;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;padding:0 4px;font-size:.6rem;overflow:hidden}.song-parts-head{background:var(--accent-primary);width:2px;position:absolute;top:0;bottom:0;box-shadow:0 0 8px #38bdf8cc}.song-stage-foot{align-items:center;gap:var(--space-4);display:flex}.song-skip{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-secondary);opacity:.75;font-size:.72rem;transition:color .2s,opacity .2s;display:inline-flex}.song-skip:hover{color:var(--text-primary);opacity:1}.song-cell.is-correct .song-cell-chord,.song-cell.is-correct .strum-arrow{color:var(--success-color)}.song-real{gap:var(--space-4);flex-direction:column;width:100%;max-width:640px;min-height:0;margin:0 auto;display:flex}.song-real-video{aspect-ratio:16/9;border-radius:var(--radius-lg);background:var(--bg-primary,#06141d);width:100%;position:relative;overflow:hidden;box-shadow:0 24px 60px -24px #000c,0 0 0 1px #ffffff0d}.song-real-video iframe{border:0;width:100%;height:100%;display:block;position:absolute;inset:0}.song-real-link{align-items:center;gap:var(--space-3);text-align:center;padding:var(--space-5) var(--space-4);border-radius:var(--radius-lg);border:1px dashed #ffffff29;flex-direction:column;display:flex}.song-real-link-row{gap:var(--space-2);width:100%;display:flex}.song-real-link-row .task-input{flex:1;min-width:0}.song-real-foot{justify-content:flex-end;align-items:center;gap:var(--space-3);flex:none;display:flex}.song-real-foot .song-skip{margin-right:auto}.song-cell-tag{font-family:var(--font-secondary);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:.58rem}.song-cell.is-now .song-cell-tag{color:var(--accent-primary)}.om-cal-hero{font-size:clamp(3rem,12vw,5rem)}.om-cal-blurb{text-transform:none;letter-spacing:normal;text-align:center;max-width:34ch;font-size:.95rem;line-height:1.5}.om-cal-reset{margin-top:var(--space-2);opacity:.7;font-size:.8rem}.cal-setting-status{color:var(--text-secondary);margin:var(--space-1) 0 var(--space-2);font-size:.85rem}.calibration-overlay{z-index:1200}.account-modal-content{gap:var(--space-4);flex-direction:column;display:flex}.auth-form{gap:var(--space-3);flex-direction:column;display:flex}.auth-title,.settings-title{font-family:var(--font-primary);color:var(--text-primary);margin-bottom:0;font-size:1.1rem;font-weight:600}.auth-subtitle{color:var(--text-secondary);margin-bottom:var(--space-3);font-size:.85rem;line-height:1.4}.auth-error{color:#ef4444;padding:var(--space-3);border-radius:var(--radius-md);background:#ef44441a;font-size:.85rem}.auth-input{padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);color:var(--text-primary);background:#ffffff0d;border:1px solid #ffffff1a;outline:none;font-size:.95rem;transition:all .2s}.auth-input:focus{background:#ffffff14;border-color:#38bdf880}.auth-submit{justify-content:center;align-items:center;gap:var(--space-2);background:var(--text-primary);color:var(--bg-color);padding:var(--space-2);border-radius:var(--radius-lg);border:none;font-size:.95rem;font-weight:500;transition:transform .2s,opacity .2s;display:flex}.auth-submit:active{transform:scale(.98)}.auth-switch{margin-top:var(--space-2);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:.8rem;transition:color .2s}.auth-switch:hover{color:var(--text-primary)}.user-email{color:var(--text-secondary);padding-bottom:var(--space-4);margin-bottom:var(--space-4);border-bottom:1px solid #ffffff1a;font-size:.95rem}.settings-actions{gap:var(--space-2);flex-direction:column;display:flex}.settings-action-btn{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;background:#ffffff08;border:1px solid #ffffff0d;font-size:.95rem;transition:background .2s;display:flex}.settings-action-btn:hover{background:#ffffff14}.settings-action-btn.logout{color:#ef4444}.settings-action-btn.logout:hover{color:var(--error-color);background:#ef44441a;border-color:#ef444433}.settings-action-btn:disabled{opacity:.6;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-icon{animation:1s linear infinite spin}.mic-setting{gap:var(--space-2);padding:var(--space-3) 0;margin:var(--space-2) 0;border-top:1px solid #ffffff0f;border-bottom:1px solid #ffffff0f;flex-direction:column;display:flex}.mic-setting-head{align-items:center;gap:var(--space-2);font-family:var(--font-secondary);color:var(--text-secondary);font-size:.82rem;font-weight:600;display:inline-flex}.mic-setting-select{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-secondary);cursor:pointer;background:#00000040;border:1px solid #ffffff1a;font-size:.85rem}.mic-setting-select option{color:var(--text-primary);background:#1a1a1d}.mic-setting-unlock{font-family:var(--font-secondary);color:var(--accent-primary);opacity:.9;align-self:flex-start;font-size:.75rem}.mic-setting-unlock:hover{opacity:1}.mic-setting-unlock:disabled{opacity:.5;cursor:default}.pattern-manager{gap:var(--space-2);padding:var(--space-3) 0;margin-bottom:var(--space-2);border-bottom:1px solid #ffffff0f;flex-direction:column;display:flex}.pattern-list{gap:var(--space-1);flex-direction:column;display:flex}.pattern-item{align-items:center;gap:var(--space-3);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);display:flex}.pattern-item:hover{background:#ffffff08}.pattern-item-name{font-family:var(--font-secondary);color:var(--text-primary);flex:1;font-size:.82rem}.pattern-item-remove{color:var(--text-secondary);border-radius:var(--radius-sm);padding:4px;transition:color .2s}.pattern-item-remove:hover{color:#f87171}.pattern-add{gap:var(--space-2);align-items:center;display:flex}.pattern-add .task-input{padding:var(--space-2) var(--space-3);flex:1;font-size:.85rem}.pattern-add-code{text-transform:uppercase;letter-spacing:.08em;flex:0 0 110px}.pattern-add-btn{border-radius:var(--radius-md);background:var(--accent-primary);color:#06141d;flex:none;justify-content:center;align-items:center;width:34px;height:34px;transition:opacity .2s;display:inline-flex}.pattern-add-btn:disabled{opacity:.4;cursor:not-allowed}.pattern-hint{font-family:var(--font-secondary);color:var(--text-secondary);margin:0;font-size:.7rem}.streak-container{flex-direction:row;align-items:center;gap:16px;margin:0;display:flex}.streak-header-info{align-items:center;display:flex}.streak-count{color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);letter-spacing:.5px;text-transform:uppercase;border-radius:12px;padding:4px 12px;font-size:.9rem;font-weight:600}.streak-graph{justify-content:center;align-items:flex-end;gap:6px;display:flex}.streak-day-col{flex-direction:column;align-items:center;gap:6px;display:flex}.streak-block{background-color:var(--bg-tertiary,#2c2c2c);border:1px solid #ffffff0d;border-radius:4px;width:14px;height:14px;transition:all .3s}.streak-block.intensity-1{background-color:var(--accent-primary);opacity:.4;box-shadow:0 0 8px #00ffaa1a}.streak-block.intensity-2{background-color:var(--accent-primary);opacity:.6;box-shadow:0 0 10px #0fa3}.streak-block.intensity-3{background-color:var(--accent-primary);opacity:.8;box-shadow:0 0 12px #00ffaa4d}.streak-block.intensity-4{background-color:var(--accent-primary);opacity:1;box-shadow:0 0 15px #0fa6}.streak-day-label{color:var(--text-secondary);text-transform:uppercase;font-size:.55rem;font-weight:500}.app-layout{flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.app-header{padding:var(--space-6) var(--space-8);z-index:50;justify-content:space-between;align-items:center;display:flex;position:absolute;top:0;left:0;right:0}.header-date{font-family:var(--font-primary);color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;font-size:1.1rem;font-weight:500}.header-account{align-items:center;display:flex}.account-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2);color:var(--text-secondary);background:0 0;border:none;font-size:1rem;transition:color .2s;display:flex}.account-btn:hover,.account-btn.active-mode{color:var(--text-primary)}.center-content{min-height:0;padding-top:120px;padding-bottom:calc(80px + env(safe-area-inset-bottom));z-index:20;flex-direction:column;flex:1;justify-content:flex-start;align-items:center;width:100%;max-width:800px;margin:0 auto;display:flex;overflow-y:auto}@media (width<=600px){.app-header{padding:var(--space-4)}.header-date{letter-spacing:.03em;font-size:.8rem}.header-actions{gap:var(--space-3)!important}.center-content{padding-top:92px;padding-bottom:64px}}
