:root{--font-ui: "Anuphan", "Noto Sans Thai", "IBM Plex Sans Thai", ui-sans-serif, system-ui, sans-serif;font-family:var(--font-ui);color:#17201b;background:#eef0e8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"liga" 1,"kern" 1}*{box-sizing:border-box}body{margin:0;line-height:1.55;letter-spacing:.01em;overflow-x:clip}button,input{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding:24px;padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right));padding-bottom:max(24px,env(safe-area-inset-bottom));overflow-x:clip;background:linear-gradient(135deg,rgba(41,111,82,.13),transparent 32%),linear-gradient(315deg,rgba(186,60,40,.11),transparent 36%),#eef0e8}.session-leave-btn{display:none}.topbar,.session-header,.panel-heading,.brand-block,.room-card-topline,.stage-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar{margin:0 auto 18px;max-width:1440px}.brand-block{justify-content:flex-start}.brand-mark{display:grid;place-items:center;width:48px;height:48px;border-radius:8px;color:#fffaf1;background:#1d2b24;box-shadow:0 10px 24px #121d173d}.eyebrow{margin:0 0 4px;color:#667468;font-size:.78rem;font-weight:600;letter-spacing:.04em}h1,h2,h3,p{margin-top:0}h1{margin-bottom:0;color:#101915;font-size:2.35rem;font-weight:700;line-height:1.2;letter-spacing:-.01em}.workspace{display:grid;grid-template-columns:minmax(300px,360px) minmax(0,1fr);gap:18px;margin:0 auto;max-width:1440px}.rooms-panel,.player-panel{border:1px solid rgba(22,32,25,.12);border-radius:8px;background:#ffffffd1;box-shadow:0 18px 50px #222b231f}.player-panel{min-height:calc(100vh - 88px);padding:0;overflow:hidden}.rooms-panel{position:sticky;top:12px;align-self:start;display:flex;flex-direction:column;gap:0;padding:14px;height:calc(100vh - 88px);min-height:520px;overflow:hidden}.sidebar-create{flex-shrink:0;margin-bottom:10px;background:#17201b!important;border-radius:10px!important}.sidebar-create .ant-collapse-item{border:0!important}.sidebar-create .ant-collapse-header{color:#eef0e8!important;padding:10px 12px!important;align-items:center!important}.sidebar-create .ant-collapse-content-box{padding:0 12px 12px!important}.sidebar-create-label{display:inline-flex;align-items:center;gap:8px;font-weight:700}.sidebar-rooms{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.chord-sync-banner{display:grid;gap:8px;margin-bottom:12px;border:1px solid #cfe0d4;border-radius:10px;padding:12px;background:#f4fbf7}.chord-sync-banner-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#1f6b4f}.chord-sync-banner-phase{color:#4f6558;font-size:.88rem;font-weight:600}.chord-sync-banner-song{color:#17201b;font-size:.92rem}.chord-sync-banner-meta,.chord-sync-banner-error{font-size:.82rem}.guest-name-field{display:grid;gap:6px;margin-bottom:12px;color:#4d5b51;font-size:.88rem;font-weight:600;flex-shrink:0}.room-panel-heading{flex-shrink:0;align-items:center;margin-top:0;margin-bottom:10px}.room-panel-heading h2{margin:0}.create-room{display:grid;gap:10px;margin-bottom:0;border-radius:0;padding:0;background:transparent}.create-room-queue-option{display:grid;gap:8px;border:1px solid #d9dfd5;border-radius:8px;padding:10px 12px;background:#fbfcf8}.create-room-queue-toggle{display:flex;align-items:center;gap:10px;color:#4d5b51;font-size:.88rem;font-weight:600}.create-room-queue-hint{font-size:.82rem;line-height:1.45}.room-list{flex:1;min-height:0;display:grid;gap:8px;align-content:start;margin-top:0;margin-bottom:0;max-height:none;overflow-y:auto;padding-right:6px;scrollbar-gutter:stable}.room-list-empty{margin:24px 0}.spotify-compact{flex-shrink:0;margin-top:12px;padding-top:12px;border-top:1px solid rgba(22,32,25,.1)}.spotify-compact-body{display:grid;gap:10px}.spotify-compact-meta{margin:0;color:#4f6558;font-size:.86rem;line-height:1.45}.spotify-open-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:44px;border:1px solid #96a69a;border-radius:8px;color:#17201b;background:#eef0e8;font-weight:700}.spotify-open-btn:hover{border-color:#1db954;background:#e8f7ee}.spotify-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:20px;background:#080c0a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spotify-modal{display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr) auto;width:min(760px,100%);max-height:min(90vh,900px);border:1px solid #d9dfd5;border-radius:14px;background:#fbfcf8;box-shadow:0 24px 60px #222b232e;overflow:hidden}.spotify-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 8px}.spotify-modal-eyebrow{margin:0 0 4px;color:#667468;font-size:.78rem;font-weight:600}.spotify-modal-header h2{margin:0;color:#101915;font-size:1.3rem}.spotify-modal-close{border-color:#d9dfd5;color:#26362d;background:#eef0e8}.spotify-modal-toolbar{display:flex;align-items:center;gap:10px;padding:0 18px 10px}.spotify-modal-toolbar .primary-button{flex:1}.spotify-modal-status{margin:0 18px 10px}.spotify-modal-search{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;margin:0 18px 12px;border:1px solid #d9dfd5;border-radius:10px;padding:10px 12px;color:#667468;background:#fff}.spotify-modal-search input{min-height:auto;border:0;padding:0;background:transparent}.spotify-modal-search span{color:#4f6558;font-size:.8rem;font-weight:700;white-space:nowrap}.spotify-modal-list{display:grid;gap:10px;margin:0 18px;overflow-y:auto;padding-right:4px;min-height:0}.spotify-modal-body{display:grid;gap:12px;padding:12px 18px 24px}.spotify-modal-empty{display:grid;justify-items:center;gap:8px;padding:28px 16px;color:#667468;text-align:center}.spotify-modal-empty strong{color:#17201b}.spotify-modal-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding:14px 18px;border-top:1px solid #e4e8e0;background:#f3f5f0;color:#4f6558;font-size:.82rem}.spotify-modal-open-ext{border-color:#d9dfd5;color:#26362d;background:#fff}.spotify-modal .text-button{border:1px solid #d9dfd5;color:#26362d;background:#eef0e8}.spotify-connect{display:inline-flex;align-items:center;justify-content:center;width:100%;text-decoration:none}.spotify-note{margin:0 0 10px;color:#4f6558;font-size:.9rem;line-height:1.45}.chordtab-frame{width:100%;min-height:480px;border:0;border-radius:8px;background:#fff}.spotify-playlists .primary-button{width:100%;margin-bottom:10px}label{display:grid;gap:6px;color:#4d5b51;font-size:.9rem;font-weight:600}.create-room label{color:#dce5dd}input:not(.ant-input){min-height:44px;width:100%;border:1px solid #c9d1c7;border-radius:6px;padding:0 12px;color:#17201b;background:#fff}input:not(.ant-input):focus{border-color:#258f6a;outline:3px solid rgba(37,143,106,.18)}.primary-button,.icon-button,.ghost-button{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:6px;font-weight:700}.primary-button{gap:8px;min-height:44px;padding:0 16px;color:#fffaf1;background:#c84f32}.primary-button:hover{background:#ad3f27}.icon-button{width:44px;height:44px;color:#fffaf1;background:#1d2b24}.ghost-button{gap:8px;min-height:40px;border:1px solid rgba(255,255,255,.18);padding:0 12px;color:#f7f1e7;background:#ffffff14}.panel-heading h2{margin-bottom:0;font-size:1rem;color:#101915}.panel-heading span{min-width:32px;border-radius:999px;padding:4px 10px;color:#173f30;background:#dcefe5;text-align:center;font-size:.85rem;font-weight:700}.room-card{position:relative;display:grid;gap:6px;width:100%;border:1px solid #d9dfd5;border-radius:10px;padding:10px 12px 28px;color:inherit;background:#fbfcf8;text-align:left;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.room-card:hover{border-color:#258f6a;background:#f6fbf8}.room-card.is-active{border-color:#1f6b4f;background:#eef8f2;box-shadow:0 0 0 2px #1f6b4f29}.room-card:disabled{opacity:.7;cursor:wait}.room-card-topline{align-items:flex-start}.room-card-title{font-weight:700;font-size:.98rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-card-code{flex-shrink:0;border-radius:999px;padding:3px 8px;color:#79402f;background:#f5dfd5;font-size:.72rem;font-weight:700;letter-spacing:.04em}.room-card-footer{display:grid;gap:4px}.room-card-meta{display:inline-flex;align-items:center;gap:6px;color:#4f6558;font-size:.8rem;font-weight:600}.room-card-song{color:#26362d;font-size:.84rem;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-card-enter,.room-card-active-badge{position:absolute;right:10px;bottom:8px;font-size:.72rem;font-weight:700}.room-card-enter{color:#1f6b4f;opacity:0;transition:opacity .15s ease}.room-card:hover .room-card-enter{opacity:1}.room-card-active-badge{display:inline-flex;align-items:center;gap:4px;color:#1f6b4f}.room-card.is-active .room-card-enter{display:none}.stage-layout{display:grid;min-height:calc(100vh - 112px);background:#101713}.session-header{min-height:76px;border-bottom:1px solid rgba(255,255,255,.08);padding:16px 18px;color:#f7f1e7}.session-header .eyebrow{color:#aeb8ae}.session-header h2{margin-bottom:0}.status-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 12px;background:#ffffff1a;color:#cdd8ce;font-size:.9rem;font-weight:700}.status-pill.live{background:#3ec17929;color:#7de3a4}.status-pill.reconnecting,.status-pill.connecting{background:#ffc14f29;color:#ffd666}.status-pill.closed,.status-pill.error{background:#ff787529;color:#ff9c99}.stage-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:0;min-height:calc(100vh - 188px)}.chord-stage{display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px;padding:18px}.stage-toolbar{color:#f7f1e7}.stage-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.now-playing-compact{display:flex;align-items:center;gap:12px;min-width:0}.now-playing-compact p{margin-bottom:2px;color:#aeb8ae;font-size:.86rem;font-weight:600}.now-playing-compact h3{margin-bottom:0;overflow-wrap:anywhere;font-size:1.8rem}.chord-paper{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-height:0;border-radius:8px;background:#fffdf8;box-shadow:0 22px 60px #00000052;overflow:hidden}.paper-header{display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid #eee3d5;padding:16px 18px;color:#735343}.paper-header span{font-size:.8rem;font-weight:700;text-transform:uppercase}.paper-header strong{color:#221a16;overflow-wrap:anywhere}.chord-image-frame{display:grid;place-items:center;min-height:380px;padding:32px;overflow:auto}.imported-chord-image{display:grid;align-content:center;justify-items:center;gap:14px;width:min(100%,860px);min-height:440px;border:1px solid #e0d4c4;border-radius:6px;padding:28px;color:#1d1814;background:repeating-linear-gradient(0deg,transparent 0,transparent 39px,#f0e7dd 40px),#fffaf2;box-shadow:inset 0 0 0 8px #fffdf8;text-align:center}.imported-chord-image span{color:#bd482c;font-size:.9rem;font-weight:700;text-transform:uppercase}.imported-chord-image strong{max-width:100%;overflow-wrap:anywhere;font-size:clamp(1.8rem,4vw,3.8rem);line-height:1.15}.imported-chord-image p{max-width:520px;margin-bottom:0;color:#6d665c;line-height:1.55}.image-note{border-top:1px solid #eee3d5;padding:12px 18px;color:#6d665c;background:#faf2e8;font-size:.9rem}.control-rail{display:grid;align-content:start;gap:14px;border-left:1px solid rgba(255,255,255,.08);padding:18px;color:#f7f1e7;background:#17201b}.control-rail-tabs{display:none}.control-rail-section{display:grid;gap:14px}.control-rail-tab{display:grid;justify-items:center;gap:4px;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:10px 8px;color:#c5cfc7;background:#ffffff0a;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease}.control-rail-tab span{font-size:.78rem;font-weight:600}.control-rail-tab.is-active{color:#f7f1e7;border-color:#7de3a48c;background:#3ec17929}.control-rail-tab .ant-tag{margin:0;line-height:1.2}.session-queue-btn{color:#f0f5f1;border-color:#7de3a473;background:#3ec1791f}.queue-drawer .ant-drawer-body{padding-top:8px}.queue-drawer .song-queue-list{max-height:none}.control-rail .song-queue-label,.control-rail .ant-typography.song-queue-label{color:#9adfb8!important}.control-rail .song-queue-now-playing strong{color:#f7f1e7}.control-rail .ant-empty-description{color:#c5cfc7!important}.control-rail .ant-empty .ant-empty-image{opacity:.7}.control-rail .ant-btn-default{color:#f0f5f1;border-color:#ffffff47;background:#ffffff0f}.control-rail .ant-btn-default:not(:disabled):hover{color:#fff;border-color:#7de3a499;background:#3ec1792e}.control-rail .ant-btn-default:disabled{color:#f0f5f180;border-color:#ffffff29;background:#ffffff0a}.control-rail .ant-btn-text{color:#d8e2da}.control-rail .ant-btn-text:not(:disabled):hover{color:#fff;background:#ffffff14}.control-rail .ant-btn-text:disabled{color:#d8e2da61}.song-queue-panel{display:grid;gap:12px}.song-queue-artist{color:#c5cfc7;font-size:.84rem;line-height:1.4}.now-playing-artist,.imported-chord-artist{margin:2px 0 0;color:#aeb8ae;font-size:.88rem}.paper-header-song{display:grid;gap:2px;text-align:right}.paper-header-song span{color:#6d665c;font-size:.84rem}.perform-artist{margin:0;color:#d8e2da;font-size:1rem}.perform-meta-row{margin-top:8px}.sheet-view-toggle .ant-btn{min-width:64px}.sheet-section-label{width:100%;text-align:center;padding:8px 12px;background:linear-gradient(180deg,#f0a040,#d97706);color:#fff;font-weight:700;font-size:.92rem;letter-spacing:.01em}.perform-sheet-stack{display:flex;flex-direction:column;align-items:stretch;width:min(100%,100vw);height:100%;min-height:0}.perform-sheet-stack .perform-sheet-pointer-layer,.perform-sheet-stack .perform-chord-frame{flex:1;min-height:0}.perform-sheet-section{flex-shrink:0;border-radius:6px 6px 0 0}.song-queue-item-actions{justify-content:flex-end}.stats-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.song-queue-heading{display:flex;align-items:center;justify-content:space-between;gap:8px}.song-queue-heading h3{margin:0;font-size:1rem}.song-queue-now-playing{display:grid;gap:4px;border:1px solid rgba(125,227,164,.35);border-radius:10px;padding:12px;background:#3ec1791f}.song-queue-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:#9adfb8}.song-queue-actions{width:100%}.song-queue-list{display:grid;gap:8px;max-height:280px;overflow:auto;padding-right:4px}.song-queue-item{display:grid;grid-template-columns:28px minmax(0,1fr) auto;gap:8px;align-items:center;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:8px 10px;background:#ffffff0a}.song-queue-position{color:#7de3a4;font-weight:700;text-align:center}.song-queue-item-main{display:grid;gap:2px;min-width:0}.song-queue-item-main strong,.song-queue-item-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-queue-item-main span{color:#aeb8ae;font-size:.82rem}.stats-strip div{display:grid;gap:4px;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px;background:#ffffff0f}.stats-strip span{font-size:1.15rem;font-weight:700}.stats-strip small{color:#aeb8ae}.song-list-open{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border:1px solid rgba(255,255,255,.14);border-radius:6px;color:#f7f1e7;background:#ffffff14;font-weight:700}.song-list-panel{display:grid;gap:12px;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:12px;background:#ffffff0f}.song-list-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.song-list-heading h3{margin-bottom:3px;color:#f7f1e7;font-size:1rem}.song-list-heading p{margin-bottom:0;color:#aeb8ae;font-size:.84rem;line-height:1.4}.text-button{border:0;border-radius:6px;padding:6px 8px;color:#f7f1e7;background:#ffffff1a;font-size:.82rem;font-weight:700}.song-list{display:grid;gap:8px;max-height:320px;overflow:auto}.song-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;width:100%;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px;color:#f7f1e7;background:#ffffff12;text-align:left}.song-row:hover{border-color:#c84f32bf;background:#c84f3229}.song-main{display:grid;gap:3px;min-width:0}.song-main strong,.song-main small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-main small{color:#aeb8ae}.song-meta{display:grid;justify-items:end;gap:5px;color:#d7e1d8;font-size:.78rem;font-weight:700}.chord-ready,.chord-missing{border-radius:999px;padding:3px 7px}.chord-ready{color:#7de3a4;background:#3ec17924}.chord-missing{color:#f1bc87;background:#e38e4624}.song-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:20px;background:#080c0ab8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.song-modal{display:grid;grid-template-rows:auto auto auto minmax(0,1fr) auto;width:min(720px,100%);max-height:min(88vh,860px);border:1px solid rgba(255,255,255,.14);border-radius:14px;background:linear-gradient(165deg,#1a241f,#121814);box-shadow:0 24px 60px #00000073;overflow:hidden}.song-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 10px}.song-modal-header h2{margin:0;color:#f7f1e7;font-size:1.35rem}.song-modal-search{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;margin:0 18px;border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:10px 12px;color:#aeb8ae;background:#ffffff0f}.song-modal-search input{width:100%;border:0;outline:none;color:#f7f1e7;background:transparent;font-size:.95rem}.song-modal-meta{margin:10px 18px 0;color:#8f9a90;font-size:.82rem}.song-modal-list{display:grid;gap:8px;margin:12px 18px;overflow:auto;padding-right:4px}.song-modal-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;width:100%;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px;color:#f7f1e7;background:#ffffff0d;text-align:left}.song-modal-item:hover{border-color:#7de3a48c;background:#3ec1791f}.song-modal-item-main{display:grid;gap:4px;min-width:0}.song-modal-item-main strong,.song-modal-item-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-modal-item-main span{color:#aeb8ae;font-size:.86rem}.song-modal-playlist{color:#7de3a4!important;font-size:.8rem!important;white-space:normal!important;overflow:visible!important;text-overflow:unset!important;line-height:1.35}.song-modal-item-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-end}.song-modal-empty{display:grid;justify-items:center;gap:8px;padding:28px 16px;color:#aeb8ae;text-align:center}.song-modal-empty strong{color:#f7f1e7}.song-modal-footer{display:grid;gap:10px;border-top:1px solid rgba(255,255,255,.1);padding:14px 18px 18px;background:#0000002e}.song-modal-footer-title{margin:0;color:#f7f1e7;font-size:.92rem;font-weight:700}.song-modal-manual{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:8px}.song-modal-manual input{min-height:40px;border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:0 10px;color:#f7f1e7;background:#ffffff0f}.song-modal-live-query{justify-self:start}.song-modal-error{margin:0;color:#f1a07a;font-size:.84rem}@media(max-width:640px){.song-modal-manual{grid-template-columns:1fr}}.participants-panel{display:grid;gap:10px;min-width:0;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:12px;background:#ffffff0f}.participants-heading{display:flex;align-items:center;justify-content:space-between;gap:10px}.participants-heading h3{margin-bottom:0;color:#f7f1e7;font-size:1rem}.participants-heading span{min-width:28px;border-radius:999px;padding:3px 8px;color:#7de3a4;background:#3ec17924;text-align:center;font-size:.8rem;font-weight:700}.participant-list{display:grid;gap:8px}.participant-row{display:flex;align-items:center;gap:10px;border-radius:8px;padding:8px;background:#ffffff0f}.participant-avatar{display:grid;flex:0 0 auto;place-items:center;width:34px;height:34px;border-radius:999px;color:#17201b;background:#f7f1e7;font-weight:700}.participant-row span:last-child{display:grid;min-width:0}.participant-row strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.participant-row small,.muted{color:#aeb8ae}.empty-state{display:grid;place-items:center;min-height:calc(100vh - 112px);padding:24px;color:#1a241e;text-align:center}.empty-state h2{margin:14px 0 8px}.empty-state p{max-width:430px;color:#68786d;line-height:1.6}.error-banner{max-width:1440px;margin:0 auto 16px;border:1px solid #f1b5aa;border-radius:8px;padding:12px 14px;color:#8a241b;background:#fff1ee;font-weight:700}@media(max-width:1040px){.workspace{grid-template-columns:1fr}.app-shell.is-in-room .rooms-panel{display:none}.app-shell.is-in-room .workspace{gap:0}.app-shell.is-in-room .player-panel{min-height:auto}.app-shell.is-in-room .stage-layout{min-height:calc(100dvh - 88px)}.session-leave-btn{display:inline-flex}.rooms-panel{order:2;position:static;height:auto;min-height:0;max-height:none}.sidebar-rooms{min-height:280px;max-height:50vh}.player-panel{order:1;min-height:70vh}.stage-layout{min-height:70vh}.stage-grid{grid-template-columns:1fr}.control-rail{border-top:1px solid rgba(255,255,255,.08);border-left:0}}@media(max-width:640px){.app-shell{padding:10px;padding-left:max(10px,env(safe-area-inset-left));padding-right:max(10px,env(safe-area-inset-right));padding-bottom:max(10px,env(safe-area-inset-bottom))}.topbar{align-items:flex-start}.brand-mark{width:42px;height:42px}h1{font-size:1.65rem}.session-header,.stage-toolbar,.paper-header{align-items:flex-start;flex-direction:column}.session-header-actions{width:100%}.session-header-actions .ant-space-item{max-width:100%}.status-pill{font-size:.82rem;padding:6px 10px}.stage-actions{justify-content:flex-start;width:100%}.stage-actions .ghost-button{flex:1 1 130px}.now-playing-compact h3{font-size:1.35rem}.session-header{min-height:auto;padding:12px 14px}.session-header h2{font-size:1.25rem;overflow-wrap:anywhere}.chord-stage{padding:10px;gap:10px}.chord-paper{min-width:0}.paper-header{padding:12px 14px;gap:10px}.paper-header-song{width:100%;text-align:left}.chord-image-frame{min-height:min(52vh,420px);padding:10px}.chordtab-frame{min-height:min(52vh,420px)}.imported-chord-image{min-height:min(48vh,360px);padding:16px}.chord-pagination{flex-wrap:wrap;gap:8px;padding:10px 12px}.chord-pagination span{width:100%;text-align:center;font-size:.86rem}.image-note{padding:10px 12px;font-size:.82rem;line-height:1.45}.control-rail,.rooms-panel{padding:12px}.control-rail-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;position:sticky;bottom:0;z-index:2;order:99;margin-top:4px;padding-top:8px;background:linear-gradient(180deg,#17201b00,#17201b 28%)}.control-rail{display:flex;flex-direction:column;gap:12px;min-height:240px}.control-rail-section{display:none;gap:12px}.control-rail-section.is-active{display:grid;flex:1 1 auto}.player-panel,.stage-layout,.stage-grid{min-height:auto}.app-shell.is-in-room .stage-layout{min-height:calc(100dvh - 72px)}.stats-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.stats-strip div{padding:8px 6px}.stats-strip span{font-size:1rem}.stats-strip small{font-size:.72rem}.song-queue-item{grid-template-columns:24px minmax(0,1fr);grid-template-areas:"pos main" "actions actions";gap:6px 8px;padding:8px}.song-queue-position{grid-area:pos}.song-queue-item-main{grid-area:main}.song-queue-item-actions{grid-area:actions;justify-content:flex-start;padding-left:32px}.song-queue-list{max-height:min(42vh,360px)}.song-queue-item-main strong{white-space:normal;overflow:visible;text-overflow:unset;line-height:1.35;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.song-queue-item-main span{white-space:normal;overflow:visible;text-overflow:unset;line-height:1.35}.song-queue-actions .ant-btn{flex:1 1 auto}.song-modal-item{grid-template-columns:1fr;gap:10px}.song-modal-item-actions{justify-content:flex-start;flex-wrap:wrap}.playlist-song-row{flex-direction:column;align-items:stretch}.playlist-song-actions{flex-wrap:wrap;justify-content:flex-start}.live-modal.ant-modal{top:8px!important;width:calc(100vw - 16px)!important;max-width:calc(100vw - 16px)!important;margin:0 auto!important;padding-bottom:0}.live-modal .ant-modal-body{max-height:calc(100dvh - 140px);padding:0 14px 16px}.live-modal .ant-modal-header{padding:16px 14px 10px}.modal-footer-row{flex-direction:column;align-items:stretch}.modal-footer-row .ant-btn{width:100%}.song-row{grid-template-columns:1fr}.song-meta{justify-items:start}}.chordtab-img{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px #00000026;background:#fff}.chord-pagination{display:flex;align-items:center;justify-content:center;gap:16px;border-top:1px solid #eee3d5;padding:12px 18px;background:#fffdf8}.chord-pagination span{font-size:.95rem;font-weight:700;color:#735343}.chord-pagination .pagination-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:36px;border:1px solid #eee3d5;border-radius:6px;padding:0 16px;color:#735343;background:#fffaf2;font-weight:700;cursor:pointer}.chord-pagination .pagination-button:hover:not(:disabled){background:#eee3d5;color:#221a16}.chord-pagination .pagination-button:disabled{opacity:.5;cursor:not-allowed}.spotify-playlist-list{display:grid;gap:10px;max-height:400px;overflow-y:auto;margin-bottom:12px;padding-right:4px}.playlist-card{display:flex;align-items:center;gap:12px;border:1px solid #d9dfd5;border-radius:8px;padding:10px;background:#fbfcf8;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.playlist-card:hover{border-color:#96a69a;background:#fff8f3;box-shadow:0 4px 14px #222b2314}.playlist-art{width:44px;height:44px;border-radius:6px;object-fit:cover;box-shadow:0 2px 8px #222b2324}.playlist-art-placeholder{display:grid;place-items:center;width:44px;height:44px;border-radius:6px;background:#e8ede9;color:#667468}.playlist-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.playlist-name{color:#17201b;font-weight:700;font-size:.95rem;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-tracks{color:#4f6558;font-size:.82rem;font-weight:500}.rooms-panel .text-button{border:1px solid #d9dfd5;color:#26362d;background:#eef0e8}.rooms-panel .text-button:hover{border-color:#96a69a;background:#e4e8e0}.playlist-sync-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:32px;border:1px solid #1db954;border-radius:6px;padding:0 12px;color:#fff;background:#1db954;font-weight:700;font-size:.85rem;transition:all .2s ease;cursor:pointer}.playlist-sync-btn:hover:not(:disabled){background:#1ed760;border-color:#1ed760;transform:translateY(-1px)}.playlist-sync-btn:disabled{opacity:.65;cursor:not-allowed;background:#b8c4bb;border-color:#b8c4bb;color:#f7faf8}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.perform-mode-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;background:#090e0c;z-index:9999;display:flex;flex-direction:column;color:#fff;font-family:var(--font-ui)}.perform-mobile-dock{display:none}.perform-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#101713;border-bottom:1px solid rgba(255,255,255,.08)}.perform-song-info{display:flex;align-items:center;gap:16px}.perform-song-info h2{margin:0;font-size:1.6rem;color:#f7f1e7}.perform-live-badge{font-size:.75rem;font-weight:700;color:#7de3a4;background:#3ec17926;padding:4px 8px;border-radius:4px;letter-spacing:.05em}.perform-bpm{font-size:.9rem;font-weight:700;color:#aeb8ae;background:#ffffff14;padding:4px 8px;border-radius:4px}.exit-perform-btn{background:#c84f32;border:none;border-radius:6px;font-weight:700;padding:10px 16px;color:#fff;cursor:pointer;transition:background .2s ease}.exit-perform-btn:hover{background:#ad3f27}.perform-content{flex:1;display:flex;justify-content:center;align-items:center;padding:24px;overflow:hidden;position:relative}.perform-chord-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #00000080;background:#fff}.perform-chord-frame{width:100%;height:100%;border:none;border-radius:8px;background:#fff}.perform-empty-state{text-align:center;color:#aeb8ae}.perform-footer{display:flex;align-items:center;justify-content:center;gap:32px;padding:16px 24px;background:#101713;border-top:1px solid rgba(255,255,255,.08)}.perform-nav-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:0 24px;color:#fff;background:#ffffff0f;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s ease}.perform-nav-btn:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff40}.perform-nav-btn:disabled{opacity:.3;cursor:not-allowed}.perform-page-num{font-size:1.1rem;font-weight:700;color:#f7f1e7}.song-chord-sync-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;border:none;border-radius:999px;padding:3px 8px;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .2s ease}.song-chord-sync-btn.has-chord{color:#7de3a4;background:#3ec17924}.song-chord-sync-btn.has-chord:hover:not(:disabled){background:#3ec17940}.song-chord-sync-btn.no-chord{color:#f1bc87;background:#e38e4624}.song-chord-sync-btn.no-chord:hover:not(:disabled){background:#e38e4640}.song-chord-sync-btn:disabled{opacity:.6;cursor:not-allowed}.site-footer{max-width:1440px;margin:20px auto 0;padding:16px 24px 12px;border-top:1px solid rgba(22,32,25,.1);text-align:center;color:#4f6558;font-size:.84rem;line-height:1.5}.site-footer p{margin:0}.site-footer strong{color:#17201b;font-weight:700}.site-footer-note{margin-top:6px!important;color:#667468;font-size:.76rem}.perform-credit{position:absolute;right:16px;bottom:12px;margin:0;color:#aeb8aebf;font-size:.72rem;pointer-events:none}@media(max-width:768px){.perform-header,.perform-footer,.perform-credit{display:none}.perform-mobile-dock{display:flex;align-items:center;justify-content:center;gap:8px;flex-shrink:0;padding:6px 10px max(6px,env(safe-area-inset-bottom));background:#101713f7;border-top:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.perform-dock-btn.ant-btn{color:#eef0e8;border-color:#eef0e847;background:#eef0e814}.perform-dock-btn.ant-btn-text{color:#d8e2da}.perform-dock-toggle .ant-btn{min-width:52px;padding-inline:8px}.perform-dock-pages{display:inline-flex;align-items:center;gap:4px}.perform-dock-page-num{min-width:36px;color:#d8e2da;font-size:.82rem;font-weight:700;text-align:center}.perform-dock-song{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#aeb8ae;font-size:.78rem;text-align:center;padding:0 4px}.perform-content{flex:1;min-height:0;padding:4px}.perform-chord-img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;box-shadow:none}.perform-chord-frame{border-radius:4px}}.app-error-alert{max-width:1440px;margin:0 auto 16px}.live-modal .ant-modal-content{padding:0;overflow:hidden}.live-modal .ant-modal-header{padding:20px 24px 12px;margin-bottom:0}.live-modal .ant-modal-body{padding:0 24px 20px;max-height:min(70vh,640px);overflow:auto}.live-modal .ant-modal-footer{padding:12px 24px 20px;margin-top:0}.song-live-modal .ant-modal-content{background:#fbfcf8}.song-live-modal .ant-modal-header{background:#fbfcf8;border-bottom:1px solid #e3ebe3}.song-live-modal .ant-modal-title{color:#17201b}.song-live-modal .modal-eyebrow{color:#667468!important}.song-live-modal .modal-title-block .ant-typography{color:#17201b}.song-live-modal .song-modal-list{margin:0}.song-live-modal .song-modal-loading{display:flex;justify-content:center;padding:48px 16px}.song-live-modal .song-modal-item{color:#17201b;border-color:#d9dfd5;background:#fff}.song-live-modal .song-modal-item:hover{border-color:#258f6a73;background:#f4fbf7}.song-live-modal .song-modal-item-main strong{color:#17201b;font-weight:700}.song-live-modal .song-modal-item-main span{color:#4f6558}.song-live-modal .song-modal-playlist{color:#258f6a!important}.song-live-modal .song-modal-meta{color:#667468}.song-live-modal .song-modal-pagination{display:flex;justify-content:center;padding-top:4px}.song-live-modal .song-modal-footer{border-top:1px solid #e3ebe3;padding:14px 0 0;background:transparent}.song-live-modal .song-modal-footer-title{color:#17201b}.song-live-modal .song-modal-manual input{color:#17201b;border-color:#d9dfd5;background:#fff}.modal-title-block .modal-eyebrow{display:block;font-size:.78rem;font-weight:600;letter-spacing:.04em;margin-bottom:2px}.modal-footer-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.modal-empty-connect{display:grid;gap:16px;justify-items:center;padding:12px 0 8px}.sync-status-block{display:grid;gap:8px;padding:12px 14px;border-radius:10px;background:#1f6b4f0f;border:1px solid rgba(31,107,79,.12)}.spotify-connect-btn{font-weight:600}.create-room .ant-input-affix-wrapper,.create-room .ant-input{margin-top:0;background:#fff}.stage-actions.ant-space{flex-wrap:wrap}.app-shell .ant-input-affix-wrapper:not(.ant-input-affix-wrapper-sm):not(.ant-input-affix-wrapper-lg),.app-shell .ant-input:not(.ant-input-sm):not(.ant-input-lg):not(textarea),.app-shell .ant-btn:not(.ant-btn-sm):not(.ant-btn-lg):not(.ant-btn-icon-only),.app-shell .ant-space-compact .ant-input-affix-wrapper,.app-shell .ant-space-compact .ant-btn,.live-modal .ant-input-affix-wrapper:not(.ant-input-affix-wrapper-sm):not(.ant-input-affix-wrapper-lg),.live-modal .ant-input:not(.ant-input-sm):not(.ant-input-lg):not(textarea),.live-modal .ant-btn:not(.ant-btn-sm):not(.ant-btn-lg):not(.ant-btn-icon-only),.live-modal .ant-space-compact .ant-input-affix-wrapper,.live-modal .ant-space-compact .ant-btn{height:40px}.app-shell .ant-input-affix-wrapper,.live-modal .ant-input-affix-wrapper{display:inline-flex;align-items:center}.app-shell .ant-input-affix-wrapper .ant-input,.live-modal .ant-input-affix-wrapper .ant-input{height:auto;min-height:0;line-height:22px;padding-top:0;padding-bottom:0}.app-shell .ant-input-affix-wrapper .ant-input-prefix,.app-shell .ant-input-affix-wrapper .ant-input-suffix,.live-modal .ant-input-affix-wrapper .ant-input-prefix,.live-modal .ant-input-affix-wrapper .ant-input-suffix{display:inline-flex;align-items:center;line-height:1}.app-shell .ant-input:not(.ant-input-sm):not(.ant-input-lg):not(textarea),.live-modal .ant-input:not(.ant-input-sm):not(.ant-input-lg):not(textarea){line-height:22px;padding-top:8px;padding-bottom:8px}.app-shell .ant-btn-sm,.app-shell .ant-input-affix-wrapper-sm,.app-shell .ant-input-sm,.live-modal .ant-btn-sm,.live-modal .ant-input-affix-wrapper-sm,.live-modal .ant-input-sm{height:32px}.app-shell .ant-btn-lg,.app-shell .ant-input-affix-wrapper-lg,.app-shell .ant-input-lg,.live-modal .ant-btn-lg,.live-modal .ant-input-affix-wrapper-lg,.live-modal .ant-input-lg{height:44px}.app-shell .ant-btn,.live-modal .ant-btn{display:inline-flex;align-items:center;justify-content:center;line-height:1.2;padding-top:0;padding-bottom:0}.app-shell label{gap:8px}.chord-image-frame .ant-spin-nested-loading,.chord-image-frame .ant-spin-container{min-height:280px}.sheet-pointer-layer{position:relative;display:inline-block;max-width:100%}.sheet-pointer-overlay{position:absolute;z-index:4;pointer-events:none}.perform-sheet-pointer-layer{display:flex;flex:1;align-items:center;justify-content:center;width:100%;min-height:0}.perform-sheet-pointer-layer .perform-chord-img{display:block;flex:none;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.sheet-pointer-layer .chordtab-img{display:block;max-width:100%;width:auto;height:auto}.sheet-pointer-marker{position:absolute;z-index:4;transform:translate(-50%,-50%);pointer-events:none;animation:sheet-pointer-flash var(--pointer-duration, 2.5s) ease-out forwards}.sheet-pointer-dot{display:block;width:10px;height:10px;border-radius:999px;border:2px solid var(--pointer-color, #7de3a4);background:color-mix(in srgb,var(--pointer-color, #7de3a4) 45%,transparent);box-shadow:none}.sheet-pointer-ring{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border:2px solid color-mix(in srgb,var(--pointer-color, #7de3a4) 55%,transparent);border-radius:999px;background:transparent;animation:sheet-pointer-pulse 1.6s ease-out infinite}.sheet-pointer-label{position:absolute;top:-26px;left:14px;transform:none;border-radius:999px;padding:2px 8px;background:#17201bb8;border:1px solid color-mix(in srgb,var(--pointer-color, #7de3a4) 55%,transparent);color:var(--pointer-color, #7de3a4);font-size:.72rem;font-weight:700;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sheet-pointer-hint{display:block;padding:0 18px 8px;font-size:.84rem}@keyframes sheet-pointer-flash{0%{opacity:0;transform:translate(-50%,-50%) scale(.65)}10%{opacity:.92;transform:translate(-50%,-50%) scale(1)}45%{opacity:.85;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1)}}@keyframes sheet-pointer-pulse{0%{opacity:.55;transform:scale(.75)}to{opacity:0;transform:scale(1.6)}}.perform-footer{display:flex;align-items:center;justify-content:center;gap:16px}.perform-header .ant-btn{color:#eef0e8;border-color:#eef0e859;background:#eef0e814}.playlist-card.is-clickable{cursor:pointer}.playlist-card.is-clickable:focus-visible{outline:2px solid #258f6a;outline-offset:2px}.playlist-browse-hint{display:block;font-size:.82rem}.playlist-tracks-note{display:block;font-size:.82rem;line-height:1.45}.modal-back-btn{padding-left:0;margin-bottom:4px}.playlist-song-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #d9dfd5;border-radius:8px;padding:10px 12px;background:#fbfcf8}.playlist-song-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.playlist-song-main strong{color:#17201b;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-song-main span{color:#4f6558;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-song-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.song-in-playlist-list{display:grid;gap:8px}.perform-header .ant-btn:hover{color:#fff;border-color:#eef0e899;background:#eef0e829!important}
