:root{--color-bg: #1a1410;--color-bg-raised: #231e18;--color-bg-surface: #2c2520;--color-bg-hover: #352e27;--color-bg-input: #1e1914;--color-amber: #d4a04a;--color-amber-dim: #b8892e;--color-amber-glow: rgba(212, 160, 74, .15);--color-gold: #e8c56d;--color-text: #e8e0d4;--color-text-dim: #a89a8a;--color-text-muted: #7a6e62;--color-border: #3a322b;--color-border-light:#4a413a;--color-danger: #c45b4a;--color-danger-dim: rgba(196, 91, 74, .15);--color-success: #5a9e6f;--color-success-dim: rgba(90, 158, 111, .15);--status-learning: #d4a04a;--status-transcribing: #b85e2e;--status-playable: #5a9e6f;--status-polished: #6b8ec4;--status-retired: #7a6e62;--font-display: "DM Serif Display", Georgia, serif;--font-body: "IBM Plex Sans", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 30px rgba(0,0,0,.5);--ease-out: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-weight:400;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9999}h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.2;color:var(--color-text)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.2rem}a{color:var(--color-amber);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-gold)}button,.btn{font-family:var(--font-body);font-weight:500;font-size:.875rem;line-height:1;padding:.6rem 1.2rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);color:var(--color-text);cursor:pointer;transition:all .2s var(--ease-out);display:inline-flex;align-items:center;gap:var(--space-sm)}button:hover{background:var(--color-bg-hover);border-color:var(--color-border-light)}button:active{transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-amber);color:var(--color-bg);border-color:var(--color-amber);font-weight:600}.btn-primary:hover{background:var(--color-gold);border-color:var(--color-gold)}.btn-danger{color:var(--color-danger);border-color:var(--color-danger);background:var(--color-danger-dim)}.btn-danger:hover{background:var(--color-danger);color:var(--color-text)}.btn-ghost{background:transparent;border-color:transparent;color:var(--color-text-dim)}.btn-ghost:hover{color:var(--color-text);background:var(--color-bg-hover)}.btn-sm{font-size:.8rem;padding:.4rem .8rem}.btn-action{font-size:.9rem;padding:.25rem .5rem;min-width:32px;min-height:32px;display:inline-flex;align-items:center;justify-content:center}input,textarea,select{font-family:var(--font-body);font-size:.9375rem;padding:.6rem .8rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-input);color:var(--color-text);outline:none;transition:border-color .2s ease;width:100%}input:focus,textarea:focus,select:focus{border-color:var(--color-amber-dim);box-shadow:0 0 0 2px var(--color-amber-glow)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}textarea{resize:vertical;min-height:80px}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23a89a8a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8rem center;padding-right:2rem}label{font-size:.8125rem;font-weight:500;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:var(--space-xs)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.panel{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.status-badge{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .6rem;border-radius:100px;display:inline-block}.status-badge.learning{background:#d4a04a26;color:var(--status-learning)}.status-badge.transcribing{background:#b85e2e26;color:var(--status-transcribing)}.status-badge.playable{background:#5a9e6f26;color:var(--status-playable)}.status-badge.polished{background:#6b8ec426;color:var(--status-polished)}.status-badge.retired{background:#7a6e6226;color:var(--status-retired)}.star-rating{display:inline-flex;gap:2px}.star-rating .star{cursor:pointer;color:var(--color-text-muted);font-size:1.2rem;transition:color .15s ease}.star-rating .star.filled{color:var(--color-amber)}.star-rating .star:hover{color:var(--color-gold)}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--color-text-muted)}.empty-state h3{color:var(--color-text-dim);margin-bottom:var(--space-sm)}.empty-state p{margin-bottom:var(--space-lg)}.divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-lg) 0}.text-muted{color:var(--color-text-muted)}.text-dim{color:var(--color-text-dim)}.text-amber{color:var(--color-amber)}.text-sm{font-size:.8125rem}.text-mono{font-family:var(--font-mono)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s var(--ease-out) both}.slide-up{animation:slideUp .4s var(--ease-out) both}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:40ms}.stagger>*:nth-child(3){animation-delay:80ms}.stagger>*:nth-child(4){animation-delay:.12s}.stagger>*:nth-child(5){animation-delay:.16s}.stagger>*:nth-child(6){animation-delay:.2s}.stagger>*:nth-child(7){animation-delay:.24s}.stagger>*:nth-child(8){animation-delay:.28s}.stagger>*:nth-child(9){animation-delay:.32s}.stagger>*:nth-child(10){animation-delay:.36s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;max-width:960px;width:100%;margin:0 auto;padding:var(--space-xl) var(--space-lg)}.nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-raised);position:sticky;top:0;z-index:100}.nav-brand{font-family:var(--font-display);font-size:1.4rem;color:var(--color-amber);letter-spacing:-.01em;-webkit-user-select:none;user-select:none}.nav-links{display:flex;align-items:center;gap:var(--space-xs)}.nav-link{font-size:.875rem;font-weight:500;color:var(--color-text-dim);padding:.4rem .9rem;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;border:none;background:none}.nav-link:hover{color:var(--color-text);background:var(--color-bg-hover)}.nav-link.active{color:var(--color-amber);background:var(--color-amber-glow)}.nav-divider{width:1px;height:20px;background:var(--color-border);margin:0 var(--space-sm)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg)}.login-container{width:100%;max-width:380px;animation:slideUp .5s var(--ease-out) both}.login-header{text-align:center;margin-bottom:var(--space-2xl)}.login-header h1{font-family:var(--font-display);font-size:2.5rem;color:var(--color-amber);margin-bottom:var(--space-sm)}.login-header p{color:var(--color-text-muted);font-size:.9375rem}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.login-form button[type=submit]{margin-top:var(--space-sm);width:100%;justify-content:center;padding:.75rem}.login-toggle{text-align:center;margin-top:var(--space-lg);color:var(--color-text-muted);font-size:.875rem}.login-toggle button{background:none;border:none;color:var(--color-amber);cursor:pointer;font-weight:500;padding:0;font-size:.875rem}.login-toggle button:hover{color:var(--color-gold);background:none;border:none}.login-error{color:var(--color-danger);font-size:.8125rem;text-align:center;padding:var(--space-sm) var(--space-md);background:var(--color-danger-dim);border-radius:var(--radius-md)}.login-divider{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-md) 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-divider span{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.btn-google{width:100%;padding:.6rem 1.2rem;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s var(--ease-out)}.btn-google:hover{background:var(--color-bg-hover);border-color:var(--color-border-light)}.tune-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);gap:var(--space-md)}.tune-list-header h1{white-space:nowrap}.tune-list-header .btn-primary{font-size:.8rem;padding:.5rem .75rem;line-height:1;white-space:nowrap}.tune-filters{display:flex;gap:var(--space-sm);align-items:center}.filter-btn{font-size:.8rem;padding:.35rem .75rem;border-radius:100px;background:transparent;border:1px solid var(--color-border);color:var(--color-text-dim);cursor:pointer;transition:all .2s ease;white-space:nowrap}.filter-btn:hover{border-color:var(--color-border-light);color:var(--color-text)}.filter-btn.active{background:var(--color-amber-glow);border-color:var(--color-amber-dim);color:var(--color-amber)}.sort-select{font-size:.8rem;padding:.35rem .6rem;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-dim);cursor:pointer}.tune-grid{display:flex;flex-direction:column;gap:var(--space-sm)}.tune-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease-out)}.tune-row:hover{border-color:var(--color-border-light);background:var(--color-bg-surface);transform:translate(4px)}.tune-row-info h3{font-family:var(--font-body);font-weight:500;font-size:1rem;margin-bottom:2px}.tune-row-meta{font-size:.8125rem;color:var(--color-text-muted);display:flex;gap:var(--space-md)}.tune-row-meta span{display:inline-flex;align-items:center;gap:4px}.tune-recording-count{font-size:.8rem;color:var(--color-text-muted);font-family:var(--font-mono);white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:#0a0806cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:var(--space-lg);overflow-y:auto;animation:fadeIn .2s ease both}.modal{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:680px;margin:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s var(--ease-out) both}.modal h2{margin-bottom:var(--space-lg)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg)}.tune-detail-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-xl)}.tune-detail-header h1{margin-bottom:var(--space-xs)}.tune-detail-actions{display:flex;gap:var(--space-sm);align-items:flex-start}.tune-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.meta-item{display:flex;flex-direction:column;gap:2px}.meta-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.meta-value{font-size:.9375rem;color:var(--color-text)}.tune-notes{color:var(--color-text-dim);font-size:.9375rem;line-height:1.7;padding:var(--space-md);background:var(--color-bg-surface);border-radius:var(--radius-md);border-left:3px solid var(--color-amber-dim);margin-bottom:var(--space-xl)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.section-header h2{font-size:1.15rem}.recording-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-xl)}.recording-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .2s ease}.recording-item:hover{border-color:var(--color-border-light)}.recording-item.expanded{border-color:var(--color-amber-dim);background:var(--color-bg-surface);border-bottom-left-radius:0;border-bottom-right-radius:0}.recording-expanded{border:1px solid var(--color-amber-dim);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--space-lg);background:var(--color-bg-surface);margin-bottom:var(--space-sm)}.recording-info{display:flex;flex-direction:column;gap:2px;min-width:0}.recording-name{font-weight:500;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recording-meta{font-size:.8rem;color:var(--color-text-muted);display:flex;gap:var(--space-md)}.recording-actions{display:flex;gap:var(--space-sm);align-items:center;flex-shrink:0}.upload-area{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;cursor:pointer;transition:all .2s ease;margin-bottom:var(--space-md)}.upload-area:hover{border-color:var(--color-amber-dim);background:var(--color-amber-glow)}.upload-area.dragover{border-color:var(--color-amber);background:var(--color-amber-glow)}.upload-icon{font-size:2rem;margin-bottom:var(--space-sm)}.upload-area p{color:var(--color-text-dim);font-size:.9375rem}.upload-area .text-sm{color:var(--color-text-muted);margin-top:var(--space-xs)}.upload-fields{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-md)}.upload-file-name{font-family:var(--font-mono);font-size:.8125rem;color:var(--color-amber);padding:var(--space-sm) var(--space-md);background:var(--color-amber-glow);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:space-between}.segment-list{display:flex;flex-direction:column;gap:var(--space-sm)}.segment-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.segment-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.segment-info{flex:1;min-width:0}.segment-label{font-weight:500;font-size:.9375rem;display:block;margin-bottom:2px}.segment-times{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);display:block}.segment-actions{display:flex;gap:var(--space-xs)}.segment-form{display:grid;grid-template-columns:1fr auto auto auto;gap:var(--space-sm);align-items:end;padding:var(--space-md);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.segment-form .time-inputs{display:flex;gap:var(--space-sm)}.segment-form input[type=number]{width:80px}.mark-input{display:flex;gap:4px;align-items:stretch}.mark-input input{flex:1;min-width:60px}.mark-btn{font-size:.7rem;font-weight:600;padding:.4rem .6rem;border-radius:var(--radius-sm);background:var(--color-amber-glow);border:1px solid var(--color-amber-dim);color:var(--color-amber);cursor:pointer;white-space:nowrap;transition:all .15s ease}.mark-btn:hover{background:var(--color-amber);color:var(--color-bg);border-color:var(--color-amber)}.audio-player{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.player-error{color:var(--color-danger);font-size:.8125rem;margin-bottom:var(--space-md)}.player-timeline{position:relative;height:32px;background:var(--color-bg-input);border-radius:var(--radius-sm);cursor:pointer;overflow:hidden;margin-bottom:var(--space-xs)}.timeline-segment{position:absolute;top:0;height:100%;opacity:.25;transition:opacity .2s ease;pointer-events:none}.timeline-segment.looping{opacity:.45;animation:loopPulse 2s ease-in-out infinite}@keyframes loopPulse{0%,to{opacity:.35}50%{opacity:.55}}.timeline-progress{position:absolute;top:0;left:0;height:100%;background:var(--color-amber);opacity:.15;pointer-events:none}.timeline-head{position:absolute;top:0;width:2px;height:100%;background:var(--color-amber);pointer-events:none;transition:left .05s linear}.player-time{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-dim);margin-bottom:var(--space-md)}.player-controls{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.player-transport{display:flex;align-items:center;gap:var(--space-sm)}.transport-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:50%;background:var(--color-bg-surface);border:1px solid var(--color-border);font-size:.9rem;cursor:pointer;transition:all .15s ease}.transport-btn:hover{border-color:var(--color-border-light);background:var(--color-bg-hover)}.transport-btn.play-btn{width:44px;height:44px;font-size:1.1rem;background:var(--color-amber);border-color:var(--color-amber);color:var(--color-bg)}.transport-btn.play-btn:hover{background:var(--color-gold);border-color:var(--color-gold)}.player-speed{display:flex;align-items:center;gap:var(--space-sm);flex:1;min-width:0}.speed-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);white-space:nowrap}.speed-presets{display:flex;gap:2px}.speed-preset{font-size:.75rem;font-family:var(--font-mono);padding:.25rem .5rem;border-radius:var(--radius-sm);background:var(--color-bg-surface);border:1px solid var(--color-border);color:var(--color-text-dim);cursor:pointer;transition:all .15s ease}.speed-preset:hover{color:var(--color-text);border-color:var(--color-border-light)}.speed-preset.active{background:var(--color-amber-glow);border-color:var(--color-amber-dim);color:var(--color-amber)}.speed-slider{flex:1;min-width:60px;max-width:120px;height:4px;-webkit-appearance:none;appearance:none;background:var(--color-border);border-radius:2px;outline:none;border:none;padding:0}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-amber);cursor:pointer;border:none}.speed-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--color-amber);cursor:pointer;border:none}.speed-value{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-dim);min-width:3.5em;text-align:right}.loop-indicator{display:flex;align-items:center;gap:var(--space-sm);font-size:.8125rem;color:var(--color-text-dim);padding:.3rem .6rem;background:var(--color-bg-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.loop-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.loop-label{white-space:nowrap}.loop-indicator-wrap{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.ramp-toggle{font-size:.75rem;padding:.3rem .6rem;background:none;border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all .15s ease;white-space:nowrap}.ramp-toggle:hover{border-color:var(--color-amber-dim);color:var(--color-amber)}.ramp-controls{display:flex;align-items:center;gap:var(--space-sm);font-size:.8rem;padding:.3rem .6rem;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.ramp-title{font-weight:600;color:var(--color-amber);font-size:.75rem;white-space:nowrap}.ramp-fields{display:flex;gap:var(--space-sm);align-items:center}.ramp-fields label{display:flex;align-items:center;gap:var(--space-xs);font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.ramp-fields select{font-size:.75rem;padding:.15rem .3rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text)}.ramp-done{color:var(--color-success);font-weight:600;font-size:.75rem;white-space:nowrap}.player-segments{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.player-segment-chip{display:flex;align-items:center;gap:4px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s ease}.player-segment-chip.active{border-color:var(--color-amber-dim);background:var(--color-amber-glow)}.segment-chip-color{width:10px;height:10px;border-radius:50%;margin-left:var(--space-sm);flex-shrink:0}.segment-chip-label{font-size:.8125rem;font-weight:500;color:var(--color-text);padding:.3rem .4rem;background:none;border:none;cursor:pointer;transition:color .15s ease}.segment-chip-label:hover{color:var(--color-amber);background:none;border:none}.segment-chip-loop{font-size:.85rem;padding:.3rem .5rem;background:none;border:none;border-left:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;transition:all .15s ease}.segment-chip-loop:hover{color:var(--color-amber);background:var(--color-amber-glow);border:none;border-left:1px solid var(--color-border)}.segment-chip-loop.active{color:var(--color-amber);background:var(--color-amber-glow)}.practice-summary{margin-bottom:var(--space-xl)}.summary-stats{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg)}.summary-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-lg) var(--space-md);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.summary-number{font-family:var(--font-display);font-size:2rem;color:var(--color-amber);line-height:1;margin-bottom:var(--space-xs)}.summary-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.summary-details{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.summary-section{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.summary-section h3{font-family:var(--font-body);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-md)}.summary-tune-list{display:flex;flex-direction:column;gap:var(--space-sm)}.summary-tune-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md)}.summary-tune-title{font-weight:500;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.summary-tune-count{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}.summary-tempo-range{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-dim);white-space:nowrap;flex-shrink:0}.tempo-up{color:var(--color-success);font-weight:600}.tempo-down{color:var(--color-danger);font-weight:600}.summary-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.summary-section-header h3{margin-bottom:0}.perf-form{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.perf-form input{font-size:.8125rem;padding:.4rem .6rem}.perf-list{display:flex;flex-direction:column;gap:var(--space-sm)}.perf-item{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-sm)}.perf-info{display:flex;flex-direction:column;gap:2px;min-width:0}.perf-title{font-weight:500;font-size:.9375rem}.perf-meta{font-size:.8rem;color:var(--color-text-muted)}.perf-countdown{margin-left:var(--space-sm);color:var(--color-amber);font-weight:500}.practice-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.session-list{display:flex;flex-direction:column;gap:var(--space-md)}.session-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.session-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .2s ease}.session-card-header:hover{background:var(--color-bg-surface)}.session-date{font-family:var(--font-display);font-size:1.1rem}.session-duration{font-size:.8125rem;color:var(--color-text-muted);font-family:var(--font-mono)}.session-entries{padding:var(--space-md) var(--space-lg)}.entry-row{display:grid;grid-template-columns:1fr auto auto auto auto auto;gap:var(--space-sm);align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);font-size:.9375rem}.entry-row:last-child{border-bottom:none}.entry-edit-form{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-sm)}.entry-edit-form:last-child{border-bottom:none}.session-edit-form{padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.entry-tune{font-weight:500}.entry-focus{font-size:.8rem;color:var(--color-text-dim);text-transform:capitalize}.entry-tempo{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted)}.entry-duration{font-size:.8125rem;color:var(--color-text-muted);font-family:var(--font-mono)}.practice-form{display:flex;flex-direction:column;gap:var(--space-lg)}.practice-entry-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.practice-entry-card .form-row{margin-bottom:var(--space-sm)}.practice-entry-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.add-entry-btn{border-style:dashed;width:100%;justify-content:center;padding:var(--space-md);color:var(--color-text-muted)}.add-entry-btn:hover{color:var(--color-amber);border-color:var(--color-amber-dim)}@media(max-width:1024px){.main-content{padding:var(--space-md)}.nav{padding:var(--space-sm) var(--space-md)}.nav-brand{font-size:1.1rem}.nav-links{gap:2px}.nav-link{font-size:.8rem;padding:.5rem .3rem}.nav-divider{margin:0 var(--space-xs)}.tune-list-header{flex-direction:column;align-items:stretch}.tune-list-header>div{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.tune-filters{flex-wrap:wrap;width:100%}.tune-row{grid-template-columns:1fr auto;gap:var(--space-sm);padding:var(--space-md)}.tune-recording-count{display:none}.tune-meta-grid{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}.entry-row{display:flex;flex-wrap:nowrap;align-items:center;gap:var(--space-xs)}.entry-row .entry-tune{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entry-row .entry-focus,.entry-row .entry-tempo,.entry-row .star-rating{display:none}.segment-form,.summary-details{grid-template-columns:1fr}.summary-stats{gap:var(--space-sm)}.summary-number{font-size:1.5rem}.session-card-header{flex-direction:column;gap:var(--space-sm);align-items:flex-start}.audio-player{padding:var(--space-md)}.player-controls{gap:var(--space-md)}.transport-btn{width:44px;height:44px;font-size:1rem}.transport-btn.play-btn{width:52px;height:52px;font-size:1.2rem}.speed-presets{gap:4px}.speed-preset{padding:.4rem .6rem;font-size:.8rem}.speed-slider{max-width:none}.player-segment-chip{flex:1 1 auto;min-width:0;justify-content:center}.segment-chip-label{font-size:.875rem;padding:.5rem .6rem}.segment-chip-loop{padding:.5rem .6rem;font-size:.95rem}.segment-item{padding:var(--space-md)}.setlist-item-row{flex-wrap:wrap}.setlist-item-fields{flex:1 1 100%;order:2}.setlist-item-actions{order:1}.recording-info{min-width:0}.recording-name{word-break:break-word}.recording-meta{flex-wrap:wrap}.practice-header{flex-wrap:wrap;gap:var(--space-sm)}}.setlist-item-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.setlist-item-number{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);min-width:1.5rem;text-align:center;flex-shrink:0}.setlist-item-fields{flex:1;min-width:0}.setlist-item-fields select{width:100%}.setlist-item-actions{display:flex;gap:2px;flex-shrink:0}.setlist-item-actions .btn-ghost{padding:.2rem .4rem;font-size:.8rem}.setlist-item-actions .btn-ghost:disabled{opacity:.25;cursor:default}.setlist-display-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0}.setlist-display-number{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);min-width:1.5rem;text-align:center;flex-shrink:0}.shed-mode{max-width:480px;margin:0 auto;padding:var(--space-md)}.shed-header{text-align:center;margin-bottom:var(--space-lg)}.shed-header h1{font-size:1.5rem}.shed-back-btn{background:none;border:none;color:var(--color-text-dim);font-size:.9rem;cursor:pointer;padding:var(--space-sm) 0;margin-bottom:var(--space-md)}.shed-tune-list{display:flex;flex-direction:column;gap:var(--space-sm)}.shed-tune-btn{display:flex;flex-direction:column;gap:2px;padding:var(--space-md) var(--space-lg);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:border-color .15s ease;min-height:54px;justify-content:center}.shed-tune-btn:hover,.shed-tune-btn:active{border-color:var(--color-amber-dim)}.shed-tune-title{font-weight:600;font-size:1.1rem;color:var(--color-text)}.shed-tune-composer{font-size:.85rem;color:var(--color-text-muted)}.shed-now-playing{text-align:center;margin-bottom:var(--space-lg)}.shed-tune-now{font-size:1.75rem;margin-bottom:var(--space-xs)}.shed-composer-now{display:block;font-size:.95rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.shed-tune-edit{padding:var(--space-md);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.shed-key-badge{display:inline-block;font-size:.8rem;font-weight:600;padding:.2rem .6rem;background:var(--color-amber-glow);color:var(--color-amber);border-radius:var(--radius-md)}.shed-recording-picker{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap;margin-bottom:var(--space-lg)}.shed-recording-btn{font-size:.8rem;padding:.4rem .8rem;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-dim);cursor:pointer;transition:all .15s ease;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shed-recording-btn.active{background:var(--color-amber-glow);border-color:var(--color-amber-dim);color:var(--color-amber)}.shed-timeline{position:relative;height:32px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;margin-bottom:var(--space-sm)}.shed-timeline-segment{position:absolute;top:0;height:100%;opacity:.25;transition:opacity .2s ease}.shed-timeline-segment.looping{opacity:.5}.shed-timeline-progress{position:absolute;top:0;left:0;height:100%;background:var(--color-amber);opacity:.15}.shed-timeline-playhead{position:absolute;top:0;width:2px;height:100%;background:var(--color-amber)}.shed-time{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--space-lg)}.shed-transport{display:flex;justify-content:center;margin-bottom:var(--space-lg)}.shed-play-btn{width:80px;height:80px;border-radius:50%;border:none;background:var(--color-amber);color:var(--color-bg);font-size:1.8rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.shed-play-btn:active{transform:scale(.95);background:var(--color-gold)}.shed-speed{display:flex;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl)}.shed-speed-btn{font-family:var(--font-mono);font-size:.9rem;padding:.6rem 1rem;border-radius:var(--radius-md);background:var(--color-bg-surface);border:1px solid var(--color-border);color:var(--color-text-dim);cursor:pointer;transition:all .15s ease;min-width:56px}.shed-speed-btn.active{background:var(--color-amber-glow);border-color:var(--color-amber-dim);color:var(--color-amber)}.shed-speed-btn:active{transform:scale(.95)}.shed-segment-edit{padding:var(--space-md);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.shed-segment-edit-times{display:flex;gap:var(--space-md)}.shed-segment-edit-field{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.shed-segment-edit-field label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.shed-segment-edit-field input{font-size:1rem}.shed-speed-slider{display:flex;align-items:center;gap:var(--space-md);padding:0 var(--space-sm)}.shed-speed-slider input[type=range]{flex:1;height:36px;cursor:pointer;accent-color:var(--color-amber)}.shed-speed-value{font-family:var(--font-mono);font-size:.9rem;color:var(--color-text-dim);min-width:3.5rem;text-align:right}.shed-segments{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.shed-segment-btn{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all .15s ease;min-height:54px}.shed-segment-btn.active{border-color:var(--color-amber);background:var(--color-amber-glow)}.shed-segment-btn:active{transform:scale(.98)}.shed-segment-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.shed-segment-label{font-weight:600;font-size:1rem;color:var(--color-text);flex:1}.shed-segment-time{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted)}.shed-loop-indicator{text-align:center;font-size:.85rem;color:var(--color-amber);font-weight:500;display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-md)}.shed-loop-clear{font-size:.8rem;padding:.3rem .7rem;background:none;border:1px solid var(--color-amber-dim);border-radius:var(--radius-md);color:var(--color-amber);cursor:pointer}.shed-loop-clear:active{background:var(--color-amber-glow)}.shed-ramp-panel{margin-top:var(--space-md)}.shed-ramp-toggle{display:block;width:100%;padding:var(--space-sm) var(--space-md);margin-top:var(--space-sm);background:none;border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.85rem;cursor:pointer;transition:all .15s ease}.shed-ramp-toggle:active{border-color:var(--color-amber-dim);color:var(--color-amber)}.shed-ramp-controls{margin-top:var(--space-sm);padding:var(--space-md);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.shed-ramp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.shed-ramp-fields{display:flex;gap:var(--space-md)}.shed-ramp-field{flex:1}.shed-ramp-field label{display:block;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.shed-ramp-field select{width:100%;font-size:1rem;padding:var(--space-sm)}.shed-ramp-done{text-align:center;margin-top:var(--space-md);padding:var(--space-sm);color:var(--color-success);font-weight:600;font-size:.9rem}.shed-mark-trigger{display:block;width:100%;padding:var(--space-md);background:none;border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .15s ease;margin-top:var(--space-md)}.shed-mark-trigger:active{border-color:var(--color-amber-dim);color:var(--color-amber)}.shed-mark-panel{margin-top:var(--space-md);padding:var(--space-lg);background:var(--color-bg-raised);border:1px solid var(--color-amber-dim);border-radius:var(--radius-lg)}.shed-mark-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.shed-mark-title{font-weight:600;color:var(--color-amber)}.shed-mark-buttons{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.shed-mark-btn{flex:1;padding:var(--space-md);background:var(--color-bg-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s ease;text-align:center;min-height:54px}.shed-mark-btn:active{transform:scale(.97)}.shed-mark-btn.marked{border-color:var(--color-amber);background:var(--color-amber-glow);color:var(--color-amber)}.shed-mark-save{display:flex;gap:var(--space-sm)}.shed-mark-input{flex:1;font-size:1rem;padding:var(--space-md)}.toast-container{position:fixed;bottom:var(--space-lg);left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--space-sm);z-index:1000;pointer-events:none}.toast{padding:.75rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;pointer-events:auto;white-space:nowrap;box-shadow:0 4px 12px #0000004d}.toast-success{background:var(--color-success);color:var(--color-bg)}.toast-error{background:var(--color-danger);color:#fff}.toast-info{background:var(--color-bg-raised);color:var(--color-text);border:1px solid var(--color-border)}
