: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}button,input{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding:24px;background:linear-gradient(135deg,rgba(41,111,82,.13),transparent 32%),linear-gradient(315deg,rgba(186,60,40,.11),transparent 36%),#eef0e8}.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}.rooms-panel{align-self:start;padding:16px}.player-panel{min-height:calc(100vh - 112px);padding:0;overflow:hidden}.create-room{display:grid;gap:12px;margin-bottom:22px;border-radius:8px;padding:14px;background:#17201b}.spotify-panel{margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.08)}.spotify-connect{display:inline-flex;align-items:center;justify-content:center;width:100%;text-decoration:none}.spotify-note{margin:0 0 10px;color:#9fb0a3;font-size:.9rem}.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{min-height:44px;width:100%;border:1px solid #c9d1c7;border-radius:6px;padding:0 12px;color:#17201b;background:#fff}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}.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-list{display:grid;gap:10px;margin-top:14px}.room-card{display:grid;gap:8px;width:100%;border:1px solid #d9dfd5;border-radius:8px;padding:14px;color:inherit;background:#fbfcf8;text-align:left}.room-card:hover{border-color:#96a69a}.room-card.is-active{border-color:#c84f32;background:#fff8f3;box-shadow:0 0 0 3px #c84f3224}.room-card-title{font-weight:700}.room-card-code{border-radius:999px;padding:4px 8px;color:#79402f;background:#f5dfd5;font-size:.72rem;font-weight:700}.room-card-meta{display:inline-flex;align-items:center;gap:6px;color:#4f6558;font-size:.9rem}.room-card-song{color:#26362d;font-size:.95rem}.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}.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}.song-control{display:grid;gap:12px}.song-control label{color:#cfd9d0}.stats-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.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}.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}.rooms-panel{order:2}.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}.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}.stage-actions{justify-content:flex-start;width:100%}.stage-actions .ghost-button{flex:1 1 130px}.session-header{min-height:auto}.chord-stage{padding:10px}.chord-image-frame{min-height:58vh;padding:18px}.imported-chord-image{min-height:52vh}.control-rail,.rooms-panel{padding:12px}.stats-strip{grid-template-columns:1fr 1fr 1fr}.song-row{grid-template-columns:1fr}.song-meta{justify-items:start}}
