*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#05060a;--primary:#1e7bff;--accent:#00e5ff;--text:#f2f5f7;--muted:#8a94a6;--surface:#05060ae6;--border:#f2f5f714;--radius:6px;--header-h:48px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Inter,sans-serif}html,body,#root{background:var(--bg);width:100%;height:100%;color:var(--text);overflow:hidden}.app-layout{flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.app-header{height:var(--header-h);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px)saturate(180%);z-index:20;background:#05060af2;flex-shrink:0;align-items:center;padding:0 12px;display:flex;position:relative}.app-header-left{align-items:center;gap:6px;display:flex}.app-header-center{pointer-events:none;gap:8px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.header-lang{gap:4px;display:flex}.app-header-right{align-items:center;gap:4px;margin-left:auto;display:flex}.app-body{flex:1;display:flex;overflow:hidden}.app-sidebar{background:var(--surface);-webkit-backdrop-filter:blur(16px)saturate(180%);border-right:1px solid var(--border);flex-shrink:0;width:260px;overflow-y:auto}.app-visual{background:var(--bg);flex:1;position:relative;overflow:hidden}.app-visual canvas{width:100%;height:100%;display:block}.app-visual:fullscreen{width:100vw;height:100vh}.app-visual:fullscreen{width:100vw;height:100vh}.start-screen{background:var(--bg);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.start-card{border:1px solid var(--border);text-align:center;background:#1e7bff0a;border-radius:16px;flex-direction:column;align-items:center;gap:16px;max-width:420px;padding:48px 56px;display:flex}.start-logo{color:var(--accent);font-size:40px;line-height:1}.start-title-row{align-items:center;gap:12px;display:flex}.start-lang{gap:4px;padding-top:2px;display:flex}.start-title{letter-spacing:-.5px;color:var(--text);font-size:32px;font-weight:700}.start-subtitle{color:var(--muted);letter-spacing:.04em;font-size:14px}.start-hint{color:var(--muted);margin-top:4px;font-size:11px;line-height:1.6}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;letter-spacing:.02em;border:none;padding:12px 32px;font-size:15px;font-weight:600;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.88;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.control-panel{flex-direction:column;gap:20px;min-height:100%;padding:16px;display:flex}.panel-title{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);white-space:nowrap;font-size:13px;font-weight:700}.btn-play-pause{border:1.5px solid var(--accent);width:30px;height:30px;color:var(--accent);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,box-shadow .15s,border-color .15s,color .15s;display:flex}.btn-play-pause:hover{background:#00e5ff1f;box-shadow:0 0 10px #00e5ff4d}.btn-play-pause.is-paused{color:#00e5ff73;border-color:#00e5ff59}.btn-play-pause.is-paused:hover{border-color:var(--accent);color:var(--accent);background:#00e5ff1a}.btn-icon{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:15px;transition:border-color .15s,color .15s;display:flex}.btn-icon:hover{border-color:var(--primary);color:var(--text)}.lang-btn{border:1px solid var(--border);color:var(--muted);letter-spacing:.06em;cursor:pointer;background:0 0;border-radius:4px;height:28px;padding:0 6px;font-size:10px;font-weight:700;transition:border-color .15s,color .15s}.lang-btn:hover{color:var(--text);border-color:#1e7bff66}.lang-btn.active{border-color:var(--primary);color:var(--primary)}.meters{flex-direction:column;gap:8px;display:flex}.meter-row{align-items:center;gap:10px;display:flex}.meter-label{letter-spacing:.1em;color:var(--muted);flex-shrink:0;width:34px;font-size:9px;font-weight:700}.meter-track{background:#ffffff0f;border-radius:2px;flex:1;height:4px;overflow:hidden}.meter-fill{border-radius:2px;width:0%;height:100%;transition:none}.meter-fill.vol{background:var(--text)}.meter-fill.bass{background:var(--primary)}.meter-fill.mids{background:#7b5ef5}.meter-fill.treble{background:var(--accent)}.meter-fill.voice{background:#ff2a4f}.voice-label{color:#ff2a4f!important}.voice-canvas{border-radius:2px;flex:1;height:20px;display:block}.control-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:10px;font-weight:600;display:block}.select{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);cursor:pointer;appearance:none;background:#ffffff0a url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238a94a6'/%3E%3C/svg%3E") right 10px center no-repeat;padding:7px 28px 7px 10px;font-size:12px}.select:focus{border-color:var(--primary);outline:none}.source-hint{color:var(--muted);margin-top:8px;font-size:10px;line-height:1.5}.preset-buttons{flex-direction:column;gap:4px;display:flex}.preset-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:10px;padding:8px 10px;font-size:12px;transition:border-color .15s,color .15s,background .15s;display:flex}.preset-btn:hover{color:var(--text);border-color:#1e7bff66}.preset-btn.active{border-color:var(--primary);color:var(--text);background:#1e7bff1a}.preset-num{color:var(--primary);flex-shrink:0;width:14px;font-size:10px;font-weight:700}.preset-name{font-size:12px}.slider-row{flex-direction:column;gap:8px;display:flex}.slider{width:100%;accent-color:var(--primary);cursor:pointer;height:4px}.hint-text{color:var(--muted);font-size:10px;line-height:1.5}.tempo-section{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:10px 0 6px;display:flex}.tempo-header{justify-content:space-between;align-items:center;display:flex}.section-label{letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-size:9px;font-weight:700}.beat-dot{background:var(--accent);opacity:.25;border-radius:50%;width:7px;height:7px;transition:opacity 80ms,transform 80ms}.tempo-grid{grid-template-columns:48px 1fr;align-items:center;gap:3px 8px;display:grid}.tempo-key{letter-spacing:.1em;color:var(--muted);text-transform:uppercase;font-size:9px;font-weight:700}.tempo-val{color:var(--text);font-variant-numeric:tabular-nums;font-size:12px;font-weight:600}.tempo-phase-track{background:#ffffff0f;border-radius:2px;height:3px;margin-top:4px;overflow:hidden}.tempo-phase-fill{background:var(--accent);border-radius:2px;width:0%;height:100%;transition:none}.meter-select{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);cursor:pointer;appearance:none;background:#ffffff0a url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238a94a6'/%3E%3C/svg%3E") right 10px center no-repeat;padding:6px 28px 6px 10px;font-size:12px}.meter-select:focus{border-color:var(--primary);outline:none}.shortcuts{color:var(--muted);letter-spacing:.03em;border-top:1px solid var(--border);margin-top:auto;padding-top:16px;font-size:10px;line-height:1.6}.debug-overlay{z-index:10;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);-webkit-backdrop-filter:blur(8px);min-width:200px;padding:12px 14px;font-family:SF Mono,Fira Code,monospace;font-size:11px;position:absolute;top:12px;right:12px}.debug-title{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;font-size:10px;font-weight:700}.debug-row{color:var(--muted);justify-content:space-between;gap:16px;padding:2px 0;display:flex}.debug-row span:last-child{color:var(--text);font-weight:600}.debug-row.beat-flash span:last-child{color:var(--accent)}.debug-row.voice-flash span:last-child{color:#ff2a4f}kbd{border:1px solid var(--border);background:#ffffff14;border-radius:3px;padding:1px 4px;font-family:inherit;font-size:9px}.debug-sep{background:var(--border);height:1px;margin:6px 0}.source-selector{flex-direction:column;display:flex}.image-upload-section{flex-direction:column;gap:8px;display:flex}.upload-btn{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--muted);cursor:pointer;text-align:left;background:0 0;padding:7px 10px;font-size:12px;transition:border-color .15s,color .15s}.upload-btn:hover{border-color:var(--primary);color:var(--text)}.image-preview{object-fit:contain;border-radius:var(--radius);border:1px solid var(--border);background:#ffffff05;width:100%;max-height:80px}.image-file-row{align-items:center;gap:8px;display:flex}.image-filename{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:10px;overflow:hidden}.remove-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;padding:3px 8px;font-size:10px;transition:border-color .15s,color .15s}.remove-btn:hover{color:#ff2a4f;border-color:#ff2a4f}.scene-director-section{flex-direction:column;gap:8px;display:flex}.toggle-row{gap:6px;display:flex}.toggle-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);letter-spacing:.04em;cursor:pointer;text-align:center;background:0 0;flex:1;padding:7px 6px;font-size:11px;font-weight:600;transition:border-color .15s,color .15s,background .15s}.toggle-btn:hover{color:var(--text);border-color:#1e7bff66}.toggle-btn.active{border-color:var(--primary);color:var(--text);background:#1e7bff1a}.status-pill{letter-spacing:.1em;text-transform:uppercase;color:var(--text);-webkit-backdrop-filter:blur(8px);-webkit-user-select:none;user-select:none;background:#8a94a61f;border:1px solid #f2f5f714;border-radius:20px;padding:5px 14px;font-size:10px;font-weight:700;transition:background-color .4s,box-shadow .4s,border-color .4s}.header-sep{background:var(--border);width:1px;height:18px;margin:0 4px}.btn-icon.active{border-color:var(--primary);color:var(--text);background:#1e7bff1a}.help-overlay{z-index:50;background:#05060afa;position:absolute;inset:0;overflow:hidden auto}.help-inner{max-width:820px;margin:0 auto;padding:0 48px 80px}.help-header-row{-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--border);z-index:2;background:#05060afa;justify-content:space-between;align-items:center;margin-bottom:28px;padding:24px 0 20px;display:flex;position:sticky;top:0}.help-header-left{color:var(--accent);align-items:center;gap:14px;display:flex}.help-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:700}.help-title{color:var(--text);letter-spacing:-.3px;margin-top:2px;font-size:22px;font-weight:700}.help-close{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;transition:border-color .15s,color .15s;display:flex}.help-close:hover{border-color:var(--text);color:var(--text)}.help-lead{color:var(--muted);margin-bottom:24px;font-size:14px;line-height:1.75}.help-screenshot{border:1px solid var(--border);border-radius:8px;width:100%;margin:16px 0 6px;display:block}.help-screenshot--narrow{float:right;max-width:280px;margin:0 0 16px 24px}.help-caption{color:var(--muted);text-align:center;letter-spacing:.02em;margin-bottom:0;font-size:11px}.help-section{border-top:1px solid var(--border);margin-top:40px;padding-top:32px;overflow:hidden}.help-section h2{color:var(--text);margin-bottom:12px;font-size:17px;font-weight:700}.help-section h3{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:20px 0 6px;font-size:11px;font-weight:700}.help-section p{color:var(--muted);margin-bottom:10px;font-size:13px;line-height:1.72}.help-section strong{color:var(--text)}.help-list{color:var(--muted);padding-left:18px;font-size:13px;line-height:1.8}.help-list li{margin-bottom:4px}.help-list strong{color:var(--text)}.help-table{border-collapse:collapse;width:100%;margin-top:10px;font-size:12px}.help-table td{border-bottom:1px solid var(--border);color:var(--muted);vertical-align:top;padding:7px 10px;line-height:1.5}.help-table td:first-child{color:var(--text);white-space:nowrap;width:130px;font-weight:600}.help-table--shortcuts td:first-child{width:100px}.help-scene-table{border-collapse:collapse;width:100%;margin-top:10px;font-size:12px}.help-scene-table td{border-bottom:1px solid var(--border);color:var(--muted);vertical-align:middle;padding:7px 10px;line-height:1.5}.help-scene-table td:first-child{color:var(--text);letter-spacing:.06em;white-space:nowrap;align-items:center;gap:8px;width:160px;font-size:11px;font-weight:700;display:flex}.scene-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;display:inline-block}.help-tip{border-radius:var(--radius);color:var(--muted);background:#1e7bff12;border:1px solid #1e7bff2e;margin:14px 0;padding:10px 14px;font-size:12px;line-height:1.65}.help-tip strong{color:var(--primary)}.help-footer{border-top:1px solid var(--border);color:var(--muted);text-align:center;letter-spacing:.04em;margin-top:56px;padding-top:20px;font-size:11px}.tooltip-popup{z-index:9999;border-radius:var(--radius);color:var(--text);letter-spacing:.01em;white-space:normal;pointer-events:none;background:#05060af7;border:1px solid #1e7bff59;max-width:230px;padding:9px 12px;font-size:11px;font-weight:400;line-height:1.55;animation:.12s tooltip-in;position:fixed;box-shadow:0 4px 20px #000000a6,0 0 0 1px #1e7bff14}@keyframes tooltip-in{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}.no-image-hint{color:var(--muted);letter-spacing:.04em;pointer-events:none;z-index:5;text-align:center;font-size:13px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
