/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:"JetBrains Mono", monospace;--radius-xl:.75rem;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--font-display:"Cormorant Garamond", serif;--font-body:"Outfit", sans-serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.static{position:static}.isolate{isolation:isolate}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--bg:#f9f6f0;--surface:#fff;--surface-el:#f0ebe1;--primary:#d9772f;--primary-hov:#c26622;--primary-rgb:217, 119, 47;--ink:#0a1128;--muted:#4a5568;--line:#e2d8c9;--chord:#d9772f;--chord-rgb:217, 119, 47;--success:#2d7a5d;--danger:#c53030;--radius-xl:1.5rem;--shadow:0 4px 24px #0a112812;--shadow-md:0 8px 40px #0a11281a;--sidebar-bg:#0c1628;--perf-bg:#0c1628}[data-theme=dark]{--bg:#0a1128;--surface:#121a35;--surface-el:#1a2447;--primary:#e68a2e;--primary-hov:#ffb067;--primary-rgb:230, 138, 46;--ink:#f9f6f0;--muted:#a0abc0;--line:#1a2447;--chord:#ffb067;--chord-rgb:255, 176, 103;--success:#38a169;--danger:#fc8181;--shadow:0 4px 24px #0000004d;--shadow-md:0 8px 40px #0006;--sidebar-bg:#060e1f;--perf-bg:#060e1f}[data-theme=purple]{--bg:#08001a;--surface:#110d2e;--surface-el:#1a1040;--primary:#bf00ff;--primary-hov:#c3f;--primary-rgb:191, 0, 255;--ink:#fff;--muted:#98b;--line:#1e0a40;--chord:#00f5ff;--chord-rgb:0, 245, 255;--success:#0f8;--danger:#f36;--shadow:0 4px 24px rgba(var(--primary-rgb),.18);--shadow-md:0 8px 40px rgba(var(--primary-rgb),.26);--sidebar-bg:#2d0060;--perf-bg:#08001a}[data-theme=pink]{--bg:#04041a;--surface:#0a0a2e;--surface-el:#10103a;--primary:#f09;--primary-hov:#f3a;--primary-rgb:255, 0, 153;--ink:#fff;--muted:#99b;--line:#1e1e50;--chord:#0af;--chord-rgb:0, 170, 255;--success:#00c875;--danger:#f36;--shadow:0 4px 24px #ff009926;--shadow-md:0 8px 40px #ff009938;--sidebar-bg:#280045;--perf-bg:#04041a}[data-theme=matrix]{--bg:#000a00;--surface:#0a1200;--surface-el:#0f1a00;--primary:#00ff41;--primary-hov:#39ff14;--primary-rgb:0, 255, 65;--ink:#e0ffe0;--muted:#4a7a4a;--line:#0a2200;--chord:#39ff14;--chord-rgb:57, 255, 20;--success:#00ff41;--danger:#f46;--shadow:0 4px 24px #00ff4126;--shadow-md:0 8px 40px #00ff4138;--sidebar-bg:#003800;--perf-bg:#000a00}[data-theme=sunset]{--bg:#0a0500;--surface:#1a0c00;--surface-el:#2a1200;--primary:#ff6b35;--primary-hov:#ff8c5a;--primary-rgb:255, 107, 53;--ink:#fff5ee;--muted:#a87;--line:#3a1800;--chord:#ffd166;--chord-rgb:255, 209, 102;--success:#00c875;--danger:#f36;--shadow:0 4px 24px #ff6b352e;--shadow-md:0 8px 40px #ff6b3542;--sidebar-bg:#2a0f00;--perf-bg:#0a0500}[data-theme=ocean]{--bg:#001020;--surface:#001a30;--surface-el:#002240;--primary:#00e5cc;--primary-hov:#3fe;--primary-rgb:0, 229, 204;--ink:#e0faff;--muted:#59a;--line:#003050;--chord:#00c8ff;--chord-rgb:0, 200, 255;--success:#0f8;--danger:#f46;--shadow:0 4px 24px #00e5cc29;--shadow-md:0 8px 40px #00e5cc3d;--sidebar-bg:#002040;--perf-bg:#001020}[data-theme=gold]{--bg:#0a0800;--surface:#1a1200;--surface-el:#2a1e00;--primary:gold;--primary-hov:#ffe033;--primary-rgb:255, 215, 0;--ink:#fff8e0;--muted:#a94;--line:#3a2e00;--chord:#ff9500;--chord-rgb:255, 149, 0;--success:#00c875;--danger:#f46;--shadow:0 4px 24px #ffd70029;--shadow-md:0 8px 40px #ffd7003d;--sidebar-bg:#261a00;--perf-bg:#0a0800}.dark{--bg:#0a1128;--surface:#121a35;--surface-el:#1a2447;--primary:#e68a2e;--primary-hov:#ffb067;--primary-rgb:230, 138, 46;--ink:#f9f6f0;--muted:#a0abc0;--line:#1a2447;--chord:#ffb067;--chord-rgb:255, 176, 103;--success:#38a169;--danger:#fc8181;--sidebar-bg:#060e1f;--perf-bg:#060e1f}*,:before,:after{box-sizing:border-box}body{background-color:var(--bg);min-height:100vh;color:var(--ink);margin:0;font-family:Outfit,sans-serif;transition:background-color .2s,color .2s}a{color:inherit;text-decoration:none}.chord-line{color:var(--chord);white-space:pre;font-family:JetBrains Mono,monospace;font-weight:700;line-height:1.2;display:block}.lyric-line{white-space:pre;line-height:1.6;display:block}.bar-row{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.bar-cell{background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.2);min-width:56px;color:var(--chord);border-radius:10px;justify-content:center;align-items:center;padding:6px 10px;font-family:JetBrains Mono,monospace;font-weight:700;display:inline-flex}.sidebar-link{color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-link:hover{background:rgba(var(--primary-rgb),.08);color:var(--primary)}.sidebar-link.active{background:rgba(var(--primary-rgb),.12);color:var(--primary)}.section-tag{text-transform:uppercase;letter-spacing:.18em;background:rgba(var(--primary-rgb),.08);color:var(--primary);border-radius:999px;align-items:center;margin-bottom:8px;padding:4px 10px;font-size:.7rem;font-weight:700;display:inline-flex}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.topbar{background:var(--surface);border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:24px;padding:18px clamp(18px,4vw,56px);display:flex}.brand{font-family:var(--font-display);font-size:1.7rem;font-weight:700}.nav,.inline-actions,.player-actions,.song-tags{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.nav a,.link-button{color:var(--muted);font:inherit;font-weight:700}.link-button{cursor:pointer;background:0 0;border:0;padding:0}.page-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:clamp(28px,5vw,56px) 0}.landing-hero,.hero-premium,.section-block,.player-shell{padding:clamp(24px,4vw,48px) 0}.landing-hero{grid-template-columns:minmax(0,1fr) minmax(280px,.85fr);align-items:center;gap:clamp(28px,5vw,64px);min-height:72vh;display:grid}.landing-kicker,.eyebrow,.song-meta{color:var(--primary);letter-spacing:.12em;text-transform:uppercase;font-size:.76rem;font-weight:800}h1,h2,p{margin-top:0}h1,h2{font-family:var(--font-display);line-height:1}h1{max-width:760px;margin-bottom:18px;font-size:clamp(2.8rem,8vw,6.4rem)}h2{font-size:clamp(1.8rem,4vw,2.7rem)}.landing-lead,.section-lead,.empty-card p,.notice{color:var(--muted);font-size:1.05rem;line-height:1.7}.landing-actions,.landing-stats{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.landing-stats span,.song-tags span,.beat-pill{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:999px;padding:8px 12px;font-weight:800}.button{border:1px solid var(--primary);background:var(--primary);color:#fff;cursor:pointer;min-height:42px;font:inherit;border-radius:12px;justify-content:center;align-items:center;padding:10px 16px;font-weight:800;display:inline-flex}.button:hover{background:var(--primary-hov)}.button.ghost,.button.subtle{background:var(--surface);color:var(--primary)}.button.danger-outline{background:var(--surface);border-color:var(--danger);color:var(--danger)}.landing-visual{min-height:420px;position:relative}.landing-device{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-md);border-radius:28px;overflow:hidden}.landing-device-top{border-bottom:1px solid var(--line);gap:8px;padding:18px;display:flex}.landing-dot{background:var(--line);border-radius:50%;width:10px;height:10px}.landing-device-body{min-height:330px;padding:24px;position:relative}.landing-panel,.landing-floating-card,.song-card,.live-set-card,.empty-card,.form-panel,.notice,.set-preview li{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:16px;padding:22px}.landing-panel-primary{margin-bottom:18px}.landing-panel strong,.landing-floating-card strong,.song-card h2,.live-set-card h2{display:block}.landing-chip-row{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.landing-chip-row span{background:var(--surface-el);border-radius:999px;padding:7px 10px}.landing-mini-meter{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.landing-mini-meter span{background:var(--primary);border-radius:8px;height:56px}@supports (color:color-mix(in lab, red, red)){.landing-mini-meter span{background:color-mix(in srgb, var(--primary) 36%, var(--surface-el))}}.landing-floating-card{width:min(210px,100% - 36px);position:absolute;bottom:18px;right:18px}.landing-floating-left{bottom:84px;left:18px;right:auto}.section-head{justify-content:space-between;align-items:end;gap:18px;margin-bottom:22px;display:flex}.section-head.compact{align-items:center;margin-bottom:12px}.section-head.compact h2{margin:0;font-size:1.4rem}.narrow{max-width:860px;margin-inline:auto}.song-grid,.live-set-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;display:grid}.song-card h2,.live-set-card h2,.empty-card h2{margin-bottom:14px}.form-panel{gap:18px;display:grid}.form-grid,.builder-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.builder-grid{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:start}label{color:var(--muted);gap:8px;font-weight:800;display:grid}input,textarea{border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);font:inherit;border-radius:12px;padding:12px 14px}textarea{font-family:var(--font-mono);line-height:1.6}.player-head{justify-content:space-between;align-items:flex-start;gap:32px;margin-bottom:36px;display:flex}.player-back{color:var(--muted);letter-spacing:.04em;align-items:center;gap:6px;margin-bottom:28px;font-size:.8rem;font-weight:700;transition:color .14s;display:inline-flex}.player-back:hover{color:var(--ink)}.player-title-block{flex:1;min-width:0}.player-title{font-family:var(--font-display);margin:4px 0 18px;font-size:clamp(2.4rem,5vw,4rem);line-height:1}.player-meta-strip{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.player-meta-tag{font-family:var(--font-mono);color:var(--muted);background:var(--surface-el);border-radius:8px;padding:4px 11px;font-size:.75rem;font-weight:700}.player-meta-sep{color:var(--line);-webkit-user-select:none;user-select:none;font-size:1rem}.player-controls{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:20px;flex-shrink:0;align-items:stretch;gap:0;padding:20px 26px;display:flex}.ctrl-group{flex-direction:column;gap:10px;padding:0 22px;display:flex}.ctrl-group:first-child{padding-left:0}.ctrl-group:last-child{padding-right:0}.ctrl-group-label{letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-size:.65rem;font-weight:800}.ctrl-row{align-items:center;gap:8px;display:flex}.ctrl-divider{background:var(--line);flex-shrink:0;align-self:stretch;width:1px}.ctrl-btn{border:1.5px solid var(--line);background:var(--bg);min-width:38px;height:38px;color:var(--ink);font-family:var(--font-mono);cursor:pointer;white-space:nowrap;border-radius:10px;justify-content:center;align-items:center;padding:0 10px;font-size:1.05rem;font-weight:700;transition:border-color .14s,background .14s;display:inline-flex}.ctrl-btn:hover{border-color:var(--primary);background:var(--primary)}@supports (color:color-mix(in lab, red, red)){.ctrl-btn:hover{background:color-mix(in srgb, var(--primary) 8%, var(--bg))}}.ctrl-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;padding:0 18px}.ctrl-btn-primary:hover{background:var(--primary-hov);border-color:var(--primary-hov)}.ctrl-key-display{font-family:var(--font-mono);color:var(--primary);text-align:center;letter-spacing:.02em;min-width:72px;font-size:.95rem;font-weight:800}.ctrl-beat-pill{background:var(--surface-el);border:1.5px solid var(--line);width:34px;height:34px;font-family:var(--font-mono);color:var(--ink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.88rem;font-weight:800;display:inline-flex}.ctrl-bpm-label{font-family:var(--font-mono);color:var(--muted);white-space:nowrap;font-size:.78rem;font-weight:600}.chart-output{background:var(--sidebar-bg);border:1px solid #ffffff0f;border-radius:18px;flex-direction:column;gap:0;padding:clamp(22px,3vw,36px);display:flex}.chart-section{box-shadow:none;background:0 0;border:none;border-radius:0;padding:22px 0}.chart-section+.chart-section{border-top:1px solid #ffffff0f}.chart-section:first-child{padding-top:0}.chart-section:last-child{padding-bottom:0}.chart-section h2{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--primary);background:rgba(var(--primary-rgb),.12);border:1px solid rgba(var(--primary-rgb),.35);border-radius:6px;margin-bottom:16px;padding:3px 10px;font-size:.65rem;font-weight:800;line-height:1.6;display:inline-flex}.chart-lines{font-family:var(--font-mono);white-space:pre-wrap;gap:14px;display:grid}.chord{color:var(--primary);font-weight:800}.chord-line{color:#ffffffe0}.lyric-line{color:#ffffff8c;font-family:var(--font-body);font-size:.95rem}.measure-line{flex-wrap:wrap;align-items:center;gap:0;display:flex}.measure{color:#ffffffeb;text-align:center;background:0 0;border:none;border-radius:0;min-width:62px;padding:6px 12px;font-size:clamp(1.05rem,2vw,1.3rem);font-weight:700}.measure-sep{color:#ffffff2e;-webkit-user-select:none;user-select:none;padding:0 2px;font-size:1rem;font-weight:300}.measure-sep-end{color:#ffffff5c;font-weight:500}.repeat-mark{font-family:var(--font-mono);color:var(--primary);-webkit-user-select:none;user-select:none;letter-spacing:-.02em;align-self:center;padding:0 6px;font-size:clamp(1rem,2vw,1.45rem);font-weight:700}.repeat-badge{font-family:var(--font-mono);color:var(--primary);background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.28);white-space:nowrap;border-radius:5px;align-self:center;margin-left:10px;padding:2px 7px;font-size:.68rem;font-weight:700}.nc-chord{font-style:italic;color:#ffffff59!important;min-width:54px!important;font-size:clamp(.85rem,1.6vw,1.15rem)!important}.slash-beat{color:#ffffff38;letter-spacing:.1em;font-weight:400}.nav-marker{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--primary);background:rgba(var(--primary-rgb),.08);border:1px solid rgba(var(--primary-rgb),.25);border-radius:6px;align-items:center;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-flex}.perf-body .repeat-mark{padding:0 8px;font-size:clamp(1.3rem,2.8vw,2rem)}.perf-body .repeat-badge{margin-left:12px;padding:3px 9px;font-size:.72rem}.perf-body .nc-chord{font-size:clamp(1.1rem,2.2vw,1.7rem)!important}.perf-body .nav-marker{padding:4px 12px;font-size:.72rem}.notice{margin-bottom:18px}.notice.danger,.notice-danger{border-color:var(--danger);color:var(--danger)}.notice-danger,.notice-success{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:14px;max-width:1180px;margin:24px auto 0;padding:14px clamp(16px,3vw,40px);font-size:.92rem;font-weight:600;line-height:1.5}.notice-success{border-color:var(--success);color:var(--success)}.library-list,.live-set-selection,.set-preview{gap:10px;margin:0;padding:0;list-style:none;display:grid}.song-pick,.live-set-item,.set-preview li{align-items:center;gap:12px;display:flex}.song-pick{border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);cursor:pointer;text-align:left;border-radius:12px;padding:12px}.song-pick strong{flex:1}.song-pick:disabled{opacity:.55;cursor:not-allowed}.live-set-item{border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:12px}.live-set-order-pill,.set-preview li>span{color:var(--primary);font-family:var(--font-mono);font-weight:800}.live-set-item-copy,.set-preview li div{flex:1;min-width:0}.live-set-item-copy small,.set-preview small,.song-pick span{color:var(--muted)}.live-set-item-actions{flex-wrap:wrap;gap:8px;display:flex}.empty-line{color:var(--muted)}.is-hidden{display:none}@media (width<=820px){.topbar,.landing-hero,.player-head,.player-controls,.section-head{flex-direction:column;align-items:stretch}.ctrl-group{padding:12px 0 0}.ctrl-group:first-child{padding-top:0}.ctrl-divider{width:auto;height:1px}.landing-hero,.builder-grid,.form-grid{grid-template-columns:1fr}.landing-visual{min-height:auto}h1{font-size:clamp(2.4rem,15vw,4.2rem)}}.dash-header{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;padding:40px 40px 28px;display:flex}.dash-header h1{font-family:var(--font-display);margin:4px 0 0;font-size:clamp(2rem,4vw,2.8rem);line-height:1}.dash-header-right{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.dash-stats{gap:8px;display:flex}.dash-stats span{font-size:.78rem;font-weight:600;font-family:var(--font-mono);color:var(--muted);background:var(--surface-el);border-radius:8px;padding:5px 12px}.song-card{border-radius:20px;flex-direction:column;padding:22px;transition:transform .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.song-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--primary));height:3px;position:absolute;inset:0 0 auto}@supports (color:color-mix(in lab, red, red)){.song-card:before{background:linear-gradient(90deg, var(--primary), color-mix(in srgb, var(--primary) 40%, transparent))}}.song-card:before{opacity:0;transition:opacity .18s}.song-card:hover{transform:translateY(-3px);box-shadow:0 16px 48px #0a112821}.song-card:hover:before{opacity:1}.song-card-top{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.song-key-badge{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--primary);background:var(--primary);flex-shrink:0;font-size:.68rem;font-weight:800}@supports (color:color-mix(in lab, red, red)){.song-key-badge{background:color-mix(in srgb, var(--primary) 10%, transparent)}}.song-key-badge{border:1px solid var(--primary)}@supports (color:color-mix(in lab, red, red)){.song-key-badge{border:1px solid color-mix(in srgb, var(--primary) 22%, transparent)}}.song-key-badge{white-space:nowrap;border-radius:7px;padding:3px 9px}.song-card-title{flex:1;margin-bottom:0;font-size:clamp(1.3rem,2vw,1.7rem);line-height:1.1}.song-card-foot{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:16px;padding-top:14px;display:flex}.song-card-chips{flex-wrap:wrap;gap:6px;display:flex}.song-card-chips span{font-size:.74rem;font-weight:700;font-family:var(--font-mono);color:var(--muted);background:var(--surface-el);border-radius:6px;padding:3px 8px}.song-card-btns{gap:6px;display:flex}.button.sm{border-radius:8px;min-height:30px;padding:5px 13px;font-size:.8rem}.song-grid{grid-template-columns:repeat(auto-fill,minmax(268px,1fr))}.auth-body{min-height:100vh;font-family:var(--font-body);background:var(--bg);color:var(--ink);margin:0;overflow-x:hidden}.auth-split{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-panel{flex-direction:column;justify-content:space-between;padding:clamp(36px,5vw,72px);display:flex}.auth-panel-dark{background:radial-gradient(ellipse at 20% 65%, rgba(var(--primary-rgb),.25) 0%, transparent 55%), radial-gradient(ellipse at 80% 15%, rgba(var(--chord-rgb),.18) 0%, transparent 60%), linear-gradient(155deg, var(--sidebar-bg) 0%, #08001a 55%, #03000f 100%);color:#fff;position:relative;overflow:hidden}:root .auth-panel-dark,[data-theme=classic] .auth-panel-dark{background:radial-gradient(at 20% 65%,#d9772f17 0%,#0000 55%),radial-gradient(at 80% 15%,#14376459 0%,#0000 60%),linear-gradient(155deg,#0e1829 0%,#0c1628 55%,#070e1d 100%)}[data-theme=dark] .auth-panel-dark{background:radial-gradient(at 20% 65%,#e68a2e1f 0%,#0000 55%),radial-gradient(at 80% 15%,#14285066 0%,#0000 60%),linear-gradient(155deg,#060e1f 0%,#0a1128 55%,#040810 100%)}[data-theme=matrix] .auth-panel-dark{background:radial-gradient(at 20% 65%,#00ff4126 0%,#0000 55%),radial-gradient(at 80% 15%,#39ff1414 0%,#0000 60%),linear-gradient(155deg,#001500 0%,#000a00 55%,#000500 100%)}.auth-panel-dark:before{content:"";pointer-events:none;background:repeating-linear-gradient(#0000 0 46px,#ffffff07 46px 47px);position:absolute;inset:0}.auth-panel-dark:after{content:"";background:radial-gradient(circle, rgba(var(--primary-rgb),.12) 0%, transparent 70%);pointer-events:none;width:420px;height:420px;position:absolute;bottom:-120px;right:-120px}.auth-brand{font-family:var(--font-display);color:#fff;z-index:1;align-items:center;gap:12px;font-size:1.25rem;font-weight:600;text-decoration:none;display:inline-flex;position:relative}.auth-brand-mark{background:var(--primary);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.15rem;display:flex}.auth-hero-copy{z-index:1;position:relative}.auth-headline{font-family:var(--font-display);color:#fff;max-width:480px;margin:0 0 20px;font-size:clamp(2.8rem,4.5vw,4.6rem);font-style:italic;font-weight:400;line-height:1}.auth-subline{color:#ffffff7a;max-width:360px;margin:0;font-size:.9rem;line-height:1.75}.auth-panel-light{background:var(--bg);justify-content:center;align-items:center}.auth-form-wrap{width:100%;max-width:390px}.auth-eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 12px;font-size:.72rem;font-weight:800}.auth-welcome{font-family:var(--font-display);color:var(--ink);margin:0 0 16px;font-size:clamp(2rem,3.5vw,2.9rem);font-weight:500;line-height:1.05}.auth-desc{color:var(--muted);margin:0 0 36px;font-size:.95rem;line-height:1.7}.auth-google-btn{background:var(--primary);color:#fff;width:100%;min-height:54px;font-family:var(--font-body);box-shadow:0 4px 18px rgba(var(--primary-rgb),.28);border-radius:14px;justify-content:center;align-items:center;gap:13px;margin-bottom:20px;font-size:1rem;font-weight:700;text-decoration:none;transition:background .15s,transform .15s,box-shadow .15s;display:flex}.auth-google-btn svg{background:#fff;border-radius:4px;flex-shrink:0;padding:2px}.auth-google-btn:hover{background:var(--primary-hov);box-shadow:0 8px 28px rgba(var(--primary-rgb),.35);transform:translateY(-1px)}.auth-fine{color:var(--muted);text-align:center;margin:0;font-size:.78rem;line-height:1.65}.auth-chord-preview{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1;background:#050a168c;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;gap:14px;padding:20px 22px;display:flex;position:relative}.auth-chord-meta{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.auth-chord-key-label{color:#ffffff61;letter-spacing:.04em;font-size:.75rem;font-family:var(--font-mono);margin-bottom:5px;display:block}.auth-chord-title{font-family:var(--font-display);color:#ffffffeb;letter-spacing:.01em;font-size:1.1rem;font-weight:600}.auth-chord-capo{font-family:var(--font-body);color:#ffffff61;font-size:.8rem;font-weight:400}.auth-chord-controls{flex-shrink:0;align-items:center;gap:6px;display:flex}.auth-transpose-btn{color:#ffffffb3;cursor:pointer;width:28px;height:28px;font-size:1rem;font-weight:700;font-family:var(--font-body);background:#ffffff12;border:1px solid #ffffff1f;border-radius:7px;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:flex}.auth-transpose-btn:hover{background:rgba(var(--primary-rgb),.25);border-color:rgba(var(--primary-rgb),.4);color:var(--primary)}.auth-chord-bpm{font-family:var(--font-mono);color:#ffffff59;white-space:nowrap;padding-left:4px;font-size:.75rem}.auth-chord-hr{background:#ffffff14;height:1px;margin:0 -2px}.auth-chord-section{flex-direction:column;gap:9px;display:flex}.auth-chord-section-tag{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--primary);background:rgba(var(--primary-rgb),.12);border:1px solid rgba(var(--primary-rgb),.35);border-radius:6px;align-self:flex-start;align-items:center;padding:2px 9px;font-size:.65rem;font-weight:800;display:inline-flex}.auth-chord-row{font-family:var(--font-mono);align-items:center;display:flex}.auth-bar{color:#ffffffeb;text-align:center;letter-spacing:.01em;min-width:54px;font-size:1.15rem;font-weight:700;transition:color .15s}.auth-bar-sep{color:#ffffff2e;-webkit-user-select:none;user-select:none;padding:0 1px;font-size:1.1rem;font-weight:300}.auth-bar-end{color:#ffffff59;font-weight:500}@media (width<=820px){.auth-split{grid-template-columns:1fr}.auth-panel-dark{justify-content:space-between;min-height:52vh}.auth-chord-preview{display:none}.auth-panel-light{justify-content:flex-start;padding:52px 32px 64px}.auth-headline{font-size:clamp(2.4rem,12vw,3.6rem)}}.nav-profile-link{color:var(--muted);align-items:center;gap:7px;font-weight:700;text-decoration:none;display:inline-flex}.nav-avatar{object-fit:cover;border:2px solid var(--line);border-radius:50%;flex-shrink:0;width:28px;height:28px}.nav-avatar-placeholder{background:var(--primary);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.nav-avatar-placeholder{background:color-mix(in srgb, var(--primary) 15%, transparent)}}.nav-avatar-placeholder{color:var(--primary);flex-shrink:0;font-size:.78rem;font-weight:800}.profile-setup-shell{justify-content:center;align-items:center;min-height:70vh;padding:40px 16px;display:flex}.profile-setup-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);width:100%;max-width:560px;padding:clamp(28px,5vw,52px)}.profile-setup-heading{font-family:var(--font-display);margin:8px 0 12px;font-size:clamp(2rem,4vw,2.8rem);line-height:1.05}.profile-setup-lead{color:var(--muted);margin:0 0 28px;font-size:.95rem;line-height:1.7}.profile-setup-form{gap:20px;display:grid}.profile-field-label{color:var(--muted);margin:0 0 10px;font-size:.9rem;font-weight:800}.instrument-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;display:grid}.instrument-btn{cursor:pointer;-webkit-user-select:none;user-select:none;display:block}.instrument-btn input[type=radio]{opacity:0;width:0;height:0;position:absolute}.instrument-btn span{border:1.5px solid var(--line);background:var(--surface);color:var(--muted);text-align:center;border-radius:12px;justify-content:center;align-items:center;padding:10px 14px;font-size:.88rem;font-weight:700;transition:border-color .14s,background .14s,color .14s;display:flex}.instrument-btn input[type=radio]:checked+span{border-color:var(--primary);background:var(--primary)}@supports (color:color-mix(in lab, red, red)){.instrument-btn input[type=radio]:checked+span{background:color-mix(in srgb, var(--primary) 10%, transparent)}}.instrument-btn input[type=radio]:checked+span{color:var(--primary)}.instrument-btn span:hover{border-color:var(--primary);color:var(--primary)}.field-error{color:var(--danger);margin:4px 0 0;font-size:.82rem}.role-badge{letter-spacing:.06em;text-transform:uppercase;font-size:.68rem;font-weight:800;font-family:var(--font-mono);white-space:nowrap;border-radius:7px;align-items:center;padding:3px 9px;display:inline-flex}.role-badge.role-admin{color:#b45309;background:#d977061f;border:1px solid #d9770640}.role-badge.role-editor{color:#1d4ed8;background:#2563eb1a;border:1px solid #2563eb38}.role-badge.role-viewer{background:var(--surface-el);color:var(--muted);border:1px solid var(--line)}.member-list{gap:10px;display:grid}.member-item{background:var(--surface);border:1px solid var(--line);border-radius:14px;align-items:center;gap:12px;padding:12px 16px;display:flex}.member-avatar{object-fit:cover;background:var(--surface-el);border-radius:50%;flex-shrink:0;width:38px;height:38px}.member-avatar-placeholder{background:var(--primary);border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.member-avatar-placeholder{background:color-mix(in srgb, var(--primary) 15%, transparent)}}.member-avatar-placeholder{color:var(--primary);flex-shrink:0;font-size:.9rem;font-weight:800}.invite-link-box{align-items:center;gap:8px;display:flex}.invite-link-input{min-width:0;font-family:var(--font-mono);text-overflow:ellipsis;white-space:nowrap;background:var(--surface-el);border-color:var(--line);color:var(--muted);cursor:default;flex:1;font-size:.78rem;overflow:hidden}.group-shell{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:32px;display:grid}@media (width<=960px){.group-shell{grid-template-columns:1fr}}.song-picker{position:relative}.song-picker-field{border:1.5px solid var(--line);background:var(--surface);cursor:text;border-radius:12px;align-items:center;gap:8px;height:48px;padding:0 12px;transition:border-color .15s,box-shadow .15s;display:flex}.song-picker-field.open{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary)}@supports (color:color-mix(in lab, red, red)){.song-picker-field.open{box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 12%, transparent)}}.song-picker-search-icon{width:16px;height:16px;color:var(--muted);flex-shrink:0}.song-picker-input{min-width:0;color:var(--ink);font:inherit;background:0 0;border:none;outline:none;flex:1;font-size:.92rem}.song-picker-input::placeholder{color:var(--muted);opacity:.55}.song-picker-chevron{width:16px;height:16px;color:var(--muted);flex-shrink:0;transition:transform .18s}.song-picker-field.open .song-picker-chevron{transform:rotate(180deg)}.song-picker-dropdown{background:var(--surface);border:1.5px solid var(--line);z-index:60;border-radius:14px;max-height:300px;margin:0;padding:6px;list-style:none;display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto;box-shadow:0 14px 48px #0a112821}.song-picker-dropdown.open{display:block}.song-picker-option{cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;transition:background .1s;display:flex}.song-picker-option:hover,.song-picker-option.highlighted{background:var(--surface-el)}.song-picker-option-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.9rem;font-weight:600;overflow:hidden}.song-picker-option-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:.78rem;overflow:hidden}.song-picker-option-key{font-family:var(--font-mono);color:var(--primary);background:var(--primary);flex-shrink:0;font-size:.68rem;font-weight:800}@supports (color:color-mix(in lab, red, red)){.song-picker-option-key{background:color-mix(in srgb, var(--primary) 10%, transparent)}}.song-picker-option-key{border:1px solid var(--primary)}@supports (color:color-mix(in lab, red, red)){.song-picker-option-key{border:1px solid color-mix(in srgb, var(--primary) 20%, transparent)}}.song-picker-option-key{border-radius:5px;padding:2px 7px}.song-picker-empty{text-align:center;color:var(--muted);padding:14px 12px;font-size:.86rem}.song-search-wrap{margin-bottom:24px}.song-search-bar{align-items:center;max-width:520px;display:flex;position:relative}.song-search-icon{width:18px;height:18px;color:var(--muted);pointer-events:none;flex-shrink:0;position:absolute;left:14px}.song-search-input{border:1.5px solid var(--line);background:var(--surface);width:100%;height:48px;color:var(--ink);font:inherit;border-radius:14px;outline:none;padding:0 120px 0 44px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.song-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary)}@supports (color:color-mix(in lab, red, red)){.song-search-input:focus{box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 12%, transparent)}}.song-search-input::placeholder{color:var(--muted);opacity:.55}.song-search-input::-webkit-search-cancel-button{cursor:pointer}.song-search-count{font-family:var(--font-mono);color:var(--muted);white-space:nowrap;pointer-events:none;font-size:.72rem;font-weight:700;position:absolute;right:14px}.app-layout{min-height:100vh;display:flex}.app-main{background:var(--bg);flex:1;min-width:0}.app-main>.section-block,.app-main>.player-shell,.app-main>.dash-header,.app-main>.page-shell,.app-main>.form-wrap,.app-main>.profile-setup-shell{box-sizing:border-box;width:100%;max-width:1180px;margin-left:auto;margin-right:auto;padding-left:clamp(16px,3vw,40px);padding-right:clamp(16px,3vw,40px)}.app-main>.notice{max-width:1180px;margin-left:auto;margin-right:auto;padding-left:clamp(16px,3vw,40px);padding-right:clamp(16px,3vw,40px)}.sidebar{background:var(--sidebar-bg);border-right:1px solid rgba(var(--primary-rgb), .12);color:#ffffffd9;z-index:40;flex-direction:column;flex-shrink:0;width:240px;height:100vh;transition:width .22s,background .2s;display:flex;position:sticky;top:0;overflow:hidden auto}.sidebar.collapsed{width:64px}.sidebar-header{flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:22px 14px 14px;display:flex}.sidebar-brand{font-family:var(--font-display);color:#fff;white-space:nowrap;align-items:center;gap:9px;min-width:0;font-size:1.35rem;font-weight:700;text-decoration:none;display:flex;overflow:hidden}.sidebar-brand-mark{color:var(--primary);flex-shrink:0;font-size:1.5rem;line-height:1}.sidebar-toggle-btn{color:#f9f6f073;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;transition:background .15s,color .15s;display:flex}.sidebar-toggle-btn:hover{color:#fff;background:#ffffff1f}.sidebar-toggle-btn svg{transition:transform .22s}.sidebar.collapsed .sidebar-toggle-btn svg{transform:rotate(180deg)}.sidebar-profile{background:#ffffff0f;border-radius:12px;flex-shrink:0;align-items:center;gap:10px;min-height:56px;margin:0 8px 8px;padding:10px 12px;transition:padding .22s;display:flex;overflow:hidden}.sidebar-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:36px;height:36px}.sidebar-avatar-init{color:#e8904a;font-family:var(--font-mono);background:#d9772f33;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.88rem;font-weight:800;display:inline-flex}.sidebar-user-meta{flex:1;min-width:0;overflow:hidden}.sidebar-user-meta strong{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.87rem;font-weight:700;line-height:1.3;display:block;overflow:hidden}.sidebar-user-meta small{color:#f9f6f06b;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.72rem;display:block;overflow:hidden}.sidebar-nav{flex-direction:column;flex-shrink:0;gap:2px;padding:4px 8px;display:flex}.sidebar .sidebar-link{color:#f9f6f085;cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-family:inherit;font-size:.9rem;font-weight:500;line-height:1;text-decoration:none;transition:background .15s,color .15s;display:flex;overflow:hidden}.sidebar .sidebar-link:hover{color:#f9f6f0e6;background:#ffffff12}.sidebar .sidebar-link.active{color:#fff;background:#ffffff1a;font-weight:700}.sidebar-icon{opacity:.65;flex-shrink:0;width:18px;height:18px;transition:opacity .15s}.sidebar .sidebar-link:hover .sidebar-icon{opacity:.85}.sidebar .sidebar-link.active .sidebar-icon{opacity:1;color:var(--primary)}.sidebar-spacer{flex:1}.sidebar-bottom{border-top:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;gap:2px;padding:8px 8px 20px;display:flex}.sidebar.collapsed .sidebar-text,.sidebar.collapsed .sidebar-user-meta{display:none}.sidebar.collapsed .sidebar-header{justify-content:center;padding:20px 8px 14px}.sidebar.collapsed .sidebar-brand{pointer-events:none}.sidebar.collapsed .sidebar-profile{justify-content:center;margin:0 4px 8px;padding:10px 8px}.sidebar.collapsed .sidebar .sidebar-link{justify-content:center;gap:0;padding:10px}.sidebar.collapsed .sidebar-icon{opacity:.7}.mobile-topbar{background:var(--sidebar-bg);z-index:80;border-bottom:1px solid #ffffff0f;align-items:center;gap:14px;height:56px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0}.mobile-menu-btn{color:#f9f6f0cc;cursor:pointer;background:#ffffff12;border:1px solid #ffffff1f;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.mobile-brand{font-family:var(--font-display);color:#fff;font-size:1.25rem;font-weight:700;text-decoration:none}.sidebar-overlay{z-index:70;background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.mobile-topbar{display:flex}.app-main{padding-top:56px}.sidebar{z-index:90;height:100vh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%);width:260px!important}.sidebar-toggle-btn{display:none}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open .sidebar-text,.sidebar.mobile-open .sidebar-user-meta{display:block}.sidebar.mobile-open .sidebar-header{justify-content:space-between;padding:22px 14px 14px}.sidebar.mobile-open .sidebar-brand{pointer-events:auto}.sidebar.mobile-open .sidebar-profile{justify-content:flex-start;margin:0 8px 8px;padding:10px 14px}.sidebar.mobile-open .sidebar-link{justify-content:flex-start;gap:12px;padding:10px 14px}.sidebar.mobile-open .sidebar-icon{opacity:1}.sidebar.mobile-open .theme-switcher{flex-wrap:wrap;padding:8px 14px 14px}.sidebar.mobile-open~.sidebar-overlay,.sidebar-overlay.visible{display:block}}.song-form-page{flex-direction:column;min-height:100dvh;display:flex}.song-form-topbar{z-index:20;background:var(--bg);border-bottom:1px solid var(--line);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:12px clamp(18px,3vw,36px);display:flex;position:sticky;top:0}.song-form-heading{font-family:var(--font-display);color:var(--ink);margin:2px 0 0;font-size:clamp(1.15rem,2vw,1.5rem);font-weight:700;line-height:1}.song-form-topbar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.song-form-body{flex:1;grid-template-columns:290px 1fr;min-height:0;display:grid}.song-form-sidebar{border-right:1px solid var(--line);background:var(--surface);flex-direction:column;gap:0;padding:0 20px;display:flex;overflow-y:auto}.song-form-section{flex-direction:column;gap:12px;padding:20px 0;display:flex}.song-form-section+.song-form-section{border-top:1px solid var(--line)}.song-form-section-label{font-size:.6rem;font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 2px;font-weight:700}.song-form-sidebar label{gap:6px;font-size:.72rem}.song-form-sidebar input,.song-form-sidebar textarea{border-radius:10px;padding:9px 12px;font-size:.88rem}.song-meta-pair{grid-template-columns:1fr 1fr;gap:10px;display:grid}.song-form-editor-wrap{background:var(--bg);flex-direction:column;display:flex;overflow:hidden}.song-form-editor-head{border-bottom:1px solid var(--line);background:var(--surface);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 20px;display:flex}.song-form-syntax-chips{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.song-form-syntax-chip{font-family:var(--font-mono);color:var(--primary);background:rgba(var(--primary-rgb),.07);border:1px solid rgba(var(--primary-rgb),.2);white-space:nowrap;border-radius:5px;padding:2px 8px;font-size:.67rem}.song-form-editor-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.song-form-editor-area textarea{background:var(--surface);font-family:var(--font-mono);resize:none;min-height:520px;color:var(--ink);box-shadow:none;border:none;border-radius:0;outline:none;flex:1;width:100%;padding:22px 24px;font-size:.9rem;line-height:1.8}.song-form-editor-area textarea:focus{box-shadow:none;border-color:#0000;outline:none}.song-form-editor-area textarea::placeholder{color:var(--muted);opacity:.4}@media (width<=860px){.song-form-body{grid-template-columns:1fr}.song-form-sidebar{border-right:none;border-bottom:1px solid var(--line);padding:0 16px}.song-form-editor-area textarea{min-height:380px}.song-form-syntax-chips{display:none}}.perf-body{background:var(--perf-bg);color:#ffffffeb;min-height:100vh;font-family:var(--font-body)}.perf-wrap{max-width:980px;margin:0 auto}.perf-header{padding:clamp(24px,4vw,56px) clamp(20px,4vw,56px) 0}.perf-back{color:#ffffff47;font-size:.74rem;font-family:var(--font-mono);letter-spacing:.06em;align-items:center;gap:6px;margin-bottom:28px;text-decoration:none;transition:color .15s;display:inline-flex}.perf-back:hover{color:#ffffff9e}.perf-meta{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.perf-meta-info{flex:1;min-width:0}.perf-key-label{font-family:var(--font-mono);color:#ffffff4d;letter-spacing:.06em;margin-bottom:7px;font-size:.72rem;display:block}.perf-title{font-family:var(--font-display);color:#fffffff2;letter-spacing:.01em;margin:0 0 6px;font-size:clamp(2rem,4.5vw,3.4rem);font-weight:700;line-height:1.1}.perf-artist{color:#ffffff4d;letter-spacing:.02em;margin:0;font-size:.82rem}.perf-notes-line{color:#ffffff47;margin:5px 0 0;font-size:.8rem;font-style:italic}.perf-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:10px;padding-top:4px;display:flex}.perf-controls{align-items:center;gap:7px;display:flex}.perf-btn{color:#ffffff9e;cursor:pointer;width:34px;height:34px;font-size:1.15rem;font-weight:700;font-family:var(--font-body);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s,border-color .12s;display:flex}.perf-btn:hover{background:rgba(var(--primary-rgb),.2);border-color:rgba(var(--primary-rgb),.36);color:var(--primary)}.perf-bpm{font-family:var(--font-mono);color:#ffffff4d;white-space:nowrap;padding:0 4px;font-size:.82rem}.perf-metro{align-items:center;gap:7px;display:flex}.perf-metro-btn{color:#fff6;height:30px;font-size:.68rem;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;padding:0 13px;transition:background .12s,color .12s,border-color .12s}.perf-metro-btn:hover{background:rgba(var(--primary-rgb),.15);border-color:rgba(var(--primary-rgb),.25);color:#ffffffa6}.perf-beat{font-family:var(--font-mono);color:#ffffff40;text-align:center;min-width:14px;font-size:.68rem}.perf-hr{background:#ffffff12;height:1px;margin:24px clamp(20px,4vw,56px) 30px}.perf-body .chart-output{background:0 0;border:none;border-radius:0;padding:0 clamp(20px,4vw,56px) clamp(32px,4vw,56px)}.perf-body .chart-section{padding:28px 0}.perf-body .chart-section:first-child{padding-top:0}.perf-body .chart-section:last-child{padding-bottom:0}.perf-body .chart-section+.chart-section{border-top:1px solid #ffffff12}.perf-body .chart-lines{gap:22px}.perf-body .measure{color:#ffffffeb;min-width:78px;padding:6px 16px;font-size:clamp(1.55rem,3.2vw,2.4rem)}.perf-body .measure-sep{color:#ffffff24;font-size:clamp(1.3rem,2.6vw,2rem)}.perf-body .measure-sep-end{color:#ffffff4d}.perf-body .chord{color:var(--chord);font-size:clamp(1.05rem,2vw,1.45rem)}@media (width<=640px){.perf-header{z-index:30;background:var(--perf-bg);border-bottom:1px solid #ffffff12;padding:12px 18px 14px;position:sticky;top:0}.perf-back{opacity:.5;margin-bottom:12px;font-size:.68rem}.perf-meta{flex-flow:row;align-items:center;gap:12px}.perf-meta-info{flex:1;min-width:0}.perf-key-label{opacity:.7;margin-bottom:2px;font-size:.62rem}.perf-title{white-space:nowrap;text-overflow:ellipsis;margin-bottom:0;font-size:1.15rem;overflow:hidden}.perf-artist{margin-top:1px;font-size:.72rem}.perf-notes-line{display:none}.perf-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;padding-top:0}.perf-controls{background:#ffffff0d;border:1px solid #ffffff17;border-radius:10px;gap:2px;padding:3px 4px}.perf-btn{background:0 0;border:none;width:30px;height:30px;font-size:1.1rem}.perf-btn:hover{background:#ffffff14;border:none}.perf-bpm{padding:0 5px;font-size:.72rem}.perf-metro{gap:5px}.perf-metro-btn{border-radius:7px;height:26px;padding:0 10px;font-size:.62rem}.perf-beat{min-width:12px;font-size:.65rem}.perf-hr{margin:16px 18px 20px}.perf-body .chart-output{padding:0 18px 40px}.perf-body .chart-section{padding:20px 0}.perf-body .measure{min-width:68px;padding:6px 12px;font-size:1.85rem}.perf-body .measure-sep{font-size:1.55rem}.perf-body .chord{font-size:1.1rem}.perf-body .repeat-mark{padding:0 5px;font-size:1.5rem}.perf-body .chart-lines{gap:18px}}.group-index-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.group-index-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:22px 22px 18px;transition:box-shadow .18s,transform .18s;display:flex}.group-index-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0a11281a}.group-index-card-top{justify-content:space-between;align-items:center;display:flex}.group-index-avatar{background:var(--primary);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-family:Cormorant Garamond,serif;font-size:1.4rem;font-weight:700;display:flex}.role-badge{letter-spacing:.06em;text-transform:uppercase;background:var(--bg);color:var(--muted);border:1px solid var(--border);border-radius:20px;padding:3px 9px;font-size:.68rem;font-weight:700}.role-badge.role-admin{background:rgba(var(--primary-rgb),.1);color:var(--primary);border-color:rgba(var(--primary-rgb),.25)}.role-badge.role-leader{color:#2563eb;background:#2563eb14;border-color:#2563eb33}.group-index-name{color:var(--ink);margin:0;font-family:Cormorant Garamond,serif;font-size:1.28rem;font-weight:700;line-height:1.2}.group-index-desc{color:var(--muted);flex:1;margin:0;font-size:.82rem;line-height:1.5}.group-index-foot{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:6px;padding-top:14px;display:flex}.group-index-meta{color:var(--muted);align-items:center;gap:5px;font-size:.78rem;font-weight:500;display:flex}.set-index-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.set-index-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:20px 20px 16px;transition:box-shadow .18s,transform .18s;display:flex}.set-index-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0a11281a}.set-index-card-top{justify-content:space-between;align-items:center;display:flex}.set-index-count{letter-spacing:.07em;text-transform:uppercase;color:var(--primary);font-size:.72rem;font-weight:700}.set-index-date{color:var(--muted);font-size:.72rem;font-weight:500}.set-index-name{color:var(--ink);margin:0;font-family:Cormorant Garamond,serif;font-size:1.35rem;font-weight:700;line-height:1.2}.set-index-tracks{flex-direction:column;flex:1;gap:4px;display:flex}.set-index-track{color:var(--muted);align-items:center;gap:7px;font-size:.8rem;line-height:1.3;display:flex}.set-index-track-num{color:var(--primary);font-variant-numeric:tabular-nums;opacity:.7;min-width:14px;font-size:.68rem;font-weight:700}.set-index-track-more{color:var(--primary);opacity:.8;padding-left:21px;font-size:.74rem;font-weight:600}.set-index-foot{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:6px;padding-top:14px;display:flex}.set-index-foot .button{text-align:center;flex:1}.live-form-page{flex-direction:column;min-height:100vh;display:flex}.live-form-topbar{z-index:20;background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:14px clamp(18px,3vw,36px);display:flex;position:sticky;top:0}.live-form-topbar-left{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.live-form-title-input{color:var(--ink);width:100%;caret-color:var(--primary);background:0 0;border:none;outline:none;padding:0;font-family:Cormorant Garamond,serif;font-size:1.45rem;font-weight:700}.live-form-title-input::placeholder{color:var(--muted);opacity:.6}.live-form-title-input:focus{border-bottom:1.5px solid var(--primary)}.live-form-topbar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.live-form-body{flex:1;grid-template-columns:1fr 1fr;min-height:0;display:grid}@media (width<=700px){.live-form-body{grid-template-columns:1fr}}.live-library{border-right:1px solid var(--border);flex-direction:column;min-height:0;display:flex}.live-library-head{border-bottom:1px solid var(--border);padding:18px clamp(14px,2.5vw,28px) 14px}.live-library-search-wrap{position:relative}.live-library-search-icon{width:15px;height:15px;color:var(--muted);opacity:.55;pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.live-library-search{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--ink);border-radius:8px;outline:none;padding:8px 12px 8px 32px;font-size:.82rem;transition:border-color .15s}.live-library-search:focus{border-color:var(--primary)}.live-library-list{flex:1;padding:10px 0;overflow-y:auto}.live-library-item{border-bottom:1px solid #0a11280d;align-items:center;gap:10px;padding:10px clamp(14px,2.5vw,28px);transition:background .12s;display:flex}.live-library-item:hover{background:var(--bg)}.live-library-key{color:var(--primary);text-align:center;background:rgba(var(--primary-rgb),.09);border-radius:6px;flex-shrink:0;min-width:28px;padding:3px 6px;font-size:.75rem;font-weight:700}.live-library-info{flex:1;min-width:0}.live-library-info strong{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;display:block;overflow:hidden}.live-library-info span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.74rem;display:block;overflow:hidden}.live-library-empty{text-align:center;color:var(--muted);padding:48px 24px;font-size:.88rem}.live-order{flex-direction:column;min-height:0;display:flex}.live-order-head{border-bottom:1px solid var(--border);padding:18px clamp(14px,2.5vw,28px) 14px}.live-order-list{flex:1;margin:0;padding:10px 0;list-style:none;overflow-y:auto}.live-order-empty{text-align:center;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;font-size:.85rem;line-height:1.5;display:flex}.live-order-empty.is-hidden{display:none}.live-order-item{border-bottom:1px solid #0a11280d;align-items:center;gap:10px;padding:11px clamp(14px,2.5vw,28px);transition:background .12s;display:flex}.live-order-item:hover{background:var(--bg)}.live-order-num{color:var(--primary);font-variant-numeric:tabular-nums;opacity:.7;flex-shrink:0;min-width:24px;font-size:.72rem;font-weight:700}.live-order-info{flex:1;min-width:0}.live-order-info strong{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;display:block;overflow:hidden}.live-order-info span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.74rem;display:block;overflow:hidden}.live-order-btns{flex-shrink:0;align-items:center;gap:3px;display:flex}.live-order-btn{border:1px solid var(--border);background:var(--surface);width:28px;height:28px;color:var(--muted);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;padding:0;font-size:.9rem;transition:background .12s,color .12s,border-color .12s;display:flex}.live-order-btn:hover{background:var(--bg);color:var(--ink);border-color:var(--ink)}.live-order-remove:hover{color:var(--danger,#c53030);background:#c5303012;border-color:#c530304d}.perf-back-brand{font-family:var(--font-display);letter-spacing:.04em;font-size:.9rem;font-weight:700;color:var(--primary)!important;opacity:1!important}.perf-public-footer{text-align:center;border-top:1px solid #ffffff0f;margin-top:48px;padding:18px clamp(20px,4vw,56px)}.perf-public-footer a{font-size:.72rem;font-family:var(--font-mono);color:#ffffff38;letter-spacing:.05em;align-items:center;gap:6px;text-decoration:none;transition:color .15s;display:inline-flex}.perf-public-footer a:hover{color:#ffffff80}.pub-body{background:var(--bg);color:var(--ink);font-family:var(--font-body);min-height:100vh}.pub-nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:20;justify-content:space-between;align-items:center;padding:14px clamp(18px,4vw,56px);display:flex;position:sticky;top:0}.pub-nav-brand{font-family:var(--font-display);color:var(--ink);align-items:center;gap:7px;font-size:1.3rem;font-weight:700;text-decoration:none;display:flex}.pub-nav-mark{color:var(--primary);font-size:1.1rem}.pub-nav-right{align-items:center;gap:16px;display:flex}.pub-nav-link{color:var(--muted);font-size:.84rem;font-weight:500;text-decoration:none;transition:color .13s}.pub-nav-link:hover{color:var(--ink)}.pub-nav-cta{color:var(--primary);border:1.5px solid rgba(var(--primary-rgb),.35);border-radius:9px;padding:7px 16px;font-size:.84rem;font-weight:700;text-decoration:none;transition:background .13s}.pub-nav-cta:hover{background:rgba(var(--primary-rgb),.07)}.pub-hero{text-align:center;max-width:680px;margin:0 auto;padding:clamp(40px,6vw,80px) clamp(18px,4vw,56px) 32px}.pub-hero-title{font-family:var(--font-display);color:var(--ink);margin:0 0 12px;font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;line-height:1.1}.pub-hero-sub{color:var(--muted);margin:0 0 28px;font-size:1rem;line-height:1.5}.pub-search-wrap{max-width:420px;margin:0 auto;position:relative}.pub-search-icon{width:16px;height:16px;color:var(--muted);opacity:.5;pointer-events:none;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.pub-search-input{border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--ink);border-radius:12px;outline:none;padding:11px 14px 11px 38px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.pub-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.pub-main{max-width:1200px;margin:0 auto;padding:0 clamp(18px,4vw,56px) clamp(40px,4vw,64px)}.pub-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-bottom:32px;display:grid}.pub-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:8px;padding:20px 20px 16px;transition:box-shadow .18s,transform .18s;display:flex}.pub-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0a112817}.pub-card[style*="display: none"]{display:none!important}.pub-card-top{justify-content:space-between;align-items:center;display:flex}.pub-key-badge{font-family:var(--font-mono);color:var(--primary);background:rgba(var(--primary-rgb),.09);border:1px solid rgba(var(--primary-rgb),.22);letter-spacing:.04em;border-radius:6px;padding:3px 9px;font-size:.7rem;font-weight:700}.pub-card-meta{color:var(--muted);font-size:.72rem;font-family:var(--font-mono)}.pub-card-title{font-family:var(--font-display);color:var(--ink);margin:0;font-size:1.3rem;font-weight:700;line-height:1.2}.pub-card-artist{color:var(--muted);flex:1;margin:0;font-size:.82rem}.pub-card-foot{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:4px;padding-top:12px;display:flex}.pub-card-by{color:var(--muted);align-items:center;gap:5px;font-size:.74rem;font-weight:500;display:flex}.pub-pagination{justify-content:center;padding:16px 0;display:flex}.pub-footer{border-top:1px solid var(--border);color:var(--muted);align-items:center;gap:12px;padding:18px clamp(18px,4vw,56px);font-size:.78rem;display:flex}.pub-footer a{color:var(--muted);font-weight:500;text-decoration:none}.pub-footer a:hover,.pub-footer a.active{color:var(--primary)}.song-visibility-box{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.song-visibility-box.is-public{background:#22c55e0a;border-color:#22c55e59}.song-visibility-status{align-items:center;gap:10px;min-width:0;display:flex}.song-visibility-status>div{flex-direction:column;gap:1px;min-width:0;display:flex}.song-visibility-status strong{color:var(--ink);font-size:.82rem;font-weight:700}.song-visibility-box.is-public .song-visibility-status strong{color:#15803d}.song-visibility-status span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.song-publish-dot{background:var(--border);border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .15s,box-shadow .15s}.song-visibility-box.is-public .song-publish-dot{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.sidebar-plan-badge{letter-spacing:.07em;text-transform:uppercase;color:#ffffff73;background:#ffffff12;border:1px solid #ffffff1a;border-radius:5px;margin-top:3px;padding:2px 7px;font-size:.6rem;font-weight:700;text-decoration:none;transition:background .13s;display:inline-block}.sidebar-plan-badge:hover{color:#ffffffb3;background:#ffffff21}.sidebar-plan-badge.plan-basic{background:rgba(var(--primary-rgb),.18);color:#bf00ff;border-color:rgba(var(--primary-rgb),.3)}.sidebar-plan-badge.plan-pro{color:#818cf8;background:#6366f12e;border-color:#6366f14d}.sidebar-plan-badge.plan-premium{color:#fbbf24;background:#eab3082e;border-color:#eab3084d}.pricing-wrap{max-width:1100px;margin:0 auto;padding:0 clamp(18px,4vw,48px) 64px}.pricing-hero{text-align:center;padding:clamp(40px,5vw,72px) 0 40px}.pricing-upgrade-notice{background:rgba(var(--primary-rgb),.08);border:1px solid rgba(var(--primary-rgb),.25);color:var(--primary);text-align:left;border-radius:10px;align-items:center;gap:8px;max-width:520px;margin-bottom:24px;padding:10px 18px;font-size:.84rem;display:inline-flex}.pricing-title{font-family:var(--font-display);color:var(--ink);margin:0 0 12px;font-size:clamp(2rem,4.5vw,3.2rem);font-weight:700;line-height:1.1}.pricing-sub{color:var(--muted);margin:0 0 14px;font-size:1rem}.pricing-current-plan{color:var(--muted);margin:0;font-size:.82rem}.pricing-current-plan strong{color:var(--primary)}.pricing-grid{grid-template-columns:repeat(4,1fr);align-items:start;gap:16px;margin-bottom:32px;display:grid}@media (width<=900px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=520px){.pricing-grid{grid-template-columns:1fr}}.pricing-card{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;flex-direction:column;gap:18px;padding:24px 22px 20px;transition:box-shadow .18s;display:flex;position:relative}.pricing-card:hover{box-shadow:0 6px 28px #0a112817}.pricing-card.is-popular{border-color:var(--primary);box-shadow:0 4px 24px rgba(var(--primary-rgb),.14)}.pricing-card.is-current{background:#22c55e08;border-color:#22c55e}.pricing-card-tag{background:var(--primary);color:#fff;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border-radius:20px;padding:3px 12px;font-size:.65rem;font-weight:800;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.pricing-card-head{flex-direction:column;gap:6px;display:flex}.pricing-plan-name{font-family:var(--font-display);color:var(--ink);margin:0;font-size:1.3rem;font-weight:700}.pricing-price{align-items:baseline;gap:2px;display:flex}.pricing-currency{color:var(--ink);font-size:1rem;font-weight:700}.pricing-amount{color:var(--ink);font-size:2rem;font-weight:800;line-height:1}.pricing-period{color:var(--muted);margin-left:2px;font-size:.8rem}.pricing-features{flex-direction:column;flex:1;gap:9px;margin:0;padding:0;list-style:none;display:flex}.pricing-features li{color:var(--ink);align-items:center;gap:8px;font-size:.82rem;font-weight:500;display:flex}.pricing-features li.unavailable{color:var(--muted);opacity:.55}.feat-check{color:#22c55e;flex-shrink:0}.feat-x{color:var(--muted);opacity:.45;flex-shrink:0}.pricing-card-foot{margin-top:4px}.pricing-btn{text-align:center;background:var(--primary);color:#fff;width:100%;font-size:.84rem;font-weight:700;font-family:var(--font-body);border:1.5px solid var(--primary);cursor:pointer;border-radius:10px;padding:10px 16px;text-decoration:none;transition:background .13s,transform .1s;display:block}.pricing-btn:hover{background:#c46a28;transform:translateY(-1px)}.pricing-btn.ghost{color:var(--ink);border-color:var(--border);background:0 0}.pricing-btn.ghost:hover{background:var(--bg);border-color:var(--ink)}.pricing-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.pricing-btn-current{text-align:center;color:#15803d;background:#22c55e14;border:1.5px solid #22c55e4d;border-radius:10px;width:100%;padding:10px 16px;font-size:.82rem;font-weight:700;display:block}.pricing-note{text-align:center;color:var(--muted);font-size:.78rem;line-height:1.6}.theme-switcher{flex-shrink:0;align-items:center;gap:7px;padding:8px 14px 16px;display:flex}.theme-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:20px;height:20px;padding:0;transition:transform .15s,border-color .15s,box-shadow .15s}.theme-dot:hover{transform:scale(1.2)}.theme-dot.active{border-color:#ffffffd9;box-shadow:0 0 0 1px #ffffff40}.td-classic{background:linear-gradient(135deg,#f9f6f0 50%,#d9772f 50%);border-color:#fff3}.td-dark{background:linear-gradient(135deg,#0a1128 50%,#e68a2e 50%)}.td-purple{background:#bf00ff;box-shadow:0 0 6px #bf00ff99}.td-pink{background:#f09;box-shadow:0 0 6px #f099}.td-matrix{background:#00ff41;box-shadow:0 0 6px #00ff4199}.td-sunset{background:linear-gradient(135deg,#ff6b35 50%,#ffd166 50%);box-shadow:0 0 6px #ff6b3599}.td-ocean{background:linear-gradient(135deg,#00e5cc 50%,#00c8ff 50%);box-shadow:0 0 6px #00e5cc99}.td-gold{background:linear-gradient(135deg,gold 50%,#ff9500 50%);box-shadow:0 0 6px #ffd70099}.td-classic.active{border-color:#645032cc}.sidebar.collapsed .theme-switcher{flex-wrap:wrap;gap:5px;padding:8px 6px 14px}.set-perf-topstrip{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.set-perf-counter{align-items:center;gap:10px;display:flex}.set-nav-btn{color:#fffc;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff26;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;transition:background .15s,color .15s;display:inline-flex}.set-nav-btn:hover{color:#fff;background:#ffffff24}.set-nav-btn:disabled{opacity:.25;cursor:default}.set-perf-pos{color:#ffffff80;text-align:center;letter-spacing:.04em;min-width:44px;font-size:.82rem;font-weight:700}.set-perf-name{color:#ffffff59;text-align:right;text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:.75rem;overflow:hidden}.set-song-strip{scrollbar-width:none;border-top:1px solid #ffffff0f;gap:8px;margin-top:32px;padding:20px clamp(18px,3vw,36px) 28px;display:flex;overflow-x:auto}.set-song-strip::-webkit-scrollbar{display:none}.set-song-chip{color:#ffffff73;cursor:pointer;white-space:nowrap;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:10px;flex-shrink:0;align-items:center;gap:6px;padding:7px 12px;font-size:.78rem;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.set-song-chip:hover{color:#fffc;background:#ffffff1a}.set-song-chip.active{background:rgba(var(--primary-rgb), .18);border-color:rgba(var(--primary-rgb), .45);color:var(--primary)}.set-chip-num{font-family:var(--font-mono);opacity:.6;font-size:.7rem}.set-chip-key{font-family:var(--font-mono);color:var(--chord);opacity:.8;background:#ffffff12;border-radius:5px;padding:1px 5px;font-size:.68rem}.avatar-upload-row{align-items:center;gap:18px;padding:18px 0 8px;display:flex}.avatar-upload-preview{background:rgba(var(--primary-rgb), .15);border:2px solid rgba(var(--primary-rgb), .25);width:72px;height:72px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.8rem;font-weight:700;display:flex;overflow:hidden}.avatar-upload-preview img{object-fit:cover;width:100%;height:100%}.avatar-upload-actions{flex-direction:column;gap:6px;display:flex}.avatar-upload-label{border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;border-radius:10px;align-items:center;gap:7px;padding:8px 14px;font-size:.85rem;font-weight:600;transition:background .15s;display:inline-flex}.avatar-upload-label:hover{background:var(--surface-el)}.avatar-upload-hint{color:var(--muted);font-size:.74rem}.ai-suggest-open-btn{align-items:center;gap:5px;display:inline-flex}.ai-overlay{-webkit-backdrop-filter:blur(4px);z-index:300;background:#0000008c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.ai-panel{background:var(--surface);border:1px solid var(--line);width:min(520px,100%);max-height:88vh;box-shadow:var(--shadow-md), 0 0 0 1px rgba(var(--primary-rgb),.08);border-radius:20px;flex-direction:column;display:flex;overflow-y:auto}.ai-panel-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px 14px;font-size:.95rem;font-weight:700;display:flex}.ai-panel-close{border:1px solid var(--line);background:var(--surface-el);width:28px;height:28px;color:var(--muted);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;line-height:1;transition:background .15s;display:flex}.ai-panel-close:hover{background:var(--line)}.ai-panel-body,.ai-panel-loading,.ai-panel-result{flex-direction:column;gap:16px;padding:20px;display:flex}.ai-option-label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 8px;font-size:.72rem;font-weight:800}.ai-checks{flex-wrap:wrap;gap:7px;display:flex}.ai-checks label{border:1px solid var(--line);background:var(--surface-el);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:9px;align-items:center;gap:6px;padding:6px 13px;font-size:.82rem;font-weight:600;transition:border-color .13s,background .13s,color .13s;display:inline-flex}.ai-checks label:has(input:checked){border-color:var(--primary);background:rgba(var(--primary-rgb), .1);color:var(--primary)}.ai-checks input{display:none}.ai-panel-loading{justify-content:center;align-items:center;gap:14px;min-height:160px}.ai-spinner{border:3px solid rgba(var(--primary-rgb), .18);border-top-color:var(--primary);border-radius:50%;width:38px;height:38px;animation:.75s linear infinite ws-spin}@keyframes ws-spin{to{transform:rotate(360deg)}}.ai-panel-loading p{color:var(--muted);margin:0;font-size:.88rem}.ai-result-preview{background:var(--surface-el);border:1px solid var(--line);font-family:var(--font-mono);color:var(--muted);white-space:pre-wrap;word-break:break-word;border-radius:12px;max-height:280px;margin:0;padding:14px 16px;font-size:.73rem;line-height:1.75;overflow-y:auto}.ai-result-hint{color:var(--muted);margin:0;font-size:.78rem}.ai-result-actions{flex-wrap:wrap;gap:10px;display:flex}.song-form-hint{color:var(--muted);margin:4px 0 5px;font-size:.72rem;display:block}.song-tag-presets{flex-wrap:wrap;gap:5px;margin-top:2px;display:flex}.tag-preset-chip{background:rgba(var(--primary-rgb), .1);border:1px solid rgba(var(--primary-rgb), .25);color:var(--primary);cursor:pointer;border-radius:20px;padding:2px 10px;font-size:.72rem;transition:background .15s}.tag-preset-chip:hover{background:rgba(var(--primary-rgb), .22)}.song-card-tag{background:rgba(var(--primary-rgb), .1);color:var(--primary);letter-spacing:.02em;border-radius:20px;padding:1px 8px;font-size:.68rem;font-weight:600}.song-tag-filter{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.tag-filter-chip{background:var(--surface-el);border:1px solid var(--line);color:var(--muted);cursor:pointer;border-radius:20px;padding:4px 14px;font-size:.78rem;font-weight:500;transition:all .15s}.tag-filter-chip:hover{border-color:var(--primary);color:var(--primary)}.tag-filter-chip.active{background:rgba(var(--primary-rgb), .12);border-color:var(--primary);color:var(--primary);font-weight:700}.perf-ccli{color:#fff6;font-size:.72rem;font-family:var(--font-mono);letter-spacing:.04em;margin:4px 0 0}.perf-tags{flex-wrap:wrap;gap:5px;margin-top:6px;display:flex}.perf-tag{background:rgba(var(--primary-rgb), .15);color:var(--primary);letter-spacing:.03em;border-radius:20px;padding:2px 9px;font-size:.7rem;font-weight:600}.capo-toggle-btn{background:rgba(var(--primary-rgb), .1);border:1px solid rgba(var(--primary-rgb), .25);color:var(--primary);cursor:pointer;border-radius:20px;align-items:center;gap:5px;margin:8px 0 0 16px;padding:4px 14px;font-size:.78rem;font-weight:600;transition:background .15s;display:inline-flex}.capo-toggle-btn:hover{background:rgba(var(--primary-rgb), .2)}.capo-bar{background:rgba(var(--primary-rgb), .06);border-bottom:1px solid rgba(var(--primary-rgb), .12);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 16px;display:flex}.capo-label{color:var(--primary);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-size:.72rem;font-weight:700}.capo-chips{flex-wrap:wrap;flex:1;gap:6px;display:flex}.capo-chip{color:#ffffffb3;font-size:.78rem;font-family:var(--font-mono);white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;padding:4px 12px}.capo-chip b{color:#ffffff80;margin-right:4px;font-weight:700}.capo-chip-good{background:rgba(var(--primary-rgb), .14);border-color:rgba(var(--primary-rgb), .4);color:var(--primary)}.capo-chip-good b{color:var(--primary);opacity:.7}.capo-chip-open{border-color:rgba(var(--chord-rgb), .5);color:var(--chord)}.capo-chip-open b{color:var(--chord);opacity:.7}.capo-close{color:#ffffff59;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:.9rem;line-height:1}.capo-close:hover{color:#ffffffb3}.key-flow-row{align-items:center;gap:8px;list-style:none;background:0 0!important;border:none!important;border-radius:0!important;padding:4px 16px!important;display:flex!important}.key-flow-arrow{opacity:.4;color:var(--muted);flex-shrink:0;font-size:.75rem}.key-flow-label{font-size:.75rem;font-weight:600;font-family:var(--font-mono);border-radius:20px;padding:2px 10px}.key-flow-same .key-flow-label{color:var(--success);background:#2d7a5d26}.key-flow-easy .key-flow-label{color:var(--success);opacity:.8;background:#2d7a5d1a}.key-flow-medium .key-flow-label{color:#e6973a;background:#e68a2e1f}.key-flow-hard .key-flow-label{color:var(--danger);background:#fc81811f}.follow-btn{background:rgba(var(--primary-rgb), .1);border:1px solid rgba(var(--primary-rgb), .3);color:var(--primary);cursor:pointer;white-space:nowrap;font-size:.72rem;font-weight:600;font-family:var(--font-body);border-radius:20px;padding:2px 10px;transition:all .15s}.follow-btn:hover{background:rgba(var(--primary-rgb), .2)}.follow-btn.following{background:rgba(var(--primary-rgb), .08);border-color:rgba(var(--primary-rgb), .18);color:var(--muted)}.follow-btn.following:hover{color:var(--danger);background:#c530301a;border-color:#c530304d}.pub-card-creator{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pub-creator-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:22px;height:22px}.pub-creator-init{background:rgba(var(--primary-rgb), .15);color:var(--primary);justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:inline-flex}.following-feed{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-top:4px;display:grid}.following-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;flex-direction:column;gap:6px;padding:14px 16px;text-decoration:none;transition:box-shadow .18s,transform .18s,border-color .18s;display:flex}.following-card:hover{box-shadow:var(--shadow);border-color:rgba(var(--primary-rgb), .25);transform:translateY(-2px)}.following-card-top{align-items:center;gap:7px;display:flex}.following-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:24px;height:24px}.following-avatar-init{background:rgba(var(--primary-rgb), .15);color:var(--primary);justify-content:center;align-items:center;font-size:.68rem;font-weight:700;display:inline-flex}.following-name{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.75rem;font-weight:600;overflow:hidden}.following-title{color:var(--ink);margin:0;font-size:.95rem;font-weight:700;line-height:1.3}.following-artist{color:var(--muted);margin:0;font-size:.78rem}.dash-following-empty{color:var(--muted);margin:8px 0 0;font-size:.88rem}.dash-follow-cta{background:var(--surface);border:1px dashed var(--line);text-align:center;border-radius:16px;padding:24px}.dash-follow-cta h2{margin:6px 0 8px}.perf-font-controls{align-items:center;gap:2px;display:flex}.perf-font-btn{color:#fff9;cursor:pointer;font-size:.75rem;font-family:var(--font-body);background:#ffffff12;border:none;border-radius:6px;padding:4px 8px;line-height:1;transition:background .15s,color .15s}.perf-font-btn:hover{color:#fff;background:#ffffff26}.set-perf-right-controls{align-items:center;gap:12px;display:flex}.sidebar-notif-wrap{align-items:center;display:inline-flex;position:relative}.sidebar-notif-badge{background:var(--primary);color:#fff;text-align:center;border-radius:99px;min-width:14px;padding:1px 4px;font-size:.6rem;font-weight:700;line-height:1.3;position:absolute;top:-4px;right:-6px}.notif-list{flex-direction:column;gap:2px;display:flex}.notif-item{background:var(--surface);border:1px solid var(--line);border-radius:12px;align-items:flex-start;gap:14px;padding:14px 16px;display:flex;position:relative}.notif-unread{background:var(--primary)}@supports (color:color-mix(in lab, red, red)){.notif-unread{background:color-mix(in srgb, var(--primary) 6%, var(--surface))}}.notif-unread{border-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.notif-unread{border-color:color-mix(in srgb, var(--primary) 25%, var(--line))}}.notif-icon{background:rgba(var(--primary-rgb), .12);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.notif-icon svg{width:16px;height:16px;color:var(--primary)}.notif-content{flex:1;min-width:0}.notif-message{color:var(--ink);margin:0 0 4px;font-size:.9rem;line-height:1.4}.notif-time{color:var(--muted);margin-bottom:4px;font-size:.78rem;display:block}.notif-link{color:var(--primary);font-size:.8rem;font-weight:600;text-decoration:none}.notif-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px}.bookmark-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:1.1rem;line-height:1;transition:color .15s,background .15s}.bookmark-btn:hover{color:var(--primary);background:rgba(var(--primary-rgb), .08)}.bookmark-btn.bookmarked{color:var(--primary)}.revision-list{flex-direction:column;gap:12px;display:flex}.revision-item{background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden}.revision-meta{justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.revision-snapshot{color:var(--ink);margin:0 0 3px;font-size:.88rem}.revision-time{color:var(--muted);font-size:.78rem}.revision-preview{font-family:var(--font-mono);color:var(--muted);background:var(--surface-el);border-top:1px solid var(--line);white-space:pre-wrap;max-height:120px;margin:0;padding:12px 16px;font-size:.75rem;overflow:hidden}.perf-scripture{color:#ffffff8c;margin:2px 0 0;font-size:.82rem;font-style:italic}.perf-vocal-range{color:#ffffff73;margin:1px 0 0;font-size:.78rem}.perf-comments{max-width:700px;margin:40px auto 60px;padding:0 20px}.perf-comments-heading{color:#ffffffb3;border-bottom:1px solid #ffffff1a;margin:0 0 16px;padding-bottom:10px;font-size:1rem;font-weight:700}.perf-comment-form{flex-direction:column;gap:8px;margin-bottom:24px;display:flex}.perf-comment-input{color:#ffffffe6;font-size:.88rem;font-family:var(--font-body);resize:vertical;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;min-height:70px;padding:10px 14px;transition:border-color .15s}.perf-comment-input::placeholder{color:#ffffff4d}.perf-comment-input:focus{border-color:var(--primary);outline:none}.perf-comment-auth{color:#ffffff73;margin-bottom:20px;font-size:.85rem}.perf-comment-auth a{color:var(--primary)}.perf-comment{border-bottom:1px solid #ffffff12;gap:12px;padding:12px 0;display:flex}.perf-comment-avatar{background:rgba(var(--primary-rgb), .2);width:34px;height:34px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex;overflow:hidden}.perf-comment-avatar img{object-fit:cover;width:100%;height:100%}.perf-comment-body{flex:1;min-width:0}.perf-comment-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.perf-comment-meta strong{color:#ffffffd9;font-size:.83rem}.perf-comment-meta time{color:#ffffff59;font-size:.75rem}.perf-comment-delete{color:#ffffff40;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:.7rem;line-height:1;transition:color .15s}.perf-comment-delete:hover{color:var(--danger)}.perf-comment-text{color:#ffffffb3;white-space:pre-wrap;word-break:break-word;margin:0;font-size:.88rem;line-height:1.5}.perf-comment-empty{color:#ffffff59;text-align:center;padding:20px 0;font-size:.85rem}.danger-zone{background:#c530300a;border:1px solid #c530304d;border-radius:12px;margin-top:32px;padding:20px 24px}.danger-zone-title{color:var(--danger);text-transform:uppercase;letter-spacing:.08em;margin:0 0 6px;font-size:.88rem;font-weight:700}.danger-zone-desc{color:var(--muted);margin:0 0 14px;font-size:.85rem}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-panel{background:var(--surface);border:1px solid var(--line);border-radius:16px;width:100%;max-width:420px;padding:28px;box-shadow:0 20px 60px #0003}.delete-confirm-input{border:1px solid var(--line);width:100%;font-size:.95rem;font-family:var(--font-mono);background:var(--surface-el);color:var(--ink);box-sizing:border-box;border-radius:8px;padding:10px 14px;transition:border-color .15s}.delete-confirm-input:focus{border-color:var(--danger);outline:none}[data-swipeable]{touch-action:pan-y;-webkit-user-select:none;user-select:none}[data-swipeable].swipe-left{animation:.2s forwards swipeOutLeft}[data-swipeable].swipe-right{animation:.2s forwards swipeOutRight}@keyframes swipeOutLeft{to{opacity:0;transform:translate(-60px)}}@keyframes swipeOutRight{to{opacity:0;transform:translate(60px)}}.dash-follow-cta p{color:var(--muted);margin:0 0 14px;font-size:.9rem}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
