*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100%;height:100%;overflow:hidden}html{overflow-x:hidden!important}body{max-width:100vw!important;overflow-x:hidden!important}#app-wrap,.main,.pg{overflow-x:hidden!important}:root,[data-theme=dark]{--bg:#070f1d;--bg2:#0c1828;--bg3:#101f32;--surface:#0f1e30;--surface2:#152638;--surface3:#1b2f45;--border:#ffffff12;--border2:#ffffff21;--shadow:0 2px 20px #0009;--primary:#1e3a5f;--primary-dim:#1e3a5f2e;--teal:#1e4976;--teal-dim:#1e49762e;--amber:#f59e0b;--amber-dim:#f59e0b1f;--green:#10b981;--green-dim:#10b9811f;--red:#ef4444;--red-dim:#ef44441f;--purple:#8b5cf6;--purple-dim:#8b5cf61f;--orange:#f97316;--orange-dim:#f973161f;--text:#f0f7ff;--text2:#c8dff2;--text3:#96bcd8;--primary-fg:#38bdf8;--teal-fg:#60b4e8;--font-h:"Plus Jakarta Sans", sans-serif;--font-b:"Inter", sans-serif;--font-m:"IBM Plex Mono", monospace;--sb-icon-color:#ffffff73;--sb-icon-hover:#ffffffd9;--sb-icon-active:#fff}[data-theme=light]{--bg:#f1f5f9;--bg2:#fff;--bg3:#e2e8f0;--surface:#fff;--surface2:#f8fafc;--surface3:#f1f5f9;--border:#00000014;--border2:#00000024;--shadow:0 2px 16px #00000014;--primary:#1e3a5f;--primary-dim:#1e3a5f1a;--teal:#1e4976;--teal-dim:#1e49761a;--amber:#d97706;--amber-dim:#d977061a;--green:#059669;--green-dim:#0596691a;--red:#dc2626;--red-dim:#dc262617;--purple:#7c3aed;--purple-dim:#7c3aed1a;--orange:#ea580c;--orange-dim:#ea580c1a;--text:#0a0f1e;--text2:#1e293b;--text3:#475569;--primary-fg:#1e3a5f;--teal-fg:#1e4976;--sb-icon-color:#334155;--sb-icon-hover:#0f172a;--sb-icon-active:#1e3a5f}html{background:var(--bg);color:var(--text);font-family:var(--font-b);font-size:14px;transition:background .25s,color .25s}body{min-height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--bg2);border-right:1px solid var(--border);z-index:200;flex-direction:column;align-items:center;gap:3px;width:64px;padding:20px 0;transition:background .25s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:visible}.sidebar-logo{background:linear-gradient(140deg, var(--primary), var(--teal));width:36px;height:36px;font-family:var(--font-h);color:#fff;cursor:pointer;letter-spacing:-.3px;border-radius:9px;justify-content:center;align-items:center;margin-bottom:22px;font-size:10px;font-weight:800;text-decoration:none;display:flex}.sb-icon{width:40px;height:40px;color:var(--sb-icon-color);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:9px;justify-content:center;align-items:center;transition:all .18s;display:flex;position:relative}.sb-icon:hover{background:var(--surface2);color:var(--sb-icon-hover)}.sb-icon.active{background:var(--primary-dim);color:var(--sb-icon-active);font-weight:700}.sb-icon svg{pointer-events:none;stroke-width:2px;width:17px;height:17px}.sb-tooltip{background:var(--surface3);color:var(--text);white-space:nowrap;pointer-events:none;opacity:0;border:1px solid var(--border2);box-shadow:var(--shadow);z-index:300;border-radius:6px;padding:4px 9px;font-size:11.5px;font-weight:500;transition:opacity .15s;position:absolute;left:52px}.sb-icon:hover .sb-tooltip{opacity:1}.sb-bottom{flex-direction:column;align-items:center;gap:3px;margin-top:auto;display:flex}.sb-avatar{background:linear-gradient(135deg, #1e40af, var(--teal));width:32px;height:32px;font-family:var(--font-h);color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;margin-top:8px;font-size:11.5px;font-weight:700;display:flex}#app-wrap{width:100%;height:100%;display:block;overflow:hidden}.main{flex-direction:column;display:flex;position:fixed;inset:0 0 0 64px;overflow:hidden}.pg{flex-direction:column;flex:1;display:none;overflow:hidden auto}.pg.active{display:flex}.topbar{background:var(--bg2);z-index:100;flex-direction:column;flex-shrink:0;transition:background .25s;display:flex;position:sticky;top:0;overflow:hidden}.topbar-main{align-items:flex-start;gap:10px;padding:14px 24px 6px;display:flex}.topbar-left{flex-direction:column;gap:2px;display:flex}.topbar-slogan{color:var(--text3);letter-spacing:.2px;font-size:10.5px;font-weight:400}.topbar-page-row{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:6px 24px 12px;display:flex}.topbar-brand{font-family:var(--font-h);color:var(--text);letter-spacing:-.5px;font-size:28px;font-weight:800}.breadcrumb{color:var(--text2);align-items:center;gap:5px;font-size:12.5px;display:flex}.breadcrumb span{opacity:.5}.breadcrumb a{color:var(--text2);cursor:pointer;text-decoration:none;transition:color .15s}.breadcrumb a:hover{color:var(--primary-fg)}.topbar-right{align-items:center;gap:8px;margin-left:auto;display:flex}.topbar-clock{font-family:var(--font-m);color:var(--text2);letter-spacing:.5px;font-size:13px}.theme-toggle{background:var(--surface2);border:1px solid var(--border);border-radius:7px;display:flex;overflow:hidden}.theme-btn{cursor:pointer;width:28px;height:26px;color:var(--text3);background:0 0;border:none;justify-content:center;align-items:center;transition:all .18s;display:flex}.theme-btn.active{background:var(--primary-dim);color:var(--primary-fg)}.theme-btn svg{width:13px;height:13px}.icon-btn{border:1px solid var(--border);width:30px;height:30px;color:var(--text3);cursor:pointer;background:0 0;border-radius:7px;justify-content:center;align-items:center;transition:all .18s;display:flex;position:relative}.icon-btn:hover{background:var(--surface2);color:var(--text)}.icon-btn svg{width:14px;height:14px}.notif-badge{background:var(--red);color:#fff;border:2px solid var(--bg2);border-radius:50%;justify-content:center;align-items:center;width:15px;height:15px;font-size:9px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.dash-content{background:var(--bg);flex:1;padding:20px 24px;transition:background .25s}.kpi-row{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px;display:grid}.kpi-card{background:var(--surface);border:1px solid var(--border);cursor:default;border-radius:12px;flex-direction:column;gap:6px;padding:14px 16px;transition:background .25s,border-color .18s;display:flex;position:relative;overflow:hidden}.kpi-card:hover{border-color:var(--border2)}.kpi-card:before{content:"";border-radius:99px 99px 0 0;height:2.5px;position:absolute;top:0;left:0;right:0}.kpi-card.k-blue:before{background:linear-gradient(90deg,#0ea5e9,#06b6d4)}.kpi-card.k-green:before{background:linear-gradient(90deg,#10b981,#34d399)}.kpi-card.k-amber:before{background:linear-gradient(90deg,#f59e0b,#fb923c)}.kpi-card.k-red:before{background:linear-gradient(90deg,#ef4444,#fb7185)}.kpi-card.k-purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.kpi-icon{border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;margin-bottom:2px;display:flex}.kpi-icon svg{width:15px;height:15px}.kpi-label{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.kpi-val{font-family:var(--font-h);color:var(--text);font-size:26px;font-weight:800;line-height:1}.kpi-val span{color:var(--text3);margin-left:3px;font-size:13px;font-weight:500}.kpi-delta{align-items:center;gap:4px;font-size:11.5px;display:flex}.delta-up{color:var(--green)}.delta-dn{color:var(--red)}.toolbar{background:var(--bg2);border-bottom:1px solid var(--border);flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:6px;padding:8px 16px;display:flex;overflow:hidden}.btn{cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-b);border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;transition:all .18s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn-secondary{background:var(--surface2);border:1px solid var(--border2);color:var(--text2)}.btn-secondary:hover{background:var(--surface3);color:var(--text)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid #ef444440}.btn-danger:hover{background:#ef444433}.btn-green{background:var(--green-dim);color:var(--green);border:1px solid #10b98140}.btn-green:hover{background:#10b98133}.btn svg{width:14px;height:14px}.btn-sm{padding:5px 10px;font-size:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:background .25s}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.card-title{font-family:var(--font-h);color:var(--text);font-size:13.5px;font-weight:700}.card-body{padding:16px 18px}.tbl-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border2);white-space:nowrap;background:var(--bg2);padding:10px 14px;font-size:11px;font-weight:600}tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface2)}tbody td{color:var(--text2);vertical-align:middle;padding:11px 14px;font-size:13px}td.text-mono{font-family:var(--font-m)}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge:before{content:"";background:currentColor;border-radius:50%;width:5px;height:5px}.badge-green{background:var(--green-dim);color:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-blue{background:var(--primary-dim);color:var(--primary-fg)}.badge-purple{background:var(--purple-dim);color:var(--purple)}.badge-teal{background:var(--teal-dim);color:var(--teal-fg)}.badge-gray{background:var(--surface2);color:var(--text3)}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text2);font-size:12px;font-weight:600}.form-input,.form-select{background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-size:13px;font-family:var(--font-b);border-radius:8px;outline:none;flex-shrink:1;width:100%;min-width:0;padding:8px 12px;transition:border-color .18s}.form-input:focus,.form-select:focus{border-color:var(--primary-fg)}.form-input::placeholder{color:var(--text3)}.form-select option{background:var(--surface3)}.search-wrap{position:relative}.search-wrap svg{width:14px;height:14px;color:var(--text3);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);width:100%;font-size:13px;font-family:var(--font-b);border-radius:8px;outline:none;padding:7px 12px 7px 32px;transition:border-color .18s}.search-input:focus{border-color:var(--primary-fg)}.search-input::placeholder{color:var(--text3)}.tabs{background:var(--bg2);border-bottom:1px solid var(--border);gap:2px;padding:0 24px;display:flex}.tab-btn{color:var(--text3);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-b);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:13px 16px;transition:all .18s}.tab-btn:hover{color:var(--text2)}.tab-btn.active{color:var(--primary-fg);border-bottom-color:var(--primary-fg);font-weight:700}.tab-pane{display:none}.tab-pane.active{display:block}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@keyframes wave-pulse{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}@keyframes cd-spin{to{transform:rotate(360deg)}}.wave-bar{background:var(--primary);border-radius:2px;width:3px;animation:.8s ease-in-out infinite wave-pulse;display:inline-block}.wave-bar:nth-child(2){animation-delay:.1s}.wave-bar:nth-child(3){animation-delay:.2s}.wave-bar:nth-child(4){animation-delay:.15s}.wave-bar:nth-child(5){animation-delay:50ms}.wave-icon{align-items:center;gap:2px;height:16px;display:flex}@keyframes lp-ring{0%{opacity:.8;transform:scale(.6)}to{opacity:0;transform:scale(1.4)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.pulse-anim{animation:.9s ease-in-out infinite pulse-dot}@keyframes lp-bar{0%,to{height:6px}50%{height:28px}}.lp-bar{animation:.7s ease-in-out infinite lp-bar}.lp-bar:first-child{animation-delay:0s}.lp-bar:nth-child(2){animation-delay:.1s}.lp-bar:nth-child(3){animation-delay:.2s}.lp-bar:nth-child(4){animation-delay:50ms}.lp-bar:nth-child(5){animation-delay:.15s}.lp-bar:nth-child(6){animation-delay:.25s}.lp-bar:nth-child(7){animation-delay:.1s}.lp-bar:nth-child(8){animation-delay:.2s}.lp-bar:nth-child(9){animation-delay:50ms}[data-theme=light] #live-player-wrap{background:#f0f6ff;border-color:#1e3a5f26}[data-theme=light] #live-play-trigger{background:linear-gradient(135deg,#eef5ff,#f8fafc)}[data-theme=light] #lp-play-btn{box-shadow:0 4px 14px #1e3a5f4d!important}[data-theme=light] .lp-ring-layer{border-color:#1e3a5f1f!important}.lp-bar:nth-child(10){animation-delay:.15s}.lp-bar:nth-child(11){animation-delay:.3s}.lp-bar:nth-child(12){animation-delay:80ms}.lp-bar.paused{animation-play-state:paused;height:6px!important}.prog-bar{background:var(--border2);border-radius:99px;height:5px;margin-top:4px;overflow:hidden}.prog-fill{border-radius:99px;height:100%;transition:width .6s}.audio-player{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;align-items:center;gap:10px;padding:8px 14px;display:flex}.play-btn{background:var(--primary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .18s;display:flex}.play-btn:hover{filter:brightness(1.15)}.play-btn svg{color:#fff;width:12px;height:12px;margin-left:2px}.audio-track{flex:1;min-width:0}.audio-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:12px;font-weight:600;overflow:hidden}.audio-prog{background:var(--border2);cursor:pointer;border-radius:99px;height:4px}.audio-prog-fill{background:var(--primary);border-radius:99px;width:35%;height:100%}.audio-time{font-family:var(--font-m);color:var(--text3);flex-shrink:0;font-size:11px}.spot-grid{grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:16px;display:grid}.spot-day{background:var(--surface);border:1px solid var(--border);text-align:center;cursor:pointer;border-radius:10px;padding:12px;transition:all .18s}.spot-day:hover{border-color:var(--border2);background:var(--surface2)}.spot-day.ok{background:#10b9810f;border-color:#10b9814d}.spot-day.partial{background:#f59e0b0f;border-color:#f59e0b4d}.spot-day.miss{background:#ef44440f;border-color:#ef44444d}.spot-day.future{opacity:.45;cursor:default}.spot-day.off{opacity:.6;pointer-events:none;border:2px dashed var(--border2)!important;background:var(--bg2)!important;cursor:default!important;background-image:repeating-linear-gradient(-45deg,#0000,#0000 5px,#8080800a 5px 10px)!important}.spot-day-name{color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;font-size:10px}.spot-day-date{font-family:var(--font-m);color:var(--text);margin-bottom:6px;font-size:13px;font-weight:600}.spot-check{margin-bottom:4px;font-size:16px}.spot-counts{color:var(--text3);font-size:11px}.stat-row{gap:0;display:flex}.stat-item{text-align:center;border-right:1px solid var(--border);flex:1;padding:12px 8px}.stat-item:last-child{border-right:none}.stat-val{font-family:var(--font-h);color:var(--text);font-size:22px;font-weight:800}.stat-lbl{color:var(--text3);margin-top:2px;font-size:11px}.det-header{background:var(--bg2);border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:16px 24px;display:flex}.det-avatar{width:48px;height:48px;font-family:var(--font-h);color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:800;display:flex}.det-name{font-family:var(--font-h);color:var(--text);font-size:18px;font-weight:700}.det-sub{color:var(--text3);margin-top:2px;font-size:12.5px}.det-badges{flex-wrap:wrap;gap:8px;display:flex}.det-stat{background:var(--surface);border:1px solid var(--border2);border-radius:9px;align-items:center;gap:10px;padding:8px 14px;display:flex}.det-stat-icon{border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.det-stat-icon svg{width:12px;height:12px}.det-stat-val{font-family:var(--font-h);color:var(--text);font-size:16px;font-weight:700}.det-stat-lbl{color:var(--text3);font-size:10.5px}.tl-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 0;display:flex}.tl-row:last-child{border-bottom:none}.tl-time{font-family:var(--font-m);color:var(--primary-fg);flex-shrink:0;width:50px;font-size:12px}.tl-dur{color:var(--text3);flex-shrink:0;width:45px;font-size:11px}.tl-file{flex:1}.tl-file-name{color:var(--text);font-size:13px;font-weight:500}.tl-file-meta{color:var(--text3);font-size:11px}.ledger-row{gap:0;display:flex}.ledger-row td.credit{color:var(--green);font-family:var(--font-m);font-weight:600}.ledger-row td.debit{color:var(--red);font-family:var(--font-m);font-weight:600}.ledger-row td.balance-pos{color:var(--green);font-family:var(--font-m);font-weight:700}.ledger-row td.balance-neg{color:var(--red);font-family:var(--font-m);font-weight:700}.modal-overlay{z-index:500;opacity:0;pointer-events:none;background:#0009;justify-content:center;align-items:center;padding:20px;transition:opacity .2s;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:14px;width:100%;max-width:640px;max-height:90vh;transition:transform .2s;overflow-y:auto;transform:translateY(12px);box-shadow:0 20px 60px #00000080}.modal-overlay.open .modal{transform:translateY(0)}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-title{font-family:var(--font-h);color:var(--text);font-size:15px;font-weight:700}.modal-close{width:28px;height:28px;color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--surface2);color:var(--text)}.modal-close svg{width:15px;height:15px}.modal-body{padding:22px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:16px 22px;display:flex}.user-menu-wrap{display:inline-block;position:relative}.user-menu{background:var(--surface);border:1px solid var(--border2);z-index:600;border-radius:10px;min-width:200px;padding:6px;animation:.12s ease-out user-menu-in;position:absolute;box-shadow:0 14px 40px #00000073}@keyframes user-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:8px 12px 10px}.user-menu-header .name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:700;overflow:hidden}.user-menu-header .email{color:var(--text3);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;overflow:hidden}.user-menu-divider{background:var(--border);height:1px;margin:4px 0}.user-menu-item{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text2);border-radius:7px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;transition:background .15s,color .15s;display:flex}.user-menu-item svg{flex-shrink:0;width:14px;height:14px}.user-menu-item:hover{background:var(--surface2);color:var(--text)}.user-menu-item.danger{color:var(--red)}.user-menu-item.danger:hover{background:var(--red-dim);color:var(--red)}.toast-container{z-index:1000;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;top:16px;right:16px}.toast{background:var(--surface);border:1px solid var(--border2);min-width:240px;max-width:360px;color:var(--text);pointer-events:auto;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:12.5px;animation:.18s ease-out toast-in;display:flex;box-shadow:0 10px 30px #00000059}.toast.success{border-left:3px solid var(--green,#10b981)}.toast.error{border-left:3px solid var(--red,#ef4444)}.toast-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.toast.success .toast-dot{background:var(--green,#10b981)}.toast.error .toast-dot{background:var(--red,#ef4444)}@keyframes toast-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.radio-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;gap:10px;padding:16px;transition:all .18s;display:flex;position:relative;overflow:hidden}.radio-card:hover{border-color:var(--border2);background:var(--surface2)}.radio-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--teal));height:3px;position:absolute;top:0;left:0;right:0}.radio-card-top{align-items:center;gap:10px;display:flex}.radio-logo{background:linear-gradient(135deg, var(--primary-dim), var(--teal-dim));border:1px solid var(--border2);width:44px;height:44px;font-family:var(--font-h);color:var(--primary-fg);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:800;display:flex}.radio-name{font-family:var(--font-h);color:var(--text);font-size:14px;font-weight:700}.radio-freq{font-family:var(--font-m);color:var(--teal-fg);font-size:12px}.radio-city{color:var(--text3);font-size:11px}.fill-blue{background:linear-gradient(90deg,#0ea5e9,#06b6d4)}.fill-green{background:linear-gradient(90deg,#10b981,#34d399)}.fill-amber{background:linear-gradient(90deg,#f59e0b,#fb923c)}.fill-purple{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.fill-red{background:linear-gradient(90deg,#ef4444,#fb7185)}.section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.section-title{font-family:var(--font-h);color:var(--text);font-size:14px;font-weight:700}.divider{background:var(--border);height:1px;margin:16px 0}.wf-shell{background:var(--surface);border:1px solid var(--border);border-radius:12px;max-width:100%;overflow:hidden}.wf-topbar{border-bottom:1px solid var(--border);background:var(--bg2);align-items:center;gap:10px;padding:10px 16px;display:flex}.wf-channel-label{font-family:var(--font-h);color:var(--text2);font-size:13px;font-weight:700}.wf-tc{font-family:var(--font-m);color:var(--primary-fg);background:var(--surface2);border:1px solid var(--border2);border-radius:6px;margin-left:auto;padding:4px 10px;font-size:12px}.wf-subbar{border-bottom:1px solid var(--border);background:var(--bg2);flex-wrap:wrap;align-items:center;gap:10px;padding:8px 14px;display:flex}.wf-legend{color:var(--text3);align-items:center;gap:5px;font-size:11px;display:flex}.wf-legend-dot{border-radius:2px;width:10px;height:10px}.wf-zoom-btns{gap:3px;margin-left:auto;display:flex}.wf-zoom-btn{background:var(--surface2);border:1px solid var(--border2);font-size:10px;font-family:var(--font-m);color:var(--text3);cursor:pointer;border-radius:5px;padding:3px 9px;transition:all .15s}.wf-zoom-btn:hover,.wf-zoom-btn.bm-act{background:var(--primary);color:#fff;border-color:var(--primary-fg);box-shadow:0 0 8px #0ea5e959}.wf-date-input{background:var(--surface2);border:1px solid var(--border2);font-size:11px;font-family:var(--font-m);color:var(--text2);border-radius:6px;outline:none;padding:3px 10px}.wf-canvas-wrap{cursor:crosshair;-webkit-user-select:none;user-select:none;position:relative}#bmCanvas{width:100%;height:150px;display:block}.wf-tooltip{pointer-events:none;background:var(--surface);border:1px solid var(--border2);font-size:11px;font-family:var(--font-m);color:var(--text);box-shadow:var(--shadow);opacity:0;z-index:20;white-space:nowrap;border-radius:8px;padding:8px 12px;line-height:1.8;transition:opacity .15s;position:absolute}.wf-tooltip strong{color:var(--primary-fg);margin-bottom:2px;font-size:12px;display:block}.wf-tooltip.bm-show{opacity:1}.wf-ruler{font-family:var(--font-m);color:var(--text3);border-top:1px solid var(--border);background:var(--bg2);justify-content:space-between;height:20px;padding:4px 14px;font-size:9.5px;display:flex;position:relative}.wf-controls{border-top:1px solid var(--border);background:var(--bg2);align-items:center;gap:10px;padding:10px 14px;display:flex;overflow:hidden}.wf-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:30px;height:30px;color:var(--text2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.wf-btn:hover,.wf-btn.bm-act{background:var(--primary);color:#fff;border-color:var(--primary-fg);box-shadow:0 0 10px #0ea5e959}.wf-btn svg{width:13px;height:13px}.wf-prog-wrap{background:var(--surface3);cursor:pointer;border-radius:99px;flex:1;height:5px;position:relative;overflow:visible}.wf-prog-fill{background:linear-gradient(90deg,var(--primary),var(--teal));pointer-events:none;border-radius:99px;height:100%;position:relative}.wf-prog-head{border:2px solid var(--primary);clip-path:none;pointer-events:none;background:#fff;border-radius:50%;width:13px;height:13px;position:absolute;top:50%;right:0;transform:translate(50%,-50%);box-shadow:0 0 8px #0ea5e966}.wf-dur{font-family:var(--font-m);color:var(--text3);font-size:11px}.wf-detlist{border-top:1px solid var(--border);background:var(--surface)}.wf-detlist-hd{font-family:var(--font-m);color:var(--text3);letter-spacing:1.5px;text-transform:uppercase;border-bottom:1px solid var(--border);padding:8px 14px;font-size:9.5px}.bm-det-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;padding:9px 14px;transition:background .12s;display:flex}.bm-det-item:hover{background:var(--surface2)}.bm-det-item:last-child{border-bottom:none}.bm-det-item.bm-selected{background:var(--surface2);border-left:3px solid var(--amber)}.det-color{border-radius:2px;flex-shrink:0;width:4px;height:36px}.det-info{flex:1;min-width:0}.det-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text);font-size:12.5px;font-weight:600;overflow:hidden}.det-time{font-family:var(--font-m);color:var(--text3);margin-top:2px;font-size:10.5px}.det-conf{font-family:var(--font-m);background:var(--green-dim);color:var(--green);border:1px solid #10b98133;border-radius:5px;flex-shrink:0;padding:2px 7px;font-size:11px}.det-dur{font-family:var(--font-m);color:var(--text3);text-align:right;flex-shrink:0;width:34px;font-size:10px}.det-play{background:var(--surface2);border:1px solid var(--border2);width:26px;height:26px;color:var(--primary-fg);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.det-play:hover{background:var(--primary);color:#fff;box-shadow:0 0 8px #0ea5e966}.det-play svg{width:10px;height:10px;margin-left:1px}.bm-chain-blk{background:var(--surface2);border:1px solid var(--border2);border-radius:9px;margin-bottom:10px;overflow:hidden}.bm-chain-hd{font-size:11px;font-family:var(--font-m);color:var(--amber);background:#f59e0b12;border-bottom:1px solid #f59e0b2e;align-items:center;gap:8px;padding:8px 12px;display:flex}.bm-chain-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;padding:7px 12px;font-size:12px;transition:background .12s;display:flex}.bm-chain-item:hover{background:var(--surface3)}.bm-chain-item:last-child{border-bottom:none}.bm-json{background:var(--surface2);border:1px solid var(--border2);font-family:var(--font-m);color:var(--text2);border-radius:9px;padding:14px;font-size:10.5px;line-height:1.9;overflow-x:auto}.bm-jk{color:var(--primary-fg)}.bm-jv{color:var(--green)}.bm-js{color:var(--amber)}.bm-jn{color:var(--purple)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.text-muted{color:var(--text3);font-size:12px}.font-mono{font-family:var(--font-m)}.font-bold{font-weight:700;font-family:var(--font-h)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}.text-primary{color:var(--primary-fg)}.text-teal{color:var(--teal-fg)}.upload-zone{border:2px dashed var(--border2);text-align:center;cursor:pointer;border-radius:10px;padding:28px;transition:all .18s}.upload-zone:hover{border-color:var(--primary-fg);background:var(--primary-dim)}.upload-zone svg{width:32px;height:32px;color:var(--text3);margin-bottom:8px}.upload-zone p{color:var(--text3);font-size:13px}.upload-zone strong{color:var(--primary-fg)}.chip{background:var(--surface2);color:var(--text3);border:1px solid var(--border);border-radius:6px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.chip-blue{background:var(--primary-dim);color:var(--primary-fg);border-color:#0ea5e933}.chip-green{background:var(--green-dim);color:var(--green);border-color:#10b98133}.chip-teal{background:var(--teal-dim);color:var(--teal-fg);border-color:#06b6d433}.chip-purple{background:var(--purple-dim);color:var(--purple);border-color:#8b5cf633}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.music-type-chip{border:1px solid var(--border2);background:var(--surface2);cursor:pointer;color:var(--text3);text-align:center;-webkit-user-select:none;user-select:none;border-radius:7px;justify-content:center;align-items:center;padding:7px 10px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.music-type-chip:hover{border-color:var(--primary-fg);color:var(--text2)}.music-type-chip.selected{background:var(--primary-dim);color:var(--primary-fg);border-color:#0ea5e966;font-weight:700}.city-chip{background:var(--primary-dim);color:var(--primary-fg);cursor:default;border:1px solid #0ea5e940;border-radius:6px;align-items:center;gap:5px;padding:3px 8px 3px 10px;font-size:12px;font-weight:600;display:inline-flex}.city-chip button{color:var(--primary-fg);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;font-size:13px;line-height:1}.city-chip button:hover{opacity:1}.city-dd-item{color:var(--text2);cursor:pointer;border-radius:7px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;transition:background .12s;display:flex}.city-dd-item:hover{background:var(--surface2)}.city-dd-item.selected{color:var(--primary-fg);font-weight:600}.city-dd-item.selected:after{content:"✓";color:var(--primary-fg);font-weight:700}.day-chip{border:1px solid var(--border2);background:var(--surface2);cursor:pointer;color:var(--text3);-webkit-user-select:none;user-select:none;border-radius:7px;align-items:center;padding:5px 11px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.day-chip:hover{border-color:var(--primary-fg);color:var(--text2)}.day-chip.on{background:var(--primary-dim);color:var(--primary-fg);border-color:#0ea5e966}.price-row,.day-row{background:var(--surface);border:1px solid var(--border2);border-radius:9px;margin-bottom:8px;padding:12px 14px}.price-row:last-child,.day-row:last-child{margin-bottom:0}
