:root,:root[data-theme=dark]{color-scheme:dark;--bg: #0a0a0b;--body-bg: radial-gradient(circle at top left, rgba(30, 144, 255, .18), transparent 34rem), radial-gradient(circle at bottom right, rgba(255, 179, 71, .12), transparent 30rem), #0a0a0b;--panel: rgba(24, 24, 27, .82);--panel-strong: rgba(18, 18, 20, .96);--surface: rgba(10, 10, 11, .42);--surface-soft: rgba(10, 10, 11, .38);--surface-subtle: rgba(10, 10, 11, .5);--border: #2d2d33;--border-strong: #52525b;--text: #f4f4f5;--muted: #a1a1aa;--muted-strong: #d4d4d8;--eyebrow: #38bdf8;--blue: #1b82e6;--blue-soft: rgba(27, 130, 230, .14);--green: #34d399;--green-soft: rgba(52, 211, 153, .12);--mango: #ffb347;--mango-soft: rgba(255, 179, 71, .14);--danger: #f87171;--danger-soft: rgba(248, 113, 113, .1);--danger-hover: rgba(248, 113, 113, .16);--danger-text: #fca5a5;--track: #27272a;--shadow: 0 20px 60px rgba(0, 0, 0, .22);--shadow-soft: 0 20px 60px rgba(0, 0, 0, .16);--dialog-backdrop: rgba(0, 0, 0, .68);--strum-down: #f4f4f5;--strum-down-soft: rgba(244, 244, 245, .12);--strum-up: #ffef96;--strum-up-soft: rgba(255, 239, 150, .1);--diagram-bg: rgba(10, 10, 11, .42);--diagram-string: rgba(244, 244, 245, .62);--diagram-fret: rgba(244, 244, 245, .48);--diagram-nut: rgba(244, 244, 245, .9);--diagram-open-string: #7dd3fc;--diagram-muted-string: #fca5a5;--diagram-finger-label: #ffffff}:root[data-theme=light]{color-scheme:light;--bg: #f6f8fb;--body-bg: radial-gradient(circle at top left, rgba(27, 130, 230, .14), transparent 34rem), radial-gradient(circle at bottom right, rgba(255, 179, 71, .18), transparent 30rem), #f6f8fb;--panel: rgba(255, 255, 255, .9);--panel-strong: rgba(255, 255, 255, .98);--surface: rgba(248, 250, 252, .88);--surface-soft: rgba(241, 245, 249, .78);--surface-subtle: rgba(255, 255, 255, .86);--border: #d7dde7;--border-strong: #94a3b8;--text: #111827;--muted: #64748b;--muted-strong: #334155;--eyebrow: #0f4f9e;--blue: #0f72d8;--blue-soft: rgba(15, 114, 216, .12);--green: #059669;--green-soft: rgba(5, 150, 105, .12);--mango: #f59e0b;--mango-soft: rgba(245, 158, 11, .16);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .1);--danger-hover: rgba(220, 38, 38, .16);--danger-text: #b91c1c;--track: #dbe3ef;--shadow: 0 20px 60px rgba(15, 23, 42, .12);--shadow-soft: 0 20px 60px rgba(15, 23, 42, .08);--dialog-backdrop: rgba(15, 23, 42, .34);--strum-down: #1f2937;--strum-down-soft: rgba(31, 41, 55, .08);--strum-up: #d97706;--strum-up-soft: rgba(245, 158, 11, .16);--diagram-bg: #f8fafc;--diagram-string: rgba(51, 65, 85, .64);--diagram-fret: rgba(100, 116, 139, .52);--diagram-nut: rgba(15, 23, 42, .82);--diagram-open-string: #0284c7;--diagram-muted-string: #dc2626;--diagram-finger-label: #ffffff}body{background:var(--body-bg)}:root[data-theme=light] .hero-card,:root[data-theme=light] .panel-card,:root[data-theme=light] .song-card,:root[data-theme=light] .session-card{box-shadow:var(--shadow)}:root[data-theme=light] select,:root[data-theme=light] .select-control,:root[data-theme=light] .custom-song-form select{background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%23334155' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}button,select,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.app-shell{min-height:100vh;color:var(--text)}.app-grid{width:min(1440px,100%);margin:0 auto;display:grid;grid-template-columns:320px 1fr;gap:24px;padding:24px}.sidebar,.main-content,.song-column{display:grid;align-content:start;gap:18px}.top-grid{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}.dashboard-top-grid{align-items:start}.hero-card,.panel-card,.song-card,.session-card{border:1px solid var(--border);border-radius:28px;background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.hero-card{padding:24px}.panel-card,.song-card,.session-card{padding:18px}.path-card,.step-card,.chord-card,.transition-card,.song-section-card,.info-card{border:1px solid var(--border);border-radius:20px;background:var(--surface)}.hero-card h1{margin:8px 0 12px;font-size:38px;line-height:.98;letter-spacing:-.06em}.panel-card h2,.session-card h2{margin:0;font-size:20px;letter-spacing:-.03em}.hero-card p,.song-header p,.section-copy,.step-card p,.session-length-card p,.path-card small,.chord-card p{color:var(--muted);line-height:1.55}.song-header p{margin:10px 0 5px}.eyebrow{margin:0;color:var(--eyebrow);font-size:12px;font-weight:900;letter-spacing:.22em;text-transform:uppercase}.ghost-button,.selected-button,.mastered-button{border:1px solid var(--border);border-radius:999px;background:var(--surface-subtle);color:var(--text);padding:10px 14px;font-weight:900}.selected-button{border-color:var(--blue);background:var(--blue);color:#fff}.mastered-button{border-color:var(--green);background:var(--green-soft);color:var(--green)}.danger-button,.metronome-stop-button{border:1px solid rgba(248,113,113,.45);border-radius:999px;background:var(--danger-soft);color:var(--danger-text);padding:10px 14px;font-weight:900}.danger-button:hover,.metronome-stop-button:hover{border-color:var(--danger);background:#f8717129}.path-card:hover,.step-card:hover,.ghost-button:hover{border-color:var(--border-strong)}.form-control,.custom-song-form input,.custom-song-form textarea,.genre-manager-form input,.genre-manager-form textarea,.custom-genre-content textarea,.bpm-input-wrap input{width:100%;border:1px solid var(--border);border-radius:16px;background:var(--panel-strong);color:var(--text);padding:11px 12px;outline:none}select,.select-control,.custom-song-form select{width:100%;border:1px solid var(--border);border-radius:18px;background-color:var(--panel-strong);color:var(--text);padding:12px 34px 12px 14px;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%23d4d4d8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:14px 14px}textarea,.textarea-control,.custom-song-form textarea{resize:vertical}select::-ms-expand{display:none}.form-control:focus,.select-control:focus,textarea:focus,select:focus,.custom-song-form input:focus,.custom-song-form select:focus,.custom-song-form textarea:focus,.genre-manager-form input:focus,.genre-manager-form textarea:focus,.custom-genre-content textarea:focus,.bpm-input-wrap input:focus{border-color:var(--blue)}.select-label{display:block;margin-bottom:8px;color:var(--muted-strong);font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.confirm-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:var(--dialog-backdrop);padding:18px}.confirm-dialog{display:grid;width:min(420px,100%);gap:18px;border:1px solid var(--border);border-radius:24px;background:var(--panel-strong);box-shadow:0 22px 80px #0000006b;padding:20px}.confirm-dialog-copy{display:grid;gap:8px}.confirm-dialog-copy h2{margin:0;font-size:24px;letter-spacing:-.04em}.confirm-dialog-copy p:not(.eyebrow){margin:0;color:var(--muted);font-size:14px;line-height:1.5}.confirm-dialog-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.confirm-dialog-actions button{min-width:120px}.path-list,.step-list,.transition-list,.section-list{display:grid;gap:10px;margin-top:14px}.step-list p{margin-bottom:0}.path-card,.step-card{width:100%;padding:14px;color:var(--text);text-align:left}.path-card{display:grid;gap:6px}.path-card span,.step-card strong,.session-length-card strong{font-weight:900}.path-card.is-active{border-color:var(--blue);background:var(--blue-soft)}.genre-manager-card{display:grid;gap:14px}.genre-manager-form{display:grid;grid-template-columns:1fr auto;gap:8px}.genre-manager-form textarea{grid-column:1 / -1}.custom-genre-list{display:grid;gap:8px}.custom-genre-row{border:1px solid var(--border);border-radius:16px;background:var(--surface);padding:12px}.custom-genre-row.is-active{border-color:var(--blue);background:var(--blue-soft)}.custom-genre-row.is-editing{padding:14px}.custom-genre-content{display:grid;min-width:0;gap:8px}.custom-genre-content strong{display:block;font-size:13px}.custom-genre-content p{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.custom-genre-content small{color:var(--muted);font-size:11px}.custom-genre-content textarea{min-height:92px;border-radius:14px;padding:10px 12px}.custom-genre-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:2px}.custom-genre-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.genre-action-button{min-width:72px;padding:8px 10px;font-size:12px}.genre-remove-button{display:inline-grid;width:34px;min-width:34px;height:34px;place-items:center;padding:0;font-size:18px;line-height:1}.genre-manager-empty,.genre-manager-message{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.genre-manager-message{color:var(--danger-text);font-weight:800}.local-progress-card{display:grid;gap:14px}.progress-stat-grid,.history-stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.progress-stat-grid div,.history-stat-grid div{border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:12px}.progress-stat-grid span,.history-stat-grid span{display:block;color:var(--text);font-size:24px;font-weight:900}.history-stat-grid span{font-size:28px}.progress-stat-grid small,.history-stat-grid small{display:block;margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}.metronome-card{display:grid;gap:16px}.metronome-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.metronome-header p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.45}.beat-orb{display:grid;width:58px;height:58px;flex:0 0 auto;place-items:center;border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--muted-strong);font-size:22px;font-weight:900}.beat-orb.is-running{border-color:var(--blue);background:var(--blue-soft);color:var(--blue);box-shadow:0 0 0 6px #1b82e614}.metronome-bpm-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:end}.bpm-button{min-width:44px;min-height:44px;padding:0;font-size:22px}.bpm-input-wrap{display:grid;gap:6px}.bpm-input-wrap span{color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.bpm-input-wrap input{font-size:16px;font-weight:900}.beat-dots{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.beat-dot{height:10px;border-radius:999px;background:var(--track);transition:background .12s ease,transform .12s ease,box-shadow .12s ease}.beat-dot.is-accent{background:var(--mango-soft)}.beat-dot.is-active{background:var(--blue);box-shadow:0 0 18px #1b82e661;transform:scaleY(1.45)}.beat-dot.is-active.is-accent{background:var(--mango);box-shadow:0 0 18px #ffb34773}.metronome-note{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.dashboard-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border);border-radius:24px;background:var(--panel);padding:10px;box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.dashboard-nav-main{display:flex;flex-wrap:wrap;gap:10px;min-width:0}.dashboard-nav-button{border:1px solid var(--border);border-radius:999px;background:var(--surface-subtle);color:var(--muted-strong);padding:10px 14px;font-weight:900}.dashboard-nav-button:hover{border-color:var(--border-strong)}.dashboard-nav-button.is-active{border-color:var(--blue);background:var(--blue);color:#fff}.dashboard-nav a{text-decoration:none}.dashboard-nav-button{display:inline-flex;align-items:center;justify-content:center}.dashboard-settings-button{width:44px;min-width:44px;height:44px;padding:0;flex:0 0 44px}.dashboard-settings-button svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.compact-song-card{align-self:start}.song-card.compact-song-card{display:grid;gap:22px}.song-header,.session-header,.section-heading-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.compact-song-card .song-header{align-items:flex-start}.song-card-control-row-wrapper{display:flex;flex-direction:column;gap:10px}.song-card-control-row{display:grid;grid-template-columns:minmax(280px,1fr) auto;gap:14px;align-items:center;margin-bottom:8px}.song-select-inline-control{width:100%;height:42px;border-radius:999px;padding:0 34px 0 14px}.song-header-main{display:grid;gap:10px;max-width:760px}.song-header h2,.song-header-main h2{margin:0;font-size:42px;line-height:1;letter-spacing:-.06em}.song-header-main .goal{margin:6px 0 0;color:var(--muted);font-size:16px;line-height:1.45}.compact-song-card .song-header h2{margin-bottom:8px}.song-detail-grid-wrap{display:grid;margin:0 0 10px;row-gap:10px}.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:22px 0}.song-detail-grid{grid-template-columns:repeat(3,1fr);margin:0}.compact-song-card .info-grid{margin:12px 0 0}.compact-song-card .info-grid:last-of-type{margin:0}.info-card{padding:14px}.compact-info-grid .info-card{padding:12px}.info-card span{color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.info-card strong{display:block;margin-top:6px;font-size:22px}.compact-info-grid .info-card strong{font-size:18px}.song-header-actions{display:flex;align-items:flex-start;justify-content:flex-end;gap:14px;flex-wrap:wrap}.song-header-actions button{min-width:138px;white-space:nowrap}.song-header-actions .ghost-button,.song-header-actions .mastered-button,.song-header-actions .danger-button{flex-shrink:0}.song-header-actions.song-icon-actions{flex-direction:row;align-items:center;flex-wrap:nowrap;gap:8px}.song-header-actions.song-icon-actions .icon-button{display:inline-grid;width:42px;min-width:42px;height:42px;flex:0 0 42px;place-items:center;padding:0}.icon-button svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2.35;stroke-linecap:round;stroke-linejoin:round}.edit-icon-button{color:#7dd3fc}.edit-icon-button:hover{border-color:var(--blue);background:var(--blue-soft)}.mastered-icon-button{border:1px solid var(--border);border-radius:999px;background:var(--surface-subtle);color:var(--muted)}.mastered-icon-button svg{fill:none}.mastered-icon-button:hover{border-color:var(--mango);background:var(--mango-soft);color:var(--mango)}.mastered-icon-button.is-mastered{border-color:var(--mango);border-radius:999px;background:var(--mango-soft);color:var(--mango)}.mastered-icon-button.is-mastered svg{fill:currentColor}.progress-badge{display:grid;width:64px;height:64px;place-items:center;border:1px solid var(--blue);border-radius:999px;background:var(--blue-soft);color:#7dd3fc;font-weight:900}.progress-badge.is-empty{border-color:#f8717173;background:var(--danger-soft);color:var(--danger-text)}.progress-badge.is-active{border-color:var(--blue);background:var(--blue-soft);color:#7dd3fc}.progress-badge.is-complete{border-color:var(--green);background:var(--green-soft);color:var(--green)}.session-length-card{display:grid;gap:10px;margin-top:18px;border:1px solid var(--border);border-radius:20px;background:var(--surface);padding:14px}.session-length-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.session-length-actions .ghost-button,.session-length-actions .selected-button{min-width:0;padding:9px 12px}.progress-track{height:8px;margin:18px 0;overflow:hidden;border-radius:999px;background:var(--track)}.progress-fill{height:100%;border-radius:inherit;background:var(--blue);transition:width .18s ease,background .18s ease}.progress-fill.is-empty{background:var(--danger)}.progress-fill.is-active{background:var(--blue)}.progress-fill.is-complete{background:var(--green)}.step-card span,.transition-card div,.chord-card-header,.chord-card>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:12px}.step-card small,.transition-card span,.chord-card span{color:var(--muted);font-size:12px}.step-card.is-complete{border-color:var(--green);background:var(--green-soft)}.complete-session-card{display:grid;gap:14px;margin-top:18px;border:1px solid var(--border);border-radius:22px;background:var(--surface);padding:16px}.complete-session-card h3{margin:0;font-size:18px;letter-spacing:-.03em}.complete-session-card p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.45}.session-timer-display{display:grid;gap:4px;border:1px solid var(--border);border-radius:20px;background:var(--surface-soft);padding:14px;text-align:center}.session-timer-display span{color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.session-timer-display strong{color:var(--text);font-size:42px;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.04em}.session-timer-display small{color:var(--muted);font-size:12px}.session-timer-actions,.rating-row{display:grid;gap:8px}.session-primary-action{width:100%;min-height:46px}.session-running-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.session-icon-button{display:inline-grid;min-height:46px;place-items:center;border:1px solid var(--border);border-radius:999px;background:var(--surface-subtle);color:var(--muted-strong);padding:0}.session-icon-button:hover{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.session-icon-button:disabled{border-color:var(--border);background:var(--surface-soft);color:var(--muted);cursor:not-allowed;opacity:.68}.session-icon-button svg{width:20px;height:20px;flex:0 0 auto}.session-record-button:hover,.session-record-button.is-recording{border-color:var(--danger);background:var(--danger-soft);color:var(--danger)}.session-record-button.is-recording{animation:session-record-pulse 1.15s ease-in-out infinite}.session-stop-button:hover{border-color:var(--danger);background:var(--danger-soft);color:var(--danger)}.session-stop-button svg{stroke:none}.session-recording-status{margin:-2px 0 0!important;border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--muted-strong)!important;padding:8px 10px;text-align:center;font-size:12px!important;font-weight:900}.session-recording-status.is-recording{border-color:var(--danger);background:var(--danger-soft);color:var(--danger)!important}.session-recording-status.is-ready{border-color:var(--green);background:var(--green-soft);color:var(--green)!important}.session-rating-block{display:grid;gap:8px}.session-rating-label{margin:0!important;color:var(--eyebrow)!important;font-size:11px!important;font-weight:900;letter-spacing:.16em;line-height:1;text-align:center;text-transform:uppercase;transition:color .16s ease}.session-rating-label.is-muted{color:var(--muted)!important}.rating-row{grid-template-columns:repeat(3,1fr)}.rating-row button:disabled{border-color:var(--border);background:var(--surface-soft);color:var(--muted);cursor:not-allowed;opacity:1}.complete-session-button{border:1px solid var(--green);border-radius:999px;background:var(--green-soft);color:var(--green);padding:11px 14px;font-weight:900}.complete-session-button:hover{background:#34d3992e}.complete-session-button:disabled{border-color:var(--border);background:var(--surface-soft);color:var(--muted);opacity:1;cursor:not-allowed}.session-message{border:1px solid rgba(52,211,153,.32);border-radius:16px;background:var(--green-soft);color:var(--green)!important;padding:10px 12px;font-weight:800}@keyframes session-record-pulse{0%,to{box-shadow:0 0 #f8717100}50%{box-shadow:0 0 0 6px #f871711f}}.chord-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px}.chord-card,.transition-card,.song-section-card{padding:14px}.chord-card{display:grid;gap:14px}.chord-card strong{margin-right:5px;font-size:26px}.chord-card p.chord-detail{margin:4px 0}.chord-card-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.chord-card-header>div{min-width:0}.chord-audio-button{display:inline-grid;width:42px;min-width:42px;height:42px;flex:0 0 42px;place-items:center;border:1px solid var(--border);border-radius:999px;background:var(--surface-subtle);color:var(--muted-strong);padding:0}.chord-audio-button:hover{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.chord-audio-button.is-playing{border-color:var(--green);background:var(--green-soft);color:var(--green)}.chord-audio-button svg{width:18px;height:18px;fill:currentColor;transform:translate(1px)}.chord-diagram{display:grid;justify-items:center;gap:8px;border:1px solid var(--border);border-radius:18px;background:var(--diagram-bg);padding:12px}.chord-diagram-empty{min-height:170px;place-items:center;color:var(--muted);font-size:13px;font-weight:800}.chord-diagram-name{color:var(--text);font-size:15px;font-weight:900}.chord-diagram svg{width:min(100%,180px);height:auto}.guitar-string{stroke:var(--diagram-string);stroke-width:1.6;stroke-linecap:round}.guitar-fret{stroke:var(--diagram-fret);stroke-width:1.6;stroke-linecap:round}.guitar-nut{stroke:var(--diagram-nut);stroke-width:5;stroke-linecap:round}.open-string{fill:transparent;stroke:var(--diagram-open-string);stroke-width:2}.string-marker{fill:var(--diagram-muted-string);font-size:17px;font-weight:900;text-anchor:middle;dominant-baseline:auto}.fretted-note{fill:var(--blue);stroke:#fff6;stroke-width:1}.finger-label{fill:var(--diagram-finger-label);font-size:10px;font-weight:900;text-anchor:middle}.fret-label{fill:var(--muted);font-size:11px;font-weight:900}.detail-section-card{min-height:420px}.detail-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.transition-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.transition-card input{width:100%;margin-top:14px;accent-color:var(--blue)}.strum-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:18px;padding:9px 12px;color:var(--muted-strong);font-size:13px;font-weight:800}.strum-pill>span:first-child{color:var(--muted-strong)}.song-section-card{display:grid;gap:8px}.song-section-card span{color:#7dd3fc;font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.song-section-card strong{font-size:18px}.session-history-card{display:grid;gap:18px}.history-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.history-summary-card{display:grid;gap:4px;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:14px}.history-summary-card strong{display:block;color:var(--text);font-size:28px;font-weight:900;line-height:1;letter-spacing:-.04em}.history-summary-card span{color:var(--muted-strong);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.history-summary-card small{color:var(--muted);font-size:12px;line-height:1.35}.history-summary-card--green{border-color:var(--green);background:var(--green-soft)}.history-summary-card--green strong{color:var(--green)}.history-summary-card--muted strong{color:var(--muted-strong)}.history-streak-card{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;border:1px solid var(--border);border-radius:22px;background:var(--surface);padding:16px}.history-streak-card h3{margin:0;color:var(--text);font-size:24px;letter-spacing:-.04em}.history-streak-card p:not(.eyebrow){margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.history-streak-meta{display:grid;min-width:180px;gap:4px;border:1px solid var(--border);border-radius:18px;background:var(--surface-soft);padding:14px;text-align:right}.history-streak-meta span{color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.history-streak-meta strong{color:var(--text);font-size:24px;line-height:1}.history-streak-meta small{color:var(--muted);font-size:12px}.history-list{display:grid;gap:10px}.history-card{display:grid;gap:12px;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:14px}.history-card-header{display:flex;justify-content:space-between;gap:12px}.history-card-header>div{display:grid;min-width:0;gap:4px}.history-card strong{color:var(--text);font-size:17px}.history-card-header small,.history-card-header span{color:var(--muted);font-size:13px}.history-card-date{justify-items:end;text-align:right}.history-card-date small{font-size:12px}.history-card-footer{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.history-card-metrics{display:flex;flex-wrap:wrap;gap:8px}.history-card-metrics span{border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--muted-strong);padding:6px 10px;font-size:12px;font-weight:800}.history-recording-actions{display:grid;flex:0 0 auto;justify-items:end;gap:6px}.history-recording-controls{display:flex;align-items:center;justify-content:flex-end;gap:6px}.history-recording-button{display:inline-flex;min-height:36px;align-items:center;justify-content:center;gap:6px;border:1px solid var(--blue);border-radius:999px;background:var(--blue-soft);color:var(--blue);padding:7px 11px;font-size:12px;font-weight:900}.history-recording-button:hover{background:#1b82e62e}.history-recording-button:disabled,.history-recording-stop-button:disabled{border-color:var(--border);background:var(--surface-soft);color:var(--muted);cursor:not-allowed}.history-recording-button:disabled{cursor:wait}.history-recording-button.is-playing{border-color:var(--green);background:var(--green-soft);color:var(--green)}.history-recording-button.is-replay{border-color:var(--mango);background:var(--mango-soft);color:var(--mango)}.history-recording-stop-button{display:inline-grid;width:36px;min-width:36px;min-height:36px;place-items:center;border:1px solid var(--danger);border-radius:999px;background:var(--danger-soft);color:var(--danger);padding:0}.history-recording-stop-button:not(:disabled):hover{background:var(--danger-hover)}.history-recording-button svg,.history-recording-stop-button svg{width:15px;height:15px;flex:0 0 auto}.history-recording-button svg.history-replay-icon{width:20px;height:20px}.history-recording-stop-button svg{stroke:none}.history-playback-message{margin:0;color:var(--muted);font-size:12px;font-weight:400;line-height:1.35;text-align:right}.history-empty{display:grid;gap:8px;border:1px dashed var(--border);border-radius:18px;background:var(--surface-soft);padding:18px}.history-empty h3{margin:0;color:var(--text);font-size:20px;letter-spacing:-.03em}.history-empty p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}@media (max-width: 900px){.history-summary-grid{grid-template-columns:repeat(2,1fr)}.history-streak-card{grid-template-columns:1fr}.history-streak-meta{text-align:left}.history-card-footer{display:grid}.history-recording-actions{justify-items:stretch}.history-recording-controls{justify-content:stretch}.history-recording-button{width:100%}.history-playback-message{text-align:left}}@media (max-width: 560px){.history-summary-grid{grid-template-columns:1fr}.history-card-header{display:grid}.history-card-date{justify-items:start;text-align:left}}.weekly-plan-card{display:grid;gap:18px}.weekly-plan-header{margin-bottom:0}.weekly-focus-card{display:grid;gap:8px;border:1px solid var(--border);border-radius:22px;background:var(--surface);padding:16px}.weekly-focus-card span{color:var(--eyebrow);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.weekly-focus-card strong{display:block;margin-top:6px;color:var(--text);font-size:26px;line-height:1;letter-spacing:-.04em}.weekly-focus-card p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.weekly-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.weekly-summary-grid div{border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:14px}.weekly-summary-grid span{display:block;color:var(--text);font-size:24px;font-weight:900}.weekly-summary-grid small{display:block;margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}.weekly-day-list{display:grid;gap:10px}.weekly-day-card{display:grid;grid-template-columns:84px 1fr;gap:14px;border:1px solid var(--border);border-radius:20px;background:var(--surface);padding:14px}.weekly-day-badge{display:grid;min-height:54px;place-items:center;border:1px solid var(--blue);border-radius:18px;background:var(--blue-soft);color:var(--blue);font-size:13px;font-weight:900}.weekly-day-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.weekly-day-title-row h3{margin:0;color:var(--text);font-size:18px;letter-spacing:-.03em}.weekly-day-title-row span{flex:0 0 auto;border:1px solid var(--border);border-radius:999px;background:var(--surface-subtle);color:var(--muted-strong);padding:5px 9px;font-size:12px;font-weight:900}.weekly-day-card p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.settings-panel{display:grid;gap:22px}.settings-hero{display:grid;gap:10px;max-width:760px}.settings-hero h2{margin:0;font-size:42px;line-height:1;letter-spacing:-.06em}.settings-hero p:not(.eyebrow){margin:0;color:var(--muted);font-size:16px;line-height:1.5}.settings-grid{display:grid;gap:14px}.settings-section-card{display:grid;gap:18px;border:1px solid var(--border);border-radius:22px;background:var(--surface);padding:18px}.settings-section-card h3{margin:0;font-size:24px;letter-spacing:-.04em}.settings-section-card p:not(.eyebrow){margin:8px 0 0;color:var(--muted);font-size:14px;line-height:1.5}.settings-section-content{display:grid;gap:8px}.settings-option-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.settings-option-card{display:grid;gap:6px;min-height:104px;border:1px solid var(--border);border-radius:18px;background:var(--surface-soft);color:var(--text);padding:14px;text-align:left}.settings-option-card:hover{border-color:var(--border-strong)}.settings-option-card.is-selected{border-color:var(--blue);background:var(--blue-soft)}.settings-option-card span{font-size:15px;font-weight:900}.settings-option-card small{color:var(--muted);font-size:12px;line-height:1.4}.settings-placeholder-row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--border);border-radius:16px;background:var(--surface-soft);padding:12px 14px}.settings-placeholder-row span{color:var(--muted);font-size:13px;font-weight:800}.settings-placeholder-row strong{color:var(--muted-strong);font-size:13px}@media (max-width: 760px){.settings-option-grid{grid-template-columns:1fr}}.custom-song-card,.custom-song-form{display:grid;gap:16px}.custom-song-form{gap:14px}.custom-song-header,.custom-song-actions{display:grid;gap:16px}.custom-song-header{grid-template-columns:1fr auto;align-items:start}.custom-song-actions{grid-template-columns:1fr auto;align-items:center}.custom-song-button-group{display:flex;justify-content:flex-end;gap:10px}.form-grid.two{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.custom-song-form label{display:grid;gap:7px}.custom-song-form label span{color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.custom-song-message{min-height:1.35em;margin:0;font-size:13px;font-weight:800;line-height:1.35}.custom-song-message.is-error{color:var(--danger-text)}.custom-song-message.is-info{color:var(--blue)}.import-link-card{display:grid;gap:12px;border:1px solid rgba(125,211,252,.25);border-radius:20px;background:var(--blue-soft);padding:14px}.import-link-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.custom-song-preview{display:grid;gap:10px;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:12px}.custom-song-preview>span{color:var(--eyebrow);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.custom-song-preview div{display:flex;flex-wrap:wrap;gap:8px}.custom-song-preview strong{border:1px solid var(--blue);border-radius:999px;padding:6px 10px;background:var(--blue-soft);color:var(--blue);font-size:13px}.custom-song-preview small{color:var(--muted)}.strumming-builder{display:grid;gap:14px;border:1px solid var(--border);border-radius:20px;background:var(--surface);padding:14px}.strumming-builder>div:first-child>span{color:var(--eyebrow);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.strumming-builder>div:first-child>p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.45}.strumming-subdivision-toggle{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.strumming-subdivision-toggle .ghost-button,.strumming-subdivision-toggle .selected-button{min-width:0;padding:9px 12px}.strumming-pattern-display{display:grid;gap:4px;overflow-x:auto;border:1px solid var(--border);border-radius:18px;background:var(--panel-strong);padding:12px}.strumming-arrow-row,.strumming-beat-row{display:grid;min-width:calc(var(--strumming-slot-count, 8) * 28px);grid-template-columns:repeat(var(--strumming-slot-count, 8),minmax(22px,1fr));gap:6px;text-align:center}.strumming-direction{display:grid;min-height:34px;place-items:center;color:var(--muted);font-size:28px;font-weight:900;line-height:1}.strumming-direction.is-active.is-down{color:var(--strum-down)}.strumming-direction.is-active.is-up{color:var(--strum-up)}.strumming-beat-row span{color:var(--muted);font-size:13px;font-weight:900}.strumming-pattern-display.is-compact{border-radius:14px;padding:8px}.strumming-pattern-display.is-compact .strumming-arrow-row,.strumming-pattern-display.is-compact .strumming-beat-row{min-width:calc(var(--strumming-slot-count, 8) * 20px);grid-template-columns:repeat(var(--strumming-slot-count, 8),minmax(16px,1fr));gap:4px}.strumming-pattern-display.is-compact .strumming-direction{min-height:24px;font-size:20px}.strumming-pattern-display.is-compact .strumming-beat-row span{font-size:11px}.strumming-slot-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:8px;padding:0 12px}.strumming-builder.is-sixteenth .strumming-slot-grid{grid-template-columns:repeat(8,minmax(0,1fr))}.strumming-slot-card{display:grid;gap:7px;border:1px solid var(--border);border-radius:16px;background:var(--surface-soft);padding:8px}.strumming-slot-card>span{color:var(--muted);font-size:12px;font-weight:900;text-align:center}.strumming-slot-card>div{display:grid;gap:6px}.strum-arrow-button{display:grid;min-height:44px;place-items:center;border:1px solid var(--border);border-radius:14px;background:var(--surface-subtle);color:var(--text);font-size:28px;font-weight:900;line-height:1}.strum-arrow-button:hover{border-color:var(--blue)}.strum-arrow-button.is-selected{border-color:var(--blue);background:var(--blue-soft)}.strum-down-button{color:var(--strum-down)}.strum-up-button,.strum-up{color:var(--strum-up)}.strum-up-button.is-selected{border-color:var(--strum-up);background:var(--strum-up-soft);color:var(--strum-up)}.strum-up-button:hover{border-color:var(--strum-up)}.inline-strumming-display{display:inline-flex;align-items:center;flex-wrap:wrap;gap:4px}.inline-strumming-display strong{display:inline-grid;place-items:center;color:var(--strum-down);font-size:22px;font-weight:900;line-height:1}.strumming-playback-guide{display:grid;gap:12px;border:1px solid var(--border);border-radius:20px;background:var(--surface);padding:14px}.strumming-playback-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.strumming-playback-header span{color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.strumming-playback-cue{border:1px solid var(--border);border-radius:999px;background:var(--surface-subtle);color:var(--muted-strong);padding:7px 10px;font-size:12px;font-weight:900}.strumming-playback-guide.is-idle .strumming-playback-cue,.strumming-playback-guide.is-idle .strumming-playback-slot-beat{opacity:.68}.strumming-playback-cue.is-down{border-color:var(--border-strong);background:var(--strum-down-soft);color:var(--strum-down)}.strumming-playback-cue.is-up{border-color:var(--strum-up);background:var(--strum-up-soft);color:var(--strum-up)}.strumming-playback-cue.is-rest{color:var(--muted)}.strumming-playback-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:8px}.strumming-playback-guide.is-sixteenth .strumming-playback-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.strumming-playback-slot{display:grid;grid-template-rows:auto auto;min-height:68px;align-content:center;justify-items:center;justify-content:center;gap:7px;border:1px solid var(--border);border-radius:16px;background:var(--surface-soft);padding:8px 6px;text-align:center;transition:border-color .14s ease,background .14s ease,box-shadow .14s ease,transform .14s ease}.strumming-playback-slot.is-active{border-color:var(--blue);background:var(--blue-soft);box-shadow:0 0 0 5px #1b82e614;transform:translateY(-1px)}.strumming-playback-slot.is-active.is-up{border-color:var(--strum-up);background:var(--strum-up-soft);box-shadow:0 0 0 5px #f59e0b14}.strumming-playback-slot-stack{display:flex;flex-direction:column;justify-content:center;gap:4px}.strumming-playback-slot-direction{display:grid;min-height:28px;place-items:center;color:var(--muted);font-size:26px;font-weight:900;line-height:1}.strumming-playback-slot.is-down .strumming-playback-slot-direction{color:var(--strum-down)}.strumming-playback-slot.is-up .strumming-playback-slot-direction{color:var(--strum-up)}.strumming-playback-slot-beat{display:block;color:var(--muted);font-size:11px;font-weight:900;line-height:1}.metronome-card .strumming-playback-guide{margin-top:2px}@media (max-width: 1100px){.app-grid,.top-grid{grid-template-columns:1fr}.info-grid{grid-template-columns:repeat(2,1fr)}.transition-grid{grid-template-columns:1fr}.weekly-summary-grid{grid-template-columns:repeat(2,1fr)}.strumming-slot-grid,.strumming-playback-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width: 640px){.app-grid{padding:14px}.hero-card h1,.song-header h2,.song-header-main h2{font-size:32px}.song-header,.session-header,.section-heading-row{flex-direction:column}.song-card-control-row,.custom-song-header,.custom-song-actions,.custom-song-button-group{grid-template-columns:1fr}.song-card-control-row{align-items:stretch}.custom-song-button-group{display:grid}.song-header-actions.song-icon-actions{flex-direction:row;align-items:center;justify-content:flex-start}.dashboard-nav,.genre-manager-form{grid-template-columns:1fr}.dashboard-nav{display:grid}.dashboard-nav-button{width:100%}.detail-section-card{min-height:unset}.chord-grid,.info-grid,.song-detail-grid,.form-grid.two,.rating-row,.history-stat-grid,.session-timer-actions,.weekly-summary-grid,.weekly-day-card{grid-template-columns:1fr}.custom-genre-footer{flex-direction:column;align-items:stretch}.custom-genre-actions{justify-content:flex-end}.weekly-day-title-row{flex-direction:column}.strumming-slot-grid,.strumming-playback-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.strumming-arrow-row,.strumming-beat-row{gap:3px}.strumming-direction{font-size:22px}.history-card div{flex-direction:column}}*{box-sizing:border-box}:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0a0a0b;color:#f4f4f5}html,body,#root{min-height:100%}body{margin:0;background:var(--body-bg, #0a0a0b)}
