*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--gold: #D4A843;--gold-light: #F0C96A;--dark: #141414;--surface: #1E1E1E;--card: #252525;--card-border: #333;--text: #F0EDE8;--muted: #888;--green: #1DB954;--tag-bg: #2a2a2a}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--dark);color:var(--text);min-height:100vh;padding-bottom:calc(110px + env(safe-area-inset-bottom))}#login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 24px;text-align:center}.login-logo{font-size:48px;margin-bottom:16px}.login-venue{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}.login-title{font-size:24px;font-weight:800;margin-bottom:10px}.login-desc{font-size:14px;color:var(--muted);max-width:280px;line-height:1.5;margin-bottom:40px}.spotify-btn{background:var(--green);color:#fff;border:none;border-radius:50px;padding:16px 36px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:10px;transition:opacity .15s,transform .1s}.spotify-btn:active{transform:scale(.97);opacity:.9}.login-note{font-size:12px;color:#555;margin-top:20px;max-width:260px;line-height:1.5}header{background:linear-gradient(135deg,#1a1a1a,#241d0e);border-bottom:2px solid var(--gold);padding:16px 16px 14px;position:sticky;top:0;z-index:20}.header-row{display:flex;justify-content:space-between;align-items:flex-start}.venue-name{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}.venue-sub{font-size:17px;font-weight:800;color:var(--text);margin-top:1px}.header-right{text-align:right}.clock-time{font-size:21px;font-weight:700;color:var(--gold-light);font-variant-numeric:tabular-nums}.clock-slot{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:1px}.now-playing-bar{margin-top:10px;background:#1db9541a;border:1px solid rgba(29,185,84,.25);border-radius:8px;padding:7px 10px;display:flex;align-items:center;gap:8px}.np-dot{width:7px;height:7px;background:var(--green);border-radius:50%;flex-shrink:0;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.np-text{font-size:12px;color:var(--green);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.logout-btn{background:none;border:1px solid #333;color:var(--muted);font-size:11px;padding:3px 8px;border-radius:4px;cursor:pointer;flex-shrink:0}#device-banner{background:var(--surface);border-bottom:1px solid var(--card-border);padding:10px 16px;display:flex;align-items:center;gap:8px;cursor:pointer}.device-icon{font-size:16px}.device-label{flex:1;font-size:13px;color:var(--muted)}.device-name{font-weight:600;color:var(--text)}.device-change{font-size:11px;color:var(--gold);font-weight:600}#crowd-selector{background:var(--surface);border-bottom:1px solid var(--card-border);padding:10px 16px;display:flex;align-items:center;gap:10px}.crowd-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);flex-shrink:0}.crowd-options{display:flex;gap:6px;flex:1}.crowd-btn{flex:1;background:var(--tag-bg);border:1px solid var(--card-border);color:var(--muted);font-size:12px;font-weight:600;padding:6px 0;border-radius:6px;cursor:pointer;transition:all .15s}.crowd-btn:active{transform:scale(.96)}.crowd-btn.active.quiet{background:#111e2e;border-color:#1e4a7a;color:#6aacdd}.crowd-btn.active.moderate{background:#1a2e1a;border-color:#2a5a2a;color:#7ec87e}.crowd-btn.active.busy{background:#2e1e0a;border-color:#7a4a10;color:#e0943a}.crowd-btn.active.packed{background:#2e0f0f;border-color:#7a1a1a;color:#e05555}.section{padding:18px 14px 0}.section-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.now-card{background:linear-gradient(135deg,#17321f,#1c2a17);border:1px solid #2a5c38;border-radius:12px;padding:14px;margin-bottom:10px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:border-color .15s,transform .1s}.now-card:active{transform:scale(.98)}.now-card:hover{border-color:var(--green)}.now-icon{width:46px;height:46px;border-radius:8px;object-fit:cover;background:#333;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px;overflow:hidden}.now-icon img{width:100%;height:100%;object-fit:cover;border-radius:8px}.now-info{flex:1;min-width:0}.now-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-meta{font-size:11px;color:#aaa;margin-top:2px}.play-btn{background:var(--green);color:#fff;border:none;border-radius:24px;padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0;transition:opacity .15s,transform .1s}.play-btn:active{transform:scale(.95)}.play-btn:hover{opacity:.85}.play-btn.playing{background:#333;color:var(--green)}.play-group{display:flex;gap:4px;flex-shrink:0}.after-btn{background:#2a2a2a;color:var(--muted);border:1px solid #333;border-radius:24px;padding:8px 10px;font-size:13px;cursor:pointer;flex-shrink:0;transition:all .15s}.after-btn:active{transform:scale(.95)}.after-btn.pending{background:#1a2a1a;border-color:var(--gold);color:var(--gold)}.empty-state{background:var(--card);border:1px dashed var(--card-border);border-radius:12px;padding:24px;text-align:center;color:var(--muted);font-size:13px;line-height:1.6}.grid-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sort-row{display:flex;gap:4px}.sort-btn{background:none;border:1px solid var(--card-border);color:var(--muted);font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;cursor:pointer;transition:all .15s;white-space:nowrap}.sort-btn.active{background:var(--surface);border-color:#555;color:var(--text)}.filter-row{display:flex;gap:7px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;margin-bottom:12px}.filter-row::-webkit-scrollbar{display:none}.filter-btn{background:var(--tag-bg);border:1px solid var(--card-border);color:var(--muted);font-size:12px;font-weight:600;padding:6px 14px;border-radius:20px;cursor:pointer;white-space:nowrap;transition:all .15s}.filter-btn.active{background:var(--gold);border-color:var(--gold);color:var(--dark)}.playlist-grid{display:flex;flex-direction:column;gap:8px}.playlist-card{background:var(--card);border:1px solid var(--card-border);border-radius:12px;padding:12px 14px;transition:border-color .15s}.playlist-card:hover{border-color:#444}.card-top{display:flex;align-items:center;gap:12px}.playlist-thumb{width:44px;height:44px;border-radius:6px;background:#333;flex-shrink:0;object-fit:cover;display:flex;align-items:center;justify-content:center;font-size:18px;overflow:hidden}.playlist-thumb img{width:100%;height:100%;object-fit:cover;border-radius:6px}.playlist-info{flex:1;min-width:0}.playlist-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-meta{font-size:11px;color:var(--muted);margin-top:2px}.slot-row{display:flex;gap:5px;margin-top:10px;flex-wrap:wrap;align-items:center}.slot-label{font-size:10px;color:#555;margin-right:2px;text-transform:uppercase;letter-spacing:.06em}.slot-toggle{font-size:10px;font-weight:700;letter-spacing:.04em;padding:3px 9px;border-radius:4px;cursor:pointer;border:1px solid #3a3a3a;background:#2a2a2a;color:#555;text-transform:uppercase;transition:all .12s}.slot-toggle.on.lunch{background:#1a3025;border-color:#2a6040;color:#7ec8a0}.slot-toggle.on.afternoon{background:#2e2210;border-color:#6a4a10;color:#d4a843}.slot-toggle.on.evening{background:#1e1a2e;border-color:#4a3a8a;color:#9b8fd4}.slot-toggle.on.late{background:#2e1a10;border-color:#6a3510;color:#d47a43}.slot-toggle.on.quiet{background:#111e2e;border-color:#1e4a7a;color:#6aacdd}.slot-toggle.on.moderate{background:#1a2e1a;border-color:#2a5a2a;color:#7ec87e}.slot-toggle.on.busy{background:#2e1e0a;border-color:#7a4a10;color:#e0943a}.slot-toggle.on.packed{background:#2e0f0f;border-color:#7a1a1a;color:#e05555}.device-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009}.sheet-panel{position:absolute;bottom:0;left:0;right:0;background:var(--surface);border-radius:20px 20px 0 0;padding:20px 16px 40px;border-top:2px solid var(--gold)}.sheet-title{font-size:16px;font-weight:800;margin-bottom:4px}.sheet-sub{font-size:12px;color:var(--muted);margin-bottom:18px}.device-option{display:flex;align-items:center;gap:14px;padding:14px;border-radius:10px;cursor:pointer;transition:background .12s;margin-bottom:4px}.device-option:hover,.device-option:active{background:var(--card)}.device-option-icon{font-size:22px}.device-option-info{flex:1}.device-option-name{font-size:14px;font-weight:700}.device-option-type{font-size:11px;color:var(--muted);margin-top:1px}.device-option-active{font-size:11px;color:var(--green);font-weight:700}.no-devices{text-align:center;padding:24px;color:var(--muted);font-size:14px;line-height:1.6}#player-footer{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom));left:0;right:0;display:flex;justify-content:center;z-index:30;pointer-events:none;-webkit-transform:translateZ(0);transform:translateZ(0)}.player-pill{display:flex;align-items:center;gap:8px;background:#161616eb;border:1px solid rgba(255,255,255,.08);border-radius:50px;padding:10px 16px 10px 12px;box-shadow:0 8px 32px #0000008c,0 2px 8px #0000004d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);pointer-events:all}.footer-playpause{width:62px;height:62px;border-radius:50%;background:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#000;flex-shrink:0;transition:transform .12s,opacity .15s;box-shadow:0 2px 12px #0006}.footer-playpause svg{width:26px;height:26px}.footer-playpause:active{transform:scale(.91);opacity:.9}.footer-skip{width:52px;height:52px;background:none;border:none;color:#ffffffbf;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s,color .15s;padding:0;flex-shrink:0}.footer-skip svg{width:30px;height:30px}.footer-skip:active{color:#fff;opacity:.6}.footer-skip:disabled{opacity:.25;cursor:default}.footer-shuffle{width:52px;height:52px;background:none;border:none;color:#fff6;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,opacity .15s;padding:0;flex-shrink:0;position:relative}.footer-shuffle svg{width:24px;height:24px}.footer-shuffle:active{opacity:.6}.footer-shuffle.active{color:var(--green)}.footer-shuffle.active:after{content:"";position:absolute;bottom:8px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--green)}#toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(20px);background:var(--card);border:1px solid #444;border-radius:24px;padding:10px 20px;font-size:13px;font-weight:600;color:var(--text);opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;white-space:nowrap;z-index:200}#toast.show{opacity:1;transform:translate(-50%) translateY(0)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid #333;border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}
