:root{--bg: #0b0d10;--sidebar-bg: #101319;--panel: #11141a;--text: #f2f4f7;--muted: #8b93a1;--divider: rgba(255, 255, 255, .07);--accent: #e8e2d4;--danger: #ff6b6b;--danger-soft: rgba(255, 107, 107, .15);--radius: 10px;--radius-lg: 14px}*{box-sizing:border-box}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Noto Sans Thai,Sarabun,Segoe UI,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font:inherit}.shell{display:grid;grid-template-columns:320px minmax(0,1fr);height:100dvh;min-height:100dvh;overflow:hidden;background:var(--bg)}.left-pane{background:var(--sidebar-bg);padding:12px;border-right:1px solid var(--divider);display:flex;flex-direction:column;gap:10px;min-height:0;overflow:auto}.right-pane{padding:12px 16px;min-width:0;display:flex;flex-direction:column;gap:10px;overflow:hidden;background:var(--bg)}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-shrink:0}.title-area{min-width:0}.title-area h1{margin:0;font-size:1.1rem;line-height:1.1;letter-spacing:-.02em}.panel{background:var(--panel);border:1px solid var(--divider);border-radius:var(--radius-lg);padding:14px}.panel-title{display:flex;align-items:center;gap:10px;margin-bottom:12px;color:var(--text)}.panel-title h2,.panel-title h3{margin:0;font-size:.82rem;letter-spacing:.02em;font-weight:650;color:#f2f4f7f0}.mode-switch{display:inline-flex;align-items:center;gap:8px;margin-top:8px}.mode-switch .button{width:36px;min-width:36px;height:36px;min-height:36px;border-color:transparent;background:#ffffff0f}.mode-switch .button.primary{background:#e8e2d4f2;color:#0b0d10;border-color:transparent}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:33px;height:33px;border:1px solid var(--divider);border-radius:999px;color:var(--text);background:#ffffff0a;flex-shrink:0}.grid{display:grid;gap:10px}.stack{display:grid;gap:12px}h3,h2,h4{margin:0}.muted{color:var(--muted);margin:0}.notice{border:1px solid var(--divider);background:#e8e2d424;color:#0b0d10;padding:10px 12px;border-radius:var(--radius);font-size:.82rem;flex-shrink:0}.button,.icon-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--divider);border-radius:var(--radius);color:var(--text);background:#ffffff08;padding:0 6px;min-height:32px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .08s ease;text-decoration:none}.button:hover,.icon-button:hover{background:#ffffff14;border-color:#ffffff2e}.button:active,.icon-button:active{transform:translateY(1px)}.button.primary{background:var(--accent);border-color:var(--accent);color:#0b0d10}.button.primary:hover{background:#f2f4f7}.button-row{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.button.small{min-height:28px;padding:0 10px;font-size:.8rem}.button:disabled,.icon-button:disabled{opacity:.45;cursor:not-allowed}.icon-button{width:34px;min-width:34px;padding:0}select,input[type=text],input[type=number],input:not([type]){min-height:32px;width:100%;background:#ffffff08;border:1px solid var(--divider);border-radius:var(--radius);color:var(--text);padding:0 12px;outline:none}select:focus,input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #e8e2d440}.inline-checkbox{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:.78rem}.inline-checkbox input[type=checkbox]{width:14px;height:14px}.panel-title .icon-button{width:28px;min-width:28px;height:28px}.facts{margin:0;display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:.8rem}.facts dt{color:var(--muted)}.facts dd{margin:0}.now-panel{min-height:0}.now-layout{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}.now-cover-wrap{display:grid;align-items:start;width:100%}.cover{width:100%;aspect-ratio:1;border-radius:12px;object-fit:cover;background:#ffffff0d}.youtube-shell{width:100%;max-width:100%;aspect-ratio:16 / 9;border-radius:10px;overflow:hidden}#youtube-player{width:100%;height:100%;display:block}.now-stack{min-width:0}.now-title{margin:2px 0 6px;font-size:1.12rem;color:var(--text);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.now-meta{margin-top:4px!important}.seek-bar{display:block;width:100%;height:5px;border-radius:999px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;background:var(--divider)}progress::-webkit-progress-bar{background:var(--divider);border-radius:999px}progress::-webkit-progress-value{background:var(--accent);border-radius:999px}progress::-moz-progress-bar{background:var(--accent);border-radius:999px}.controls{display:flex;align-items:center;gap:8px}.controls .icon-button{background:#ffffff0d}.controls .primary-play{background:var(--accent);color:#0b0d10;border-color:var(--accent)}.now-bottom-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.volume-control{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px}.volume-control label{color:var(--muted);font-size:.8rem}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:5px;background:var(--divider);border-radius:999px;border:none;margin:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid #0b0d10}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;border:2px solid #0b0d10;background:var(--accent)}.volume-text{color:var(--muted);min-width:42px;text-align:right;font-size:.8rem}.library-panel{display:flex;flex:1;min-height:0;flex-direction:column}.filters{margin-bottom:10px;display:grid;grid-template-columns:190px 180px 170px 1fr auto;gap:8px;align-items:center}.table{display:grid;gap:6px;min-height:0;overflow:auto;flex:1}.choice-row{display:grid;grid-template-columns:48px 1fr auto;gap:12px;align-items:center;border:1px solid transparent;border-radius:var(--radius);padding:8px 10px;background:transparent;color:var(--text);cursor:pointer;position:relative;min-width:0;transition:background .18s ease}.choice-row:hover,.choice-row-selected{background:#ffffff0a}.choice-row-playing{background:#ffffff0b;border-left:2px solid var(--accent)}.choice-row-playing:before{content:"";position:absolute;left:8px;top:50%;width:3px;height:12px;border-radius:999px;transform:translateY(-50%);background:linear-gradient(180deg,var(--accent) 0%,transparent 100%);opacity:.9;animation:pulse-eq 1s infinite}@keyframes pulse-eq{0%,to{opacity:.45;height:10px}50%{opacity:.95;height:16px}}.thumb{width:48px;height:48px;border-radius:8px;object-fit:cover;background:#ffffff0f}.choice-main{min-width:0;display:grid;gap:2px}.choice-main strong,.choice-main span,.choice-main small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.choice-main strong{font-size:.93rem;color:var(--text)}.choice-main span{color:var(--muted);font-size:.84rem}.choice-main small{color:var(--muted);font-size:.76rem}.choice-main .status-text{opacity:.85}.choice-actions{display:inline-flex;align-items:center;gap:6px;justify-content:flex-end}.icon-button.primary{background:#e8e2d424;color:#0b0d10;border-color:transparent}.icon-button.primary:hover{background:var(--accent)}.row-menu-wrap{position:relative}.row-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:10;min-width:150px;background:var(--panel);border:1px solid var(--divider);border-radius:var(--radius);padding:6px;display:grid;gap:4px;box-shadow:0 10px 30px #0006}.menu-item{width:100%;text-align:left;border:none;background:transparent;color:var(--text);padding:8px 10px;border-radius:8px;min-height:30px;display:flex;align-items:center;font-size:.84rem;text-decoration:none}.menu-item:hover{background:#ffffff14}.menu-item.danger{color:var(--danger)}.pager{margin-top:10px;display:flex;align-items:center;justify-content:center;color:var(--muted);gap:8px}.pager .button{min-width:84px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#0b0d108c;display:grid;place-items:center;padding:16px}.modal{width:min(640px,100%);background:var(--panel);border:1px solid var(--divider);border-radius:var(--radius-lg);padding:18px}.modal-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.modal-title h3{margin:0;font-size:1rem}.modal-subtitle{color:var(--muted);font-size:.9rem;margin-bottom:8px}.modal-loading{color:var(--muted);margin:12px 0}.candidate-list{display:grid;gap:7px;max-height:46vh;overflow:auto}.candidate-row{display:grid;grid-template-columns:44px 18px 1fr auto;gap:10px;align-items:center;border:1px solid var(--divider);border-radius:var(--radius);padding:10px}.candidate-row:hover,.candidate-row:focus-within{background:#ffffff0d}.candidate-row-selected{border-color:var(--accent);background:#e8e2d41f}.candidate-art{width:44px;height:44px;object-fit:cover;border-radius:8px;background:#ffffff0f}.candidate-main{min-width:0;display:grid;gap:2px}.candidate-main strong,.candidate-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidate-main span{color:var(--muted)}.candidate-score{color:var(--muted);font-size:.8rem}.modal-actions{margin-top:12px;display:flex;justify-content:flex-end;gap:8px}.busy{position:fixed;right:16px;bottom:16px;background:var(--panel);color:var(--text);border:1px solid var(--divider);padding:8px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;font-size:.82rem}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1023px){.shell{grid-template-columns:280px minmax(0,1fr)}.filters{grid-template-columns:1fr 1fr;grid-auto-rows:minmax(0,auto)}.filters input,.filters .button{grid-column:span 2}}@media(max-width:767px){.shell{display:flex;flex-direction:column;height:100dvh;min-height:100dvh;overflow:hidden}.left-pane{flex:0 0 auto;border-right:none;border-bottom:1px solid var(--divider);padding:10px 12px;gap:8px;overflow:visible}.left-pane .grid{display:none}.title-area h1{font-size:1.05rem}.mode-switch{margin-top:4px}.mode-switch .button{width:32px;min-width:32px;height:32px;min-height:32px}.notice{padding:6px 10px;font-size:.78rem}.panel{padding:10px;border-radius:var(--radius)}.panel-title{margin-bottom:8px}.now-panel{padding:10px}.now-layout{grid-template-columns:1fr 1fr;gap:10px;align-items:center}.now-cover-wrap{max-width:none}.cover,.youtube-shell{border-radius:8px}.now-stack{gap:6px}.now-title{font-size:.92rem;margin:0 0 2px}.now-stack .muted{font-size:.78rem}.seek-bar{height:4px}.controls{gap:4px}.controls .icon-button{width:28px;min-width:28px;height:28px}.now-bottom-row{gap:6px}.volume-control{grid-template-columns:auto 1fr auto;gap:6px}.volume-control label{font-size:.72rem}.volume-text{font-size:.72rem;min-width:32px}.right-pane{flex:1 1 auto;min-height:0;overflow:hidden;padding:10px 12px;gap:8px}.library-panel{overflow:hidden;min-height:0}.library-panel .panel-title{margin-bottom:6px}.library-panel .panel-title h2{font-size:.78rem}.filters{display:flex;flex-wrap:nowrap;gap:6px;margin-bottom:8px;overflow-x:auto;padding-bottom:2px}.filters select,.filters input,.filters .button{min-height:30px;font-size:.8rem;flex:0 0 auto}.filters select{min-width:110px}.filters input{flex:1 1 auto;min-width:0}.filters .button{flex:0 0 auto;padding:0 10px}.table{overflow-y:auto;min-height:0;gap:4px}.choice-row{grid-template-columns:44px 1fr auto;gap:8px;padding:6px 8px}.thumb{width:44px;height:44px;border-radius:6px}.choice-main strong{font-size:.88rem}.choice-main span{font-size:.78rem}.choice-main small{font-size:.72rem}.choice-actions{gap:4px}.choice-actions .icon-button{width:28px;min-width:28px;height:28px}.row-menu{min-width:130px}.pager{margin-top:8px;gap:6px;font-size:.8rem}.pager .button{min-width:70px;min-height:28px;padding:0 8px;font-size:.8rem}.modal{padding:14px}.candidate-list{max-height:50vh}.busy{right:10px;bottom:10px;padding:6px 10px;font-size:.78rem}}
