*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #15151f;--surface: #1d1d2c;--surface-hi: #252538;--hairline: rgba(255, 255, 255, .06);--text: #f0eef7;--text-dim: rgba(240, 238, 247, .55);--text-faint: rgba(240, 238, 247, .35);--accent: #ef4f6c;--accent-soft: rgba(239, 79, 108, .16);--good: #5ed4a4;--good-soft: rgba(94, 212, 164, .16);--drop: #f5b14a}html,body,#root{min-height:100dvh}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro,system-ui,sans-serif;overflow:hidden;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none}button,input{font:inherit}button{touch-action:manipulation}.app-shell{display:flex;flex-direction:column;gap:12px;height:100dvh;margin:0 auto;max-width:480px;padding:calc(14px + env(safe-area-inset-top)) 22px calc(16px + env(safe-area-inset-bottom));touch-action:pan-y}.topbar{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;padding:0 2px}.brand{align-items:center;color:var(--text-dim);display:flex;font-size:12px;font-weight:600;gap:8px;letter-spacing:1.4px;text-transform:uppercase}.brand-dot{background:var(--accent);border-radius:4px;box-shadow:0 0 10px var(--accent);height:8px;width:8px}.inbox-count{color:var(--text-dim);font-size:12px;font-variant-numeric:tabular-nums}.inbox-count strong{color:var(--text);font-weight:600}.topbar button{background:none;border:0;border-radius:6px;color:var(--text-faint);cursor:pointer;padding:4px 8px}.stats-strip{display:flex;flex-shrink:0;gap:8px}.stat{align-items:baseline;background:var(--surface);border-radius:10px;display:flex;flex:1;gap:6px;padding:8px 12px}.stat-val{font-size:18px;font-variant-numeric:tabular-nums;font-weight:700}.stat-val.kept{color:var(--good)}.stat-val.skipped{color:var(--accent)}.stat-label{color:var(--text-faint);font-size:10px;letter-spacing:1px;text-transform:uppercase}.section-label{color:var(--text-faint);flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:1.6px;padding-left:2px;text-transform:uppercase}.queue-list{flex:1;margin-top:-4px;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.queue-list::-webkit-scrollbar{display:none}.queue-item{align-items:baseline;border-bottom:1px solid var(--hairline);display:flex;gap:10px;min-width:0;padding:8px 2px}.q-num{color:var(--text-faint);flex-shrink:0;font-size:11px;font-variant-numeric:tabular-nums;text-align:right;width:16px}.q-text{color:var(--text-dim);flex:1;font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.q-artist{color:var(--text);font-weight:500}.player-panel{background:var(--surface);border-radius:22px;box-shadow:0 10px 30px #00000059;flex-shrink:0;overflow:hidden;padding:18px 18px 16px;position:relative;transform:translate(0) rotate(0);transition:transform .25s cubic-bezier(.2,.8,.2,1);will-change:transform}.player-panel.swipe-keep{transform:translate(32px) rotate(8deg)}.player-panel.swipe-skip{transform:translate(-32px) rotate(-8deg)}.player-panel.swipe-drag{transition:none}.track-info{margin-bottom:12px}.artist{color:var(--text-faint);font-size:10px;font-weight:600;letter-spacing:1.6px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.title{color:var(--text);font-size:18px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waveform-container{cursor:pointer;height:72px;margin-top:4px;position:relative;touch-action:none}.waveform-container canvas{display:block;height:100%;left:0;position:absolute;top:0;width:100%}.waveform-progress-canvas{pointer-events:none}.playhead{background:var(--text);bottom:-2px;pointer-events:none;position:absolute;top:-2px;width:1.5px}.drop-tag{bottom:-14px;color:var(--drop);font-size:8px;font-weight:700;position:absolute;text-transform:uppercase;transform:translate(-50%)}.time-display{color:var(--text-faint);display:flex;font-size:11px;font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:10px}.swipe-stamp{backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border:2px solid;border-radius:6px;font-size:18px;font-weight:800;letter-spacing:2px;opacity:0;padding:6px 14px;pointer-events:none;position:absolute;top:14px;transition:opacity .15s}.swipe-stamp.keep{background:var(--good-soft);border-color:var(--good);color:var(--good);left:14px;transform:rotate(-10deg)}.swipe-stamp.skip{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);right:14px;transform:rotate(10deg)}.player-panel.swipe-keep .swipe-stamp.keep,.player-panel.swipe-skip .swipe-stamp.skip,.swipe-stamp.visible{opacity:1}.actions{display:grid;flex-shrink:0;gap:12px;grid-template-columns:.85fr 1fr .9fr 1fr}.action-btn{align-items:center;border:0;border-radius:18px;color:var(--text);cursor:pointer;display:flex;font-size:24px;font-weight:700;height:64px;justify-content:center}.action-btn:disabled{cursor:default;opacity:.35}.action-btn.prev{background:var(--surface-hi);color:var(--text-dim)}.action-btn.skip{background:var(--accent-soft);color:var(--accent)}.action-btn.play{background:var(--surface-hi);font-size:20px}.action-btn.keep{background:var(--good-soft);color:var(--good)}.empty-state{align-items:center;color:var(--text-dim);display:flex;flex:1;flex-direction:column;font-size:16px;gap:12px;justify-content:center}.empty-mark{align-items:center;border:1.5px solid var(--good);border-radius:50%;color:var(--good);display:flex;font-size:24px;height:56px;justify-content:center;width:56px}.empty-state small{color:var(--text-faint);font-size:12px}.error-banner{align-items:center;background:#ef4f6c24;border:1px solid rgba(239,79,108,.24);border-radius:10px;color:var(--text);display:flex;gap:10px;padding:10px 12px}.error-banner span{flex:1;font-size:12px}.error-banner button{background:var(--surface-hi);border:0;border-radius:6px;color:var(--text);padding:6px 8px}.login-screen{align-items:center;display:flex;min-height:100dvh;padding:22px}.login-panel{background:var(--surface);border-radius:20px;box-shadow:0 10px 30px #00000059;display:grid;gap:14px;margin:0 auto;max-width:420px;padding:22px;width:100%}.login-brand{margin-bottom:4px}.login-panel label{color:var(--text-dim);display:grid;font-size:12px;gap:6px;letter-spacing:.4px}.login-panel input{background:var(--bg);border:1px solid var(--hairline);border-radius:10px;color:var(--text);min-height:44px;padding:10px 12px}.login-panel button{background:var(--accent);border:0;border-radius:12px;color:#fff;font-weight:700;min-height:48px}.form-error{color:var(--accent);font-size:12px}
