/*! 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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--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-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--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{.collapse{visibility:collapse}.visible{visibility:visible}.relative{position:relative}.static{position:static}.isolate{isolation:isolate}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.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,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#0a0818;--surface:#12102c;--surface-el:#1c1a40;--primary:#7c3aed;--primary-hov:#9b59f6;--primary-rgb:124, 58, 237;--ink:#ede9fe;--muted:#7b70a8;--line:#242040;--chord:#a78bfa;--chord-rgb:167, 139, 250;--success:#34d399;--danger:#f87171;--radius-xl:1.5rem;--shadow:0 4px 24px #7c3aed38;--shadow-md:0 8px 40px #7c3aed57;--sidebar-bg:#050412;--perf-bg:#0a0818}.dark{--bg:#0a0818;--surface:#12102c;--surface-el:#1c1a40;--primary:#7c3aed;--primary-hov:#9b59f6;--primary-rgb:124, 58, 237;--ink:#ede9fe;--muted:#7b70a8;--line:#242040;--chord:#a78bfa;--chord-rgb:167, 139, 250;--success:#34d399;--danger:#f87171;--sidebar-bg:#050412;--perf-bg:#0a0818}*,: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(16px,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}.cl-pair{vertical-align:top;white-space:nowrap;flex-direction:column;align-items:flex-start;display:inline-flex}.cl-lyric{white-space:pre;display:inline-block}.chord-ph{visibility:hidden;pointer-events:none;-webkit-user-select:none;user-select:none;min-height:1.3em;display:block}.chord-only-line{flex-wrap:wrap;align-items:baseline;gap:0 1em;display:inline-flex}.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{color:var(--danger);background:#c530300d}.notice-success{color:var(--success);background:#27ae600f}.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-chip-tag{color:var(--primary)!important;background:rgba(var(--primary-rgb), .09)!important}.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}.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{flex-shrink:0;justify-content:center;align-items:center;display:flex}.auth-hero-copy{z-index:1;margin-bottom:28px;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-features{z-index:1;flex-direction:column;gap:14px;margin:0 0 28px;padding:0;list-style:none;display:flex;position:relative}.auth-feature-item{color:#ffffffd1;align-items:flex-start;gap:13px;display:flex}.auth-feature-icon{width:30px;height:30px;color:var(--primary);background:#d9772f2e;border:1px solid #d9772f40;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.auth-feature-item strong{color:#fff;margin-bottom:1px;font-size:.82rem;font-weight:700;display:block}.auth-feature-item span{color:#ffffff7a;font-size:.76rem;line-height:1.4}.auth-logo-sm{align-items:center;margin-bottom:28px;display:flex}.auth-highlights{background:var(--surface-el);border:1px solid var(--line);border-radius:12px;flex-direction:column;gap:9px;margin:20px 0 24px;padding:18px 20px;display:flex}.auth-highlight-item{color:var(--muted);align-items:center;gap:10px;font-size:.82rem;line-height:1.4;display:flex}.auth-highlight-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:6px;height:6px}.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{flex-direction:column;display:flex}.member-item{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:11px 0;display:flex}.member-item:last-child{border-bottom:none;padding-bottom:0}.member-item:first-child{padding-top:0}.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}.grp-banner{background:linear-gradient(135deg,#0c1628 0%,#1a2a4a 100%);border-radius:20px;margin-bottom:28px;padding:28px clamp(18px,3vw,36px);position:relative;overflow:hidden}.grp-banner:before{content:"";background:radial-gradient(ellipse at 80% 50%, rgba(var(--primary-rgb), .12) 0%, transparent 70%);pointer-events:none;position:absolute;inset:0}.grp-banner-inner{flex-wrap:wrap;align-items:flex-start;gap:20px;display:flex;position:relative}.grp-banner-avatar{background:rgba(var(--primary-rgb), .2);border:2px solid rgba(var(--primary-rgb), .35);width:72px;height:72px;color:var(--primary);font-family:var(--font-display);border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.grp-banner-info{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.grp-banner-top{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.grp-banner-name{color:#fff;margin:0;font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:700;line-height:1.1}.grp-banner-role{letter-spacing:.1em;text-transform:uppercase;border-radius:20px;padding:3px 10px;font-size:.65rem;font-weight:700}.grp-banner-role.role-admin{background:rgba(var(--primary-rgb),.25);color:var(--primary);border:1px solid rgba(var(--primary-rgb),.4)}.grp-banner-role.role-editor{color:#78beff;background:#78beff26;border:1px solid #78beff4d}.grp-banner-role.role-viewer{color:#ffffff8c;background:#ffffff14;border:1px solid #ffffff24}.grp-banner-count{color:#ffffff73;align-items:center;gap:5px;font-size:.78rem;font-weight:600;display:flex}.grp-banner-desc{color:#ffffff73;margin:0;font-size:.85rem;line-height:1.5}.grp-banner-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.grp-back-btn{color:#fff6;border-radius:8px;padding:6px 12px;font-size:.78rem;font-weight:600;text-decoration:none;transition:color .14s}.grp-back-btn:hover{color:#ffffffbf}.grp-shell{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 290px;align-items:start;gap:24px;display:grid}@media (width<=1200px){.grp-shell{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.grp-shell>aside{grid-column:1/-1}}@media (width<=700px){.grp-shell{grid-template-columns:1fr}}.grp-col{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden}.grp-col-head{border-bottom:1px solid var(--line);padding:18px 20px 14px}.grp-col-eyebrow{letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin:0 0 2px;font-size:.62rem;font-weight:800}.grp-col-sub{color:var(--primary);margin:0;font-size:.82rem;font-weight:600}.grp-share-form{border-bottom:1px solid var(--line);background:var(--bg);padding:14px 20px}.grp-share-form form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.grp-ls-select{border:1px solid var(--line);background:var(--surface);min-width:0;color:var(--ink);font:inherit;border-radius:10px;flex:1;padding:8px 12px;font-size:.83rem}.grp-empty{text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:12px;padding:40px 24px;font-size:.85rem;line-height:1.6;display:flex}.grp-song-list{flex-direction:column;display:flex}.grp-song-item{border-bottom:1px solid #0a11280d;align-items:center;gap:10px;padding:11px 20px;transition:background .1s;display:flex}.grp-song-item:last-child{border-bottom:none}.grp-song-item:hover{background:var(--bg)}.grp-song-key{color:var(--primary);text-align:center;background:rgba(var(--primary-rgb), .09);min-width:48px;font-size:.7rem;font-weight:800;font-family:var(--font-mono);border-radius:7px;flex-shrink:0;padding:4px 8px}.grp-song-info{flex:1;min-width:0}.grp-song-info strong{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;display:block;overflow:hidden}.grp-song-info span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.73rem;display:block;overflow:hidden}.grp-song-btns{flex-shrink:0;align-items:center;gap:5px;display:flex}.grp-remove-btn{border:1px solid var(--line);color:var(--muted);font:inherit;cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;transition:border-color .14s,color .14s,background .14s;display:flex}.grp-remove-btn:hover{border-color:var(--danger);color:var(--danger);background:#c530300d}.grp-ls-list{flex-direction:column;display:flex}.grp-ls-card{border-bottom:1px solid var(--line);flex-direction:column;gap:12px;padding:16px 20px;transition:background .1s;display:flex}.grp-ls-card:last-child{border-bottom:none}.grp-ls-card:hover{background:var(--bg)}.grp-ls-card-head{flex-direction:column;gap:3px;display:flex}.grp-ls-card-meta{align-items:center;gap:10px;margin-bottom:2px;display:flex}.grp-ls-date{color:var(--primary);align-items:center;gap:4px;font-size:.72rem;font-weight:700;display:flex}.grp-ls-songs-count{color:var(--muted);background:var(--surface-el);border-radius:20px;padding:2px 8px;font-size:.72rem;font-weight:600}.grp-ls-name{color:var(--ink);margin:0;font-size:.95rem;font-weight:700}.grp-ls-by{color:var(--muted);margin:0;font-size:.73rem}.grp-ls-tracks{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.grp-ls-tracks li{align-items:center;gap:8px;font-size:.8rem;display:flex}.grp-ls-track-num{color:var(--muted);text-align:right;flex-shrink:0;width:18px;font-size:.65rem;font-weight:700}.grp-ls-track-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:500;overflow:hidden}.grp-ls-track-key{color:var(--primary);font-size:.68rem;font-weight:700;font-family:var(--font-mono);flex-shrink:0}.grp-ls-track-more{color:var(--muted);font-size:.72rem;font-style:italic}.grp-ls-card-foot{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.grp-aside{flex-direction:column;gap:14px;display:flex}.grp-aside-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;flex-direction:column;gap:14px;padding:18px 20px;display:flex}.grp-aside-heading{letter-spacing:.13em;text-transform:uppercase;color:var(--muted);align-items:center;gap:7px;margin:0;font-size:.62rem;font-weight:800;display:flex}.grp-member-list{flex-direction:column;gap:2px;display:flex}.grp-member-item{border-bottom:1px solid #0a11280d;align-items:center;gap:10px;padding:8px 0;display:flex}.grp-member-item:last-child{border-bottom:none;padding-bottom:0}.grp-member-item:first-child{padding-top:0}.grp-member-avatar-wrap{flex-shrink:0;position:relative}.grp-member-avatar{object-fit:cover;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}img.grp-member-avatar{background:var(--surface-el)}.grp-member-initial{background:var(--primary)}@supports (color:color-mix(in lab, red, red)){.grp-member-initial{background:color-mix(in srgb, var(--primary) 14%, transparent)}}.grp-member-initial{color:var(--primary);font-size:.88rem;font-weight:800}.grp-owner-crown{background:var(--primary);color:#fff;border:1.5px solid var(--surface);border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:.52rem;display:flex;position:absolute;bottom:-4px;right:-4px}.grp-member-info{flex:1;min-width:0}.grp-member-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.85rem;font-weight:700;overflow:hidden}.grp-member-instrument{color:var(--muted);margin:1px 0 0;font-size:.72rem}.grp-role-select{border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:.75rem;font-family:var(--font-body);cursor:pointer;border-radius:8px;padding:4px 7px}.grp-role-badge{letter-spacing:.06em;text-transform:uppercase;border-radius:20px;flex-shrink:0;padding:3px 9px;font-size:.65rem;font-weight:700}.grp-role-badge.role-admin{background:rgba(var(--primary-rgb),.12);color:var(--primary)}.grp-role-badge.role-editor{color:#5aabf8;background:#78beff1f}.grp-role-badge.role-viewer{background:var(--surface-el);color:var(--muted)}.group-liveset-list{flex-direction:column;gap:12px;margin-top:12px;display:flex}.group-liveset-card{border:1px solid var(--line);background:var(--surface);border-radius:14px;padding:16px 18px}.group-liveset-card-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.group-liveset-name{color:var(--ink);margin:0 0 3px;font-size:1rem;font-weight:700}.group-liveset-meta{color:var(--muted);margin:0;font-size:.78rem}.group-liveset-date{color:var(--primary);font-weight:600}.group-liveset-tracks{border-top:1px solid var(--line);flex-direction:column;gap:5px;margin:12px 0 0;padding:10px 0 0;list-style:none;display:flex}.group-liveset-tracks li{align-items:center;gap:8px;font-size:.82rem;display:flex}.group-liveset-num{color:var(--muted);text-align:right;flex-shrink:0;width:18px;font-size:.68rem;font-weight:700}.group-liveset-song-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:500;overflow:hidden}.group-liveset-song-key{color:var(--primary);font-size:.72rem;font-weight:700;font-family:var(--font-mono)}.group-liveset-more{color:var(--muted);font-size:.75rem;font-style:italic}.group-liveset-select{border:1px solid var(--line);background:var(--surface);color:var(--ink);font:inherit;border-radius:12px;padding:9px 14px;font-size:.88rem}.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,.app-main>.settings-page,.app-main>.lsb-page,.app-main>.page-banner,.app-main>.songs-banner,.app-main>.songs-tag-bar,.app-main>.songs-grid{box-sizing:border-box;width:100%;padding-left:clamp(16px,2.5vw,32px);padding-right:clamp(16px,2.5vw,32px)}.app-main>.notice{padding-left:clamp(16px,2.5vw,32px);padding-right:clamp(16px,2.5vw,32px)}.trial-expired-banner{background:linear-gradient(135deg,#7b1d1d,#c53030);border-bottom:1px solid #ffffff1a;padding:0}.trial-expired-inner{flex-wrap:wrap;align-items:center;gap:14px;max-width:1180px;margin:0 auto;padding:14px clamp(16px,3vw,40px);display:flex}.trial-expired-icon{flex-shrink:0;font-size:1.2rem}.trial-expired-text{color:#ffffffe6;flex:1;min-width:200px;font-size:.88rem;line-height:1.5}.trial-expired-text strong{color:#fff}.trial-expired-cta{color:#c53030;white-space:nowrap;background:#fff;border-radius:8px;flex-shrink:0;padding:8px 16px;font-size:.82rem;font-weight:700;text-decoration:none}.trial-expired-cta:hover{background:#fff5f5}.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{flex-shrink:0;display:block}.sidebar-brand-logo{flex-shrink:0;width:auto;max-width:160px;height:44px;display:block}.sidebar.collapsed .sidebar-brand-logo{object-fit:cover;object-position:left center;width:36px;height:36px}.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-account{cursor:pointer;background:#ffffff0d;border:1px solid #ffffff12;border-radius:12px;flex-shrink:0;align-items:center;gap:10px;min-height:60px;margin:0 8px 8px;padding:10px 12px;text-decoration:none;transition:background .18s,border-color .18s;display:flex;overflow:hidden}.sidebar-account:hover{background:#ffffff17;border-color:#ffffff21}.sidebar-account-avatar-wrap{flex-shrink:0;position:relative}.sidebar-account-edit-dot{background:var(--primary);color:#fff;border:2px solid #0c1628;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;display:flex;position:absolute;bottom:-2px;right:-2px}.sidebar-account-label{letter-spacing:.1em;text-transform:uppercase;color:#f9f6f04d;margin-bottom:1px;font-size:.6rem;font-weight:700;display:block}.sidebar-pub-profile{cursor:pointer;color:#f9f6f0e6;background:0 0;border:1.5px solid #d9772f8c;border-radius:12px;flex-shrink:0;align-items:center;gap:10px;min-height:56px;margin:0 8px 8px;padding:10px 12px;text-decoration:none;transition:border-color .18s,background .18s;display:flex;overflow:hidden}.sidebar-pub-profile:hover{border-color:var(--primary);background:#d9772f14}.sidebar-pub-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex;overflow:hidden}.sidebar-pub-avatar img{object-fit:cover;width:100%;height:100%}.sidebar-pub-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sidebar-pub-label{letter-spacing:.1em;text-transform:uppercase;color:#f9f6f073;white-space:nowrap;font-size:.6rem;font-weight:700}.sidebar-pub-name{color:#f9f6f0eb;white-space:nowrap;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;font-weight:700;overflow:hidden}.sidebar-pub-ext{opacity:.4;flex-shrink:0}.sidebar-pub-profile:hover .sidebar-pub-ext{opacity:.7}.sidebar.collapsed .sidebar-pub-profile{justify-content:center;margin:0 8px 8px;padding:10px}.sidebar.collapsed .sidebar-pub-info,.sidebar.collapsed .sidebar-pub-ext{display:none}.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 .sidebar-upgrade-link{background:rgba(var(--primary-rgb), .15);color:var(--primary);margin-top:4px;font-weight:600}.sidebar .sidebar-upgrade-link .sidebar-icon{opacity:1;color:var(--primary)}.sidebar .sidebar-upgrade-link:hover{background:rgba(var(--primary-rgb), .25)}.sidebar-lock{opacity:.55;margin-left:4px;font-size:.7rem}.sidebar .sidebar-link-locked{opacity:.6}.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,.sidebar.collapsed .sidebar-account{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{z-index:80;background:#fff;border-bottom:1px solid #ebe6de;align-items:center;gap:12px;height:56px;padding:0 12px;display:none;position:fixed;top:0;left:0;right:0}.mobile-menu-btn{color:#1c2b3a;cursor:pointer;background:#f3f0eb;border:1px solid #e5e0d8;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:#2a7a8c;white-space:nowrap;flex:1;align-items:center;gap:7px;font-size:1.1rem;font-weight:700;text-decoration:none;display:flex;overflow:hidden}.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}.app-main>.page-banner:first-child,.app-main>.songs-banner:first-child{margin-top:12px}.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-account{justify-content:flex-start;margin:0 8px 8px;padding:10px 14px}.sidebar.mobile-open .sidebar-pub-profile{justify-content:flex-start;padding:10px 12px}.sidebar.mobile-open .sidebar-pub-info,.sidebar.mobile-open .sidebar-pub-ext{display:flex}.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~.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,.song-form-sidebar select{border-radius:10px;padding:9px 12px;font-size:.88rem}.song-form-sidebar select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A5568' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.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}.editor-ai-nudge{background:rgba(var(--primary-rgb), .08);border:1px solid rgba(var(--primary-rgb), .22);color:var(--muted);border-radius:8px;align-items:center;gap:8px;margin-bottom:8px;padding:9px 14px;font-size:.82rem;display:flex}.editor-ai-nudge svg{color:var(--primary);flex-shrink:0}.editor-ai-nudge-btn{cursor:pointer;color:var(--primary);font-weight:700;font-size:inherit;text-underline-offset:2px;background:0 0;border:none;padding:0;text-decoration:underline}.chord-suggest-bar{background:#e4e4dc;border-bottom:1px solid #bdc5bd;flex-wrap:wrap;align-items:center;gap:8px;min-height:38px;padding:7px 14px;display:flex}.chord-suggest-label{text-transform:uppercase;letter-spacing:.12em;color:#6b7280;white-space:nowrap;flex-shrink:0;font-size:.68rem;font-weight:800}.chord-suggest-chips{flex-wrap:wrap;flex:1;gap:5px;display:flex}.chord-suggest-chip{font-size:.84rem;font-weight:700;font-family:var(--font-mono);color:#2a7a8c;cursor:pointer;background:#fff;border:1px solid #a2b7b4;border-radius:6px;padding:3px 11px;line-height:1.6;transition:background .12s,border-color .12s,transform 80ms}.chord-suggest-chip:hover{background:#e5eff1;border-color:#2a7a8c;transform:translateY(-1px)}.chord-suggest-chip:active{transform:translateY(0)}.chord-suggest-hint{color:#6b7280;white-space:nowrap;flex-shrink:0;font-size:.66rem}.song-form-editor-area{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.chordpro-highlight{font-family:var(--font-mono);white-space:pre-wrap;word-wrap:break-word;scrollbar-width:none;pointer-events:none;color:#1c2b3a;z-index:1;tab-size:4;box-sizing:border-box;background:#fff;border:none;margin:0;padding:22px 24px;font-size:.9rem;line-height:1.8;position:absolute;inset:0;overflow:auto}.chordpro-highlight::-webkit-scrollbar{display:none}.song-form-editor-area:has([data-chordpro-highlight]) textarea{color:#0000}.hl-chord{color:#2a7a8c;font-weight:600}.hl-bar-chord{color:#d9772f}.hl-directive{color:#6b7280;opacity:.65}.song-form-editor-area textarea{font-family:var(--font-mono);resize:none;color:#1c2b3a;caret-color:#1c2b3a;min-height:520px;box-shadow:none;z-index:2;background:0 0;border:none;border-radius:0;outline:none;flex:1;width:100%;padding:22px 24px;font-size:.9rem;line-height:1.8;position:relative}.song-form-editor-area textarea:focus{box-shadow:none;border-color:#0000;outline:none}.song-form-editor-area textarea::placeholder{color:#6b7280;opacity:.4;caret-color:#1c2b3a}.sf-desktop-only{display:inline-flex}.sf-mobile-only,.song-form-mobile-tabs{display:none}@media (width<=860px){.song-form-topbar{gap:8px;padding:10px 16px}.song-form-heading{font-size:1.05rem}.song-form-topbar-actions{gap:6px}.sf-desktop-only{display:none!important}.sf-mobile-only{display:inline-flex!important}.song-form-mobile-tabs{background:#fff;border-bottom:1px solid #e2d8c9;flex-shrink:0;display:flex}.sfm-tab{font-size:.8rem;font-weight:600;font-family:var(--font-body);color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:11px 8px;transition:color .15s,border-color .15s;display:flex}.sfm-tab.active{color:#2a7a8c;border-bottom-color:#2a7a8c}.sfm-tab svg{opacity:.7}.sfm-tab.active svg{opacity:1}.sfm-hidden{display:none!important}.song-form-body{flex:1;grid-template-columns:1fr}.song-form-sidebar{border-bottom:none;border-right:none;padding:0 16px 24px;overflow-y:auto}.song-form-section{gap:10px;padding:16px 0}.song-form-editor-wrap{flex-direction:column;flex:1;display:flex;overflow:hidden}.song-form-editor-head{padding:10px 16px}.song-form-editor-area{flex:1}.song-form-editor-area textarea,.chordpro-highlight{min-height:calc(100dvh - 180px);padding:16px;font-size:.82rem}.song-form-syntax-chips{display:none}}.perf-body{background:var(--perf-bg);color:#ffffffeb;min-height:100vh;font-family:var(--font-body);--chord-font-scale:1}.perf-wrap{width:100%}.perf-header{padding:clamp(16px,2vw,28px) clamp(24px,5vw,64px) 0}.perf-topbar{z-index:201;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:0;display:flex;position:relative}.perf-back{color:#ffffff47;font-size:.74rem;font-family:var(--font-mono);letter-spacing:.06em;flex-shrink:0;align-items:center;gap:6px;text-decoration:none;transition:color .15s;display:inline-flex}.perf-back:hover{color:#ffffff9e}.perf-controls-strip{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.perf-strip-sep{background:#ffffff1a;flex-shrink:0;width:1px;height:28px}.perf-ctrl-grp{flex-direction:column;align-items:center;gap:3px;display:flex}.perf-ctrl-lbl{text-transform:uppercase;letter-spacing:.1em;color:#ffffff6b;white-space:nowrap;font-size:.58rem;font-weight:700;line-height:1}.perf-ctrl-grp .perf-controls,.perf-ctrl-grp .perf-metro{align-items:center;gap:5px;display:flex}.perf-meta{justify-content:space-between;align-items:flex-start;gap:20px;margin-top:16px;display:flex}.perf-meta-info{flex:1;min-width:0}.perf-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:10px;display:flex}.perf-key-label{font-family:var(--font-mono);color:#ffffff94;letter-spacing:.1em;white-space:nowrap;background:#ffffff12;border:1px solid #ffffff24;border-radius:20px;margin-bottom:12px;padding:4px 13px;font-size:.62rem;display:inline-block}.perf-capo-label{font-family:var(--font-mono);background:var(--primary);color:#fff;letter-spacing:.06em;vertical-align:middle;border-radius:20px;margin-left:8px;padding:2px 8px;font-size:.65rem}.perf-title{font-family:var(--font-display);color:#fffffff5;letter-spacing:.01em;margin:0 0 8px;font-size:clamp(1.9rem,3.6vw,3rem);font-weight:700;line-height:1.08}.perf-artist{color:#ffffff80;letter-spacing:.02em;margin:0 0 2px;font-size:.84rem;font-weight:400}.perf-notes-line{color:#ffffff5c;margin:6px 0 0;font-size:.79rem;font-style:italic}.perf-scripture{color:#ffffff61;letter-spacing:.01em;margin:4px 0 0;font-size:.76rem}.perf-tag{color:#ffffff73;letter-spacing:.04em;background:#ffffff12;border:1px solid #ffffff21;border-radius:20px;padding:2px 9px;font-size:.63rem;font-weight:600}.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-btn-upgrade{background:rgba(var(--primary-rgb),.14);border:1px solid rgba(var(--primary-rgb),.3);width:auto;height:34px;color:var(--primary);cursor:pointer;font-size:.78rem;font-weight:600;font-family:var(--font-body);white-space:nowrap;border-radius:8px;align-items:center;gap:5px;padding:0 12px;text-decoration:none;transition:background .12s,border-color .12s;display:flex}.perf-btn-upgrade:hover{background:rgba(var(--primary-rgb),.25);border-color:rgba(var(--primary-rgb),.5);color:var(--primary)}.perf-bpm{font-family:var(--font-mono);color:#ffffff8c;white-space:nowrap;padding:0 4px;font-size:.82rem}.perf-metro{align-items:center;gap:7px;display:flex}.perf-metro-btn{color:#fff9;height:30px;font-size:.68rem;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:#ffffff12;border:1px solid #ffffff24;border-radius:8px;padding:0 14px;transition:background .12s,color .12s,border-color .12s}.perf-metro-btn:hover{background:rgba(var(--primary-rgb),.18);border-color:rgba(var(--primary-rgb),.32);color:#ffffffd9}.perf-beat{font-family:var(--font-mono);color:#ffffff40;text-align:center;min-width:14px;font-size:.68rem}.perf-hr{background:#ffffff17;height:1px;margin:22px clamp(24px,5vw,64px) 28px}.perf-body .chart-output{background:0 0;border:none;border-radius:0;padding:0 clamp(24px,5vw,64px) clamp(36px,5vw,60px)}.perf-body .chart-section{padding:32px 0}.perf-body .chart-section:first-child{padding-top:6px}.perf-body .chart-section:last-child{padding-bottom:4px}.perf-body .chart-section+.chart-section{border-top:1px solid #ffffff14}.perf-body .chart-section h2{letter-spacing:.2em;border:none;border-left:2px solid rgba(var(--primary-rgb), .65);color:#ffffffa6;background:0 0;border-radius:0;margin-bottom:24px;padding:0 0 0 12px;font-size:.6rem;font-weight:800;line-height:1.4;display:block}.perf-body .chart-lines{gap:18px}.perf-body .measure-line{padding:4px 0}.perf-body .measure{font-size:calc(clamp(1.5rem, 2.8vw, 2.2rem) * var(--chord-font-scale));color:#fffffff0;min-width:68px;padding:4px 14px}.perf-body .measure[data-chord]{cursor:pointer;border-radius:6px;transition:background .12s}.perf-body .measure[data-chord]:hover{background:#ffffff14}.perf-body .chord[data-chord]{cursor:pointer}.perf-body .measure-sep{color:#0000;background:#ffffff29;flex-shrink:0;align-self:stretch;width:1px;margin:8px 0;padding:0;font-size:0;display:inline-block}.perf-body .measure-sep-end{color:#fff6;background:#ffffff47;width:2px}.perf-body .chord{color:var(--chord);font-size:clamp(.85rem,1.5vw,1.1rem)}.perf-body .cl-lyric{color:#ffffffe6;font-size:clamp(1rem,2vw,1.35rem)}.perf-body .cl-pair{margin-bottom:2px}@media (width<=640px){.perf-header{padding:12px 18px 16px}.perf-topbar{z-index:30;background:var(--perf-bg);border-bottom:1px solid #ffffff12;flex-wrap:nowrap;gap:10px;margin:-12px -18px 16px;padding:10px 18px;position:sticky;top:0;overflow-x:auto}.perf-back{flex-shrink:0;font-size:.68rem}.perf-controls-strip{flex-wrap:nowrap;flex-shrink:0;gap:4px}.perf-strip-sep{height:16px}.perf-key-label{opacity:.7;margin-bottom:2px;font-size:.62rem}.perf-title{margin-bottom:2px;font-size:clamp(1.5rem,6vw,2.2rem)}.perf-artist{font-size:.76rem}.perf-notes-line{display:none}.perf-controls{background:#ffffff0d;border:1px solid #ffffff17;border-radius:10px;gap:1px;padding:2px 3px}.perf-btn{background:0 0;border:none;width:28px;height:28px;font-size:1.1rem}.perf-btn:hover{background:#ffffff14;border:none}.perf-bpm{padding:0 4px;font-size:.7rem}.perf-metro{gap:4px}.perf-metro-btn{border-radius:7px;height:26px;padding:0 9px;font-size:.6rem}.perf-beat{min-width:12px;font-size:.62rem}.perf-font-btn{width:26px;height:26px;font-size:.7rem}.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:52px;padding:4px 8px;font-size:1.2rem}.perf-body .measure-sep{font-size:1rem}.perf-body .chord{font-size:.9rem}.perf-body .measure-line{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.perf-body .measure-line::-webkit-scrollbar{display:none}.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.group-locked{opacity:.65}.grp-locked-chip{text-transform:uppercase;letter-spacing:.05em;color:var(--danger);background:#c530301a;border:1px solid #c5303040;border-radius:6px;align-items:center;gap:3px;margin-left:auto;padding:2px 7px;font-size:.65rem;font-weight:700;display:inline-flex}.grp-locked-banner{color:var(--ink);background:#c5303014;border:1px solid #c5303040;border-radius:12px;align-items:center;gap:14px;margin:0 clamp(16px,3vw,40px) 20px;padding:14px 20px;font-size:.88rem;display:flex}.grp-locked-banner svg{color:var(--danger);flex-shrink:0}.grp-locked-banner strong{color:var(--danger);margin-bottom:2px;display:block}.grp-locked-banner span{color:var(--muted)}.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}.lsb-page{flex-direction:column;min-height:100vh;display:flex}.lsb-bar{z-index:20;background:#0c1628;justify-content:space-between;align-items:flex-start;gap:20px;padding:16px clamp(16px,3vw,36px);display:flex;position:sticky;top:0;box-shadow:0 2px 16px #00000038}.lsb-bar-left{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.lsb-name-input{color:#fff;caret-color:#2a7a8c;background:0 0;border:none;outline:none;width:100%;padding:0;font-family:Cormorant Garamond,serif;font-size:1.6rem;font-weight:700;line-height:1.15}.lsb-meta-row{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.lsb-meta-field{color:#ffffff80;background:#ffffff12;border:1px solid #ffffff1f;border-radius:8px;align-items:center;gap:6px;padding:5px 10px;display:flex}.lsb-meta-input{color:#fffc;font:inherit;background:0 0;border:none;outline:none;width:auto;min-width:0;font-size:.8rem}.lsb-meta-input[type=date]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;width:130px}.lsb-meta-input[type=text]{width:180px}.lsb-bar-actions{flex-shrink:0;align-items:center;gap:10px;padding-top:4px;display:flex}.lsb-cancel-btn{color:#ffffffa6;font:inherit;cursor:pointer;background:0 0;border:1px solid #ffffff2e;border-radius:10px;padding:9px 18px;font-size:.84rem;font-weight:600;text-decoration:none;transition:background .14s,color .14s}.lsb-cancel-btn:hover{color:#fff;background:#ffffff14}.lsb-save-btn{color:#fff;font:inherit;cursor:pointer;letter-spacing:.01em;background:#2a7a8c;border:none;border-radius:10px;padding:9px 22px;font-size:.84rem;font-weight:700;transition:opacity .14s}.lsb-save-btn:hover{opacity:.88}.lsb-error-bar{color:#c53030;background:#c530300f;border-bottom:1px solid #c5303033;padding:10px clamp(16px,3vw,36px);font-size:.82rem}@media (width<=720px){.lsb-body{grid-template-columns:1fr}}.lsb-library{background:#fff;border-right:1px solid #e2d8c9;flex-direction:column;display:flex}.lsb-lib-tabs{background:#f0ebe1;border-bottom:1px solid #e2d8c9;display:flex}.lsb-lib-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-size:.78rem;font-weight:600;transition:color .14s,border-color .14s;display:flex}.lsb-lib-tab-count{background:#e2d8c9;border-radius:10px;padding:1px 6px;font-size:.68rem;font-weight:700}.lsb-lib-panel{flex-direction:column;flex:1;display:flex;overflow:hidden}.lsb-import-btn.lsb-added,.lsb-import-btn:disabled{opacity:.55}.lsb-library-head{border-bottom:1px solid #e2d8c9;flex-direction:column;gap:10px;padding:18px clamp(14px,2vw,24px) 14px;display:flex}.lsb-library-title{align-items:center;gap:8px;display:flex}.lsb-refresh-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:2px;line-height:1;transition:color .14s,transform .2s}.lsb-refresh-btn:hover{color:#2a7a8c;transform:rotate(180deg)}.lsb-panel-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#6b7280;font-size:.62rem;font-weight:700}.lsb-library-count,.lsb-order-count{color:#2a7a8c;font-size:.8rem;font-weight:600}.lsb-search-wrap{position:relative}.lsb-search-icon{color:#6b7280;opacity:.5;pointer-events:none;width:14px;height:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.lsb-search-input{color:#1c2b3a;width:100%;font-size:.83rem;font-family:var(--font-body);background:#f7f5f1;border:1px solid #e2d8c9;border-radius:10px;outline:none;padding:8px 12px 8px 32px;transition:border-color .15s}.lsb-search-input:focus{border-color:#2a7a8c}.lsb-library-list{flex:1;overflow-y:auto}.lsb-song-row{border-bottom:1px solid #0a11280f;align-items:center;gap:10px;padding:11px clamp(14px,2vw,24px);transition:background .1s;display:flex}.lsb-song-key{color:#2a7a8c;text-align:center;letter-spacing:.02em;min-width:46px;font-size:.72rem;font-weight:800;font-family:var(--font-mono);background:#2a7a8c17;border-radius:7px;flex-shrink:0;padding:4px 8px}.lsb-song-info{flex:1;min-width:0}.lsb-song-info strong{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.88rem;font-weight:600;display:block;overflow:hidden}.lsb-song-info span{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;font-size:.73rem;display:block;overflow:hidden}.lsb-content-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:4px;margin-top:3px;padding:1px 6px;font-size:.62rem;font-weight:700;display:inline-block}.lsb-content-chords{color:#2a7a8c;background:#d9772f26}.lsb-content-lyrics{color:#63b3ed;background:#63b3ed26}.lsb-add-btn{color:#1c2b3a;font:inherit;cursor:pointer;background:#fff;border:1px solid #e2d8c9;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:.78rem;font-weight:600;transition:background .12s,border-color .12s,color .12s;display:flex}.lsb-library-empty{text-align:center;color:#6b7280;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;font-size:.88rem;display:flex}.lsb-order{background:#f7f5f1;flex-direction:column;display:flex}.lsb-order-head{background:#fff;border-bottom:1px solid #e2d8c9;align-items:baseline;gap:10px;padding:18px clamp(14px,2vw,24px) 14px;display:flex}.lsb-order-list{flex-direction:column;flex:1;gap:10px;margin:0;padding:16px clamp(14px,2vw,24px);list-style:none;display:flex;overflow-y:auto}.lsb-order-empty{text-align:center;color:#6b7280;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:64px 24px;font-size:.85rem;line-height:1.6;display:flex}.lsb-order-empty.is-hidden{display:none}.lsb-order-card{background:#fff;border:1px solid #e2d8c9;border-radius:14px;align-items:flex-start;gap:10px;padding:14px 14px 14px 10px;transition:box-shadow .15s;display:flex}.lsb-order-card:hover{box-shadow:0 2px 12px #00000012}.lsb-order-card.dragging{opacity:.5;box-shadow:0 8px 24px #00000026}.lsb-card-drag{cursor:grab;color:#6b7280;flex-shrink:0;align-self:stretch;align-items:center;padding:6px 4px;display:flex}.lsb-card-drag:active{cursor:grabbing}.lsb-card-num{color:#2a7a8c;text-align:center;font-variant-numeric:tabular-nums;letter-spacing:.02em;flex-shrink:0;min-width:22px;padding-top:5px;font-size:.7rem;font-weight:800}.lsb-card-body{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.lsb-card-top{flex-direction:column;gap:2px;display:flex}.lsb-card-title-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.lsb-card-title{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;overflow:hidden}.lsb-card-key{color:#2a7a8c;font-size:.7rem;font-weight:800;font-family:var(--font-mono);letter-spacing:.02em;background:#2a7a8c1a;border-radius:5px;flex-shrink:0;padding:2px 7px}.lsb-card-bpm{color:#6b7280;flex-shrink:0;font-size:.7rem;font-weight:600}.lsb-card-artist{color:#6b7280;margin:0;font-size:.75rem}.lsb-card-notes{color:#1c2b3a;width:100%;font:inherit;resize:none;min-height:34px;font-size:.78rem;font-family:var(--font-body);background:#f7f5f1;border:1px solid #e2d8c9;border-radius:8px;outline:none;padding:7px 10px;transition:border-color .14s}.lsb-card-actions{flex-direction:column;flex-shrink:0;gap:3px;display:flex}.lsb-card-btn{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e2d8c9;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:.9rem;transition:background .12s,color .12s,border-color .12s;display:flex}.perf-back-brand{font-family:var(--font-display);letter-spacing:.04em;font-size:.9rem;font-weight:700;color:#2a7a8c!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-hero-filter{max-width:600px}.pub-search-row{position:relative}.pub-search-row .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-row .pub-search-input{width:100%}.pub-hero-filter-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.pub-filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:20px;display:flex}.pub-filter-bar .song-search-bar{flex:1;min-width:200px}.pub-filter-select{height:38px;font-size:.85rem;font-family:var(--font-body);border:1.5px solid var(--border);background:var(--surface);color:var(--ink);cursor:pointer;border-radius:10px;outline:none;padding:0 10px;transition:border-color .15s}.pub-filter-select:focus{border-color:var(--primary)}.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:#f7f5f1;border:1.5px solid #e2d8c9;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:#1c2b3a;font-size:.82rem;font-weight:700}.song-visibility-box.is-public .song-visibility-status strong{color:#15803d}.song-visibility-status span{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.song-publish-dot{background:#e2d8c9;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.is-best{border-color:var(--primary);box-shadow:0 4px 24px rgba(var(--primary-rgb),.14)}.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-card-foot form{margin:0}.pricing-btn-cancel{text-align:center;width:100%;color:var(--muted);font-size:.76rem;font-weight:500;font-family:var(--font-body);border:1px solid var(--line);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;transition:color .13s,border-color .13s;display:block}.pricing-btn-cancel:hover{color:var(--danger);border-color:var(--danger)}.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}.pr-body{background:var(--bg);font-family:var(--font-body);min-height:100vh;margin:0;padding:0;overflow-x:hidden}.pr-nav{z-index:50;background:#0c1628;justify-content:space-between;align-items:center;height:62px;padding:0 clamp(20px,4vw,48px);display:flex;position:sticky;top:0}.pr-brand{color:#fff;letter-spacing:-.01em;align-items:center;gap:9px;font-size:1rem;font-weight:700;text-decoration:none;display:flex}.pr-brand img{flex-shrink:0}.pr-nav-link{color:#ffffffa6;border-radius:8px;padding:7px 14px;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .12s,background .12s}.pr-nav-link:hover{color:#fff;background:#ffffff14}.pr-nav-cta{color:#fff;background:#d9772f;border-radius:8px;padding:7px 16px;font-size:.875rem;font-weight:600;text-decoration:none;transition:background .12s}.pr-nav-cta:hover{background:#c46a28}.pr-hero{background:#0c1628;padding:20px clamp(16px,4vw,48px) 120px}.pr-hero-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1040px;margin:0 auto;display:flex}.pr-notice{color:#d9772f;text-align:left;background:#d9772f24;border:1px solid #d9772f47;border-radius:10px;align-items:center;gap:8px;max-width:480px;margin-bottom:32px;padding:10px 18px;font-size:.875rem;font-weight:500;display:inline-flex}.pr-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:#d9772f;margin:0 0 4px;font-size:.68rem;font-weight:700}.pr-subtitle{color:#ffffff80;margin:0;font-size:.82rem}.pr-current-badge{color:#fff9;background:#ffffff12;border:1px solid #ffffff1f;border-radius:100px;padding:7px 20px;font-size:.82rem;display:inline-block}.pr-current-badge strong{color:#d9772f}.pr-cards-outer{justify-content:center;margin-top:-110px;padding:0 clamp(12px,3vw,36px) 24px;display:flex}.pr-cards{align-items:flex-start;gap:16px;width:100%;max-width:780px;display:flex}.pr-cards-3{max-width:1040px}.pr-card{background:#fff;border:1.5px solid #0a112812;border-radius:18px;flex-direction:column;flex:1;gap:0;padding:24px 22px 20px;display:flex;position:relative;box-shadow:0 8px 32px #0a11281a}.pr-card-featured{background:#0c1628;border:1.5px solid #d9772f38;margin-top:-16px;box-shadow:0 12px 40px #0a112847,0 0 0 1px #d9772f1a}.pr-card-team{border:1.5px solid #d9772f;box-shadow:0 8px 32px #d9772f1a}.pr-card-team .pr-price-currency,.pr-card-team .pr-price-amount{color:#d9772f}.pr-phone-label-ink{color:#6b7280;font-size:.75rem;font-weight:500}.pr-phone-row-ink{border:1.5px solid var(--line);background:#f0ebe1;border-radius:10px;align-items:center;transition:border-color .12s;display:flex;overflow:hidden}.pr-phone-row-ink:focus-within{border-color:#d9772f}.pr-phone-prefix-ink{color:#6b7280;border-right:1px solid var(--line);white-space:nowrap;padding:0 10px;font-size:.875rem;font-weight:600;line-height:44px}.pr-phone-input-ink{height:44px;font-size:.9rem;font-family:var(--font-mono);color:#0a1128;letter-spacing:.05em;background:0 0;border:none;outline:none;flex:1;padding:0 12px}.pr-phone-input-ink::placeholder{color:#6b7280;font-family:var(--font-body);letter-spacing:0;opacity:.6}.pr-phone-back-ink{color:#6b7280;font-size:.78rem;font-family:var(--font-body);cursor:pointer;text-align:left;background:0 0;border:none;padding:4px 0;transition:color .12s}.pr-phone-back-ink:hover{color:#0a1128}.pr-btn-cancel-ink{text-align:center;color:#6b7280;border:1px solid var(--line);width:100%;font-family:var(--font-body);cursor:pointer;box-sizing:border-box;background:0 0;border-radius:12px;padding:10px 24px;font-size:.78rem;font-weight:500;transition:color .12s,border-color .12s;display:block}.pr-btn-cancel-ink:hover{color:var(--danger);border-color:#c5303059}.pr-featured-badge{color:#fff;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;background:#d9772f;border-radius:100px;padding:5px 16px;font-size:.64rem;font-weight:800;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.pr-card-head{margin-bottom:14px}.pr-plan-label{text-transform:uppercase;letter-spacing:.1em;color:#6b7280;margin-bottom:4px;font-size:.68rem;font-weight:700;display:block}.pr-card-featured .pr-plan-label{color:#ffffff73}.pr-price-row{align-items:baseline;gap:2px;margin-bottom:4px;display:flex}.pr-price-currency{color:#0a1128;margin-right:1px;font-size:1rem;font-weight:800}.pr-card-featured .pr-price-currency{color:#fff}.pr-price-amount{color:#0a1128;font-size:2rem;font-weight:800;line-height:1}.pr-card-featured .pr-price-amount{color:#fff}.pr-price-period{color:#6b7280;margin-left:3px;font-size:.78rem;font-weight:400}.pr-card-featured .pr-price-period{color:#fff6}.pr-plan-desc{color:#6b7280;margin:0;font-size:.75rem;line-height:1.35}.pr-card-featured .pr-plan-desc{color:#ffffff6b}.pr-feats{flex-direction:column;flex:1;gap:7px;margin:0 0 16px;padding:0;list-style:none;display:flex}.pr-feats li{color:#0a1128;align-items:center;gap:8px;font-size:.78rem;font-weight:500;display:flex}.pr-feats li svg{flex-shrink:0;width:13px;height:13px}.pr-feats li.on svg{color:#22c55e}.pr-feats li.off{color:#4a5568;opacity:1}.pr-feats li.off svg{color:#9ca3af}.pr-card-featured .pr-feats li{color:#ffffffd9}.pr-card-featured .pr-feats li.on svg{color:#d9772f}.pr-card-featured .pr-feats li.off{color:#ffffff8c;opacity:1}.pr-card-featured .pr-feats li.off svg{color:#ffffff4d}.pr-card-foot{flex-direction:column;gap:8px;margin-top:auto;display:flex}.pr-card-foot form{margin:0}.pr-btn-primary{text-align:center;color:#fff;width:100%;font-family:var(--font-body);cursor:pointer;box-sizing:border-box;background:#d9772f;border:none;border-radius:12px;padding:14px 24px;font-size:.9rem;font-weight:700;text-decoration:none;transition:background .12s,transform .12s;display:block}.pr-btn-primary:hover{color:#fff;background:#c46a28;transform:translateY(-1px)}.pr-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.pr-btn-secondary{text-align:center;color:#0a1128;border:1.5px solid var(--line);width:100%;font-family:var(--font-body);cursor:pointer;box-sizing:border-box;background:0 0;border-radius:12px;padding:14px 24px;font-size:.9rem;font-weight:600;text-decoration:none;transition:border-color .12s,background .12s;display:block}.pr-btn-secondary:hover{color:#0a1128;background:#f0ebe1;border-color:#0a1128}.pr-btn-current{text-align:center;color:#15803d;box-sizing:border-box;background:#22c55e14;border:1.5px solid #22c55e47;border-radius:12px;width:100%;padding:14px 24px;font-size:.875rem;font-weight:700;display:block}.pr-btn-current-dark{color:#4ade80;background:#22c55e1f;border-color:#22c55e38}.pr-btn-muted{text-align:center;color:#6b7280;border:1.5px solid var(--line);box-sizing:border-box;background:#f0ebe1;border-radius:12px;width:100%;padding:14px 24px;font-size:.875rem;font-weight:600;display:block}.pr-btn-cancel{text-align:center;color:#fff6;width:100%;font-family:var(--font-body);cursor:pointer;box-sizing:border-box;background:0 0;border:1px solid #ffffff1f;border-radius:12px;padding:10px 24px;font-size:.78rem;font-weight:500;transition:color .12s,border-color .12s;display:block}.pr-btn-cancel:hover{color:#fca5a5;border-color:#ef444466}.pr-phone-step{flex-direction:column;gap:8px}.pr-phone-label{color:#ffffff73;font-size:.75rem;font-weight:500}.pr-phone-row{background:#ffffff12;border:1.5px solid #ffffff24;border-radius:10px;align-items:center;transition:border-color .12s;display:flex;overflow:hidden}.pr-phone-row:focus-within{border-color:#d9772f}.pr-phone-prefix{color:#ffffff8c;white-space:nowrap;border-right:1px solid #ffffff1a;padding:0 10px;font-size:.875rem;font-weight:600;line-height:44px}.pr-phone-input{height:44px;font-size:.9rem;font-family:var(--font-mono);color:#fff;letter-spacing:.05em;background:0 0;border:none;outline:none;flex:1;padding:0 12px}.pr-phone-input::placeholder{color:#ffffff40;font-family:var(--font-body);letter-spacing:0}.pr-phone-input-error+.pr-phone-input{border-color:#ef4444}.pr-phone-row:has(.pr-phone-input-error){border-color:#ef4444}.pr-phone-input.pr-phone-input-error{color:#fca5a5}.pr-phone-back{color:#ffffff59;font-size:.78rem;font-family:var(--font-body);cursor:pointer;text-align:left;background:0 0;border:none;padding:4px 0;transition:color .12s}.pr-phone-back:hover{color:#ffffffa6}.pr-trust{color:#6b7280;text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;padding:8px 24px 16px;font-size:.75rem;display:flex}.pr-trust svg{vertical-align:middle;opacity:.45;margin-right:3px}.pr-trust strong{color:#0a1128;font-weight:600}.pr-trust-dot{opacity:.35}.pr-contact{text-align:center;color:#888;font-size:.75rem;font-family:var(--font-body);padding:4px 20px 16px}.pr-contact a{color:#888;text-decoration:underline}.pr-contact a:hover{color:#d9772f}@media (width<=720px){.pr-body{overflow-x:hidden}.pr-nav{height:56px;padding:0 20px}.pr-hero{text-align:center;padding:44px 20px 80px}.pr-headline{font-size:clamp(2rem,8vw,2.8rem)}.pr-subtitle{font-size:.9rem}.pr-cards-outer{margin-top:-56px;padding:0 16px 48px}.pr-cards{flex-direction:column;gap:16px;max-width:100%}.pr-card{padding:28px 22px 22px}.pr-card-featured{margin-top:0}.pr-featured-badge{padding:4px 14px;font-size:.6rem}.pr-price-amount{font-size:2.2rem}.pr-btn-primary,.pr-btn-secondary,.pr-btn-current,.pr-btn-muted{padding:13px 20px;font-size:.875rem}.pr-phone-row{border-radius:10px}.pr-phone-input{height:46px;font-size:1rem}.pr-trust{flex-direction:column;gap:4px;padding:0 20px 40px;font-size:.76rem}.pr-trust-dot{display:none}}.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:#d9772f}.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);color:#d9772f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;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:#0a1128;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:#f0ebe1}.avatar-upload-hint{color:#6b7280;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);color:#6b7280;cursor:pointer;background:#f0ebe1;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;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:#6b7280;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);cursor:pointer;-webkit-user-select:none;user-select:none;background:#f0ebe1;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){background:rgba(var(--primary-rgb), .1);color:#d9772f;border-color:#d9772f}.ai-checks input{display:none}.ai-option-hint{color:#6b7280;margin:0;font-size:.78rem}.ai-lang-badge{background:rgba(var(--primary-rgb), .12);color:#d9772f;letter-spacing:.02em;vertical-align:1px;border-radius:5px;margin-left:5px;padding:1px 7px;font-size:.72rem;font-weight:700;display:inline-block}.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:#d9772f;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:#6b7280;margin:0;font-size:.88rem}.ai-result-preview{border:1px solid var(--line);font-family:var(--font-mono);color:#6b7280;white-space:pre-wrap;word-break:break-word;background:#f0ebe1;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:#6b7280;margin:0;font-size:.78rem}.ai-result-actions{flex-wrap:wrap;gap:10px;display:flex}.song-form-hint{color:#6b7280;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{color:#2a7a8c;cursor:pointer;background:#2a7a8c1a;border:1px solid #2a7a8c40;border-radius:20px;padding:2px 10px;font-size:.72rem;transition:background .15s}.tag-preset-chip:hover{background:#2a7a8c38}.tag-preset-chip.active{color:#fff;background:#2a7a8c;border-color:#2a7a8c}.song-card-tag{color:#2a7a8c;letter-spacing:.02em;background:#2a7a8c1a;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{color:#6b7280;cursor:pointer;background:#f0ebe1;border:1px solid #e2d8c9;border-radius:20px;padding:4px 14px;font-size:.78rem;font-weight:500;transition:all .15s}.tag-filter-chip:hover{color:#2a7a8c;border-color:#2a7a8c}.tag-filter-chip.active{color:var(--primary);background:#2a7a8c1f;border-color:#2a7a8c;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}.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:#6b7280;flex-shrink:0;font-size:.75rem}.key-flow-label{border-radius:20px;padding:2px 10px;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:600}.key-flow-same .key-flow-label{color:#2d7a5d;background:#2d7a5d26}.key-flow-easy .key-flow-label{color:#2d7a5d;opacity:.8;background:#2d7a5d1a}.key-flow-medium .key-flow-label{color:#e6973a;background:#e68a2e1f}.key-flow-hard .key-flow-label{color:#c53030;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}.sort-bar{align-items:center;gap:4px;display:flex}.sort-chip{border:1px solid var(--line);color:var(--muted);white-space:nowrap;border-radius:20px;padding:5px 12px;font-size:.78rem;font-weight:600;text-decoration:none;transition:background .12s,color .12s,border-color .12s}.sort-chip:hover{background:var(--surface-el);color:var(--ink)}.sort-chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}.live-order-notes{width:100%;font-size:.76rem;font-family:var(--font-body);color:var(--ink);background:var(--surface-el);border:1px solid var(--line);resize:none;box-sizing:border-box;border-radius:6px;min-height:32px;margin-top:5px;padding:5px 8px;transition:border-color .15s;display:block}.live-order-notes:focus{border-color:var(--primary);outline:none}.live-order-notes::placeholder{color:var(--muted);opacity:.6}.set-position-notes{color:var(--primary);margin-top:2px;font-style:italic;display:block}.perf-position-notes{color:var(--primary);opacity:.9;margin:4px 0 0;font-size:.82rem;font-style:italic}.song-note-wrap{align-items:flex-start;gap:6px;width:100%;margin-top:8px;display:flex}.song-note-input{color:#1c2b3a;resize:vertical;background:#f0ebe1;border:1px solid #e2d8c9;border-radius:6px;flex:1;min-height:38px;padding:6px 10px;font-family:Outfit,sans-serif;font-size:.82rem;line-height:1.4;transition:border-color .15s}.song-note-input:focus{border-color:#2a7a8c;outline:none}.song-note-input::placeholder{color:#6b7280;opacity:.7}.song-note-saved{color:#2a7a8c;white-space:nowrap;opacity:0;padding-top:10px;font-size:.72rem;transition:opacity .2s}.song-note-saved.song-note-saved-visible{opacity:1}.perf-personal-note{color:var(--muted);border-left:2px solid var(--primary);white-space:pre-wrap;background:#ffffff0d;border-radius:0 4px 4px 0;margin:6px 0 0;padding:6px 10px;font-size:.8rem;font-style:italic;line-height:1.45}.notice-danger,.notice-success{border-left:4px solid;border-radius:10px;align-items:center;gap:10px;max-width:1180px;margin:20px auto 0;padding:13px 16px;font-size:.88rem;font-weight:500;line-height:1.5;animation:.25s noticeSlideIn;display:flex;position:relative}@keyframes noticeSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notice-icon{color:#fff;background:currentColor;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.9rem;font-weight:700;display:flex}.notice-success .notice-icon{background:var(--success);color:#fff}.notice-danger .notice-icon{background:var(--danger);color:#fff}.notice-text{flex:1}.notice-close{color:currentColor;cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:1.1rem;line-height:1;transition:opacity .15s}.notice-close:hover{opacity:1}.profile-hero{border-bottom:1px solid var(--line);align-items:center;gap:28px;margin-bottom:32px;padding:32px 0 36px;display:flex}.profile-hero-avatar-wrap{flex-shrink:0}.profile-hero-avatar{object-fit:cover;border-radius:50%;width:90px;height:90px;display:block}.profile-hero-avatar-init{background:var(--primary);color:#fff;width:90px;height:90px;font-size:2.2rem;font-weight:700;font-family:var(--font-display);border-radius:50%;justify-content:center;align-items:center;display:flex}.profile-hero-info{flex:1;min-width:0}.profile-hero-name{font-family:var(--font-display);color:var(--ink);margin:0 0 6px;font-size:clamp(1.5rem,4vw,2.4rem);font-weight:700;line-height:1.15}.profile-hero-meta-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.profile-hero-instrument{color:var(--primary);background:rgba(var(--primary-rgb), .1);border:1px solid rgba(var(--primary-rgb), .2);border-radius:20px;padding:3px 11px;font-size:.8rem;font-weight:600}.profile-hero-location{color:var(--muted);align-items:center;gap:4px;font-size:.8rem;display:flex}.profile-hero-location svg{opacity:.6;flex-shrink:0}.profile-hero-bio{color:var(--muted);max-width:480px;margin:0 0 12px;font-size:.88rem;line-height:1.6}.profile-hero-stats{color:var(--muted);flex-wrap:wrap;align-items:center;gap:20px;font-size:.84rem;display:flex}.profile-hero-stats strong{color:var(--ink);font-weight:700}.profile-hero-action{flex-shrink:0;margin-left:auto}@media (width<=560px){.profile-hero{flex-direction:column;align-items:flex-start;gap:16px;padding:24px 0 28px}.profile-hero-name{font-size:1.55rem}.profile-hero-action{margin-left:0}}.pub-card-by-link{color:inherit;text-decoration:none;transition:color .15s}.pub-card-by-link:hover{color:var(--primary)}.import-textarea{width:100%;font-family:var(--font-mono);color:var(--ink);background:var(--bg);border:1px solid var(--line);resize:vertical;box-sizing:border-box;border-radius:10px;padding:12px 14px;font-size:.82rem;line-height:1.6;transition:border-color .15s}.import-textarea:focus{border-color:var(--primary);outline:none}.modal-desc{color:var(--muted);margin:0 0 14px;font-size:.84rem;line-height:1.6}.modal-desc code{font-family:var(--font-mono);background:var(--surface-el);color:var(--primary);border-radius:4px;padding:1px 5px;font-size:.78rem}.profile-stat-link{color:var(--muted);border-bottom:1px solid #0000;align-items:baseline;gap:4px;padding-bottom:2px;font-size:.85rem;text-decoration:none;transition:color .15s;display:inline-flex}.profile-stat-link:hover,.profile-stat-link.active{color:var(--ink);border-bottom-color:var(--ink)}.profile-stat-link strong{color:var(--ink);font-size:.95rem;font-weight:700}.profile-tabs{border-bottom:1px solid var(--line);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0;margin-bottom:28px;display:flex;overflow-x:auto}.profile-tabs::-webkit-scrollbar{display:none}.profile-tab{color:var(--muted);white-space:nowrap;border-bottom:2px solid #0000;flex-shrink:0;align-items:center;gap:7px;margin-bottom:-1px;padding:10px 18px;font-size:.86rem;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s;display:flex}.profile-tab:hover{color:var(--ink)}.profile-tab.active{color:var(--ink);border-bottom-color:var(--primary)}.profile-tab-count{background:var(--surface-el);color:var(--muted);border-radius:20px;padding:1px 7px;font-size:.72rem;font-weight:700;line-height:1.6}.profile-tab.active .profile-tab-count{background:rgba(var(--primary-rgb),.12);color:var(--primary)}.profile-people-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.person-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;transition:box-shadow .15s,border-color .15s;display:flex}.person-card:hover{border-color:var(--primary);box-shadow:0 2px 12px #0000000f}.person-card-link{flex:1;align-items:center;gap:12px;min-width:0;text-decoration:none;display:flex}.person-card-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:44px;height:44px}.person-card-avatar-init{background:var(--primary);color:#fff;width:44px;height:44px;font-size:1.1rem;font-weight:700;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.person-card-info{flex-direction:column;gap:2px;min-width:0;display:flex}.person-card-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;display:block;overflow:hidden}.person-card-instrument{color:var(--muted);font-size:.75rem}.chord-popup{z-index:300;text-align:center;pointer-events:auto;-webkit-user-select:none;user-select:none;background:#0c1628;border:1px solid #ffffff24;border-radius:14px;min-width:260px;max-width:280px;padding:12px 14px 14px;animation:.12s popup-in;position:absolute;box-shadow:0 12px 40px #0000008c}@keyframes popup-in{0%{opacity:0;transform:translateY(4px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.chord-popup-name{font-family:var(--font-mono);letter-spacing:.06em;color:var(--primary);text-transform:uppercase;margin-bottom:6px;font-size:.78rem;font-weight:600}.chord-popup svg{fill:#ffffffe6;stroke:#ffffffe6;margin:0 auto;display:block}.chord-popup-notes{font-family:var(--font-mono);color:#ffffffd9;justify-content:center;align-items:center;gap:3px;margin-top:8px;font-size:.8rem;font-weight:700;display:flex}.cpn{letter-spacing:.04em}.cpn-sep{color:#ffffff40;font-size:.6rem}.chord-popup-instr{text-transform:uppercase;letter-spacing:.12em;color:#ffffff4d;text-align:center;margin-top:6px;font-size:.62rem;font-weight:600}.chord-popup-why{color:#ffffff4d;text-align:center;border-top:1px solid #ffffff14;max-width:180px;margin-top:9px;padding-top:8px;font-size:.71rem;font-style:italic;line-height:1.45;animation:1.2s ease-in-out infinite cpw-pulse}.chord-popup-why.loaded{color:#ffffff9e;font-style:italic;animation:none}@keyframes cpw-pulse{0%,to{opacity:.4}50%{opacity:.9}}.cp-tabs{background:#ffffff0f;border-radius:8px;gap:2px;margin-bottom:10px;padding:3px;display:flex}.cp-tab{font-size:.72rem;font-weight:700;font-family:var(--font-body);letter-spacing:.04em;color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:5px 10px;transition:background .15s,color .15s}.cp-tab.active{color:#ffffffe6;background:#ffffff1f}.cp-lead-title{font-family:var(--font-mono);color:var(--primary);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:8px;margin-bottom:10px;font-size:.8rem;font-weight:700;display:flex}.cp-lead-scale-label{color:#ffffff59;text-transform:uppercase;letter-spacing:.08em;font-size:.62rem}.cp-scale-types{flex-wrap:wrap;gap:4px;margin-bottom:10px;display:flex}.cp-scale-btn{font-size:.65rem;font-weight:600;font-family:var(--font-body);color:#ffffff73;cursor:pointer;background:0 0;border:1px solid #ffffff24;border-radius:20px;padding:3px 8px;transition:border-color .12s,color .12s,background .12s}.cp-scale-btn:hover{color:#d9772fcc;border-color:#d9772f80}.cp-scale-btn.active{border-color:var(--primary);color:var(--primary);background:#d9772f26}.cp-scale-notes{font-family:var(--font-mono);flex-wrap:wrap;align-items:center;gap:3px;margin-bottom:10px;font-size:.78rem;font-weight:700;display:flex}.cp-scale-note{color:#ffffffb3}.cp-scale-note.root{color:var(--primary)}.cp-scale-diagram{margin-bottom:12px;overflow:hidden}.cp-scale-diagram svg{max-width:100%;display:block}.cp-intro-btn{width:100%;font-size:.72rem;font-weight:700;font-family:var(--font-body);color:var(--primary);cursor:pointer;background:#d9772f14;border:1px solid #d9772f66;border-radius:8px;margin-bottom:8px;padding:7px 12px;transition:background .15s,border-color .15s;display:block}.cp-intro-btn:hover:not(:disabled){border-color:var(--primary);background:#d9772f2e}.cp-intro-btn:disabled{opacity:.5;cursor:default}.cp-intro-loading{color:#ffffff59;text-align:center;padding:4px 0;font-size:.7rem;font-style:italic}.cp-intro-empty{color:#ffffff4d;text-align:center;margin:4px 0;font-size:.7rem}.cp-intro-ideas{flex-direction:column;gap:6px;display:flex}.cp-intro-idea{background:#ffffff0d;border-radius:7px;padding:7px 10px}.cp-intro-phrase{font-family:var(--font-mono);color:#ffffffe0;letter-spacing:.06em;margin-bottom:2px;font-size:.78rem;font-weight:700}.cp-intro-feel{color:#ffffff61;font-size:.65rem;font-style:italic}.lyrics-mode .chord,.lyrics-mode .chord-ph,.lyrics-mode .chord-only-line,.lyrics-mode .measure-sep,.lyrics-mode .measure{display:none}.perf-lyr-btn{color:#fff9;height:28px;font-family:var(--font-mono);letter-spacing:.04em;cursor:pointer;background:#ffffff12;border:1px solid #ffffff1f;border-radius:7px;flex-shrink:0;padding:0 9px;font-size:.72rem;font-weight:600;transition:background .12s,color .12s,border-color .12s}.perf-lyr-btn:hover{color:#fff;background:#ffffff21}.perf-lyr-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.perf-view-toggle{background:#ffffff12;border:1px solid #ffffff1f;border-radius:8px;flex-shrink:0;display:flex;overflow:hidden}.perf-view-btn{color:#ffffff80;height:28px;font-size:.75rem;font-weight:600;font-family:var(--font-body);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0 12px;transition:background .12s,color .12s}.perf-view-btn:hover{color:#ffffffd9}.lyrics-mode .chart-lines{gap:2px}.lyrics-mode .cl-lyric{font-size:1.05em}.section-jump-nav{scrollbar-width:none;background:#0c162899;border-bottom:1px solid #ffffff0f;gap:6px;padding:8px 16px;display:flex;overflow-x:auto}.section-jump-nav::-webkit-scrollbar{display:none}.section-jump-chip{color:#ffffff8c;cursor:pointer;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:20px;flex-shrink:0;padding:4px 11px;font-size:.72rem;font-weight:500;transition:background .12s,color .12s,border-color .12s}.section-jump-chip:hover{color:#fff;background:#ffffff1f}.presence-bubbles{align-items:center;gap:-6px;display:flex}.presence-bubble{border:2px solid var(--surface);background:var(--primary);color:#fff;text-transform:uppercase;cursor:default;z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-left:-6px;font-size:.65rem;font-weight:700;transition:transform .15s;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 4px #0003}.presence-bubble:first-child{margin-left:0}.presence-bubble:hover{z-index:2;transform:scale(1.15)}.presence-bubble img{object-fit:cover;width:100%;height:100%}.presence-bubbles-sm .presence-bubble{border-color:#0c1628;width:24px;height:24px;font-size:.58rem}.set-comments-heading{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-size:.85rem;font-weight:600}.set-comment-form{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.set-comment-input{color:#1c2b3a;resize:vertical;background:#f0ebe1;border:1px solid #e2d8c9;border-radius:10px;width:100%;padding:10px 12px;font-family:Outfit,sans-serif;font-size:.9rem;transition:border-color .15s}.set-comment-input:focus{border-color:#2a7a8c;outline:none}.set-comment{border-bottom:1px solid #e2d8c9;gap:10px;padding:12px 0;display:flex}.set-comment-avatar{color:#fff;background:#2a7a8c;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.7rem;font-weight:700;display:flex;overflow:hidden}.set-comment-avatar img{object-fit:cover;width:100%;height:100%}.set-comment-body{flex:1;min-width:0}.set-comment-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.set-comment-meta strong{color:#1c2b3a;font-size:.85rem}.set-comment-meta time{color:#6b7280;font-size:.78rem}.set-comment-delete{color:#6b7280;cursor:pointer;opacity:.5;background:0 0;border:none;padding:0 4px;font-size:.75rem;transition:opacity .12s}.set-comment-delete:hover{opacity:1}.set-comment-text{color:#1c2b3a;font-size:.88rem;line-height:1.5}.set-comment-empty{color:#6b7280;font-size:.85rem;font-style:italic}.gs-backdrop{z-index:400;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a1128b3;justify-content:center;align-items:flex-start;padding-top:12vh;animation:.12s gs-fade-in;display:flex;position:fixed;inset:0}@keyframes gs-fade-in{0%{opacity:0}to{opacity:1}}.gs-modal{background:var(--surface);border:1px solid var(--line);border-radius:16px;width:min(640px,100vw - 32px);animation:.14s gs-slide-in;overflow:hidden;box-shadow:0 24px 80px #0000004d}@keyframes gs-slide-in{0%{opacity:0;transform:translateY(-8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.gs-input-wrap{border-bottom:1px solid var(--line);align-items:center;gap:10px;padding:14px 16px;display:flex}.gs-icon{width:18px;height:18px;color:var(--muted);flex-shrink:0}.gs-input{font-family:var(--font-body);color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-size:1rem}.gs-input::placeholder{color:var(--muted)}.gs-esc{font-family:var(--font-mono);color:var(--muted);background:var(--surface-el);border:1px solid var(--line);border-radius:5px;flex-shrink:0;padding:2px 6px;font-size:.68rem}.gs-results{max-height:60vh;overflow-y:auto}.gs-empty{text-align:center;color:var(--muted);padding:28px;font-size:.88rem}.gs-group-heading{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:10px 16px 4px;font-size:.7rem;font-weight:700}.gs-result{cursor:pointer;color:inherit;align-items:center;gap:10px;padding:10px 16px;text-decoration:none;transition:background .1s;display:flex}.gs-result:hover,.gs-result.focused{background:var(--surface-el)}.gs-result-icon{background:var(--surface-el);width:30px;height:30px;color:var(--primary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;display:flex}.gs-result-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.9rem;font-weight:500;overflow:hidden}.gs-result-sub{color:var(--muted);margin-top:1px;font-size:.78rem}.gs-result-badge{font-family:var(--font-mono);color:var(--primary);background:#d9772f1a;border-radius:5px;flex-shrink:0;padding:2px 6px;font-size:.7rem;font-weight:600}@keyframes slide-out-left{to{opacity:0;transform:translate(-40px)}}@keyframes slide-out-right{to{opacity:0;transform:translate(40px)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(40px)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(-40px)}}.swipe-left{animation:.18s forwards slide-out-left}.swipe-right{animation:.18s forwards slide-out-right}.swipe-in-left{animation:.18s slide-in-left}.swipe-in-right{animation:.18s slide-in-right}.prof-edit-preview{background:var(--surface);border:1px solid var(--line);border-radius:16px;align-items:center;gap:18px;margin-bottom:24px;padding:20px 24px;display:flex;position:relative}.prof-edit-preview-avatar{background:var(--primary);color:#fff;border:3px solid var(--surface);width:64px;height:64px;box-shadow:0 0 0 2px var(--line);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex;overflow:hidden}.prof-edit-preview-avatar img{object-fit:cover;width:100%;height:100%}.prof-edit-preview-info{flex:1;min-width:0}.prof-edit-preview-name{font-family:var(--font-display);color:var(--ink);margin:0 0 4px;font-size:1.4rem;font-weight:700;line-height:1.2}.prof-edit-preview-inst{color:var(--primary);background:#d9772f1a;border-radius:6px;margin-bottom:8px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.prof-edit-preview-stats{color:var(--muted);align-items:center;gap:6px;font-size:.8rem;display:flex}.prof-edit-stat-sep{opacity:.4}.prof-edit-view-link{color:var(--primary);white-space:nowrap;border:1px solid #d9772f59;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:.8rem;font-weight:600;text-decoration:none;transition:background .12s;display:flex}.prof-edit-view-link:hover{background:#d9772f12}.prof-edit-section{background:var(--surface);border:1px solid var(--line);border-radius:14px;margin-bottom:16px;padding:20px 24px}.prof-edit-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 16px;font-size:.75rem;font-weight:700}.prof-edit-fields{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=560px){.prof-edit-fields{grid-template-columns:1fr}}.prof-edit-field{flex-direction:column;gap:6px;display:flex}.prof-edit-label{color:var(--ink);align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:flex}.prof-edit-optional{color:var(--muted);font-size:.72rem;font-weight:400}.prof-edit-charcount{color:var(--muted);font-size:.72rem;font-weight:400;font-family:var(--font-mono);margin-left:auto}.prof-edit-input{background:var(--surface-el);border:1px solid var(--line);width:100%;font-family:var(--font-body);color:var(--ink);border-radius:10px;padding:10px 13px;font-size:.92rem;transition:border-color .15s,box-shadow .15s}.prof-edit-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #d9772f1f}.prof-edit-textarea{resize:vertical;min-height:80px;line-height:1.55}.prof-edit-actions{align-items:center;gap:12px;margin-bottom:8px;display:flex}@media (width<=480px){.prof-edit-preview{flex-wrap:wrap}.prof-edit-view-link{justify-content:center;width:100%}.prof-edit-section{padding:16px}}.activity-feed{flex-direction:column;max-width:600px;padding:8px 0;display:flex}.activity-item{gap:0;display:flex}.activity-item-spine{flex-direction:column;flex-shrink:0;align-items:center;width:32px;display:flex}.activity-item-dot{background:var(--primary);border:2px solid var(--surface);width:10px;height:10px;box-shadow:0 0 0 2px var(--primary);z-index:1;border-radius:50%;flex-shrink:0;margin-top:14px}.activity-item--joined .activity-item-dot{background:var(--muted);box-shadow:0 0 0 2px var(--muted)}.activity-item-line{background:var(--line);flex:1;width:2px;min-height:20px;margin-top:4px}.activity-item:last-child .activity-item-line{display:none}.activity-item-body{flex:1;align-items:flex-start;gap:12px;padding:8px 0 20px 12px;display:flex}.activity-item-icon{background:rgba(var(--primary-rgb), .1);width:34px;height:34px;color:var(--primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:1rem;display:flex}.activity-item-icon--join{background:var(--surface-el);color:var(--muted)}.activity-item-content{flex:1;min-width:0}.activity-item-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0 0 3px;font-size:.75rem;font-weight:600}.activity-item-title{color:var(--ink);margin-bottom:6px;font-size:.95rem;font-weight:600;line-height:1.3;text-decoration:none;transition:color .12s;display:block}a.activity-item-title:hover{color:var(--primary)}.activity-item-artist{color:var(--muted);font-size:.88rem;font-weight:400}.activity-item-badges{flex-wrap:wrap;gap:6px;display:flex}.activity-key-badge{font-family:var(--font-mono);color:var(--primary);background:rgba(var(--primary-rgb), .1);border-radius:5px;padding:2px 7px;font-size:.7rem;font-weight:700}.activity-item-time{color:var(--muted);white-space:nowrap;flex-shrink:0;margin-top:4px;font-size:.75rem}.onboard-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px;overflow:hidden}.onboard-card-head{border-bottom:1px solid var(--line);background:linear-gradient(135deg, rgba(var(--primary-rgb),.05) 0%, transparent 60%);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;padding:22px 24px 18px;display:flex}.onboard-card-title-wrap{align-items:flex-start;gap:14px;display:flex}.onboard-icon{flex-shrink:0;margin-top:2px;font-size:1.6rem;line-height:1}.onboard-title{font-family:var(--font-display);color:var(--ink);margin:0 0 3px;font-size:1.25rem;font-weight:700;line-height:1.2}.onboard-subtitle{color:var(--muted);margin:0;font-size:.85rem}.onboard-progress-wrap{flex-shrink:0;align-items:center;gap:10px;display:flex}.onboard-progress-label{font-family:var(--font-mono);color:var(--muted);white-space:nowrap;font-size:.78rem;font-weight:600}.onboard-progress-bar{background:var(--surface-el);border-radius:99px;width:80px;height:6px;overflow:hidden}.onboard-progress-fill{background:var(--primary);border-radius:99px;height:100%;transition:width .4s}.onboard-dismiss{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:.8rem;line-height:1;transition:background .12s,color .12s}.onboard-dismiss:hover{background:var(--surface-el);color:var(--ink)}.onboard-steps{flex-direction:column;display:flex}.onboard-step{border-bottom:1px solid var(--line);align-items:center;gap:14px;padding:14px 24px;transition:background .12s;display:flex}.onboard-step:last-child{border-bottom:none}.onboard-step:hover{background:var(--surface-el)}.onboard-step.done{opacity:.55}.onboard-step-check{border:2px solid var(--line);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:background .15s,border-color .15s;display:flex}.onboard-step-check svg{color:#fff;width:12px;height:12px;display:none}.onboard-step.done .onboard-step-check{background:var(--primary);border-color:var(--primary)}.onboard-step.done .onboard-step-check svg{display:block}.onboard-step-body{flex:1;min-width:0}.onboard-step-title{color:var(--ink);margin:0 0 2px;font-size:.9rem;font-weight:600}.onboard-step-desc{color:var(--muted);margin:0;font-size:.8rem;line-height:1.4}.onboard-step-done-tag{color:var(--primary);background:rgba(var(--primary-rgb), .1);border-radius:6px;flex-shrink:0;padding:3px 9px;font-size:.72rem;font-weight:600}@media (width<=560px){.onboard-card-head{flex-direction:column}.onboard-step{padding:12px 16px}.onboard-step-desc{display:none}}.parts-section{border-top:1px dashed #e2d8c9;margin-top:8px;padding-top:8px}.parts-list{flex-direction:column;gap:5px;display:flex}.part-row{flex-direction:column;gap:4px;display:flex}.part-row-top{align-items:center;gap:6px;display:flex}.part-note{color:#1c2b3a;font-size:.76rem;font-family:var(--font-body);resize:none;box-sizing:border-box;background:#f7f5f1;border:1px solid #e2d8c9;border-radius:6px;outline:none;width:100%;padding:5px 8px;line-height:1.4}.part-note::placeholder{color:#9ca3af;font-style:italic}.part-note:focus{border-color:#2a7a8c}.part-instrument,.part-name{color:#1c2b3a;font-size:.78rem;font-family:var(--font-body);background:#f7f5f1;border:1px solid #e2d8c9;border-radius:6px;outline:none;padding:4px 8px}.part-instrument{flex-shrink:0;width:130px}.part-name{flex:1;min-width:0}.part-instrument:focus,.part-name:focus{border-color:#2a7a8c}.part-remove-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:2px 4px;font-size:1rem;line-height:1;transition:color .15s}.part-add-btn{color:#2a7a8c;cursor:pointer;background:0 0;border:1px dashed #2a7a8c;border-radius:6px;margin-top:5px;padding:3px 10px;font-size:.72rem;font-weight:600;transition:background .15s}.parts-badges{flex-wrap:wrap;gap:5px;margin-top:5px;display:flex}.parts-cues-list{flex-direction:column;gap:5px;display:flex}.parts-cue-row{flex-wrap:wrap;align-items:baseline;gap:6px;display:flex}.parts-cue-note{color:#6b7280;font-size:.76rem;font-style:italic;line-height:1.4}.parts-cue-edit-wrap{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.parts-cue-note-edit{min-width:0;font-size:.76rem;font-family:var(--font-body);color:#374151;resize:none;background:#fafaf8;border:1px solid #e2d8c9;border-radius:6px;outline:none;flex:1;padding:4px 8px;line-height:1.4;transition:border-color .14s}.parts-cue-note-edit::placeholder{color:#b0a89c;font-style:italic}.parts-cue-note-edit:focus{background:#fff;border-color:#2a7a8c}.parts-cue-saved{color:#2a7a8c;white-space:nowrap;opacity:0;flex-shrink:0;font-size:.68rem;transition:opacity .2s}.parts-cue-saved.visible{opacity:1}.part-badge{color:#1c2b3a;background:#f0ebe1;border:1px solid #e2d8c9;border-radius:20px;align-items:center;gap:4px;padding:2px 10px;font-size:.72rem;font-weight:500;display:flex}.part-badge-instrument{color:#2a7a8c;font-weight:600}.perf-parts{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.perf-part-badge{color:#ffffffbf;background:#ffffff12;border:1px solid #ffffff26;border-radius:20px;padding:2px 10px;font-size:.7rem;font-weight:500}.perf-part-badge strong{color:var(--primary);font-weight:600}.ws-toasts{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;top:20px;right:20px}.ws-toast{font-size:.875rem;font-weight:500;font-family:var(--font-body);pointer-events:all;border-radius:10px;align-items:center;gap:10px;min-width:220px;max-width:360px;padding:13px 16px;transition:transform .35s cubic-bezier(.34,1.3,.64,1);display:flex;transform:translate(calc(100% + 24px));box-shadow:0 4px 24px #00000024}.ws-toast.ws-toast-visible{transform:translate(0)}.ws-toast-success{color:#bbf7d0;background:#14532d;border:1px solid #166534}.ws-toast-error{color:#fecaca;background:#450a0a;border:1px solid #991b1b}.ws-toast svg{flex-shrink:0}.ws-toast-close{cursor:pointer;color:inherit;opacity:.55;background:0 0;border:none;flex-shrink:0;margin-left:auto;padding:0 0 0 6px;font-size:1.1rem;line-height:1;transition:opacity .15s}.ws-toast-close:hover{opacity:1}.field-error{color:var(--danger,#c53030);margin-top:3px;font-size:.75rem;font-weight:500;display:block}.input-error{background:#c530300a;border-color:var(--danger,#c53030)!important}.prof-page{max-width:1000px;padding:clamp(20px,3vw,40px) clamp(16px,3vw,40px)}.prof-page-heading{justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.prof-page-title{font-family:var(--font-display);color:var(--ink);margin:0;font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;line-height:1.15}.prof-layout{grid-template-columns:240px 1fr;align-items:start;gap:24px;display:grid}@media (width<=740px){.prof-layout{grid-template-columns:1fr}}.prof-sidebar{position:sticky;top:20px}.prof-card{background:var(--surface);border:1px solid var(--line);text-align:center;border-radius:18px;flex-direction:column;align-items:center;gap:6px;padding:24px 20px;display:flex}.prof-card-avatar{background:var(--primary);color:#fff;border:3px solid var(--surface);width:88px;height:88px;box-shadow:0 0 0 2px var(--line);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-bottom:8px;font-size:2rem;font-weight:700;display:flex;overflow:hidden}.prof-card-avatar img{object-fit:cover;width:100%;height:100%}.prof-card-name{font-family:var(--font-display);color:var(--ink);margin:0;font-size:1.25rem;font-weight:700;line-height:1.2}.prof-card-inst{color:var(--primary);background:#d9772f1a;border-radius:20px;padding:2px 10px;font-size:.73rem;font-weight:600;display:inline-block}.prof-card-location{color:var(--muted);margin:2px 0 0;font-size:.78rem}.prof-card-stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);justify-content:center;align-items:center;gap:12px;width:100%;margin:10px 0 4px;padding:12px 0;display:flex}.prof-card-stat{flex-direction:column;align-items:center;gap:1px;display:flex}.prof-card-stat strong{color:var(--ink);font-size:1rem;font-weight:700}.prof-card-stat span{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.68rem}.prof-card-stat-sep{background:var(--line);width:1px;height:28px}.prof-card-email{color:var(--muted);word-break:break-all;align-items:center;gap:5px;margin-top:8px;font-size:.73rem;display:flex}.prof-card-login-method{color:var(--muted);background:var(--surface-el);border-radius:20px;align-items:center;gap:5px;margin-top:4px;padding:4px 10px;font-size:.72rem;display:flex}.prof-main{flex-direction:column;gap:16px;display:flex}.prof-panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:20px 22px}.prof-panel-title{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 16px;font-size:.72rem;font-weight:700}.prof-panel-danger{background:#c5303008;border-color:#c5303033}.settings-page{max-width:900px;padding:clamp(20px,3vw,40px) clamp(16px,3vw,40px)}.settings-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.settings-title{font-family:var(--font-display);color:var(--ink);margin:0;font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;line-height:1.15}.settings-profile-link{background:var(--surface);border:1px solid var(--line);color:var(--ink);border-radius:12px;flex-shrink:0;align-items:center;gap:10px;padding:8px 14px 8px 8px;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex}.settings-profile-link:hover{border-color:var(--primary);box-shadow:0 0 0 3px #d9772f14}.settings-profile-link-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;font-weight:700;display:flex;overflow:hidden}.settings-profile-link-avatar img{object-fit:cover;width:100%;height:100%}.settings-profile-link-info{flex-direction:column;gap:1px;display:flex}.settings-profile-link-label{letter-spacing:.07em;text-transform:uppercase;color:var(--muted);font-size:.64rem;font-weight:700}.settings-profile-link-name{color:var(--ink);font-size:.85rem;font-weight:600}.settings-tabs{border-bottom:2px solid var(--line);gap:4px;margin-bottom:20px;display:flex}.settings-tab{color:var(--muted);border-bottom:2px solid #0000;border-radius:8px 8px 0 0;margin-bottom:-2px;padding:8px 18px;font-size:.88rem;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s}.settings-tab:hover{color:var(--ink)}.settings-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.settings-panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;margin-bottom:16px;padding:20px 22px}.settings-panel-title{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 16px;font-size:.72rem;font-weight:700}.settings-panel-danger{background:#c5303008;border-color:#c5303033}.settings-account-row{background:var(--surface-el);border-radius:10px;align-items:center;gap:12px;padding:12px 14px;display:flex}.settings-account-icon{background:var(--surface);border:1px solid var(--line);width:32px;height:32px;color:var(--muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-account-info{flex-direction:column;flex:1;gap:2px;display:flex}.settings-account-info-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:.68rem;font-weight:600}.settings-account-info-value{color:var(--ink);font-size:.88rem;font-weight:500}.settings-account-badge{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0;border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:.68rem;font-weight:700}.settings-stats-row{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (width<=500px){.settings-stats-row{grid-template-columns:repeat(2,1fr)}}.settings-stat{text-align:center;background:var(--surface-el);border-radius:10px;flex-direction:column;gap:3px;padding:14px 8px;display:flex}.settings-stat strong{color:var(--ink);font-size:1.3rem;font-weight:800}.settings-stat span{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.lyr-filter-wrap{margin-bottom:24px}.lyr-search-bar{background:var(--surface);border:1.5px solid var(--line);border-radius:14px;align-items:center;gap:0;height:48px;margin-bottom:12px;padding:0 12px;transition:border-color .15s;display:flex}.lyr-search-bar:focus-within{border-color:var(--primary)}.lyr-search-inner{flex:1;align-items:center;gap:9px;min-width:0;display:flex}.lyr-search-icon{color:var(--muted);flex-shrink:0}.lyr-search-input{color:var(--ink);font-size:.9rem;font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;min-width:0}.lyr-search-input::placeholder{color:var(--muted)}.lyr-search-divider{background:var(--line);flex-shrink:0;width:1px;height:20px;margin:0 10px}.lyr-artist-select{color:var(--ink);font-family:var(--font-body);cursor:pointer;appearance:none;white-space:nowrap;text-overflow:ellipsis;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 20 20' fill='%234A5568'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E") right 4px center no-repeat;border:none;outline:none;max-width:180px;padding:0 24px 0 4px;font-size:.84rem;font-weight:500;overflow:hidden}.lyr-clear-btn{color:var(--muted);background:var(--surface-el);white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;margin-left:8px;padding:5px 10px;font-size:.78rem;font-weight:600;text-decoration:none;transition:color .12s,background .12s;display:inline-flex}.lyr-clear-btn:hover{color:var(--danger);background:#c5303012}.lyr-cat-bar{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.lyr-cat-chip{font-size:.78rem;font-weight:600;font-family:var(--font-body);border:1.5px solid var(--line);color:var(--muted);background:var(--surface);white-space:nowrap;border-radius:20px;align-items:center;padding:5px 15px;text-decoration:none;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.lyr-cat-chip:hover{border-color:var(--primary);color:var(--primary)}.lyr-cat-chip.active{border-color:var(--primary);background:rgba(var(--primary-rgb), .1);color:var(--primary)}.lyr-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:28px;display:grid}@media (width<=600px){.lyr-grid{grid-template-columns:1fr 1fr;gap:10px}}@media (width<=380px){.lyr-grid{grid-template-columns:1fr}}.lyr-card{background:var(--surface);border:1.5px solid var(--line);border-radius:16px;flex-direction:column;gap:6px;padding:18px 20px 16px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex;position:relative;overflow:hidden}.lyr-card:before{content:"";background:var(--primary);opacity:0;width:3px;transition:opacity .15s;position:absolute;inset:0 auto 0 0}.lyr-card:hover{border-color:rgba(var(--primary-rgb), .35);transform:translateY(-2px);box-shadow:0 6px 24px #0a112817}.lyr-card:hover:before{opacity:1}.lyr-card-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:2px;display:flex}.lyr-card-cat{text-transform:uppercase;letter-spacing:.1em;color:var(--primary);background:rgba(var(--primary-rgb), .09);border-radius:10px;padding:2px 8px;font-size:.65rem;font-weight:700}.lyr-card-initial{background:var(--surface-el);border:1.5px solid var(--line);width:26px;height:26px;color:var(--muted);font-size:.72rem;font-weight:800;font-family:var(--font-body);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.lyr-card-title{font-family:var(--font-display);color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1.12rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.lyr-card-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.78rem;font-weight:500;overflow:hidden}.lyrics-filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.lyrics-search-wrap{flex:1;min-width:180px}.lyrics-search-input{border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);font-size:.9rem;font-family:var(--font-body);border-radius:8px;padding:8px 12px}.lyrics-search-input:focus{border-color:var(--primary);outline:none}.lyrics-artist-select{border:1.5px solid var(--line);background:var(--surface);height:40px;color:var(--ink);font-family:var(--font-body);cursor:pointer;border-radius:10px;padding:0 32px 0 12px;font-size:.84rem;font-weight:500}.lyrics-filter-select{border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:.85rem;font-family:var(--font-body);cursor:pointer;border-radius:8px;padding:8px 12px}.lyrics-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:28px;display:grid}.lyrics-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;flex-direction:column;gap:6px;padding:16px 18px;text-decoration:none;display:flex}.lyrics-card:hover{border-color:var(--primary);box-shadow:0 4px 16px #0000000f}.lyrics-card-top{justify-content:space-between;align-items:center;gap:6px;display:flex}.lyrics-card-title{color:var(--ink);margin:0;font-size:1rem;font-weight:700;line-height:1.3}.lyrics-card-foot{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.lyrics-card-lang,.lyrics-card-cat{color:var(--muted);background:var(--surface-el);border-radius:20px;padding:2px 7px;font-size:.7rem;font-weight:600}.lyrics-pagination{justify-content:center;margin-top:24px;display:flex}.perf-font-btn{letter-spacing:-.01em;width:auto;min-width:30px;padding:0 8px;font-size:.72rem;font-weight:800}.perf-font-btn:disabled{opacity:.25;pointer-events:none}.perf-section-nav{z-index:200;scrollbar-width:none;flex-direction:column;gap:5px;max-height:80vh;padding:4px 0;display:flex;position:fixed;top:50%;right:16px;overflow-y:auto;transform:translateY(-50%)}.perf-section-nav::-webkit-scrollbar{display:none}.section-jump-chip{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;color:#ffffff47;cursor:pointer;text-align:left;background:#ffffff0a;border:1px solid #ffffff17;border-radius:20px;padding:5px 11px;font-size:.54rem;font-weight:700;transition:background .14s,color .14s,border-color .14s;display:block}.section-jump-chip:hover{color:#ffffffa6;background:#ffffff17;border-color:#ffffff2e}.section-jump-chip.active{background:rgba(var(--primary-rgb), .14);border-color:rgba(var(--primary-rgb), .38);color:var(--primary)}@media (width<=900px){.perf-section-nav{display:none!important}}.perf-body .measure-line{border-radius:8px;transition:background .2s}.perf-body .measure-line.beat-active{background:rgba(var(--primary-rgb), .08);outline:1.5px solid rgba(var(--primary-rgb), .32);outline-offset:4px}.perf-body .measure-line.beat-active .measure{color:#fff}.ws-pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;margin-top:32px;padding-bottom:8px;display:flex}.ws-page-btn{border:1.5px solid var(--line);min-width:36px;height:36px;font-size:.82rem;font-weight:600;font-family:var(--font-body);color:var(--ink);background:var(--surface);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;padding:0 10px;text-decoration:none;transition:border-color .14s,color .14s,background .14s;display:inline-flex}.ws-page-btn:hover{border-color:var(--primary);color:var(--primary)}.ws-page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.ws-page-btn.disabled{color:var(--muted);opacity:.45;cursor:default;pointer-events:none}.ws-page-btn.ws-page-dots{cursor:default;background:0 0;border-color:#0000}.lyr-results-bar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.lyr-results-count{color:var(--muted);font-size:.8rem;font-weight:600;font-family:var(--font-body)}.lyr-results-actions{align-items:center;gap:8px;display:flex}.lyr-sort-select{border:1.5px solid var(--line);background:var(--surface);height:32px;color:var(--ink);font-family:var(--font-body);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 20 20' fill='%234A5568'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:8px;outline:none;padding:0 28px 0 10px;font-size:.78rem;font-weight:600;transition:border-color .14s}.lyr-sort-select:focus{border-color:var(--primary)}.lyr-view-toggle{border:1.5px solid var(--line);border-radius:8px;display:flex;overflow:hidden}.lyr-view-btn{background:var(--surface);width:32px;height:30px;color:var(--muted);cursor:pointer;border:none;justify-content:center;align-items:center;transition:background .14s,color .14s;display:inline-flex}.lyr-view-btn+.lyr-view-btn{border-left:1.5px solid var(--line)}.lyr-view-btn:hover{background:var(--surface-el);color:var(--ink)}.lyr-view-btn.active{background:var(--primary);color:#fff}#lyr-results-wrap.list-mode .lyr-grid{grid-template-columns:1fr;gap:3px}#lyr-results-wrap.list-mode .lyr-card{border-radius:10px;flex-direction:row;align-items:center;gap:14px;padding:11px 16px;transform:none!important}#lyr-results-wrap.list-mode .lyr-card-top{display:none}#lyr-results-wrap.list-mode .lyr-card-title{font-size:.88rem;font-family:var(--font-body);-webkit-line-clamp:1;flex:1;font-weight:600}#lyr-results-wrap.list-mode .lyr-card-artist{text-align:right;flex-shrink:0;min-width:110px;font-size:.78rem}@media (width<=500px){.lyr-results-bar{flex-wrap:wrap}#lyr-results-wrap.list-mode .lyr-card-artist{display:none}}.lyrics-show-page{max-width:1100px;margin:0 auto;padding:28px 32px}@media (width<=700px){.lyrics-show-page{padding:16px 14px}}.lyrics-show-header{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px 20px;margin-bottom:24px;padding-bottom:20px;display:flex}.lyrics-show-title{font-family:var(--font-display);color:var(--ink);margin:4px 0;font-size:2.2rem;font-weight:700;line-height:1.15}.lyrics-show-artist{color:var(--muted);margin:0 0 10px;font-size:.95rem}.lyrics-show-badges{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.lyrics-badge{color:var(--muted);background:var(--surface-el);text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:3px 9px;font-size:.7rem;font-weight:600}.lyrics-show-actions{flex-shrink:0;align-items:flex-start;gap:8px;display:flex}.lyrics-show-body{grid-template-columns:1fr 296px;align-items:start;gap:24px;display:grid}.lc-content-full{background:var(--surface);border:1px solid var(--line);border-radius:16px;min-height:300px;padding:28px 36px 36px}@media (width<=860px){.lyrics-show-body{grid-template-columns:1fr}.lyrics-add-panel{position:static}}.lyrics-text-panel{background:var(--surface);border:1px solid var(--line);border-radius:16px;min-height:300px;padding:28px 36px 36px}@media (width<=700px){.lyrics-text-panel{padding:20px 20px 28px}}.lyr-view-panel{overflow:hidden}.lyr-section{padding-bottom:1.5em}.lyr-section:last-child{padding-bottom:0}.lyr-line{font-family:var(--font-body);color:var(--ink);font-size:1.08rem;line-height:1.45;display:block;margin:0!important;padding:0!important}.lyr-line:empty{display:none}.lyrics-add-panel{position:sticky;top:20px}.lyrics-add-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px 24px}.lyrics-add-card h3{color:var(--ink);margin:4px 0 8px;font-size:1.05rem;font-weight:700}.lyrics-add-desc{color:var(--muted);margin-bottom:16px;font-size:.83rem;line-height:1.5}.lyrics-add-toggle{background:var(--surface-el);border-radius:8px;gap:4px;margin-bottom:14px;padding:3px;display:flex}.lyrics-toggle-btn{font-size:.8rem;font-weight:600;font-family:var(--font-body);color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:6px 10px;transition:background .15s,color .15s}.lyrics-toggle-btn.active{background:var(--surface);color:var(--ink);box-shadow:0 1px 4px #00000014}.lyrics-set-select,.lyrics-set-input{border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);font-size:.88rem;font-family:var(--font-body);border-radius:8px;padding:9px 12px}.lyrics-set-select:focus,.lyrics-set-input:focus{border-color:var(--primary);outline:none}.lyrics-no-sets{color:var(--muted);margin-bottom:10px;font-size:.82rem}.lyrics-editor-hint{color:var(--muted);margin:0;font-size:.78rem}.lyrics-editor-hint strong{color:var(--primary)}.lyrics-pagination nav{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.lyrics-pagination .page-link,.lyrics-pagination span{border:1px solid var(--line);min-width:32px;height:32px;font-size:.82rem;font-family:var(--font-body);color:var(--ink);background:var(--surface);border-radius:6px;justify-content:center;align-items:center;padding:0 8px;text-decoration:none;transition:border-color .15s;display:inline-flex}.lyrics-pagination .page-link:hover{border-color:var(--primary);color:var(--primary)}.lyrics-pagination .active .page-link,.lyrics-pagination [aria-current=page] span{background:var(--primary);color:#fff;border-color:var(--primary)}.lyrics-import-wrap{grid-template-columns:1fr 1fr;align-items:start;gap:28px;display:grid}@media (width<=800px){.lyrics-import-wrap{grid-template-columns:1fr}}.lyrics-import-instructions{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px 26px}.lyrics-import-cols{flex-direction:column;gap:6px;display:flex}.lyrics-import-col{align-items:center;gap:10px;font-size:.85rem;display:flex}.lyrics-col-num{background:var(--surface-el);width:22px;height:22px;color:var(--muted);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:inline-flex}.lyrics-col-name{font-family:var(--font-mono);color:var(--ink);min-width:120px;font-size:.82rem;font-weight:600}.lyrics-col-req{color:var(--primary);background:#d9772f1a;border-radius:20px;padding:1px 7px;font-size:.7rem;font-weight:600}.lyrics-col-opt{color:var(--muted);font-size:.72rem}.lyrics-import-example{margin-top:4px}.lyrics-import-code{background:var(--surface-el);font-family:var(--font-mono);color:var(--ink);white-space:pre-wrap;word-break:break-all;border-radius:8px;padding:10px 12px;font-size:.75rem;line-height:1.6;display:block}.lyrics-import-form{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px 26px}.lyrics-drop-zone{border:2px dashed var(--line);cursor:pointer;color:var(--muted);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;margin-bottom:16px;padding:32px 20px;transition:border-color .15s,background .15s;display:flex}.lyrics-drop-zone:hover,.lyrics-drop-zone.drag-over{border-color:var(--primary);color:var(--primary);background:#d9772f0a}.lyrics-drop-zone.has-file{border-color:var(--primary);background:#d9772f0d}.lyrics-drop-label{color:var(--ink);text-align:center;font-size:.88rem;font-weight:600}.lyrics-drop-sub{color:var(--muted);font-size:.75rem}.lyrics-import-options{flex-wrap:wrap;align-items:center;gap:20px;margin-bottom:4px;display:flex}.lyrics-import-check{color:var(--ink);cursor:pointer;align-items:center;gap:6px;font-size:.85rem;display:flex}.lyrics-import-option-label{color:var(--ink);align-items:center;font-size:.85rem;display:flex}.lyrics-import-note{color:var(--muted);text-align:center;margin-top:10px;font-size:.82rem}.lyr-lang-tab-bar-wrap{border-bottom:1px solid var(--line);position:relative}.lyr-lang-tab-primary{gap:4px}.lyr-lang-tab-primary:hover{color:var(--primary)}.lyr-lang-tab-bar{scrollbar-width:none;align-items:flex-end;gap:2px;padding:8px 12px 0;display:flex;overflow-x:auto}.lyr-lang-tab-bar::-webkit-scrollbar{display:none}.lyr-lang-tab{color:var(--muted);cursor:pointer;white-space:nowrap;font-size:.8rem;font-weight:500;font-family:var(--font-body);background:0 0;border:1px solid #0000;border-bottom:none;border-radius:6px 6px 0 0;align-items:center;gap:5px;padding:5px 12px;transition:background .15s,color .15s;display:inline-flex;position:relative}.lyr-lang-tab:hover{background:var(--surface-el);color:var(--ink)}.lyr-lang-tab.active{background:var(--bg);border-color:var(--line);color:var(--ink)}.lyr-lang-tab.active:after{content:"";background:var(--bg);height:1px;position:absolute;bottom:-1px;left:0;right:0}.lyr-lang-tab-close{width:15px;height:15px;color:var(--muted);cursor:pointer;pointer-events:auto;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.85rem;line-height:1;transition:background .1s,color .1s;display:inline-flex}.lyr-lang-tab-close:hover{color:var(--danger);background:#c530301f}.lyr-lang-add-btn{border:1px dashed var(--line);color:var(--muted);cursor:pointer;white-space:nowrap;font-size:.75rem;font-weight:600;font-family:var(--font-body);background:0 0;border-radius:6px;flex-shrink:0;margin-bottom:4px;margin-left:auto;padding:5px 10px;transition:border-color .15s,color .15s}.lyr-lang-add-btn:hover{border-color:var(--primary);color:var(--primary)}.lyr-lang-picker{z-index:200;background:var(--surface);border:1px solid var(--line);border-radius:10px;grid-template-columns:repeat(3,1fr);gap:3px;min-width:240px;max-height:220px;padding:8px;display:grid;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 6px 24px #00000021}.lyr-lang-picker-item{color:var(--ink);text-align:left;cursor:pointer;font-size:.78rem;font-family:var(--font-body);background:0 0;border:none;border-radius:6px;padding:6px 8px;transition:background .1s}.lyr-lang-picker-item:hover{background:var(--surface-el)}.lyr-lang-picker-item[disabled]{opacity:.35;cursor:not-allowed}.lyr-lang-panel,.song-form-editor-area.lyr-lang-panel{flex-direction:column;flex:1;display:flex}.song-form-editor-area.lyr-lang-panel textarea{flex:1}.lyr-lang-switcher{border-bottom:1px solid var(--line);flex-wrap:wrap;gap:6px;margin-bottom:22px;padding-bottom:18px;display:flex}.lyr-lang-switch-btn{border:1px solid var(--line);color:var(--muted);cursor:pointer;font-size:.82rem;font-weight:600;font-family:var(--font-body);letter-spacing:.01em;background:0 0;border-radius:20px;padding:5px 18px;transition:all .15s}.lyr-lang-switch-btn:hover{border-color:var(--primary);color:var(--primary)}.lyr-lang-switch-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.perf-ref-link{color:#ffffffb3;letter-spacing:.04em;background:#ffffff0f;border:1px solid #ffffff2e;border-radius:20px;align-items:center;gap:6px;margin-top:8px;padding:5px 14px;font-size:.78rem;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.perf-ref-link:hover{background:rgba(var(--primary-rgb), .18);border-color:rgba(var(--primary-rgb), .55);color:var(--primary)}.pub-card-plays{color:var(--muted);letter-spacing:.02em;margin:0 0 8px;font-size:.73rem;font-weight:600;display:block}.set-group-label{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:28px 0 12px;font-size:.68rem;font-weight:700}.set-index-date-service{color:var(--primary);font-weight:700}.live-form-date-row{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.live-form-date-input,.live-form-label-input{border:1px solid var(--line);background:var(--surface-el);color:var(--ink);font-size:.82rem;font-family:var(--font-body);border-radius:8px;min-width:0;padding:6px 10px}.live-form-date-input{width:150px}.live-form-label-input{flex:1;min-width:160px}.live-form-date-input::placeholder,.live-form-label-input::placeholder{color:var(--muted);opacity:.7}.live-form-date-input:focus,.live-form-label-input:focus{outline:2px solid rgba(var(--primary-rgb), .5);border-color:#0000}.liveset-share-group-wrap{position:relative}.liveset-group-dropdown{z-index:100;background:#fff;border:1px solid #e2d8c9;border-radius:12px;flex-direction:column;gap:2px;min-width:200px;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0000001f}.liveset-group-item{color:#1c2b3a;width:100%;font:inherit;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:.88rem;font-weight:500;transition:background .12s;display:flex}.liveset-group-item:hover{background:#f0ebe1}.liveset-group-icon{color:#fff;background:#2a7a8c;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.78rem;font-weight:700;display:flex}.liveset-group-shared{color:#6b7280;cursor:default}.liveset-group-shared:hover{background:0 0}.liveset-group-check{color:#2a7a8c;margin-left:auto;font-weight:700}.songs-banner{background:linear-gradient(135deg,#0c1628 0%,#1a2a4a 100%);border-radius:20px;margin-bottom:24px;padding:24px clamp(18px,3vw,32px);position:relative;overflow:hidden}.songs-banner:before{content:"";pointer-events:none;background:radial-gradient(at 85% 40%,#d9772f21 0%,#0000 65%);position:absolute;inset:0}.songs-banner-inner{flex-wrap:wrap;align-items:center;gap:18px;display:flex;position:relative}.songs-banner-icon{width:64px;height:64px;color:var(--primary);background:#d9772f2e;border:2px solid #d9772f52;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.songs-banner-info{flex-shrink:0}.songs-banner-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:#ffffff73;margin:0 0 4px;font-size:.65rem;font-weight:700}.songs-banner-title{font-size:clamp(1.6rem,3vw,2.2rem);font-family:var(--font-display);color:#fff;margin:0;font-weight:700;line-height:1.1}.songs-banner-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-left:auto;display:flex}.songs-search-wrap{align-items:center;display:flex;position:relative}.songs-search-icon{color:#fff6;pointer-events:none;width:16px;height:16px;position:absolute;left:10px}.songs-search-input{color:#fff;height:38px;font:inherit;background:#ffffff14;border:1px solid #ffffff24;border-radius:10px;width:210px;padding:0 36px 0 34px;font-size:.88rem;transition:border-color .15s,width .2s,background .15s}.songs-search-input::placeholder{color:#ffffff59}.songs-search-input:focus{background:#ffffff1c;border-color:#d9772f99;outline:none;width:250px}.songs-search-kbd{color:#ffffff59;height:18px;font-size:.65rem;font-family:var(--font-mono);background:#ffffff12;border:1px solid #ffffff26;border-radius:4px;align-items:center;padding:0 5px;display:flex;position:absolute;right:8px}.songs-sort-bar{background:#ffffff12;border:1px solid #ffffff1f;border-radius:10px;align-items:center;gap:4px;padding:3px;display:flex}.songs-sort-chip{color:#ffffff80;white-space:nowrap;border-radius:7px;padding:5px 12px;font-size:.8rem;font-weight:500;text-decoration:none;transition:background .14s,color .14s}.songs-sort-chip:hover{color:#ffffffd9}.songs-sort-chip.active{color:#fff;background:#ffffff21;box-shadow:0 1px 4px #0003}.songs-new-btn{background:var(--primary);color:#fff;white-space:nowrap;border-radius:10px;align-items:center;height:38px;padding:0 18px;font-size:.88rem;font-weight:600;text-decoration:none;transition:opacity .14s,transform .12s;display:inline-flex}.songs-new-btn:hover{opacity:.88;transform:translateY(-1px)}.songs-tag-bar{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:20px;display:flex}.songs-tag-chip{border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;border-radius:999px;padding:5px 14px;font-size:.78rem;font-weight:600;transition:background .14s,color .14s,border-color .14s}.songs-tag-chip:hover{border-color:var(--primary);color:var(--primary)}.songs-tag-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.songs-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;display:grid}.song-card2{background:var(--surface);border:1px solid var(--line);border-radius:18px;flex-direction:column;transition:transform .16s,box-shadow .16s;display:flex;position:relative;overflow:hidden}.song-card2:hover{transform:translateY(-3px);box-shadow:0 14px 40px #0a11281a}.song-card2:before{content:"";flex-shrink:0;width:100%;height:3px;display:block}.song-card2.key-sharp:before{background:linear-gradient(90deg, var(--primary), #f59e42)}.song-card2.key-flat:before{background:linear-gradient(90deg,#6366f1,#8b5cf6)}.song-card2.key-minor:before{background:linear-gradient(90deg,#14b8a6,#0ea5e9)}.sc2-top{justify-content:space-between;align-items:center;padding:14px 16px 0;display:flex}.sc2-artist{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.75rem;font-weight:600;overflow:hidden}.sc2-key{background:var(--surface-el);color:var(--ink);font-size:.78rem;font-weight:700;font-family:var(--font-mono);border-radius:7px;flex-shrink:0;padding:3px 9px}.sc2-title{font-size:1.2rem;font-family:var(--font-display);color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:8px 16px 0;font-weight:700;line-height:1.25;display:-webkit-box;overflow:hidden}.sc2-foot{justify-content:space-between;align-items:flex-end;gap:8px;margin-top:auto;padding:10px 16px 14px;display:flex}.sc2-chips{flex-wrap:wrap;align-items:center;gap:5px;min-width:0;display:flex}.sc2-chips>span{color:var(--muted);background:var(--surface-el);white-space:nowrap;border-radius:6px;padding:2px 7px;font-size:.72rem;font-weight:600}.sc2-tag{color:var(--primary)!important;background:#d9772f1a!important}.sc2-plays{color:var(--muted)!important;background:0 0!important;font-size:.7rem!important}.sc2-btns{flex-shrink:0;align-items:center;gap:6px;display:flex}@media (width<=700px){.songs-banner{border-radius:16px;margin-bottom:14px;padding:14px 16px}.songs-banner-inner{flex-wrap:wrap;align-items:center;gap:10px}.songs-banner-icon{border-radius:10px;flex-shrink:0;width:40px;height:40px}.songs-banner-icon svg{width:22px;height:22px}.songs-banner-info{flex:1;min-width:0}.songs-banner-title{font-size:1.35rem}.songs-banner-eyebrow{font-size:.6rem}.songs-banner-actions{gap:8px;width:100%;margin-left:0}.songs-search-wrap{flex:1}.songs-search-input{width:100%}.songs-sort-bar{flex:1;justify-content:space-between}.songs-search-kbd{display:none}.songs-grid{grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr));gap:10px}}.page-banner{background:linear-gradient(135deg,#0c1628 0%,#1a2a4a 100%);border-radius:20px;margin-bottom:24px;padding:24px clamp(18px,3vw,32px);position:relative;overflow:hidden}.page-banner:before{content:"";pointer-events:none;background:radial-gradient(at 85% 40%,#d9772f21 0%,#0000 65%);position:absolute;inset:0}.page-banner-inner{flex-wrap:wrap;align-items:center;gap:18px;display:flex;position:relative}.page-banner-icon{width:64px;height:64px;color:var(--primary);background:#d9772f2e;border:2px solid #d9772f52;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.page-banner-info{flex-shrink:0}.page-banner-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:#ffffff73;margin:0 0 4px;font-size:.65rem;font-weight:700}.page-banner-title{font-size:clamp(1.6rem,3vw,2.2rem);font-family:var(--font-display);color:#fff;margin:0;font-weight:700;line-height:1.1}.page-banner-desc{color:#ffffff73;margin:2px 0 0;font-size:.85rem}.page-banner-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-left:auto;display:flex}.page-banner-back-btn{color:#ffffffb3;border:1px solid #ffffff2e;border-radius:9px;padding:6px 14px;font-size:.82rem;text-decoration:none;transition:background .14s}.page-banner-back-btn:hover{background:#ffffff14}.page-banner-btn{background:var(--primary);color:#fff;white-space:nowrap;cursor:pointer;border:none;border-radius:10px;align-items:center;height:38px;padding:0 18px;font-size:.88rem;font-weight:600;text-decoration:none;transition:opacity .14s,transform .12s;display:inline-flex}.page-banner-btn:hover{opacity:.88;transform:translateY(-1px)}.page-banner-btn-ghost{color:#ffffffbf;white-space:nowrap;cursor:pointer;background:0 0;border:1px solid #ffffff2e;border-radius:10px;align-items:center;height:38px;padding:0 18px;font-size:.88rem;font-weight:600;text-decoration:none;transition:background .14s;display:inline-flex}.page-banner-btn-ghost:hover{background:#ffffff14}.page-banner-btn-danger{color:#fc8181;white-space:nowrap;cursor:pointer;background:0 0;border:1px solid #c5303080;border-radius:10px;align-items:center;height:38px;padding:0 18px;font-size:.88rem;font-weight:600;transition:background .14s,color .14s;display:inline-flex}.page-banner-btn-danger:hover{color:#feb2b2;background:#c5303026}.dash-stats-banner{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.dash-stats-banner>span{color:#ffffff8c;white-space:nowrap;background:#ffffff12;border:1px solid #ffffff1a;border-radius:8px;padding:4px 10px;font-size:.78rem;font-weight:600}@media (width<=700px){.page-banner{border-radius:16px;margin-bottom:14px;padding:14px 16px}.page-banner:before{background:radial-gradient(at 90% 30%,#d9772f26 0%,#0000 60%)}.page-banner-inner{flex-wrap:wrap;align-items:center;gap:10px}.page-banner-icon{border-radius:10px;flex-shrink:0;width:40px;height:40px}.page-banner-icon svg{width:22px;height:22px}.page-banner-icon img{border-radius:10px;width:40px;height:40px}.page-banner-info{flex:1;min-width:0}.page-banner-title{font-size:1.35rem}.page-banner-eyebrow{margin-bottom:2px;font-size:.6rem}.page-banner-desc{font-size:.78rem}.page-banner-actions{gap:8px;width:100%;margin-left:0}.page-banner-btn,.page-banner-btn-ghost{height:36px;padding:0 14px;font-size:.82rem}.dash-stats-banner{gap:5px}.dash-stats-banner>span{padding:3px 8px;font-size:.72rem}}.dash-command{grid-template-columns:1fr 220px;align-items:start;gap:16px;display:grid}.dash-next-set{background:linear-gradient(135deg,#0c1628 0%,#1a2a4a 100%);border-radius:18px;padding:24px 28px;position:relative;overflow:hidden}.dash-next-set:before{content:"";pointer-events:none;background:radial-gradient(at 85% 30%,#d9772f24 0%,#0000 60%);position:absolute;inset:0}.dash-next-label{letter-spacing:.12em;text-transform:uppercase;color:#ffffff73;align-items:center;gap:5px;margin:0 0 8px;font-size:.62rem;font-weight:700;display:flex;position:relative}.dash-next-title{font-size:clamp(1.3rem,2.5vw,1.75rem);font-family:var(--font-display);color:#fff;margin:0 0 10px;font-weight:700;line-height:1.15;position:relative}.dash-next-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex;position:relative}.dash-next-date{color:var(--primary);font-size:.82rem;font-weight:600}.dash-next-label-chip{color:#ffffff8c;background:#ffffff14;border:1px solid #ffffff1f;border-radius:6px;padding:2px 8px;font-size:.72rem;font-weight:600}.dash-next-songs{color:#ffffff73;font-size:.72rem}.dash-next-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex;position:relative}.dash-next-empty{color:#fff6;margin:0 0 16px;font-size:.85rem;position:relative}.dash-quick-actions{flex-direction:column;gap:10px;display:flex}.dash-section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;font-size:.62rem;font-weight:700}.dash-quick-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.dash-quick-card{background:var(--surface);border:1px solid var(--line);color:var(--ink);text-align:center;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:14px 8px;font-size:.75rem;font-weight:600;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .12s;display:flex}.dash-quick-card:hover{border-color:var(--primary);box-shadow:0 4px 16px rgba(var(--primary-rgb),.12);transform:translateY(-1px)}.dash-quick-icon{background:rgba(var(--primary-rgb),.1);width:36px;height:36px;color:var(--primary);border-radius:10px;justify-content:center;align-items:center;display:flex}.dash-section-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.dash-recent-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.dash-recent-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;flex-direction:column;padding:14px 16px;text-decoration:none;transition:border-color .15s,transform .12s;display:flex}.dash-recent-card:hover{border-color:var(--primary);transform:translateY(-2px)}.dash-recent-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.dash-recent-key{font-size:.72rem;font-weight:700;font-family:var(--font-mono);color:var(--primary);background:rgba(var(--primary-rgb),.1);border-radius:5px;padding:2px 7px}.dash-recent-when{color:var(--muted);font-size:.68rem}.dash-recent-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;margin:0 0 2px;font-size:.95rem;font-weight:700;overflow:hidden}.dash-recent-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.75rem;overflow:hidden}@media (width<=700px){.dash-command{grid-template-columns:1fr}.dash-next-set{padding:18px}.dash-recent-grid{grid-template-columns:1fr 1fr}}.sc2-no-chart{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:var(--surface-el);border:1px solid var(--line);border-radius:5px;margin:2px 16px 0;padding:2px 7px;font-size:.62rem;font-weight:700;display:inline-block}.sc2-play-disabled{opacity:.45;pointer-events:none}.mobile-search-btn{display:none}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton{background:var(--surface-el);border-radius:8px;animation:1.4s ease-in-out infinite skeleton-pulse}.skeleton-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;flex-direction:column;gap:10px;padding:16px;display:flex;overflow:hidden}.skeleton-card:before{content:"";background:var(--surface-el);height:3px;margin:-16px -16px 0;display:block}.skeleton-line{border-radius:6px;height:12px}.skeleton-line.short{width:45%}.skeleton-line.medium{width:70%}.skeleton-line.tall{width:80%;height:20px}#song-grid .song-card2{transition:opacity .15s}#song-grid.songs-searching .song-card2{opacity:.35;transition:opacity 80ms}.lc-has-chords-badge{background:rgba(var(--primary-rgb,217 119 47), .12);color:var(--primary)}.lc-mode-bar{flex-wrap:wrap;align-items:center;gap:12px;padding:14px 24px 0;display:flex}.lc-mode-toggle{background:var(--surface-el);border-radius:8px;padding:3px}.lc-mode-toggle .perf-view-btn{color:var(--muted);background:0 0;padding:5px 14px;font-size:.82rem}.lc-mode-toggle .perf-view-btn:hover{color:var(--ink)}.lc-mode-toggle .perf-view-btn.active{background:var(--primary);color:#fff}.lc-transpose-grp{align-items:center;gap:6px;display:flex}.lc-transpose-btn{border:1px solid var(--line);background:var(--surface);width:28px;height:28px;color:var(--ink);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:1rem;line-height:1;transition:background .15s,border-color .15s;display:flex}.lc-transpose-btn:hover{background:var(--surface-el);border-color:var(--primary)}.lc-key-display{color:var(--ink);text-align:center;min-width:28px;font-size:.88rem;font-weight:700}.lc-lang-wrap{margin-left:auto}.lc-panel{padding:20px 24px 24px}.lc-no-content{color:var(--muted);font-size:.9rem;font-style:italic}.lc-panel .chart-output{padding:0}.lc-panel .chart-section{margin-bottom:20px;padding:14px 0 0}.lc-panel .chart-section h2{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;font-size:.7rem;font-weight:700}.lc-panel .chart-lines{font-family:var(--font-mono);flex-direction:column;gap:4px;font-size:.9rem;display:flex}.lyr-card-has-chords{color:var(--primary);letter-spacing:.03em;margin-top:6px;font-size:.7rem;font-weight:600;display:block}.lc-editor-tabs{gap:4px;margin-top:3px;display:flex}.lc-editor-tab{color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;padding:4px 10px;font-size:.78rem;font-weight:600;transition:background .12s,color .12s,border-color .12s}.lc-editor-tab:hover{background:var(--surface-el);color:var(--ink)}.lc-editor-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}@media (width<=640px){.lc-mode-bar{gap:8px;padding:12px 14px 0}.lc-panel{padding:16px 14px 20px}}.app-main.dash-main{background:#f7f5f1}.dash-page{min-height:100%}.dash-topbar{z-index:20;background:#fff;border-bottom:1px solid #ebe6de;align-items:center;gap:16px;padding:12px clamp(14px,2vw,24px);display:flex;position:sticky;top:0}.dash-search-wrap{flex:1;position:relative}.dash-search-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.dash-search-input{color:#374151;cursor:pointer;background:#f3f0eb;border:1px solid #e5e0d8;border-radius:9px;outline:none;width:100%;padding:9px 14px 9px 36px;font-family:Outfit,sans-serif;font-size:.87rem;transition:border-color .14s,background .14s}.dash-search-input::placeholder{color:#9ca3af}.dash-search-input:focus{background:#fff;border-color:#2a7a8c}.dash-topbar-right{align-items:center;gap:10px;margin-left:auto;display:flex}.dash-notif-btn{color:#4b5563;cursor:pointer;background:#f3f0eb;border:1px solid #e5e0d8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;text-decoration:none;transition:background .14s;display:flex;position:relative}.dash-notif-btn:hover{background:#e8e3dc}.dash-notif-count{color:#fff;background:#d97706;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.58rem;font-weight:700;display:flex;position:absolute;top:-3px;right:-3px}.dash-avatar-btn{cursor:pointer;color:#1c2b3a;background:#f3f0eb;border:1px solid #e5e0d8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding:0;text-decoration:none;transition:border-color .14s,background .14s;display:flex;overflow:hidden}.dash-avatar-btn:hover{background:#e8e3dc;border-color:#d9772f}.dash-avatar-name,.dash-avatar-chevron{display:none}.dash-avatar-img{object-fit:cover;border-radius:50%;width:36px;height:36px;display:block}.dash-avatar-init{color:#fff;background:#2a7a8c;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8rem;font-weight:700;display:flex}.dash-avatar-name{color:#374151;font-size:.8rem;font-weight:600}.dash-avatar-chevron{color:#9ca3af;flex-shrink:0}.dash-content{flex-direction:column;gap:18px;padding:clamp(16px,2vw,24px) clamp(14px,2vw,24px);display:flex}.dash-mobile-search{display:none}.dash-greeting-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.dash-greeting-text h1{color:#1c2b3a;margin:0 0 3px;font-family:Outfit,sans-serif;font-size:clamp(1.2rem,2.2vw,1.55rem);font-weight:700;line-height:1.25}.dash-greeting-text p{color:#6b7280;margin:0;font-size:.83rem}.dash-greeting-actions{flex-wrap:wrap;flex-shrink:0;gap:8px;display:flex}.dash-btn-primary{color:#fff;white-space:nowrap;cursor:pointer;background:#2a7a8c;border:none;border-radius:8px;align-items:center;gap:5px;padding:8px 15px;font-size:.83rem;font-weight:600;text-decoration:none;transition:background .14s;display:inline-flex}.dash-btn-primary:hover{background:#246878}.dash-btn-outline{color:#2a7a8c;white-space:nowrap;cursor:pointer;background:#fff;border:1.5px solid #2a7a8c;border-radius:8px;align-items:center;gap:5px;padding:8px 15px;font-size:.83rem;font-weight:600;text-decoration:none;transition:background .14s;display:inline-flex}.dash-btn-outline:hover{background:#edf7f9}.dash-card{background:#fff;border:1px solid #e8e3dc;border-radius:10px;overflow:hidden}.dash-card-header{border-bottom:1px solid #f0ebe3;justify-content:space-between;align-items:center;padding:13px 17px;display:flex}.dash-card-title{color:#d97706;align-items:center;gap:6px;font-size:.88rem;font-weight:700;display:flex}.dash-card-link{color:#6b7280;align-items:center;gap:3px;font-size:.76rem;font-weight:600;text-decoration:none;transition:color .13s;display:flex}.dash-card-link:hover{color:#2a7a8c}.dash-upcoming-body{grid-template-columns:1fr 210px;display:grid}.dash-upcoming-main{gap:14px;padding:16px;display:flex}.dash-upcoming-thumb{color:#fff3;background:linear-gradient(135deg,#1c3a4a 0%,#0c1e2e 100%);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:96px;height:96px;display:flex}.dash-upcoming-info{flex:1;min-width:0}.dash-upcoming-name-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:5px;display:flex}.dash-upcoming-name{color:#1c2b3a;font-size:1rem;font-weight:700;text-decoration:none}.mobile-brand-logo{width:auto;max-width:130px;height:34px;display:block}.mobile-drawer-logo{width:auto;max-width:148px;height:40px;display:block}.dash-upcoming-name:hover{color:#2a7a8c}.dash-status-pill{text-transform:uppercase;letter-spacing:.05em;color:#2a7a8c;background:#edf7f9;border:1px solid #b2dde6;border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:.62rem;font-weight:700}.dash-upcoming-meta{color:#6b7280;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:11px;font-size:.76rem;display:flex}.dash-set-songs{flex-direction:column;gap:5px;margin-bottom:13px;display:flex}.dash-set-song-row{color:#374151;align-items:center;gap:8px;font-size:.81rem;display:flex}.dash-set-song-num{color:#9ca3af;text-align:right;flex-shrink:0;width:18px;font-size:.7rem;font-weight:600}.dash-set-song-title{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.dash-set-song-key{color:#d97706;flex-shrink:0;font-size:.78rem;font-weight:700}.dash-upcoming-actions{flex-wrap:wrap;gap:7px;display:flex}.dash-btn-sm{white-space:nowrap;cursor:pointer;border:none;border-radius:7px;align-items:center;gap:4px;padding:6px 12px;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:600;text-decoration:none;transition:background .14s,color .14s;display:inline-flex}.dash-btn-sm.primary{color:#fff;background:#2a7a8c}.dash-btn-sm.primary:hover{background:#246878}.dash-btn-sm.ghost{color:#374151;background:#f3f0eb;border:1px solid #e5e0d8}.dash-btn-sm.ghost:hover{background:#e8e3dc}.dash-upcoming-side{border-left:1px solid #f0ebe3;flex-direction:column;gap:16px;padding:16px;display:flex}.dash-side-label{text-transform:uppercase;letter-spacing:.08em;color:#9ca3af;margin-bottom:5px;font-size:.7rem;font-weight:700}.dash-set-notes-text{color:#4b5563;margin:0;font-size:.79rem;line-height:1.5}.dash-team-avatars{flex-wrap:wrap;gap:5px;display:flex}.dash-team-avatar{object-fit:cover;border:2px solid #fff;border-radius:50%;width:30px;height:30px}.dash-team-avatar-init{color:#fff;background:#2a7a8c;border:2px solid #fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.68rem;font-weight:700;display:flex}.dash-team-more{color:#6b7280;background:#f3f0eb;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.62rem;font-weight:700;display:flex}.dash-no-set{text-align:center;padding:32px 22px}.dash-no-set-title{color:#4b5563;margin:0 0 5px;font-size:.92rem;font-weight:600}.dash-no-set-desc{color:#9ca3af;margin:0 0 14px;font-size:.8rem}.dash-bottom-grid{grid-template-columns:1.7fr 1.4fr 1fr;align-items:start;gap:14px;display:grid}.dash-song-list{flex-direction:column;display:flex}.dash-song-item{color:inherit;border-bottom:1px solid #f5f1ec;align-items:center;gap:10px;padding:9px 16px;text-decoration:none;transition:background .12s;display:flex}.dash-song-item:last-child{border-bottom:none}.dash-song-item:hover{background:#fafaf8}.dash-song-thumb{background:linear-gradient(135deg,#1c3a4a,#0c1e2e);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.dash-song-info{flex:1;min-width:0}.dash-song-title{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;font-size:.83rem;font-weight:600;display:block;overflow:hidden}.dash-song-meta-row{color:#9ca3af;align-items:center;gap:5px;margin-top:2px;font-size:.7rem;display:flex}.dash-song-key-chip{color:#d97706;font-weight:700}.dash-song-vis{border-radius:999px;padding:1px 6px;font-size:.63rem;font-weight:600;display:inline-flex}.dash-song-vis.public{color:#2a7a8c;background:#edf7f9}.dash-song-vis.private{color:#6b7280;background:#f3f0eb}.dash-song-time{color:#9ca3af;white-space:nowrap;flex-shrink:0;font-size:.69rem}.dash-song-dots{color:#9ca3af;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;text-decoration:none;transition:background .12s,color .12s;display:flex}.dash-song-dots:hover{color:#374151;background:#f0ebe3}.dash-notes-list{padding:2px 0}.dash-note-item{border-bottom:1px solid #f5f1ec;padding:9px 16px}.dash-note-item:last-child{border-bottom:none}.dash-note-bullet{background:#2a7a8c;border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.dash-note-row{align-items:flex-start;gap:9px;display:flex}.dash-note-body{flex:1;min-width:0}.dash-note-text{color:#1c2b3a;margin:0 0 3px;font-size:.8rem;line-height:1.4}.dash-note-meta{color:#9ca3af;font-size:.7rem}.dash-notes-empty{text-align:center;color:#9ca3af;padding:26px 16px;font-size:.8rem}.dash-section-header{border-bottom:1px solid #f0ebe3;justify-content:space-between;align-items:center;padding:11px 16px;display:flex}.dash-section-title{color:#374151;font-size:.8rem;font-weight:700}.dash-section-link{color:#2a7a8c;font-size:.7rem;font-weight:600;text-decoration:none}.dash-section-link:hover{text-decoration:underline}.dash-stats-grid-wrap{display:contents}.dash-stats-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.dash-stat-card{text-align:center;background:#fff;border:1px solid #e8e3dc;border-radius:10px;padding:14px 12px;text-decoration:none;transition:border-color .14s,box-shadow .14s;display:block}.dash-stat-card:hover{border-color:#2a7a8c;box-shadow:0 2px 8px #2a7a8c14}.dash-stat-icon{color:#2a7a8c;background:#edf7f9;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;margin:0 auto 7px;display:flex}.dash-stat-num{color:#1c2b3a;margin-bottom:3px;font-size:1.5rem;font-weight:800;line-height:1}.dash-stat-label{color:#6b7280;font-size:.69rem;font-weight:600}.sidebar-plan-card{background:#ffffff0d;border:1px solid #ffffff14;border-radius:11px;flex-direction:column;gap:5px;margin:0 10px 10px;padding:11px 13px;display:flex}.sidebar.collapsed .sidebar-plan-card{display:none}.sidebar-plan-head{align-items:center;gap:6px;margin-bottom:1px;display:flex}.sidebar-plan-icon-wrap{color:#d97706;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.sidebar-plan-name{color:#ffffffd9;font-size:.76rem;font-weight:700}.sidebar-plan-days{color:#ffffff6b;font-size:.7rem;display:block}.sidebar-plan-track{background:#ffffff17;border-radius:999px;height:4px;margin:2px 0;overflow:hidden}.sidebar-plan-fill{background:#d97706;border-radius:999px;height:100%}.sidebar-plan-upgrade-btn{text-align:center;color:#d97706;background:#d9770624;border:1px solid #d9770647;border-radius:8px;margin-top:3px;padding:6px 10px;font-size:.7rem;font-weight:700;text-decoration:none;transition:background .13s;display:block}.sidebar-plan-upgrade-btn:hover{background:#d977063d}.mobile-bottom-nav{z-index:45;padding:6px 0;padding-bottom:max(6px, env(safe-area-inset-bottom));background:#fff;border-top:1px solid #ebe6de;display:none;position:fixed;bottom:0;left:0;right:0}.mobile-bottom-link{color:#9ca3af;letter-spacing:.01em;font-size:.6rem;font-weight:600;font-family:var(--font-body);flex-direction:column;flex:1;align-items:center;gap:3px;padding:5px 4px;text-decoration:none;transition:color .14s;display:flex}.mobile-bottom-link.active,.mobile-bottom-link:hover{color:#2a7a8c}@media (width<=768px){.mobile-bottom-nav{display:flex}.app-main{padding-bottom:62px}.dash-topbar{display:none}}@media (width<=960px){.dash-upcoming-body{grid-template-columns:1fr}.dash-upcoming-side{border-top:1px solid #f0ebe3;border-left:none}}@media (width<=880px){.dash-bottom-grid{grid-template-columns:1fr 1fr}.dash-stats-grid-wrap{grid-column:1/-1;display:block}.dash-stats-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=600px){.dash-greeting-row{flex-direction:column;align-items:flex-start}.dash-bottom-grid{grid-template-columns:1fr}.dash-stats-grid{grid-template-columns:1fr 1fr}.dash-upcoming-main{flex-direction:column}.dash-upcoming-thumb{width:100%;height:100px}}.songs-page{flex-direction:column;min-height:100vh;display:flex}.songs-content{width:100%;max-width:1320px;margin:0 auto;padding:0 28px 48px}.si-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;padding:28px 0 20px;display:flex}.si-title{font-family:var(--font-display);color:#1c2b3a;margin:0 0 2px;font-size:1.75rem;font-weight:700;line-height:1.15}.si-subtitle{color:#6b7280;margin:0;font-size:.82rem}.si-header-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.si-layout{grid-template-columns:1fr 272px;align-items:start;gap:24px;display:grid}.si-search-wrap{margin-bottom:14px;position:relative}.si-search-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.si-search-input{width:100%;font-size:.84rem;font-family:var(--font-body);color:#1c2b3a;box-sizing:border-box;background:#fff;border:1.5px solid #e5ddd0;border-radius:8px;outline:none;padding:9px 12px 9px 36px;transition:border-color .15s}.si-search-input:focus{border-color:#2a7a8c}.si-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.si-filter-chips{flex-wrap:wrap;gap:6px;display:flex}.si-chip{font-size:.78rem;font-family:var(--font-body);color:#4a5568;white-space:nowrap;background:#fff;border:1.5px solid #e5ddd0;border-radius:20px;align-items:center;padding:5px 12px;font-weight:500;text-decoration:none;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.si-chip:hover{color:#2a7a8c;border-color:#2a7a8c}.si-chip.active{color:#fff;background:#2a7a8c;border-color:#2a7a8c}.si-sort-wrap{flex-shrink:0;align-items:center;gap:7px;display:flex}.si-sort-label{color:#6b7280;white-space:nowrap;font-size:.78rem}.si-sort-select{font-size:.8rem;font-family:var(--font-body);appearance:none;color:#1c2b3a;cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 20 20' fill='%236B7280'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E") right 8px center no-repeat;border:1.5px solid #e5ddd0;border-radius:7px;outline:none;padding:5px 28px 5px 10px}.si-sort-select:focus{border-color:#2a7a8c}.si-table-card{background:#fff;border:1px solid #eae3d8;border-radius:12px;overflow:hidden}.si-table-wrap{overflow-x:auto}.si-table{border-collapse:collapse;width:100%;font-size:.82rem}.si-table thead tr{background:#f7f5f1;border-bottom:1px solid #eae3d8}.si-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;padding:10px 14px;font-size:.73rem;font-weight:600}.si-th-key{width:52px}.si-th-title{min-width:180px}.si-th-tags{min-width:120px}.si-th-num{text-align:center;width:52px}.si-th-vis{width:90px}.si-th-time{width:100px}.si-th-actions{text-align:right;width:90px}.si-row{border-bottom:1px solid #f3efe8;transition:background .12s}.si-row:last-child{border-bottom:none}.si-row:hover{background:#fdfaf7}.si-table td{vertical-align:middle;color:#1c2b3a;padding:11px 14px}.si-td-num{text-align:center;color:#6b7280;font-size:.8rem}.si-td-time{color:#9ca3af;white-space:nowrap;font-size:.78rem}.si-td-actions{text-align:right}.si-key-badge{color:#2a7a8c;min-width:28px;font-size:.74rem;font-weight:700;font-family:var(--font-mono);letter-spacing:.02em;white-space:nowrap;background:#edf7f9;border-radius:6px;justify-content:center;align-items:center;padding:2px 7px;display:inline-flex}.si-song-title{color:#1c2b3a;font-size:.84rem;font-weight:600;line-height:1.3;text-decoration:none;display:block}.si-song-title:hover{color:#2a7a8c}.si-song-artist{color:#9ca3af;margin-top:2px;font-size:.75rem;line-height:1.2;display:block}.si-tags{flex-wrap:wrap;gap:4px;display:flex}.si-tag-pill{color:#b45309;white-space:nowrap;background:#fef3e2;border-radius:10px;padding:2px 8px;font-size:.7rem;font-weight:500;display:inline-flex}.si-tag-more{color:#6b7280;background:#f0ebe1}.si-vis{white-space:nowrap;border-radius:10px;align-items:center;gap:4px;padding:3px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.si-vis-public{color:#166534;background:#dcfce7}.si-vis-private{color:#6b7280;background:#f3f4f6}.si-actions{justify-content:flex-end;align-items:center;gap:4px;display:flex}.si-action-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:0;text-decoration:none;transition:background .12s,color .12s;display:inline-flex}.si-action-btn:hover{color:#1c2b3a;background:#f0ebe1}.si-action-play:hover{color:#2a7a8c;background:#edf7f9}.si-action-disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.si-more-wrap{position:relative}.si-more-menu{z-index:200;background:#fff;border:1px solid #eae3d8;border-radius:9px;min-width:144px;display:none;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 6px 20px #0000001a}.si-more-menu.open{display:block}.si-more-item{color:#1c2b3a;text-align:left;cursor:pointer;width:100%;font-size:.82rem;font-family:var(--font-body);background:0 0;border:none;padding:9px 14px;text-decoration:none;transition:background .1s;display:block}.si-more-item:hover{background:#f7f5f1}.si-more-danger{color:#c53030}.si-more-danger:hover{background:#fff5f5}.si-pagination{border-top:1px solid #f3efe8;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.si-pg-info{color:#9ca3af;font-size:.78rem}.si-pg-btns{align-items:center;gap:4px;display:flex}.si-pg-btn{color:#4a5568;background:#fff;border:1.5px solid #eae3d8;border-radius:6px;justify-content:center;align-items:center;min-width:30px;height:30px;padding:0 6px;font-size:.78rem;font-weight:500;text-decoration:none;transition:border-color .12s,background .12s;display:inline-flex}.si-pg-btn:hover{color:#2a7a8c;border-color:#2a7a8c}.si-pg-btn.active{color:#fff;background:#2a7a8c;border-color:#2a7a8c}.si-pg-btn.disabled{opacity:.4;pointer-events:none}.si-pg-ellipsis{color:#9ca3af;padding:0 3px;font-size:.78rem}.si-empty-state{text-align:center;padding:48px 24px}.si-empty-title{color:#1c2b3a;margin:0 0 6px;font-size:.92rem;font-weight:600}.si-empty-desc{color:#9ca3af;margin:0 0 18px;font-size:.82rem}.si-no-results{text-align:center;color:#9ca3af;padding:32px 16px;font-size:.82rem}.si-mobile-list{display:none}.si-mobile-card{border-bottom:1px solid #f3efe8;padding:14px 16px}.si-mobile-card:last-child{border-bottom:none}.si-mobile-card-top{align-items:center;gap:10px;margin-bottom:8px;display:flex}.si-mobile-info{flex:1;min-width:0}.si-mobile-card-meta{color:#6b7280;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;font-size:.75rem;display:flex}.si-mobile-card-foot{justify-content:space-between;align-items:center;gap:8px;display:flex}.si-panel-col{flex-direction:column;gap:14px;display:flex}.si-panel-card{background:#fff;border:1px solid #eae3d8;border-radius:12px;padding:18px}.si-panel-title{text-transform:uppercase;letter-spacing:.07em;color:#6b7280;margin:0 0 14px;font-size:.78rem;font-weight:700}.si-stat-rows{flex-direction:column;gap:10px;display:flex}.si-stat-row{justify-content:space-between;align-items:center;display:flex}.si-stat-right{align-items:center;gap:8px;display:flex}.si-stat-label{color:#4a5568;font-size:.82rem}.si-stat-num{color:#1c2b3a;font-size:.92rem;font-weight:700}.si-stat-icon{border-radius:7px;justify-content:center;align-items:center;width:26px;height:26px;display:inline-flex}.si-key-rows{flex-direction:column;gap:8px;display:flex}.si-key-row{align-items:center;gap:10px;display:flex}.si-key-count{color:#6b7280;font-size:.78rem}.si-recent-rows{flex-direction:column;gap:2px;margin-bottom:14px;display:flex}.si-recent-row{border-radius:7px;align-items:center;gap:8px;padding:7px 8px;text-decoration:none;transition:background .12s;display:flex}.si-recent-row:hover{background:#f7f5f1}.si-recent-icon{color:#2a7a8c;background:#edf7f9;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.si-recent-title{color:#1c2b3a;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.8rem;font-weight:500;overflow:hidden}.si-recent-time{color:#9ca3af;white-space:nowrap;font-size:.72rem}.si-panel-empty{color:#9ca3af;margin:0;font-size:.8rem}.si-view-all-btn{text-align:center;color:#2a7a8c;border:1.5px solid #e5ddd0;border-radius:7px;padding:7px 12px;font-size:.78rem;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s;display:block}.si-view-all-btn:hover{background:#f0f9fa;border-color:#2a7a8c}@media (width<=1100px){.si-layout{grid-template-columns:1fr 240px}}@media (width<=900px){.si-layout{grid-template-columns:1fr}.si-panel-col{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}}@media (width<=640px){.songs-content{padding:0 14px 64px}.si-header{flex-direction:column;align-items:flex-start;gap:12px}.si-header-actions{justify-content:flex-start;width:100%}.si-table-wrap{display:none}.si-mobile-list{display:block}.si-panel-col{grid-template-columns:1fr}.si-toolbar{flex-direction:column;align-items:flex-start}.si-sort-wrap{align-self:flex-end}}.sets-page{flex-direction:column;min-height:100vh;display:flex}.sets-content{width:100%;max-width:1320px;margin:0 auto;padding:0 28px 48px}.sets-layout{grid-template-columns:1fr 260px;align-items:start;gap:24px;display:grid}.sets-main-col{flex-direction:column;gap:20px;min-width:0;display:flex}.sets-panel-col{flex-direction:column;gap:14px;display:flex}.sets-calendar-btn{opacity:.55;cursor:not-allowed}.sets-section-head{justify-content:space-between;align-items:center;display:flex}.sets-section-label{text-transform:uppercase;letter-spacing:.07em;color:#d97706;align-items:center;gap:6px;font-size:.78rem;font-weight:700;display:inline-flex}.sets-upcoming-card{background:#fff;border:1px solid #eae3d8;border-radius:12px;overflow:hidden}.sets-upcoming-body{grid-template-columns:1fr 220px;gap:0;display:grid}.sets-upcoming-left{gap:0;min-width:0;padding:0;display:flex}.sets-upcoming-thumb{background:#0c1628;flex-shrink:0;justify-content:center;align-items:center;width:130px;min-height:180px;display:flex}.sets-upcoming-detail{flex:1;min-width:0;padding:20px}.sets-name-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;display:flex}.sets-set-name{font-family:var(--font-display);color:#1c2b3a;font-size:1.2rem;font-weight:700;line-height:1.2}.sets-set-meta{color:#6b7280;flex-wrap:wrap;align-items:center;gap:5px;margin-bottom:14px;font-size:.78rem;display:flex}.sets-meta-sep{color:#d1c4b8}.sets-status-pill{letter-spacing:.04em;text-transform:uppercase;border-radius:10px;align-items:center;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.sets-status-planned{color:#166534;background:#dcfce7}.sets-status-past{color:#6b7280;background:#f3f4f6}.sets-status-draft{color:#b45309;background:#fef3e2}.sets-status-shared{color:#2a7a8c;background:#edf7f9}.sets-song-list{flex-direction:column;gap:3px;display:flex}.sets-song-row{border-radius:5px;align-items:center;gap:8px;padding:4px 6px;transition:background .1s;display:flex}.sets-song-row:hover{background:#f7f5f1}.sets-song-num{color:#9ca3af;font-size:.7rem;font-family:var(--font-mono);min-width:18px}.sets-song-title{color:#1c2b3a;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.82rem;overflow:hidden}.sets-song-key{color:#d97706;font-size:.72rem;font-weight:700;font-family:var(--font-mono);text-align:right;min-width:20px}.sets-song-more{color:#9ca3af;padding-left:26px;font-size:.75rem}.sets-upcoming-right{background:#fdfaf7;border-left:1px solid #f0ebe3;flex-direction:column;gap:18px;padding:20px;display:flex}.sets-panel-sublabel{text-transform:uppercase;letter-spacing:.07em;color:#9ca3af;margin-bottom:7px;font-size:.7rem;font-weight:700;display:block}.sets-notes-text{color:#4a5568;margin:0 0 4px;font-size:.8rem;line-height:1.55}.sets-notes-author{color:#9ca3af;font-size:.7rem}.sets-notes-empty{color:#9ca3af;margin:0;font-size:.78rem;font-style:italic}.sets-team-row{flex-wrap:nowrap;align-items:center;gap:-6px;display:flex}.sets-team-avatar{object-fit:cover;border:2px solid #fff;border-radius:50%;flex-shrink:0;width:28px;height:28px;margin-right:-6px;display:inline-block}.sets-team-init{color:#fff;background:#2a7a8c;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:inline-flex}.sets-team-overflow{color:#6b7280;background:#e5ddd0;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;margin-left:2px;font-size:.65rem;font-weight:700;display:inline-flex}.sets-upcoming-foot{background:#fdfcfa;border-top:1px solid #f0ebe3;align-items:center;gap:10px;padding:14px 20px;display:flex}.sets-upcoming-empty{text-align:center;background:#fff;border:1px solid #eae3d8;border-radius:12px;padding:40px 24px}.sets-all-section{flex-direction:column;gap:14px;display:flex}.sets-all-header{align-items:baseline;gap:10px;display:flex}.sets-all-title{color:#1c2b3a;font-size:1rem;font-weight:700}.sets-all-count{color:#9ca3af;font-size:.78rem}.sets-search-sort-row{align-items:center;gap:10px;display:flex}.sets-tabs{border-bottom:1.5px solid #eae3d8;gap:4px;padding-bottom:0;display:flex}.sets-tab{color:#6b7280;white-space:nowrap;border:1.5px solid #0000;border-bottom:none;border-radius:6px 6px 0 0;margin-bottom:-1.5px;padding:7px 14px;font-size:.8rem;font-weight:500;text-decoration:none;transition:color .12s,background .12s}.sets-tab:hover{color:#2a7a8c}.sets-tab.active{color:#2a7a8c;background:#fff;border-color:#eae3d8 #eae3d8 #fff;font-weight:600}.sets-card-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.sets-card{background:#fff;border:1px solid #eae3d8;border-radius:10px;flex-direction:column;transition:box-shadow .15s;display:flex;overflow:hidden}.sets-card:hover{box-shadow:0 4px 16px #00000012}.sets-card-thumb{background:#0c1628;flex-shrink:0;justify-content:center;align-items:center;height:100px;display:flex;position:relative}.sets-card-thumb-num{color:#ffffff8c;font-size:.68rem;font-family:var(--font-mono);position:absolute;top:8px;right:10px}.sets-card-body{flex:1;min-width:0;padding:12px 14px}.sets-card-name-row{flex-wrap:wrap;align-items:flex-start;gap:6px;margin-bottom:4px;display:flex}.sets-card-name{color:#1c2b3a;flex:1;font-size:.85rem;font-weight:600;line-height:1.3}.sets-card-meta{color:#9ca3af;margin-bottom:10px;font-size:.74rem}.sets-card-songs{flex-direction:column;gap:2px;display:flex}.sets-card-song-row{color:#4a5568;align-items:center;gap:6px;font-size:.74rem;display:flex}.sets-card-song-num{color:#9ca3af;font-family:var(--font-mono);min-width:14px;font-size:.68rem}.sets-card-song-title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sets-card-more{color:#9ca3af;margin-top:2px;padding-left:20px;font-size:.72rem}.sets-card-foot{background:#fdfcfa;border-top:1px solid #f3efe8;align-items:center;gap:4px;padding:8px 10px;display:flex}.sets-empty-state{text-align:center;background:#fff;border:1px solid #eae3d8;border-radius:10px;padding:36px 24px}.sets-stat-rows{flex-direction:column;gap:14px;display:flex}.sets-stat-row{align-items:center;gap:12px;display:flex}.sets-stat-icon-wrap{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sets-stat-info{flex-direction:column;gap:1px;display:flex}.sets-stat-label{color:#6b7280;font-size:.73rem;font-weight:500}.sets-stat-num{color:#1c2b3a;font-size:1.15rem;font-weight:700;line-height:1.1}.sets-stat-unit{color:#9ca3af;font-size:.68rem}.sets-keyflow-grid{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.sets-keyflow-item{flex-direction:column;align-items:center;gap:3px;display:flex}.sets-keyflow-badge{color:#2a7a8c;width:34px;height:34px;font-size:.8rem;font-weight:800;font-family:var(--font-mono);background:#edf7f9;border-radius:50%;justify-content:center;align-items:center;display:flex}.sets-keyflow-count{color:#9ca3af;font-size:.65rem}.sets-keyflow-bars{flex-direction:column;gap:6px;margin-bottom:10px;display:flex}.sets-keyflow-bar-row{align-items:center;gap:7px;display:flex}.sets-keyflow-bar-label{color:#4a5568;font-size:.7rem;font-weight:600;font-family:var(--font-mono);min-width:18px}.sets-keyflow-bar-track{background:#f0ebe1;border-radius:3px;flex:1;height:5px;overflow:hidden}.sets-keyflow-bar-fill{background:#2a7a8c;border-radius:3px;height:100%;transition:width .4s}.sets-keyflow-note{color:#9ca3af;margin:0;font-size:.72rem;font-style:italic}.sets-quick-links{flex-direction:column;gap:6px;display:flex}.sets-quick-link{color:#4a5568;background:#fff;border:1px solid #eae3d8;border-radius:8px;align-items:center;gap:7px;padding:8px 12px;font-size:.78rem;text-decoration:none;transition:background .12s,color .12s;display:flex}.sets-quick-link:hover{color:#2a7a8c;background:#f7f5f1}@media (width<=1100px){.sets-layout{grid-template-columns:1fr 230px}.sets-card-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.sets-layout{grid-template-columns:1fr}.sets-panel-col{grid-template-columns:repeat(2,1fr);display:grid}}@media (width<=700px){.sets-upcoming-body{grid-template-columns:1fr}.sets-upcoming-right{border-top:1px solid #f0ebe3;border-left:none}.sets-upcoming-thumb{width:100%;height:90px;min-height:0}.sets-upcoming-left{flex-direction:column}}@media (width<=640px){.sets-content{padding:0 14px 64px}.sets-card-grid,.sets-panel-col{grid-template-columns:1fr}.sets-tabs{padding-bottom:2px;overflow-x:auto}.sets-search-sort-row{flex-direction:column;align-items:stretch}.si-sort-wrap{align-self:flex-end}}.grp-pg-page{flex-direction:column;min-height:100vh;display:flex}.grp-pg-content{width:100%;max-width:1320px;margin:0 auto;padding:0 28px 48px}.dash-topbar-left{flex:none;align-items:center;gap:8px;display:flex}.grp-back-link{color:#6b7280;align-items:center;gap:5px;font-size:.8rem;font-weight:500;text-decoration:none;transition:color .12s;display:inline-flex}.grp-back-link:hover{color:#2a7a8c}.grp-flash{border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:.82rem}.grp-flash-success{color:#166534;background:#dcfce7;border:1px solid #bbf7d0}.grp-lock-banner{color:#92400e;background:#fff3cd;border:1px solid #fde68a;border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:.82rem;display:flex}.grp-pg-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.grp-pg-empty{text-align:center;background:#fff;border:1px solid #eae3d8;border-radius:12px;max-width:420px;padding:48px 32px}.grp-pg-empty-icon{margin:0 auto 14px;display:block}.grp-pg-card{color:inherit;background:#fff;border:1px solid #eae3d8;border-radius:12px;flex-direction:column;gap:12px;padding:18px;text-decoration:none;transition:box-shadow .15s,border-color .15s;display:flex}.grp-pg-card:hover{border-color:#d0c8bc;box-shadow:0 4px 18px #00000014}.grp-pg-card-locked{opacity:.7}.grp-pg-card-top{align-items:flex-start;gap:12px;display:flex}.grp-pg-avatar{color:#fff;width:44px;height:44px;font-size:1rem;font-weight:800;font-family:var(--font-display);letter-spacing:.02em;background:#0c1628;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.grp-pg-card-info{flex:1;min-width:0}.grp-pg-card-name-row{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:4px;display:flex}.grp-pg-card-name{color:#1c2b3a;font-size:.9rem;font-weight:700;line-height:1.2}.grp-pg-card-desc{color:#6b7280;margin:0;font-size:.78rem;line-height:1.4}.grp-pg-role-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:10px;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.grp-pg-role-admin{color:#2a7a8c;background:#edf7f9}.grp-pg-role-editor{color:#b45309;background:#fef3e2}.grp-pg-role-viewer,.grp-pg-role-member{color:#6b7280;background:#f3f4f6}.grp-pg-locked-pill{color:#b45309;background:#fef3e2;border-radius:10px;align-items:center;gap:3px;padding:2px 7px;font-size:.66rem;font-weight:600;display:inline-flex}.grp-pg-card-stats{border-top:1px solid #f3efe8;flex-wrap:wrap;gap:12px;padding-top:10px;display:flex}.grp-pg-card-stat{color:#6b7280;align-items:center;gap:5px;font-size:.75rem;display:inline-flex}.grp-pg-card-owner{color:#2a7a8c}.grp-pg-card-foot{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.grp-pg-open-btn{color:#2a7a8c;flex:1;font-size:.8rem;font-weight:600}.grp-pg-edit-chip{color:#6b7280;cursor:pointer;background:#f7f5f1;border:1px solid #eae3d8;border-radius:7px;align-items:center;gap:4px;padding:4px 10px;font-size:.74rem;transition:background .12s;display:inline-flex}.grp-pg-edit-chip:hover{color:#1c2b3a;background:#f0ebe1}.grp-ws-header{background:#fff;border:1px solid #eae3d8;border-radius:12px;flex-wrap:wrap;align-items:flex-start;gap:20px;margin-bottom:0;padding:22px 24px;display:flex}.grp-ws-header-main{flex:1;align-items:flex-start;gap:16px;min-width:220px;display:flex}.grp-ws-avatar{color:#fff;width:56px;height:56px;font-size:1.3rem;font-weight:800;font-family:var(--font-display);letter-spacing:.03em;background:#0c1628;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.grp-ws-info{flex:1;min-width:0}.grp-ws-name-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.grp-ws-name{font-family:var(--font-display);color:#1c2b3a;margin:0;font-size:1.35rem;font-weight:700;line-height:1.15}.grp-ws-desc{color:#6b7280;margin:0 0 6px;font-size:.82rem;line-height:1.45}.grp-ws-meta{color:#9ca3af;margin:0;font-size:.74rem}.grp-ws-header-stats{flex-wrap:wrap;flex-shrink:0;gap:6px;display:flex}.grp-ws-stat{text-align:center;background:#f7f5f1;border:1px solid #eae3d8;border-radius:9px;flex-direction:column;align-items:center;gap:2px;min-width:80px;padding:12px 18px;display:flex}.grp-ws-stat-num{color:#1c2b3a;font-size:1.35rem;font-weight:800;line-height:1}.grp-ws-stat-label{color:#6b7280;white-space:nowrap;font-size:.67rem;font-weight:500}.grp-ws-header-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.grp-ws-tabs{border-bottom:1.5px solid #eae3d8;gap:4px;margin-top:16px;padding-bottom:0;display:flex;overflow-x:auto}.grp-ws-tab{color:#6b7280;cursor:pointer;font-size:.8rem;font-weight:500;font-family:var(--font-body);white-space:nowrap;background:0 0;border:1.5px solid #0000;border-bottom:none;border-radius:6px 6px 0 0;align-items:center;gap:6px;margin-bottom:-1.5px;padding:8px 16px;transition:color .12s,background .12s;display:inline-flex}.grp-ws-tab:hover{color:#2a7a8c}.grp-ws-tab.active{color:#2a7a8c;background:#fff;border-color:#eae3d8 #eae3d8 #fff;font-weight:600}.grp-tab-count{color:#6b7280;background:#f0ebe1;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.66rem;font-weight:700;display:inline-flex}.grp-tab-count-alert{color:#b45309;background:#fef3e2}.grp-ws-body{grid-template-columns:1fr 280px;align-items:start;gap:20px;margin-top:16px;display:grid}.grp-ws-main{flex-direction:column;gap:0;min-width:0;display:flex}.grp-ws-sidebar{flex-direction:column;gap:14px;display:flex}.grp-tab-pane-hidden{display:none}.grp-section-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.grp-section-title{color:#1c2b3a;font-size:.92rem;font-weight:700}.grp-section-sub{color:#9ca3af;margin:0;font-size:.78rem}.grp-card-subtitle{color:#1c2b3a;margin:0;font-size:.82rem;font-weight:600}.grp-ws-card{background:#fff;border:1px solid #eae3d8;border-radius:10px;overflow:hidden}.grp-member-table-wrap{overflow-x:auto}.grp-member-table{border-collapse:collapse;width:100%;font-size:.82rem}.grp-member-table thead tr{background:#f7f5f1;border-bottom:1px solid #eae3d8}.grp-th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;padding:9px 14px;font-size:.7rem;font-weight:700}.grp-th-sm{text-align:center;width:70px}.grp-th-actions{width:48px}.grp-member-row{border-bottom:1px solid #f3efe8;transition:background .1s}.grp-member-row:last-child{border-bottom:none}.grp-member-row:hover{background:#fdfcfa}.grp-td{vertical-align:middle;color:#1c2b3a;padding:11px 14px}.grp-td-muted{color:#9ca3af;white-space:nowrap;font-size:.78rem}.grp-td-actions{text-align:right}.grp-member-cell{align-items:center;gap:10px;display:flex}.grp-member-img{object-fit:cover;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex}.grp-member-ini{color:#fff;background:#2a7a8c;font-size:.7rem;font-weight:700}.grp-member-ident{min-width:0}.grp-member-name{color:#1c2b3a;font-size:.83rem;font-weight:600;display:block}.grp-member-email{color:#9ca3af;font-size:.73rem;display:block}.grp-you-chip{color:#9ca3af;margin-left:4px;font-size:.68rem;font-weight:400}.grp-instrument-tags{flex-wrap:wrap;gap:4px;display:flex}.grp-instrument-tag{color:#4a5568;white-space:nowrap;background:#f3f0eb;border-radius:10px;padding:2px 8px;font-size:.7rem;font-weight:500;display:inline-flex}.grp-role-pill{text-transform:uppercase;letter-spacing:.04em;border-radius:10px;padding:3px 9px;font-size:.68rem;font-weight:700;display:inline-flex}.grp-role-pill-admin{color:#2a7a8c;background:#edf7f9}.grp-role-pill-editor{color:#b45309;background:#fef3e2}.grp-role-pill-viewer{color:#6b7280;background:#f3f4f6}.grp-role-select{font-size:.78rem;font-family:var(--font-body);appearance:none;color:#1c2b3a;cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 20 20' fill='%236B7280'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E") right 8px center no-repeat;border:1.5px solid #eae3d8;border-radius:7px;outline:none;padding:5px 28px 5px 10px}.grp-member-cards{display:none}.grp-member-card{border-bottom:1px solid #f3efe8;align-items:center;gap:10px;padding:12px 16px;display:flex}.grp-member-card:last-child{border-bottom:none}.grp-member-card-left{flex-shrink:0}.grp-member-card-body{flex:1;min-width:0}.grp-member-card-top{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.grp-song-table{border-collapse:collapse;width:100%;font-size:.82rem}.grp-song-table thead tr{background:#f7f5f1;border-bottom:1px solid #eae3d8}.grp-song-row{border-bottom:1px solid #f3efe8;transition:background .1s}.grp-song-row:last-child{border-bottom:none}.grp-song-row:hover{background:#fdfcfa}.grp-song-cell{align-items:center;gap:10px;display:flex}.grp-song-thumb{background:#0c1628;border-radius:6px;flex-shrink:0;width:30px;height:30px}.grp-song-title-text{color:#1c2b3a;font-size:.83rem;font-weight:600;display:block}.grp-song-artist{color:#9ca3af;font-size:.73rem;display:block}.grp-added-by-cell{align-items:center;gap:7px;display:flex}.grp-mini-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.grp-mini-init{color:#fff;background:#2a7a8c;font-size:.6rem;font-weight:700}.grp-ls-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.grp-ls-card{background:#fff;border:1px solid #eae3d8;border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.grp-ls-card-thumb{background:#0c1628;flex-shrink:0;height:80px}.grp-ls-card-body{flex:1;min-width:0;padding:12px 14px}.grp-ls-card-name-row{flex-wrap:wrap;align-items:flex-start;gap:6px;margin-bottom:4px;display:flex}.grp-ls-card-name{color:#1c2b3a;flex:1;font-size:.84rem;font-weight:600}.grp-ls-card-meta{color:#9ca3af;font-size:.73rem}.grp-invite-hint{color:#9ca3af;font-size:.74rem}.grp-invite-link-row{align-items:center;gap:8px;display:flex}.grp-invite-link-input{flex:1;font-size:.74rem}.grp-pending-inv-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.grp-pending-pill{color:#b45309;white-space:nowrap;background:#fef3e2;border-radius:10px;padding:2px 8px;font-size:.66rem;font-weight:700;display:inline-flex}.grp-invite-link-compact{margin-top:4px}.grp-tab-link{color:#2a7a8c;cursor:pointer;font-size:.75rem;font-family:var(--font-body);text-align:left;background:0 0;border:none;padding:0}.grp-empty-state{text-align:center;padding:36px 24px}.grp-form-card{background:#fff;border:1px solid #eae3d8;border-radius:12px;max-width:560px;padding:28px}.grp-form-field{flex-direction:column;gap:6px;display:flex}.grp-form-label{color:#1c2b3a;font-size:.82rem;font-weight:600}.grp-required{color:#c53030}.grp-form-optional{color:#9ca3af;font-size:.78rem;font-weight:400}@media (width<=1100px){.grp-ws-body{grid-template-columns:1fr 240px}}@media (width<=900px){.grp-ws-body{grid-template-columns:1fr}.grp-ws-sidebar{grid-template-columns:repeat(2,1fr);display:grid}.grp-ws-header{flex-direction:column;gap:14px}.grp-ws-header-stats{width:100%}.grp-ws-stat{flex:1}}@media (width<=700px){.grp-member-table-wrap{display:none}.grp-member-cards{flex-direction:column;display:flex}}@media (width<=640px){.grp-pg-content{padding:0 14px 64px}.grp-ws-sidebar,.grp-ls-grid,.grp-pg-grid{grid-template-columns:1fr}.grp-ws-header-actions{width:100%}.grp-ws-stat{min-width:70px}}.lc-lib-page{flex-direction:column;min-height:100%;display:flex}.lc-lib-content{padding:0 28px 60px}.lc-lib-layout{grid-template-columns:1fr 276px;align-items:start;gap:24px;display:grid}.lc-lib-filter-section{margin-bottom:20px}.lc-lib-search-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.lc-lib-search-box{background:#fff;border:1.5px solid #e2d8c9;border-radius:10px;flex:1;align-items:center;gap:8px;height:42px;padding:0 12px;transition:border-color .15s;display:flex}.lc-lib-search-box:focus-within{border-color:#2a7a8c}.lc-lib-search-icon{color:#6b7280;flex-shrink:0}.lc-lib-search-input{color:#1c2b3a;font-size:.88rem;font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;min-width:0}.lc-lib-search-input::placeholder{color:#6b7280}.lc-lib-search-clear{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;display:flex}.lc-lib-search-clear:hover{color:var(--danger)}.lc-lib-sort-select{color:#1c2b3a;height:42px;font-size:.82rem;font-family:var(--font-body);cursor:pointer;appearance:none;white-space:nowrap;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 20 20' fill='%234A5568'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E") right 8px center no-repeat;border:1.5px solid #e2d8c9;border-radius:10px;outline:none;flex-shrink:0;padding:0 28px 0 11px;font-weight:500}.lc-lib-sort-select:focus{border-color:#2a7a8c}.lc-lib-chips{scrollbar-width:none;flex-wrap:nowrap;gap:6px;margin-bottom:14px;padding-bottom:4px;display:flex;overflow-x:auto}.lc-lib-chips::-webkit-scrollbar{display:none}.lc-lib-chip{color:#6b7280;white-space:nowrap;font-size:.76rem;font-weight:600;font-family:var(--font-body);background:#fff;border:1.5px solid #e2d8c9;border-radius:20px;align-items:center;padding:5px 14px;text-decoration:none;transition:border-color .14s,color .14s,background .14s;display:inline-flex}.lc-lib-chip:hover{color:#2a7a8c;border-color:#2a7a8c}.lc-lib-chip.active{background:rgba(var(--primary-rgb), .1);color:#2a7a8c;border-color:#2a7a8c}.lc-lib-toolbar{justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.lc-lib-count{color:#6b7280;font-size:.8rem;font-weight:500}.lc-lib-clear-link{color:#6b7280;align-items:center;gap:5px;font-size:.76rem;font-weight:600;text-decoration:none;transition:color .12s;display:inline-flex}.lc-lib-clear-link:hover{color:var(--danger)}.lc-lib-grid{grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:28px;display:grid}.lc-lib-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:12px;flex-direction:column;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex;overflow:hidden}.lc-lib-card:hover{border-color:#2a7a8c52;transform:translateY(-1px);box-shadow:0 4px 20px #0a112812}.lc-lib-card-body{flex-direction:column;flex:1;gap:5px;padding:16px 18px 12px;display:flex}.lc-lib-card-head{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:2px;display:flex}.lc-lib-card-title{color:#1c2b3a;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;min-width:0;font-size:.94rem;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.lc-lib-card-menu-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:3px 5px;line-height:1;text-decoration:none}.lc-lib-card-menu-btn:hover{color:#1c2b3a;background:#f0ebe1}.lc-lib-card-artist{color:#6b7280;font-size:.78rem;font-weight:500}.lc-lib-card-badges{flex-wrap:wrap;gap:4px;margin-top:3px;display:flex}.lc-lib-card-badge{border-radius:20px;padding:2px 8px;font-size:.64rem;font-weight:700}.lc-lib-badge-cat{color:#2a7a8c;background:#2a7a8c1a}.lc-lib-badge-lang{color:#6b7280;background:#f0ebe1}.lc-lib-badge-chords{color:#6b7280;background:#f3f4f6}.lc-lib-card-preview{color:#6b7280;-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;margin-top:6px;font-size:.77rem;line-height:1.55;display:-webkit-box;overflow:hidden}.lc-lib-card-actions{border-top:1px solid #e2d8c9;display:flex}.lc-lib-action-btn{color:#6b7280;cursor:pointer;font-size:.73rem;font-weight:600;font-family:var(--font-body);white-space:nowrap;background:0 0;border:none;border-right:1px solid #e2d8c9;flex:1;justify-content:center;align-items:center;gap:5px;padding:9px 6px;text-decoration:none;transition:color .12s,background .12s;display:inline-flex}.lc-lib-action-btn:last-child{border-right:none}.lc-lib-action-btn:hover{color:#1c2b3a;background:#f0ebe1}.lc-lib-action-primary{color:#2a7a8c}.lc-lib-action-primary:hover{color:#2a7a8c;background:#2a7a8c14}.lc-lib-empty{text-align:center;background:#fff;border:1.5px solid #e2d8c9;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:52px 24px;display:flex}.lc-lib-empty-title{color:#1c2b3a;margin:4px 0 0;font-size:1.05rem;font-weight:700}.lc-lib-empty-desc{color:#6b7280;margin-bottom:8px;font-size:.84rem}.lc-lib-panel{flex-direction:column;gap:16px;display:flex;position:sticky;top:24px}.lc-lib-panel-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:12px;padding:18px 20px}.lc-lib-panel-title{text-transform:uppercase;letter-spacing:.09em;color:#6b7280;margin-bottom:14px;font-size:.7rem;font-weight:700}.lc-lib-panel-title-row{justify-content:space-between;align-items:center;display:flex}.lc-lib-panel-view-all{color:#2a7a8c;font-size:.75rem;font-weight:600;text-decoration:none}.lc-lib-panel-view-all:hover{text-decoration:underline}.lc-lib-stat-row{border-bottom:1px solid #e2d8c9;justify-content:space-between;align-items:center;padding:9px 0;display:flex}.lc-lib-stat-row:last-child{border-bottom:none}.lc-lib-stat-label{color:#6b7280;align-items:center;gap:10px;font-size:.82rem;font-weight:500;display:flex}.lc-lib-stat-icon{background:#2a7a8c14;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.lc-lib-stat-value{color:#1c2b3a;font-size:.95rem;font-weight:700}.lc-lib-recent-item{border-bottom:1px solid #e2d8c9;align-items:center;gap:10px;padding:7px 0;text-decoration:none;display:flex}.lc-lib-recent-item:last-child{border-bottom:none}.lc-lib-recent-initial{color:#6b7280;width:28px;height:28px;font-size:.7rem;font-weight:800;font-family:var(--font-body);background:#f0ebe1;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.lc-lib-recent-info{flex:1;min-width:0}.lc-lib-recent-name{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.lc-lib-recent-artist{color:#6b7280;font-size:.71rem}.lc-lib-recent-ago{color:#6b7280;flex-shrink:0;font-size:.7rem}.lc-lib-recent-item:hover .lc-lib-recent-name{color:#2a7a8c}.lc-lib-cat-item{cursor:pointer;border-bottom:1px solid #e2d8c9;align-items:center;gap:8px;padding:7px 0;text-decoration:none;display:flex}.lc-lib-cat-item:last-child{border-bottom:none}.lc-lib-cat-item:hover .lc-lib-cat-name{color:#2a7a8c}.lc-lib-cat-item.active .lc-lib-cat-name{color:#2a7a8c;font-weight:700}.lc-lib-cat-icon{color:#6b7280;flex-shrink:0}.lc-lib-cat-name{color:#1c2b3a;flex:1;font-size:.8rem;font-weight:500}.lc-lib-cat-count{color:#6b7280;font-size:.76rem;font-weight:700}.lcs-page{flex-direction:column;min-height:100%;display:flex}.lcs-content{padding:0 28px 60px}.lcs-header{border-bottom:1px solid #e2d8c9;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;padding-bottom:20px;display:flex}.lcs-header-main{flex:1;align-items:flex-start;gap:16px;min-width:0;display:flex}.lcs-header-initial{color:#2a7a8c;width:52px;height:52px;font-size:1.4rem;font-weight:800;font-family:var(--font-display);background:#2a7a8c1a;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.lcs-header-info{flex:1;min-width:0}.lcs-title{font-family:var(--font-display);color:#1c2b3a;margin:0 0 4px;font-size:1.9rem;font-weight:700;line-height:1.15}.lcs-artist{color:#6b7280;margin:0 0 10px;font-size:.9rem}.lcs-badges{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.lcs-badge{border-radius:20px;padding:3px 9px;font-size:.68rem;font-weight:700}.lcs-badge-cat{color:#2a7a8c;background:#2a7a8c1a}.lcs-badge-lang,.lcs-badge-meta{color:#6b7280;background:#f0ebe1}.lcs-badge-chords{color:#6b7280;background:#f3f4f6}.lcs-header-actions{flex-wrap:wrap;flex-shrink:0;align-items:flex-start;gap:8px;display:flex}.lcs-action-sm{padding:7px 14px!important;font-size:.78rem!important}.lcs-delete-btn{font-size:.78rem;font-weight:600;font-family:var(--font-body);color:var(--danger);cursor:pointer;background:0 0;border:1.5px solid #c530304d;border-radius:8px;align-items:center;padding:7px 14px;transition:background .12s,border-color .12s;display:inline-flex}.lcs-delete-btn:hover{border-color:var(--danger);background:#c5303012}.lcs-body{grid-template-columns:1fr 264px;align-items:start;gap:20px;display:grid}.lcs-main{min-width:0}.lcs-content-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:14px;min-height:280px;padding:24px 28px 32px}.lcs-chart{padding:0!important}.lcs-no-content{color:#6b7280;flex-direction:column;align-items:center;gap:10px;padding:40px 0;font-size:.88rem;display:flex}.lcs-sidebar{flex-direction:column;gap:16px;display:flex;position:sticky;top:24px}.lcs-panel-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:12px;padding:18px 20px}.lcs-panel-title{text-transform:uppercase;letter-spacing:.09em;color:#6b7280;margin-bottom:14px;font-size:.7rem;font-weight:700}.lcs-panel-label{color:#1c2b3a;margin-bottom:6px;font-size:.78rem;font-weight:600;display:block}.lcs-select{color:#1c2b3a;width:100%;font-size:.84rem;font-family:var(--font-body);cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 20 20' fill='%234A5568'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E") right 10px center no-repeat;border:1.5px solid #e2d8c9;border-radius:8px;outline:none;margin-bottom:10px;padding:8px 30px 8px 11px}.lcs-select:focus{border-color:#2a7a8c}.lcs-input{color:#1c2b3a;width:100%;font-size:.84rem;font-family:var(--font-body);box-sizing:border-box;background:#fff;border:1.5px solid #e2d8c9;border-radius:8px;outline:none;margin-bottom:10px;padding:8px 11px}.lcs-input:focus{border-color:#2a7a8c}.lcs-add-btn{justify-content:center;width:100%;margin-bottom:10px}.lcs-new-set-toggle{color:#2a7a8c;cursor:pointer;font-size:.76rem;font-weight:600;font-family:var(--font-body);text-align:center;background:0 0;border:none;width:100%;padding:0;transition:opacity .12s;display:block}.lcs-new-set-toggle:hover{opacity:.75}.lcs-hidden{display:none!important}.lcs-upgrade-note{color:#6b7280;margin-bottom:12px;font-size:.8rem;line-height:1.5}.lcs-info-row{border-bottom:1px solid #e2d8c9;justify-content:space-between;align-items:center;padding:7px 0;display:flex}.lcs-info-row:last-child{border-bottom:none}.lcs-info-label{color:#6b7280;font-size:.78rem;font-weight:500}.lcs-info-value{color:#1c2b3a;font-size:.84rem;font-weight:600}@media (width<=1100px){.lc-lib-layout{grid-template-columns:1fr 250px}.lc-lib-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.lc-lib-layout{grid-template-columns:1fr}.lc-lib-panel{grid-template-columns:repeat(2,1fr);display:grid;position:static}.lcs-body{grid-template-columns:1fr}.lcs-sidebar{position:static}}@media (width<=700px){.lc-lib-content,.lcs-content{padding:0 14px 60px}.lcs-header{flex-direction:column}.lcs-title{font-size:1.55rem}}@media (width<=640px){.lc-lib-grid,.lc-lib-panel{grid-template-columns:1fr}.lcs-header-main{flex-direction:column;gap:10px}.lcs-header-initial{width:42px;height:42px;font-size:1.1rem}}.comm-page{flex-direction:column;min-height:100%;display:flex}.comm-content{padding:0 28px 60px}.comm-layout{grid-template-columns:1fr 280px;align-items:start;gap:24px;display:grid}.comm-main{min-width:0}.comm-panel{flex-direction:column;gap:16px;display:flex;position:sticky;top:24px}.comm-filter-section{margin-bottom:20px}.comm-search-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.comm-search-box{background:#fff;border:1.5px solid #e2d8c9;border-radius:10px;flex:1;align-items:center;gap:8px;height:42px;padding:0 12px;transition:border-color .15s;display:flex}.comm-search-box:focus-within{border-color:#2a7a8c}.comm-search-icon{color:#6b7280;flex-shrink:0}.comm-search-input{color:#1c2b3a;font-size:.88rem;font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;min-width:0}.comm-search-input::placeholder{color:#6b7280}.comm-sort-select{color:#1c2b3a;height:42px;font-size:.82rem;font-family:var(--font-body);cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 20 20' fill='%234A5568'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E") right 8px center no-repeat;border:1.5px solid #e2d8c9;border-radius:10px;outline:none;flex-shrink:0;padding:0 28px 0 11px;font-weight:500}.comm-sort-select:focus{border-color:#2a7a8c}.comm-chips{scrollbar-width:none;flex-wrap:nowrap;gap:6px;margin-bottom:14px;padding-bottom:4px;display:flex;overflow-x:auto}.comm-chips::-webkit-scrollbar{display:none}.comm-chip{color:#6b7280;white-space:nowrap;font-size:.76rem;font-weight:600;font-family:var(--font-body);background:#fff;border:1.5px solid #e2d8c9;border-radius:20px;align-items:center;padding:5px 14px;text-decoration:none;transition:border-color .14s,color .14s,background .14s;display:inline-flex}.comm-chip:hover{color:#2a7a8c;border-color:#2a7a8c}.comm-chip.active{background:rgba(var(--primary-rgb), .1);color:#2a7a8c;border-color:#2a7a8c}.comm-toolbar{justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.comm-count{color:#6b7280;font-size:.8rem;font-weight:500}.comm-clear-link{color:#6b7280;align-items:center;gap:5px;font-size:.76rem;font-weight:600;text-decoration:none;transition:color .12s;display:inline-flex}.comm-clear-link:hover{color:var(--danger)}.comm-featured-wrap{margin-bottom:28px}.comm-featured-eyebrow{color:#d97706;text-transform:uppercase;letter-spacing:.07em;align-items:center;gap:6px;margin-bottom:10px;font-size:.74rem;font-weight:700;display:flex}.comm-featured-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:14px;transition:box-shadow .15s;display:flex;overflow:hidden}.comm-featured-card:hover{box-shadow:0 6px 28px #0a112817}.comm-featured-thumb{background:#1c2b3a;flex-shrink:0;justify-content:center;align-items:center;width:220px;min-width:220px;text-decoration:none;display:flex}.comm-featured-initial{font-size:5rem;font-weight:800;font-family:var(--font-display);color:#ffffff1f;-webkit-user-select:none;user-select:none}.comm-featured-body{flex-direction:column;flex:1;gap:8px;min-width:0;padding:22px 24px;display:flex}.comm-featured-title{font-family:var(--font-display);color:#1c2b3a;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:1.65rem;font-weight:700;line-height:1.15;display:-webkit-box;overflow:hidden}.comm-featured-artist{color:#6b7280;font-size:.84rem}.comm-featured-meta{flex-wrap:wrap;gap:5px;display:flex}.comm-featured-key{color:#2a7a8c;background:rgba(var(--primary-rgb), .09);font-size:.7rem;font-weight:700;font-family:var(--font-mono);border-radius:6px;padding:3px 8px}.comm-featured-pill{color:#6b7280;background:#f0ebe1;border-radius:6px;padding:3px 8px;font-size:.7rem;font-weight:600}.comm-featured-pub{align-items:center;gap:7px;display:flex}.comm-featured-pub-av{object-fit:cover;border-radius:50%;flex-shrink:0;width:24px;height:24px}.comm-featured-pub-av-init{color:#2a7a8c;width:24px;height:24px;font-size:.65rem;font-weight:800;font-family:var(--font-body);background:#2a7a8c1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.comm-featured-pub-info{flex-direction:column;display:flex}.comm-featured-pub-name{color:#1c2b3a;font-size:.78rem;font-weight:600;text-decoration:none}.comm-featured-pub-name:hover{color:#2a7a8c}.comm-featured-pub-time{color:#6b7280;font-size:.7rem}.comm-featured-preview{color:#6b7280;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:.81rem;line-height:1.55;display:-webkit-box;overflow:hidden}.comm-featured-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.comm-featured-bm-btn{font-size:.78rem;font-weight:600;font-family:var(--font-body);color:#6b7280;cursor:pointer;background:0 0;border:1.5px solid #e2d8c9;border-radius:8px;align-items:center;gap:5px;padding:7px 14px;transition:color .12s,border-color .12s;display:inline-flex}.comm-featured-bm-btn:hover,.comm-featured-bm-btn.bookmarked{color:#d97706;border-color:#d97706}.comm-featured-follow-btn{font-size:.78rem;font-weight:600;font-family:var(--font-body);color:#2a7a8c;cursor:pointer;background:0 0;border:1.5px solid #2a7a8c;border-radius:8px;align-items:center;gap:5px;padding:7px 14px;transition:background .12s;display:inline-flex}.comm-featured-follow-btn:hover,.comm-featured-following-btn{background:#2a7a8c14}.comm-section-hd{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.comm-section-title{color:#1c2b3a;margin:0;font-size:.9rem;font-weight:700}.comm-section-link{color:#2a7a8c;font-size:.76rem;font-weight:600;text-decoration:none}.comm-section-link:hover{text-decoration:underline}.comm-song-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.comm-song-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:12px;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.comm-song-card:hover{border-color:#2a7a8c4d;box-shadow:0 3px 16px #0a11280f}.comm-song-thumb{background:#1c2b3a;flex-shrink:0;justify-content:center;align-items:center;width:70px;min-width:70px;text-decoration:none;display:flex}.comm-song-initial{font-size:1.4rem;font-weight:800;font-family:var(--font-display);color:#ffffff29}.comm-song-body{flex-direction:column;flex:1;gap:4px;min-width:0;padding:10px 11px;display:flex}.comm-song-head{justify-content:space-between;align-items:flex-start;gap:5px;display:flex}.comm-song-title-wrap{flex:1;min-width:0}.comm-song-title{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.84rem;font-weight:700;line-height:1.25;overflow:hidden}.comm-song-artist{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.71rem;overflow:hidden}.comm-bm-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;flex-shrink:0;padding:1px;line-height:1;transition:color .12s}.comm-bm-btn:hover,.comm-bm-active{color:#d97706}.comm-song-meta{flex-wrap:wrap;gap:3px;display:flex}.comm-key-pill{color:#2a7a8c;background:rgba(var(--primary-rgb), .09);font-size:.61rem;font-weight:700;font-family:var(--font-mono);border-radius:5px;padding:2px 6px}.comm-meta-pill,.comm-lang-pill{color:#6b7280;background:#f0ebe1;border-radius:5px;padding:2px 6px;font-size:.61rem;font-weight:600}.comm-song-tags{flex-wrap:wrap;gap:3px;display:flex}.comm-song-tag{color:#2a7a8c;background:#2a7a8c14;border-radius:5px;padding:2px 7px;font-size:.61rem;font-weight:600;text-decoration:none}.comm-song-tag:hover{background:#2a7a8c26}.comm-song-foot{justify-content:space-between;align-items:center;gap:4px;margin-top:auto;padding-top:4px;display:flex}.comm-song-pub{align-items:center;gap:4px;min-width:0;display:flex;overflow:hidden}.comm-pub-av{object-fit:cover;border-radius:50%;flex-shrink:0;width:18px;height:18px}.comm-pub-av-init{color:#2a7a8c;width:18px;height:18px;font-size:.58rem;font-weight:800;font-family:var(--font-body);background:#2a7a8c1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.comm-pub-name{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;max-width:76px;font-size:.68rem;font-weight:600;text-decoration:none;overflow:hidden}.comm-pub-name:hover{color:#2a7a8c}.comm-pub-time{display:none}.comm-song-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.comm-follow-btn{color:#2a7a8c;cursor:pointer;font-size:.6rem;font-weight:700;font-family:var(--font-body);white-space:nowrap;background:0 0;border:1.5px solid #2a7a8c;border-radius:5px;padding:3px 7px;transition:background .12s}.comm-follow-btn:hover,.comm-following-btn{background:#2a7a8c14}.comm-open-btn{color:#fff;white-space:nowrap;background:#2a7a8c;border-radius:5px;align-items:center;padding:3px 8px;font-size:.6rem;font-weight:700;text-decoration:none;transition:background .12s;display:inline-flex}.comm-open-btn:hover{background:#236876}.comm-empty{text-align:center;background:#fff;border:1.5px solid #e2d8c9;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:52px 24px;display:flex}.comm-empty-title{color:#1c2b3a;margin:4px 0 0;font-size:1.05rem;font-weight:700}.comm-empty-desc{color:#6b7280;margin-bottom:8px;font-size:.84rem}.comm-pagination-info{color:#6b7280;margin-top:10px;font-size:.77rem}.comm-panel-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:12px;padding:16px 18px}.comm-panel-title-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.comm-panel-title{text-transform:uppercase;letter-spacing:.09em;color:#6b7280;margin:0;font-size:.7rem;font-weight:700}.comm-panel-view-all{color:#2a7a8c;font-size:.74rem;font-weight:600;text-decoration:none}.comm-panel-view-all:hover{text-decoration:underline}.comm-musician-item{border-bottom:1px solid #e2d8c9;align-items:center;gap:10px;padding:7px 0;display:flex}.comm-musician-item:last-child{border-bottom:none}.comm-musician-av{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.comm-musician-av-init{color:#2a7a8c;width:32px;height:32px;font-size:.72rem;font-weight:800;font-family:var(--font-body);background:#2a7a8c1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.comm-musician-info{flex:1;min-width:0}.comm-musician-name{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;text-decoration:none;display:block;overflow:hidden}.comm-musician-name:hover{color:#2a7a8c}.comm-musician-instrument{color:#6b7280;font-size:.71rem}.comm-musician-follow{color:#2a7a8c;cursor:pointer;font-size:.69rem;font-weight:700;font-family:var(--font-body);white-space:nowrap;background:0 0;border:1.5px solid #2a7a8c;border-radius:6px;flex-shrink:0;padding:4px 10px;transition:background .12s}.comm-musician-follow:hover{background:#2a7a8c14}.comm-musician-following{color:#2a7a8c;background:#2a7a8c14;border-color:#2a7a8c}.comm-tag-cloud{flex-wrap:wrap;gap:6px;display:flex}.comm-tag-chip{color:#1c2b3a;background:#f0ebe1;border-radius:20px;align-items:center;gap:4px;padding:5px 10px;font-size:.73rem;font-weight:600;text-decoration:none;transition:background .12s;display:inline-flex}.comm-tag-chip:hover,.comm-tag-chip.active{color:#2a7a8c;background:#2a7a8c1a}.comm-tag-count{color:#6b7280;font-size:.67rem;font-weight:500}.comm-stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;display:grid}.comm-stat-box{background:#f0ebe1;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;display:flex}.comm-stat-icon{background:#2a7a8c1a;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.comm-stat-value{color:#1c2b3a;font-size:.86rem;font-weight:700;display:block}.comm-stat-label{color:#6b7280;font-size:.67rem}.comm-guide-btn{color:#6b7280;text-align:center;border:1.5px solid #e2d8c9;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;padding:8px 12px;font-size:.78rem;font-weight:600;text-decoration:none;transition:border-color .12s,color .12s;display:flex}.comm-guide-btn:hover{color:#2a7a8c;border-color:#2a7a8c}.comm-person-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:12px;align-items:center;gap:10px;padding:12px 14px;transition:border-color .14s;display:flex}.comm-person-card:hover{border-color:#2a7a8c4d}.comm-person-link{flex:1;align-items:center;gap:10px;min-width:0;text-decoration:none;display:flex}.comm-person-av{object-fit:cover;border-radius:50%;flex-shrink:0;width:36px;height:36px}.comm-person-av-init{color:#2a7a8c;width:36px;height:36px;font-size:.82rem;font-weight:800;font-family:var(--font-body);background:#2a7a8c1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.comm-person-info{min-width:0}.comm-person-name{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;font-size:.84rem;font-weight:600;display:block;overflow:hidden}.comm-person-link:hover .comm-person-name{color:#2a7a8c}.comm-person-instrument{color:#6b7280;font-size:.72rem}.uprof-page{flex-direction:column;min-height:100%;display:flex}.uprof-content{padding:0 28px 60px}.uprof-header{background:#fff;border:1.5px solid #e2d8c9;border-radius:14px;margin-bottom:24px;padding:24px}.uprof-header-inner{flex-wrap:wrap;align-items:flex-start;gap:20px;display:flex}.uprof-av{object-fit:cover;border-radius:18px;flex-shrink:0;width:72px;height:72px}.uprof-av-init{color:#2a7a8c;width:72px;height:72px;font-size:1.8rem;font-weight:800;font-family:var(--font-display);background:#2a7a8c1a;border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.uprof-info{flex:1;min-width:200px}.uprof-name{font-family:var(--font-display);color:#1c2b3a;margin:0 0 4px;font-size:1.65rem;font-weight:700;line-height:1.15}.uprof-meta{color:#6b7280;margin-bottom:8px;font-size:.82rem}.uprof-bio{color:#1c2b3a;margin-bottom:12px;font-size:.84rem;line-height:1.55}.uprof-stats{flex-wrap:wrap;gap:20px;display:flex}.uprof-stat{font-size:.82rem}.uprof-stat-val{color:#1c2b3a;font-weight:700}.uprof-stat-label{color:#6b7280}.uprof-actions{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.uprof-tabs{scrollbar-width:none;border-bottom:2px solid #e2d8c9;gap:0;margin-bottom:20px;display:flex;overflow-x:auto}.uprof-tabs::-webkit-scrollbar{display:none}.uprof-tab{color:#6b7280;white-space:nowrap;border-bottom:2.5px solid #0000;margin-bottom:-2px;padding:10px 16px;font-size:.84rem;font-weight:600;text-decoration:none;transition:color .12s}.uprof-tab:hover{color:#1c2b3a}.uprof-tab.active{color:#2a7a8c;border-bottom-color:#2a7a8c}.uprof-tab-count{color:#6b7280;background:#f0ebe1;border-radius:10px;margin-left:4px;padding:1px 6px;font-size:.72rem}.uprof-activity-feed{flex-direction:column;gap:0;display:flex}.uprof-activity-item{gap:14px;padding-bottom:20px;display:flex;position:relative}.uprof-activity-item:last-child{padding-bottom:0}.uprof-activity-spine{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.uprof-activity-dot{color:#2a7a8c;background:#2a7a8c1a;border:2px solid #2a7a8c40;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;display:flex}.uprof-activity-line{background:#e2d8c9;flex:1;width:2px;margin:4px 0}.uprof-activity-item:last-child .uprof-activity-line{display:none}.uprof-activity-body{flex:1;min-width:0;padding-top:4px}.uprof-activity-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-size:.72rem;font-weight:600}.uprof-activity-title{color:#1c2b3a;font-size:.88rem;font-weight:600;text-decoration:none;display:block}.uprof-activity-title:hover{color:#2a7a8c}.uprof-activity-time{color:#6b7280;margin-top:4px;font-size:.72rem}.uprof-key-badge{color:#2a7a8c;background:rgba(var(--primary-rgb), .09);font-size:.62rem;font-weight:700;font-family:var(--font-mono);border-radius:5px;margin-left:6px;padding:2px 7px}.uprof-people-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}@media (width<=1100px){.comm-layout{grid-template-columns:1fr 250px}.comm-song-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.comm-layout{grid-template-columns:1fr}.comm-panel{grid-template-columns:repeat(2,1fr);display:grid;position:static}.comm-song-grid{grid-template-columns:repeat(2,1fr)}.comm-featured-card{flex-direction:column}.comm-featured-thumb{width:100%;min-width:unset;height:120px}}@media (width<=700px){.comm-content,.uprof-content{padding:0 14px 60px}.comm-song-grid{grid-template-columns:1fr}.uprof-header-inner{flex-direction:column;gap:14px}.uprof-av,.uprof-av-init{width:56px;height:56px;font-size:1.4rem}}@media (width<=640px){.comm-panel{grid-template-columns:1fr}.comm-stats-grid{grid-template-columns:1fr 1fr}.uprof-stats{gap:12px}.uprof-people-grid{grid-template-columns:1fr}}.sfed-page{flex-direction:column;min-height:100dvh;display:flex}.sfed-topbar{z-index:20;background:#fff;border-bottom:1px solid #e2d8c9;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:10px clamp(16px,2.5vw,28px);display:flex;position:sticky;top:0}.sfed-topbar-left{flex-direction:column;gap:1px;min-width:0;display:flex}.sfed-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#2a7a8c;margin:0;font-size:.6rem;font-weight:700}.sfed-heading{font-family:var(--font-display);color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:clamp(1.1rem,2vw,1.45rem);font-weight:700;line-height:1.1;overflow:hidden}.sfed-topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.sfed-btn-primary{color:#fff;font-size:.83rem;font-weight:700;font-family:var(--font-body);cursor:pointer;white-space:nowrap;background:#2a7a8c;border:none;border-radius:8px;align-items:center;gap:5px;padding:8px 18px;text-decoration:none;transition:background .14s;display:inline-flex}.sfed-btn-primary:hover{background:#1e5f6e}.sfed-btn-ghost{color:#1c2b3a;font-size:.83rem;font-weight:600;font-family:var(--font-body);cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #e2d8c9;border-radius:8px;align-items:center;gap:5px;padding:7px 14px;text-decoration:none;transition:border-color .14s,background .14s;display:inline-flex}.sfed-btn-ghost:hover{color:#2a7a8c;background:#2a7a8c0d;border-color:#2a7a8c}.sfed-mobile-tabs{display:none}.sfed-body{flex:1;grid-template-columns:300px 1fr 300px;min-height:0;display:grid}.sfed-sidebar{background:#fff;border-right:1px solid #e2d8c9;flex-direction:column;padding:0;display:flex;overflow-y:auto}.sfed-section{border-bottom:1px solid #f0ebe1;flex-direction:column;gap:11px;padding:18px 20px;display:flex}.sfed-section-danger{border-bottom:none}.sfed-section-label{letter-spacing:.12em;text-transform:uppercase;color:#6b7280;font-size:.6rem;font-weight:700;font-family:var(--font-mono);margin:0}.sfed-label{color:#1c2b3a;flex-direction:column;gap:5px;font-size:.72rem;font-weight:600;display:flex}.sfed-input{width:100%;font-size:.86rem;font-family:var(--font-body);color:#1c2b3a;box-sizing:border-box;background:#fff;border:1.5px solid #e2d8c9;border-radius:8px;outline:none;padding:8px 11px;transition:border-color .14s,box-shadow .14s}.sfed-input:focus{border-color:#2a7a8c;box-shadow:0 0 0 3px #2a7a8c1f}.sfed-input::placeholder{color:#9ca3af}.sfed-input.input-error{border-color:#c53030}.sfed-select{width:100%;font-size:.86rem;font-family:var(--font-body);color:#1c2b3a;appearance:none;cursor:pointer;box-sizing:border-box;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A5568' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") right 12px center no-repeat;border:1.5px solid #e2d8c9;border-radius:8px;outline:none;padding:8px 32px 8px 11px;transition:border-color .14s}.sfed-select:focus{border-color:#2a7a8c;box-shadow:0 0 0 3px #2a7a8c1f}.sfed-notes-ta{resize:vertical;min-height:80px;line-height:1.55}.sfed-pair{grid-template-columns:1fr 1fr;gap:10px;display:grid}.sfed-error-banner{color:#c53030;background:#c530300f;border:1px solid #c5303040;border-radius:8px;margin:16px 20px 0;padding:10px 14px;font-size:.8rem}.sfed-btn-sm{font-size:.76rem;font-weight:600;font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:1.5px solid #0000;border-radius:7px;align-items:center;gap:4px;padding:5px 12px;transition:background .13s,border-color .13s;display:inline-flex}.sfed-btn-teal-sm{color:#fff;background:#2a7a8c;border-color:#2a7a8c}.sfed-btn-teal-sm:hover{background:#1e5f6e}.sfed-btn-ghost-sm{color:#1c2b3a;background:0 0;border-color:#e2d8c9}.sfed-btn-ghost-sm:hover{color:#2a7a8c;border-color:#2a7a8c}.sfed-btn-danger{width:100%;font-size:.82rem;font-weight:600;font-family:var(--font-body);color:#c53030;cursor:pointer;text-align:center;background:0 0;border:1.5px solid #c5303059;border-radius:8px;padding:9px 16px;transition:background .13s,border-color .13s}.sfed-btn-danger:hover{background:#c530300f;border-color:#c53030}.sfed-editor-wrap{background:#fafafa;border-right:1px solid #e2d8c9;flex-direction:column;display:flex;overflow:hidden}.sfed-editor-head{background:#fff;border-bottom:1px solid #e2d8c9;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 18px;display:flex}.sfed-editor-title-row{align-items:baseline;gap:8px;display:flex}.sfed-editor-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#6b7280;font-size:.58rem;font-weight:700;font-family:var(--font-mono)}.sfed-editor-name{color:#1c2b3a;font-size:.9rem;font-weight:700;font-family:var(--font-mono)}.sfed-editor-toolbar{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.sfed-insert-chip{font-family:var(--font-mono);color:#2a7a8c;white-space:nowrap;cursor:pointer;background:#2a7a8c12;border:1px solid #2a7a8c38;border-radius:5px;padding:3px 8px;font-size:.67rem;transition:background .12s,border-color .12s}.sfed-insert-chip:hover{background:#2a7a8c29;border-color:#2a7a8c}.sfed-chord-chip{color:#d9772f;background:#d9772f12;border-color:#d9772f38}.sfed-chord-chip:hover{background:#d9772f29;border-color:#d9772f}.sfed-toolbar-sep{color:#e2d8c9;-webkit-user-select:none;user-select:none;padding:0 2px;font-size:.9rem}.sfed-import-btn{font-size:.76rem;font-weight:600;font-family:var(--font-body);color:#1c2b3a;cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #e2d8c9;border-radius:7px;padding:4px 11px;transition:border-color .13s,background .13s}.sfed-import-btn:hover{color:#2a7a8c;background:#2a7a8c0d;border-color:#2a7a8c}.sfed-preview-wrap{background:#f7f5f1;flex-direction:column;gap:14px;padding:18px 16px 32px;display:flex;overflow-y:auto}.sfed-panel-label{letter-spacing:.12em;text-transform:uppercase;color:#6b7280;font-size:.6rem;font-weight:700;font-family:var(--font-mono);margin:0 0 10px}.sfed-preview-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:10px;padding:16px}.sfed-preview-song{margin-bottom:10px}.sfed-preview-title{font-family:var(--font-display);color:#1c2b3a;margin:0 0 2px;font-size:1.25rem;font-weight:700;line-height:1.2}.sfed-preview-artist{color:#6b7280;margin:0 0 10px;font-size:.8rem}.sfed-preview-meta{flex-wrap:wrap;gap:5px;display:flex}.sfed-preview-pill{color:#1c2b3a;background:#f0ebe1;border-radius:20px;padding:2px 9px;font-size:.7rem;font-weight:600}.sfed-preview-status{color:#6b7280;border-top:1px solid #f0ebe1;align-items:center;gap:6px;margin-top:4px;padding-top:10px;font-size:.72rem;display:flex}.sfed-preview-dot{background:#cbd5e0;border-radius:50%;flex-shrink:0;width:7px;height:7px}.sfed-preview-dot.sfed-dot-green{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.sfed-preview-sep{color:#e2d8c9}.sfed-tips-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:10px;padding:16px}.sfed-tips-list{flex-direction:column;gap:7px;margin:0 0 12px;padding:0;list-style:none;display:flex}.sfed-tips-list li{color:#4a5568;font-size:.78rem;line-height:1.45}.sfed-tips-list code{font-family:var(--font-mono);color:#2a7a8c;background:#f0ebe1;border-radius:4px;padding:1px 5px;font-size:.72rem}.sfed-tips-link{color:#2a7a8c;font-size:.75rem;font-weight:600;text-decoration:none}.sfed-tips-link:hover{text-decoration:underline}.sfed-quick-actions{flex-direction:column;gap:7px;display:flex}.sfed-quick-btn{text-align:center;color:#1c2b3a;background:#f7f5f1;border:1.5px solid #e2d8c9;border-radius:8px;padding:8px 14px;font-size:.8rem;font-weight:600;text-decoration:none;transition:border-color .13s,background .13s;display:block}.sfed-quick-btn:hover{color:#2a7a8c;background:#2a7a8c0d;border-color:#2a7a8c}@media (width<=960px){.sfed-body{grid-template-columns:260px 1fr 260px}}@media (width<=800px){.sfed-topbar{gap:8px;padding:9px 14px}.sfed-heading{font-size:1rem}.sfed-topbar-right{gap:6px}.sfed-btn-primary{padding:7px 13px;font-size:.8rem}.sfed-btn-ghost{padding:6px 11px;font-size:.8rem}.sfed-mobile-tabs{background:#fff;border-bottom:1px solid #e2d8c9;flex-shrink:0;display:flex}.sfm-tab{font-size:.8rem;font-weight:600;font-family:var(--font-body);color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;padding:11px 8px;transition:color .15s,border-color .15s;display:flex}.sfm-tab.active{color:#2a7a8c;border-bottom-color:#2a7a8c}.sfed-body{grid-template-columns:1fr}.sfed-sidebar{overflow-y:unset;border-right:none}.sfed-editor-wrap{border-right:none;flex:1}.sfed-preview-wrap{padding:14px 14px 32px}.sfed-editor-head{flex-direction:column;align-items:flex-start;gap:8px}.sfed-editor-toolbar{flex-wrap:nowrap;width:100%;padding-bottom:2px;overflow-x:auto}.sfed-preview-wrap,.sfed-sidebar,.sfed-editor-wrap{display:none}[data-sfm-panel].sfm-active{flex-direction:column;display:flex!important}.song-form-editor-area textarea,.chordpro-highlight{min-height:calc(100dvh - 200px);padding:14px 16px;font-size:.84rem}.sfed-topbar .sf-desktop-only{display:none!important}.sfed-topbar .sf-mobile-only{display:inline-flex!important}.sfed-editor-head .sf-desktop-only{display:none!important}.sfed-editor-head .sf-mobile-only{display:inline-flex!important}}.lsb-bar{background:#fff;border-bottom:1px solid #e2d8c9;flex-wrap:wrap;align-items:center;gap:12px;padding:10px clamp(14px,2.5vw,28px);box-shadow:0 1px #e2d8c9}.lsb-bar-left{flex:none;gap:2px;min-width:160px}.lsb-bar-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#2a7a8c;margin:0;font-size:.58rem;font-weight:700}.lsb-name-input{font-family:var(--font-display);color:#1c2b3a;caret-color:#2a7a8c;background:0 0;border:none;outline:none;max-width:260px;padding:0;font-size:1.45rem;font-weight:700;line-height:1.15}.lsb-name-input::placeholder{color:#cbd5e0}.lsb-meta-row{flex:1;justify-content:center;gap:8px;margin-top:0}.lsb-meta-field{color:#6b7280;background:#f7f5f1;border:1.5px solid #e2d8c9;border-radius:8px;padding:6px 12px}.lsb-meta-input{color:#1c2b3a;font-size:.82rem}.lsb-meta-input[type=date]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}.lsb-meta-input::placeholder{color:#9ca3af}.lsb-bar-actions{gap:8px;padding-top:0}.lsb-cancel-btn{color:#1c2b3a;background:0 0;border:1.5px solid #e2d8c9;border-radius:8px;padding:8px 16px;font-size:.83rem;font-weight:600;transition:border-color .14s,background .14s}.lsb-cancel-btn:hover{color:#2a7a8c;background:#2a7a8c0d;border-color:#2a7a8c}.lsb-save-btn{color:#fff;cursor:pointer;background:#2a7a8c;border:none;border-radius:8px;padding:8px 20px;font-size:.83rem;font-weight:700;transition:background .14s}.lsb-save-btn:hover{background:#1e5f6e}.lsb-body{background:#f7f5f1;flex:1;grid-template-columns:2.2fr 2.2fr 1.4fr;min-height:0;display:grid}.lsb-library{background:#fff;border-right:1px solid #e2d8c9}.lsb-lib-tabs{background:#fafafa;border-bottom:1px solid #e2d8c9}.lsb-lib-tab{color:#6b7280}.lsb-lib-tab.active{color:#2a7a8c;border-bottom-color:#2a7a8c}.lsb-lib-tab-count{color:#6b7280;background:#e2d8c9}.lsb-lib-tab.active .lsb-lib-tab-count{color:#2a7a8c;background:#2a7a8c1f}.lsb-library-head{border-bottom:1px solid #e2d8c9;gap:8px;padding:12px 16px}.lsb-search-input{color:#1c2b3a;background:#f7f5f1;border:1.5px solid #e2d8c9;border-radius:8px}.lsb-search-input:focus{background:#fff;border-color:#2a7a8c}.lsb-search-icon,.lsb-refresh-btn{color:#6b7280}.lsb-refresh-btn:hover{color:#2a7a8c}.lsb-song-row{border-bottom:1px solid #f0ebe1}.lsb-song-row:hover{background:#f7f5f1}.lsb-song-row.lsb-added{opacity:.45}.lsb-song-key{color:#d9772f;min-width:42px;font-family:var(--font-mono);background:#d9772f1a;border-radius:7px;font-size:.72rem;font-weight:800}.lsb-song-info strong{color:#1c2b3a}.lsb-song-info span{color:#6b7280}.lsb-add-btn{color:#1c2b3a;background:#fff;border:1.5px solid #e2d8c9;border-radius:7px;font-size:.76rem;font-weight:600}.lsb-add-btn:hover{color:#fff;background:#2a7a8c;border-color:#2a7a8c}.lsb-add-btn.lsb-added{color:#2a7a8c;pointer-events:none;background:#2a7a8c14;border-color:#2a7a8c40}.lsb-library-empty{color:#6b7280}.lsb-empty-link{color:#fff;background:#2a7a8c;border-radius:8px;padding:7px 16px;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .14s;display:inline-block}.lsb-empty-link:hover{background:#1e5f6e}.lsb-pagination{background:#fafafa;border-top:1px solid #e2d8c9;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;display:flex}.lsb-page-info{color:#6b7280;font-size:.72rem}.lsb-page-btns{gap:4px;display:flex}.lsb-page-btn{color:#1c2b3a;width:28px;height:28px;font-size:.76rem;font-weight:600;font-family:var(--font-body);cursor:pointer;background:#fff;border:1.5px solid #e2d8c9;border-radius:6px;justify-content:center;align-items:center;transition:border-color .12s,background .12s;display:flex}.lsb-page-btn:hover{color:#2a7a8c;border-color:#2a7a8c}.lsb-page-btn.active{color:#fff;background:#2a7a8c;border-color:#2a7a8c}.lsb-page-btn:disabled{opacity:.4;cursor:default}.lsb-order{background:#f7f5f1;border-right:1px solid #e2d8c9;flex-direction:column;display:flex}.lsb-order-head{background:#fff;border-bottom:1px solid #e2d8c9;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.lsb-order-head-left{align-items:baseline;gap:8px;display:flex}.lsb-panel-eyebrow{color:#1c2b3a;font-size:.78rem;font-weight:700}.lsb-order-count{color:#6b7280;font-size:.76rem;font-weight:500}.lsb-order-list{gap:10px;padding:14px 16px}.lsb-order-empty{color:#6b7280}.lsb-order-card{background:#fff;border:1.5px solid #e2d8c9;border-radius:10px;gap:8px}.lsb-order-card:hover{border-color:#2a7a8c4d;box-shadow:0 2px 10px #0a11280f}.lsb-card-drag{color:#9ca3af}.lsb-card-num{color:#2a7a8c;font-size:.72rem}.lsb-card-title{color:#1c2b3a}.lsb-card-key{color:#d9772f;font-size:.68rem;font-family:var(--font-mono);background:#d9772f1a;border-radius:5px;padding:2px 7px;font-weight:800}.lsb-card-bpm{color:#6b7280;font-size:.7rem}.lsb-card-artist{color:#6b7280}.lsb-card-notes{color:#1c2b3a;background:#f7f5f1;border:1.5px solid #e2d8c9;border-radius:7px}.lsb-card-notes:focus{border-color:#2a7a8c}.lsb-card-notes::placeholder{color:#9ca3af;opacity:1}.lsb-card-btn{color:#6b7280;background:#f7f5f1;border:1.5px solid #e2d8c9;border-radius:6px}.lsb-card-btn:hover{color:#1c2b3a;background:#fff;border-color:#6b7280}.lsb-card-remove:hover{color:#c53030;background:#c530300f;border-color:#c530304d}.lsb-band-cues-label{color:#1c2b3a;margin:0 0 5px;font-size:.68rem;font-weight:700}.lsb-band-cues-hint{color:#9ca3af;font-weight:400}.lsb-order-footer{background:#fff;border-top:1px solid #e2d8c9;flex-shrink:0;padding:12px 16px}.lsb-add-song-btn{color:#6b7280;width:100%;font-size:.82rem;font-weight:600;font-family:var(--font-body);cursor:pointer;background:0 0;border:1.5px dashed #e2d8c9;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:9px 16px;transition:border-color .14s,color .14s;display:flex}.lsb-add-song-btn:hover{color:#2a7a8c;border-color:#2a7a8c}.parts-section{border-top:1px dashed #e2d8c9}.part-instrument,.part-name,.part-note{color:#1c2b3a;background:#f7f5f1;border:1.5px solid #e2d8c9;border-radius:6px}.part-instrument:focus,.part-name:focus,.part-note:focus{border-color:#2a7a8c}.part-remove-btn{color:#9ca3af}.part-remove-btn:hover{color:#c53030}.part-add-btn{color:#2a7a8c;cursor:pointer;background:#2a7a8c0f;border:1px solid #2a7a8c38;border-radius:6px;align-items:center;gap:5px;margin-top:5px;padding:4px 10px;font-size:.72rem;font-weight:600;transition:background .14s;display:inline-flex}.part-add-btn:hover{background:#2a7a8c24}.lsb-summary{background:#f7f5f1;flex-direction:column;gap:18px;padding:18px 16px 32px;display:flex;overflow-y:auto}.lsb-summary-label{letter-spacing:.12em;text-transform:uppercase;color:#6b7280;font-size:.6rem;font-weight:700;font-family:var(--font-mono);margin:0}.lsb-summary-sublabel{letter-spacing:.1em;text-transform:uppercase;color:#9ca3af;font-size:.6rem;font-weight:700;font-family:var(--font-mono);margin:0 0 8px}.lsb-summary-rows{background:#fff;border:1.5px solid #e2d8c9;border-radius:10px;flex-direction:column;padding:4px 0;display:flex}.lsb-summary-row{border-bottom:1px solid #f0ebe1;align-items:center;gap:10px;padding:10px 14px;display:flex}.lsb-summary-row:last-child{border-bottom:none}.lsb-summary-icon{color:#9ca3af;flex-shrink:0;line-height:0}.lsb-summary-row>div{flex-direction:column;gap:1px;display:flex}.lsb-summary-row-label{color:#9ca3af;font-size:.68rem}.lsb-summary-row-value{color:#1c2b3a;font-size:.82rem;font-weight:700}.lsb-summary-keys{flex-direction:column;display:flex}.lsb-key-flow{flex-wrap:wrap;gap:5px;min-height:28px;display:flex}.lsb-key-pill{font-size:.7rem;font-weight:800;font-family:var(--font-mono);color:#d9772f;background:#d9772f1a;border-radius:6px;padding:3px 9px}.lsb-summary-tools{flex-direction:column;display:flex}.lsb-tools-list{flex-direction:column;gap:6px;display:flex}.lsb-tool-btn{color:#1c2b3a;background:#fff;border:1.5px solid #e2d8c9;border-radius:8px;align-items:center;gap:8px;padding:9px 13px;font-size:.8rem;font-weight:600;text-decoration:none;transition:border-color .13s,background .13s;display:flex}.lsb-tool-btn:hover{color:#2a7a8c;background:#2a7a8c0a;border-color:#2a7a8c}.lsb-error-bar{color:#c53030}.lsb-mobile-tabs{display:none}@media (width<=1100px){.lsb-body{grid-template-columns:2fr 2.4fr}.lsb-summary{display:none}}@media (width<=760px){.lsb-bar{flex-wrap:wrap}.lsb-meta-row{justify-content:flex-start;width:100%}.lsb-name-input{max-width:100%;font-size:1.15rem}.lsb-bar-left{flex:1}.lsb-mobile-tabs{background:#fff;border-bottom:1px solid #e2d8c9;flex-shrink:0;display:flex}.lsb-mob-tab{font-size:.8rem;font-weight:600;font-family:var(--font-body);color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:11px 8px;transition:color .15s,border-color .15s}.lsb-mob-tab.active{color:#2a7a8c;border-bottom-color:#2a7a8c}.lsb-body{grid-template-columns:1fr}.lsb-library,.lsb-order{border-right:none;display:none}.lsb-library.lsb-panel-active,.lsb-order.lsb-panel-active{display:flex}}.lsb-ph{display:none!important}.lss-hero{background:#fff;border:1px solid #e2d8c9;border-radius:18px;flex-wrap:wrap;align-items:flex-start;gap:20px;margin-bottom:24px;padding:24px 28px;display:flex}.lss-hero-thumb{color:#fff;background:linear-gradient(135deg,#2a7a8c 0%,#1e5f6e 100%);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.lss-hero-info{flex:1;min-width:0}.lss-hero-eyebrow{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin:0 0 4px;font-size:.78rem;font-weight:600}.lss-hero-title{color:#1c2b3a;margin:0 0 10px;font-family:Cormorant Garamond,Georgia,serif;font-size:1.9rem;font-weight:700;line-height:1.15}.lss-hero-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.lss-hero-status-pill{letter-spacing:.06em;text-transform:uppercase;color:#2a7a8c;background:#2a7a8c1f;border-radius:20px;padding:2px 10px;font-size:.72rem;font-weight:700}.lss-hero-meta-sep{background:#cbd5e0;border-radius:50%;flex-shrink:0;width:3px;height:3px}.lss-hero-meta-text{color:#6b7280;font-size:.82rem}.lss-hero-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.lss-hero .presence-bubble{background:#2a7a8c;border-color:#fff}.lss-btn-primary{color:#fff;cursor:pointer;background:#2a7a8c;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 18px;font-family:Outfit,sans-serif;font-size:.88rem;font-weight:600;text-decoration:none;transition:background .15s,transform .12s;display:inline-flex}.lss-btn-primary:hover{background:#1e5f6e;transform:translateY(-1px)}.lss-btn-ghost{color:#1c2b3a;cursor:pointer;background:0 0;border:1px solid #e2d8c9;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-family:Outfit,sans-serif;font-size:.88rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.lss-btn-ghost:hover{background:#f0ebe1;border-color:#c4bab0}.lss-btn-danger{color:#c53030;cursor:pointer;background:0 0;border:1px solid #feb2b2;border-radius:10px;align-items:center;padding:8px 14px;font-family:Outfit,sans-serif;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.lss-btn-danger:hover{background:#c530300f;border-color:#c53030}.lss-body{grid-template-columns:1fr 300px;align-items:flex-start;gap:24px;display:grid}.lss-main{flex-direction:column;gap:0;display:flex}.lss-sidebar{flex-direction:column;gap:14px;display:flex;position:sticky;top:20px}.lss-section-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.lss-section-label{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:700}.lss-count-chip{color:#6b7280;background:#f0ebe1;border:1px solid #e2d8c9;border-radius:20px;padding:1px 8px;font-size:.72rem;font-weight:600}.lss-song-card{background:#fff;border:1px solid #e2d8c9;border-radius:14px;align-items:flex-start;gap:14px;margin-bottom:2px;padding:16px 18px;display:flex}.lss-song-num{color:#cbd5e0;text-align:center;flex-shrink:0;width:24px;padding-top:3px;font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:700}.lss-song-body{flex:1;min-width:0}.lss-song-top{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:3px;display:flex}.lss-song-title{color:#1c2b3a;font-size:.97rem;font-weight:700;line-height:1.2}.lss-song-key-badge{color:#d9772f;background:#d9772f1f;border-radius:6px;flex-shrink:0;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:700}.lss-song-meta-chip{color:#6b7280;background:#f0ebe1;border-radius:6px;flex-shrink:0;padding:2px 7px;font-size:.72rem}.lss-song-artist{color:#6b7280;margin:0 0 4px;font-size:.82rem}.lss-song-stage-note{color:#2a7a8c;background:#2a7a8c0f;border-left:2px solid #2a7a8c;border-radius:0 6px 6px 0;margin:4px 0;padding:4px 8px;font-size:.8rem;font-style:italic}.lss-song-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.lss-open-btn{color:#2a7a8c;white-space:nowrap;background:#2a7a8c0f;border:1px solid #a8d4dc;border-radius:8px;padding:5px 12px;font-size:.78rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s}.lss-open-btn:hover{background:#2a7a8c24;border-color:#2a7a8c}.lss-kf-row{align-items:center;gap:8px;margin-bottom:2px;padding:5px 42px;display:flex}.lss-kf-arrow{color:#cbd5e0;font-size:.7rem}.lss-kf-label{border-radius:20px;padding:2px 10px;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600}.lss-kf-row.key-flow-same .lss-kf-label{color:#2d7a5d;background:#2d7a5d1f}.lss-kf-row.key-flow-easy .lss-kf-label{color:#2d7a5d;opacity:.85;background:#2d7a5d14}.lss-kf-row.key-flow-medium .lss-kf-label{color:#e6973a;background:#e68a2e1f}.lss-kf-row.key-flow-hard .lss-kf-label{color:#c53030;background:#c530301a}.lss-empty-state{text-align:center;color:#6b7280;background:#fff;border:1px dashed #e2d8c9;border-radius:14px;padding:32px 24px;font-size:.9rem}.lss-comments-card{background:#fff;border:1px solid #e2d8c9;border-radius:14px;margin-top:20px;padding:20px 22px}.lss-comments-heading{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin:0 0 16px;font-size:.78rem;font-weight:700}.lss-scard{background:#fff;border:1px solid #e2d8c9;border-radius:14px;padding:16px 18px}.lss-scard-label{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;font-size:.72rem;font-weight:700}.lss-scard-rows{flex-direction:column;gap:8px;display:flex}.lss-scard-row{justify-content:space-between;align-items:center;font-size:.83rem;display:flex}.lss-scard-row span:first-child{color:#6b7280}.lss-scard-row span:last-child{color:#1c2b3a;font-weight:600}.lss-key-pills{flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:8px;display:flex}.lss-key-pill{color:#d9772f;background:#d9772f1a;border-radius:6px;padding:2px 7px;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:700}.lss-key-arrow{color:#cbd5e0;font-size:.65rem}.lss-key-flow-note{color:#6b7280;margin:0;font-size:.78rem}.lss-qactions{flex-direction:column;gap:6px;display:flex}.lss-qaction-btn{text-align:center;color:#fff;cursor:pointer;background:#2a7a8c;border:none;border-radius:9px;padding:9px 14px;font-family:Outfit,sans-serif;font-size:.83rem;font-weight:600;text-decoration:none;transition:background .15s;display:block}.lss-qaction-btn:hover{background:#1e5f6e}.lss-qaction-btn.ghost{color:#1c2b3a;background:0 0;border:1px solid #e2d8c9}.lss-qaction-btn.ghost:hover{background:#f0ebe1}@media (width<=768px){.lss-hero{gap:14px;padding:18px 16px}.lss-hero-title{font-size:1.45rem}.lss-hero-actions{width:100%}.lss-body{grid-template-columns:1fr}.lss-sidebar{order:-1;position:static}}.perf-wrap{width:100%;max-width:none;margin:0}.perf-topbar2{z-index:200;background:var(--perf-bg);border-bottom:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;height:56px;padding:0 20px;display:flex;position:sticky;top:0}.perf-tb2-left{flex:1;align-items:center;gap:14px;min-width:0;display:flex;overflow:hidden}.perf-back2{letter-spacing:.05em;color:#ffffff4d;white-space:nowrap;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.72rem;text-decoration:none;transition:color .15s}.perf-back2:hover{color:#ffffffa6}.perf-song-id{align-items:center;gap:10px;min-width:0;display:flex;overflow:hidden}.perf-song-thumb{color:#a78bfabf;background:#7c3aed33;border:1px solid #7c3aed4d;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.perf-song-id-text{flex-direction:column;min-width:0;display:flex;overflow:hidden}.perf-title2{color:#ffffffeb;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;line-height:1.2;overflow:hidden}.perf-artist2{color:#fff6;white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;line-height:1.2;overflow:hidden}.perf-key-pill2{color:#a78bfae6;white-space:nowrap;background:#7c3aed24;border:1px solid #7c3aed47;border-radius:20px;flex-shrink:0;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:700}.perf-bpm-chip{color:#fff6;white-space:nowrap;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.68rem}.perf-tb2-right-controls{flex-shrink:0;align-items:center;gap:10px;display:flex}.perf-fs-btn{flex-shrink:0}.perf-transpose-disp{color:#ffffff8c;font-family:JetBrains Mono,monospace;font-size:.78rem}.perf-body3{grid-template-columns:minmax(240px,300px) minmax(0,1fr) minmax(200px,260px);align-items:flex-start;width:100%;min-height:calc(100vh - 128px);display:grid}.perf-band-cues{scrollbar-width:none;border-right:1px solid #ffffff0f;max-height:calc(100vh - 56px);padding:24px 22px;position:sticky;top:56px;overflow-y:auto}.perf-band-cues::-webkit-scrollbar{display:none}.perf-bc-head{align-items:center;gap:7px;margin-bottom:14px;display:flex}.perf-bc-icon{color:#5eead4a6;flex-shrink:0}.perf-bc-title{letter-spacing:.1em;text-transform:uppercase;color:#fff6;flex:1;font-size:.68rem;font-weight:700}.perf-bc-toggle{color:#ffffff40;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:1.1rem;line-height:1;transition:color .12s}.perf-bc-toggle:hover{color:#ffffff8c}.perf-bc-body{flex-direction:column;gap:14px;display:flex}.perf-bc-item{flex-direction:column;gap:3px;display:flex}.perf-bc-item-head{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.perf-bc-instrument{color:#5eead4d9;font-size:.72rem;font-weight:700}.perf-bc-name{color:#ffffff73;font-size:.7rem}.perf-bc-note{color:#ffffffad;margin:0;font-size:.76rem;line-height:1.45}.perf-bc-empty{color:#ffffff40;margin:0;font-size:.74rem;font-style:italic}.perf-bc-no-cues{display:none}.perf-chart-col{min-width:0;padding:28px 40px}.perf-chart-col .chart-output{background:0 0;border:none;border-radius:0;padding:0}.perf-sec-col{scrollbar-width:none;border-left:1px solid #ffffff0f;max-height:calc(100vh - 56px);padding:24px 18px;position:sticky;top:56px;overflow-y:auto}.perf-sec-col::-webkit-scrollbar{display:none}.perf-sec-col .perf-section-nav{max-height:none;padding:0;overflow-y:visible;position:static!important;top:auto!important;right:auto!important;transform:none!important}.perf-sec-col .section-jump-chip{letter-spacing:.1em;padding:7px 14px;font-size:.65rem}.perf-set-nav{z-index:100;background:#0c162899;border-top:1px solid #ffffff12;align-items:stretch;min-height:72px;display:flex;position:sticky;bottom:0}.perf-sn-side{flex:1;display:flex}.perf-sn-card{color:inherit;flex:1;align-items:center;gap:10px;padding:12px 20px;text-decoration:none;transition:background .15s;display:flex}.perf-sn-card:hover{background:#ffffff0a}.perf-sn-prev-card{justify-content:flex-start}.perf-sn-next-card{text-align:right;justify-content:flex-end}.perf-sn-empty{cursor:default;pointer-events:none}.perf-sn-chevron{color:#ffffff40;flex-shrink:0;font-size:1.3rem}.perf-sn-info{flex-direction:column;gap:1px;min-width:0;display:flex}.perf-sn-label{letter-spacing:.1em;text-transform:uppercase;color:#ffffff4d;font-size:.6rem;font-weight:700}.perf-sn-name{color:#fffc;white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:.82rem;font-weight:700;overflow:hidden}.perf-sn-key{color:#a78bfab3;font-family:JetBrains Mono,monospace;font-size:.65rem}.perf-sn-center{flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:10px 24px;display:flex}.perf-sn-counter{color:#ffffff59;letter-spacing:.05em;white-space:nowrap;font-size:.68rem;font-weight:600}.perf-sn-steps{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;display:flex}.perf-sn-step{color:#ffffff40;background:#ffffff0a;border:1.5px solid #ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-family:JetBrains Mono,monospace;font-size:.6rem;font-weight:700;display:flex}.perf-sn-step.done{color:#34d399;background:#34d3991f;border-color:#34d39959}.perf-sn-step.active{color:#a78bfa;background:#7c3aed40;border-color:#7c3aed99}.perf-set-nav2{z-index:100;background:#0c1628b3;border-top:1px solid #ffffff12;align-items:stretch;min-height:72px;display:flex;position:sticky;bottom:0}.perf-sn2-card{color:#ffffffa6;cursor:pointer;background:0 0;border:none;flex:1;align-items:center;gap:10px;padding:10px 20px;font-family:Outfit,sans-serif;transition:background .15s;display:flex}.perf-sn2-card:hover:not(:disabled){background:#ffffff0a}.perf-sn2-card:disabled{opacity:.3;cursor:default}.perf-sn2-prev{justify-content:flex-start}.perf-sn2-next{text-align:right;justify-content:flex-end}.perf-sn2-chevron{color:#ffffff40;flex-shrink:0;font-size:1.3rem}.perf-sn2-info{flex-direction:column;gap:2px;min-width:0;display:flex}.perf-sn2-label{letter-spacing:.1em;text-transform:uppercase;color:#ffffff47;font-size:.6rem;font-weight:700}.perf-sn2-song{align-items:baseline;gap:6px;min-width:0;display:flex}.perf-sn2-song strong{color:#ffffffc7;white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:.82rem;font-weight:700;overflow:hidden}.perf-sn2-song span{color:#a78bfab3;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.65rem}.perf-sn2-center{flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:5px;padding:8px 20px;display:flex}.perf-sn2-pos{color:#ffffff52;letter-spacing:.05em;white-space:nowrap;font-size:.68rem;font-weight:600}.perf-sn2-steps{flex-wrap:wrap;justify-content:center;align-items:center;gap:5px;display:flex}.perf-sn2-step{color:#ffffff38;cursor:pointer;background:#ffffff08;border:1.5px solid #ffffff1f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-family:JetBrains Mono,monospace;font-size:.58rem;font-weight:700;transition:background .12s,border-color .12s,color .12s;display:flex}.perf-sn2-step:hover{color:#ffffff8c;background:#ffffff17}.perf-sn2-step.active{color:#a78bfa;background:#7c3aed40;border-color:#7c3aed99}.perf-sn2-setlist-btn{color:#ffffff73;letter-spacing:.04em;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:7px;align-items:center;gap:4px;padding:4px 9px;font-family:Outfit,sans-serif;font-size:.65rem;font-weight:600;transition:background .12s,color .12s;display:flex}.perf-sn2-setlist-btn:hover{color:#ffffffbf;background:#ffffff1f}.perf-setlist-panel{z-index:150;background:#0d0c22;border-top:1px solid #ffffff1a;position:fixed;bottom:72px;left:0;right:0;box-shadow:0 -12px 40px #00000080}.perf-setlist-head{color:#ffffff8c;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:12px 20px;font-size:.75rem;font-weight:700;display:flex}.perf-setlist-head button{color:#ffffff59;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:1rem;transition:color .12s}.perf-setlist-head button:hover{color:#ffffffb3}.perf-body .chart-section h2{color:#a78bfad9;border-left-color:#7c3aedbf}.perf-sec-col .section-jump-chip.active{color:#a78bfa;background:#7c3aed2e;border-color:#7c3aed73}.perf-view-btn.active{background:var(--primary);color:#fff}.perf-band-cues.collapsed .perf-bc-body{display:none}@media (width<=768px){.perf-topbar2{flex-wrap:wrap;gap:8px;height:auto;min-height:56px;padding:8px 14px}.perf-tb2-left{gap:8px}.perf-back2{font-size:.66rem}.perf-song-id{flex-wrap:wrap;gap:6px}.perf-song-thumb{width:26px;height:26px}.perf-title2{font-size:.78rem}.perf-artist2{font-size:.64rem}.perf-body3{grid-template-columns:1fr;min-height:auto}.perf-band-cues{border-bottom:1px solid #ffffff0f;border-right:none;max-height:none;padding:12px 16px;position:static}.perf-sec-col{display:none}.perf-chart-col{padding:16px 16px 24px}.perf-set-nav{flex-wrap:nowrap}.perf-sn-name{max-width:100px}.perf-sn-center{padding:8px 12px}.perf-sn-steps{gap:4px}.perf-sn-step{width:18px;height:18px;font-size:.52rem}.perf-set-nav2{flex-wrap:nowrap}.perf-sn2-card{gap:6px;padding:8px 12px}.perf-sn2-song strong{max-width:90px}.perf-sn2-center{padding:8px 10px}.perf-sn2-steps{gap:3px}.perf-sn2-step{width:18px;height:18px;font-size:.52rem}}@media (width<=1100px){.perf-body3{grid-template-columns:minmax(200px,240px) minmax(0,1fr) minmax(180px,220px)}}@media (width<=900px){.perf-body3{grid-template-columns:220px minmax(0,1fr)}.perf-sec-col{display:none}}@media (width<=640px){.perf-body3{grid-template-columns:1fr}.perf-band-cues{border-bottom:1px solid #ffffff0f;border-right:none;max-height:none;position:static}}.app-topbar{z-index:50;background:#fff;border-bottom:1px solid #ebe6de;flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 clamp(16px,2.5vw,32px);display:flex;position:sticky;top:0}.app-topbar-right{align-items:center;gap:6px;display:flex}.app-topbar-bell{color:#6b7280;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.app-topbar-bell:hover,.app-topbar-bell.active{color:#1c2b3a;background:#f0ebe1}.app-topbar-badge{color:#fff;background:#d9772f;border-radius:8px;justify-content:center;align-items:center;min-width:15px;height:15px;padding:0 3px;font-size:.58rem;font-weight:700;line-height:1;display:flex;position:absolute;top:3px;right:3px}.app-topbar-user{position:relative}.app-topbar-avatar{cursor:pointer;color:#1c2b3a;width:34px;height:34px;font-size:.78rem;font-weight:700;font-family:var(--font-body);background:#f0ebe1;border:2px solid #e2d8c9;border-radius:50%;justify-content:center;align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.app-topbar-avatar:hover{border-color:#d9772f}.app-topbar-avatar img{object-fit:cover;width:100%;height:100%;display:block}.app-user-dropdown{z-index:500;background:#fff;border:1px solid #e2d8c9;border-radius:8px;width:230px;position:fixed;overflow:hidden;box-shadow:0 8px 28px #0a11281f}.aud-user-head{align-items:center;gap:10px;padding:12px 14px;display:flex}.aud-user-avatar{color:#1c2b3a;width:36px;height:36px;font-size:.78rem;font-weight:700;font-family:var(--font-body);background:#f0ebe1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.aud-user-avatar img{object-fit:cover;width:100%;height:100%;display:block}.aud-user-info{min-width:0}.aud-user-name{color:#1c2b3a;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;display:block;overflow:hidden}.aud-user-email{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:.72rem;display:block;overflow:hidden}.aud-divider{background:#e2d8c9;height:1px;margin:2px 0}.aud-item{font-size:.82rem;font-family:var(--font-body);color:#1c2b3a;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:8px 14px;line-height:1.4;text-decoration:none;transition:background .12s;display:flex}.aud-item svg{color:#6b7280;flex-shrink:0}.aud-item:hover{background:#f7f5f1}.aud-item-logout,.aud-item-logout svg{color:#c53030}.aud-item-logout:hover{background:#fef2f2}.mobile-topbar-right{align-items:center;gap:2px;display:flex}.mobile-notif-btn{color:#4a5568;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;text-decoration:none;transition:background .15s;display:flex;position:relative}.mobile-notif-btn:hover{background:#f3f0eb}.mobile-notif-badge{color:#fff;background:#d9772f;border-radius:7px;justify-content:center;align-items:center;min-width:14px;height:14px;padding:0 3px;font-size:.56rem;font-weight:700;line-height:1;display:flex;position:absolute;top:4px;right:4px}@media (width<=768px){.app-topbar{display:none}}.mobile-drawer{z-index:96;background:#fff;flex-direction:column;width:280px;transition:transform .25s;display:none;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0a11281a}.mobile-drawer.open{transform:translate(0)}.mobile-drawer-overlay{z-index:95;background:#0000006b;display:none;position:fixed;inset:0}.mobile-drawer-overlay.visible{display:block}.mobile-drawer-header{border-bottom:1px solid #ebe6de;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex}.mobile-drawer-brand{font-family:var(--font-display);color:#2a7a8c;align-items:center;gap:7px;font-size:1.1rem;font-weight:700;text-decoration:none;display:flex}.mobile-drawer-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:background .14s,color .14s;display:flex}.mobile-drawer-close:hover{color:#1c2b3a;background:#f3f0eb}.mobile-drawer-nav{flex:1;padding:10px 0;overflow-y:auto}.mobile-drawer-link{color:#374151;font-family:var(--font-body);align-items:center;gap:13px;padding:14px 20px;font-size:.94rem;font-weight:500;text-decoration:none;transition:background .14s,color .14s;display:flex}.mobile-drawer-link svg{color:inherit;flex-shrink:0}.mobile-drawer-link:hover{color:#1c2b3a;background:#f8f5f0}.mobile-drawer-link.active{color:#2a7a8c;background:#edf5f6}@media (width<=768px){.mobile-drawer{display:flex}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@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}
