:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body{overflow-x:hidden}body{margin:0;min-height:100vh;background-color:#f5f5f5;color:#333}#root{min-height:100vh}.song-selector{padding:1rem}.song-selector h2{margin-bottom:1rem;color:#333}.song-selector.loading,.song-selector.error,.song-selector.empty{text-align:center;padding:2rem;color:#666}.song-selector.error button{margin-top:1rem;padding:.5rem 1rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer}.song-selector .hint{font-size:.9rem;color:#888}.song-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:1rem}.song-card{display:flex;flex-direction:column;background:#fff;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .2s,box-shadow .2s;position:relative}.song-card:hover:not(.not-ready){border-color:#4a90d9;box-shadow:0 4px 12px #4a90d933}.song-card.selected{border-color:#4a90d9;background:#f0f7ff}.song-card.not-ready{cursor:not-allowed;opacity:.7}.song-thumbnail{width:100%;aspect-ratio:16 / 9;overflow:hidden}.song-thumbnail img{width:100%;height:100%;object-fit:cover}.song-info{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.song-title{margin:0;font-size:1.1rem;color:#333}.song-artist{margin:0;font-size:.9rem;color:#666}.song-meta{display:flex;gap:1rem;font-size:.8rem;color:#888}.song-tags{display:flex;flex-wrap:wrap;gap:.25rem}.song-tags .tag{padding:.125rem .5rem;background:#f0f0f0;border-radius:4px;font-size:.75rem;color:#666}.song-status{display:flex;gap:.5rem;margin-top:.5rem}.status-badge{padding:.125rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500}.status-badge.available{background:#e6f4ea;color:#137333}.status-badge.missing{background:#fce8e6;color:#c5221f}.not-ready-overlay{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:#666}.youtube-player{width:100%}.youtube-player-container{position:relative;width:100%;padding-bottom:56.25%;background:#000;border-radius:8px;overflow:hidden}.youtube-player-iframe{position:absolute;top:0;left:0;width:100%;height:100%}.youtube-player-info{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.9rem;color:#666}.youtube-player-info .status{text-transform:capitalize}.youtube-player-info .time{font-family:monospace}.step-indicator{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:1rem;background:#fff;border-radius:8px;margin-bottom:1rem}.step-item-wrapper{display:flex;align-items:center;gap:.25rem}.step-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;background:#f0f0f0;color:#888;font-size:.9rem;transition:all .2s}.step-item.active{background:#4a90d9;color:#fff;font-weight:500}.step-item.completed{background:#e6f4ea;color:#137333}.step-number{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#0000001a;font-size:.75rem;font-weight:600}.step-item.active .step-number{background:#ffffff4d}.step-item.completed .step-number{background:#137333;color:#fff}.step-label{white-space:nowrap}.step-arrow{color:#ccc;font-size:1rem;margin:0 .25rem}.step-arrow.completed{color:#137333}@media(max-width:600px){.step-indicator{gap:.125rem;padding:.75rem .5rem}.step-item{padding:.4rem .6rem;font-size:.8rem}.step-number{width:18px;height:18px;font-size:.7rem}.step-arrow{font-size:.85rem;margin:0 .125rem}}.recording-view{display:flex;flex-direction:column;gap:1rem;max-width:800px;margin:0 auto}.recording-header{display:flex;align-items:center;gap:1rem;background:#fff;padding:1rem;border-radius:8px}.btn-back{padding:.5rem 1rem;background:#f0f0f0;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-back:hover{background:#e0e0e0}.song-info-header h2{margin:0;font-size:1.25rem;color:#333}.song-info-header .artist{font-size:.9rem;color:#666}.recording-main{display:flex;flex-direction:column;gap:1rem;background:#fff;border-radius:8px;padding:1.5rem}.guidance-box{display:flex;gap:1rem;padding:1rem;background:#f0f7ff;border-radius:8px;border-left:4px solid #4a90d9;min-height:60px}.guidance-box.guidance-success{background:#e6f4ea;border-left-color:#137333}.guidance-box.guidance-recording{background:#fef3f2;border-left-color:#c5221f}.guidance-icon{font-size:1.5rem;flex-shrink:0}.guidance-text{flex:1}.guidance-text strong{display:block;font-size:1rem;color:#333;margin-bottom:.25rem}.guidance-text p{margin:0;font-size:.9rem;color:#666}.player-section{background:#000;border-radius:8px;overflow:hidden}.position-section{background:#f8f8f8;border-radius:8px;padding:1rem}.position-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.position-label{color:#666;font-size:.9rem}.position-value{font-size:1.25rem;font-family:monospace;color:#4a90d9}.position-actions{display:flex;gap:.5rem;margin-left:auto}.btn-play-pause{padding:.5rem 1rem;background:#f0f0f0;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background .2s}.btn-play-pause:hover:not(:disabled){background:#e0e0e0}.btn-play-pause:disabled{background:#f8f8f8;color:#aaa;cursor:not-allowed}.btn-confirm-position{padding:.5rem 1rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-confirm-position:hover{background:#3a7bc8}.btn-change-position{margin-left:auto;padding:.4rem .8rem;background:transparent;border:1px solid #ddd;border-radius:4px;font-size:.85rem;color:#666;cursor:pointer;transition:all .2s}.btn-change-position:hover{background:#f0f0f0;border-color:#ccc}.settings-section{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#f8f8f8;border-radius:8px}.settings-section.settings-disabled{opacity:.6}.setting-row{display:flex;align-items:center;gap:.75rem}.setting-row label{font-size:.9rem;color:#666;width:80px;flex-shrink:0}.setting-row select{padding:.5rem;font-size:.9rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer}.setting-row select:disabled{background:#f0f0f0;cursor:not-allowed}.setting-hint{font-size:.85rem;color:#888;margin-left:auto}.setting-row input[type=range]{flex:1;max-width:150px;height:4px;-webkit-appearance:none;appearance:none;background:#e0e0e0;border-radius:2px;outline:none}.setting-row input[type=range]:disabled{opacity:.5}.setting-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#4a90d9;border-radius:50%;cursor:pointer}.setting-row input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#4a90d9;border-radius:50%;cursor:pointer;border:none}.gain-value{font-size:.85rem;color:#666;width:45px;text-align:right}.level-meter-row{display:flex;align-items:center;gap:.75rem}.level-meter-row label{font-size:.9rem;color:#666;width:80px;flex-shrink:0}.level-bar-container{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;position:relative}.level-bar{height:100%;background:#4a90d9;border-radius:4px;transition:width .05s ease-out}.level-target{position:absolute;inset:-2px 30% -2px 40%;border-left:2px solid #888;border-right:2px solid #888;background:#0000000d;pointer-events:none}.action-section{display:flex;flex-direction:column;gap:1rem}.action-hint{text-align:center;padding:1rem;background:#f8f8f8;border-radius:8px;color:#888;font-size:.9rem}.btn-start-recording{width:100%;padding:1.25rem;background:#4a90d9;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-start-recording:hover:not(:disabled){background:#3a7bc8}.btn-start-recording:disabled{background:#ccc;cursor:not-allowed}.btn-stop-recording{width:100%;padding:1.25rem;background:#c5221f;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-stop-recording:hover{background:#a31b19}.preview-info-box{display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem;background:#f8f8f8;border-radius:8px}.preview-stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.8rem;color:#888;text-transform:uppercase}.stat-value{font-size:1.1rem;font-weight:500;font-family:monospace;color:#333}.recording-main .audio-preview{width:100%;max-width:none}.recording-main .audio-preview audio{width:100%;display:block}.processing-audio{padding:2rem;text-align:center;color:#888;background:#f8f8f8;border-radius:8px}.preview-actions{display:flex;gap:.75rem}.preview-actions .btn-confirm{flex:2;padding:1rem;background:#137333;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.preview-actions .btn-confirm:hover:not(:disabled){background:#0d5c28}.preview-actions .btn-confirm:disabled{background:#ccc;cursor:not-allowed}.preview-actions .btn-retry{flex:1;padding:1rem;background:#f0f0f0;color:#333;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.preview-actions .btn-retry:hover{background:#e0e0e0}.btn-reset-all{width:100%;padding:.75rem;background:transparent;color:#888;border:1px solid #ddd;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-reset-all:hover{background:#f8f8f8;border-color:#ccc;color:#666}.permission-overlay,.error-overlay{display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;min-height:300px;padding:2rem;text-align:center}.permission-content,.error-content{max-width:300px}.permission-icon,.error-icon{font-size:3rem;margin-bottom:1rem}.permission-content p,.error-content p{margin:.5rem 0;color:#333}.permission-hint{font-size:.85rem;color:#666!important}.btn-permission{margin-top:1rem;padding:.75rem 1.5rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.btn-permission:hover{background:#3a7bc8}.error-overlay .error-message{color:#c5221f}.error-overlay .btn-retry{margin-top:1rem;padding:.75rem 1.5rem;background:#f0f0f0;color:#333;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.error-overlay .btn-retry:hover{background:#e0e0e0}@media(max-width:600px){.recording-view{gap:.75rem}.recording-main{padding:1rem;gap:.75rem}.guidance-box{flex-direction:column;gap:.5rem;padding:.75rem;min-height:auto}.guidance-icon{font-size:1.25rem}.position-row{flex-direction:column;align-items:flex-start}.position-actions{width:100%;margin-left:0;margin-top:.5rem}.position-actions button{flex:1}.btn-change-position{margin-left:0}.setting-row{flex-wrap:wrap}.setting-row label{width:100%;margin-bottom:.25rem}.setting-hint{width:100%;margin-left:0;margin-top:.25rem}.preview-actions{flex-direction:column}.preview-actions .btn-confirm,.preview-actions .btn-retry{flex:none}}.processing-view{display:flex;flex-direction:column;gap:1.5rem}.processing-header{display:flex;align-items:center;gap:1rem}.processing-content{background:#fff;border-radius:8px;padding:1.5rem}.preset-section h3{margin:0 0 .5rem;font-size:1.25rem;color:#333}.preset-description{color:#666;margin-bottom:1rem}.preset-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.preset-option{display:flex;align-items:flex-start;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.preset-option:hover{border-color:#4a90d9;background:#f8fafc}.preset-option.selected{border-color:#4a90d9;background:#e6f0fa}.preset-option input{margin-right:.75rem;margin-top:.25rem}.preset-info{display:flex;flex-direction:column;gap:.25rem}.preset-name{font-weight:500;color:#333}.preset-desc{font-size:.875rem;color:#666}.processing-actions{display:flex;justify-content:center}.btn-start{padding:1rem 2rem;background:#4a90d9;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-start:hover:not(:disabled){background:#3a7bc8}.btn-start:disabled{background:#ccc;cursor:not-allowed}.progress-section{text-align:center}.progress-section h3{margin:0 0 1.5rem;font-size:1.25rem;color:#333}.progress-info{margin-bottom:1rem}.progress-stage{font-weight:500;color:#4a90d9;margin-bottom:.5rem}.progress-bar-container{height:20px;background:#e0e0e0;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.progress-bar{height:100%;background:linear-gradient(90deg,#4a90d9,#3a7bc8);border-radius:10px;transition:width .3s ease}.progress-percentage{font-size:1.5rem;font-weight:600;color:#333}.progress-message{color:#666;margin-bottom:1.5rem}.processing-tips{padding:1rem;background:#f0f7ff;border-radius:8px;font-size:.9rem;color:#666}.processing-tips p{margin:.25rem 0}.error-section{text-align:center}.error-icon{width:60px;height:60px;margin:0 auto 1rem;background:#fce8e6;color:#c5221f;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700}.error-section h3{margin:0 0 .5rem;color:#c5221f}.error-section .error-message{background:#fce8e6;color:#c5221f;padding:.75rem 1rem;border-radius:4px;margin-bottom:1.5rem}.error-actions{display:flex;gap:.75rem;justify-content:center}.btn-retry{padding:.75rem 1.5rem;background:#c5221f;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.btn-retry:hover{background:#a31b19}.completed-section{text-align:center}.completed-icon{width:80px;height:80px;margin:0 auto 1rem;background:#e6f4ea;color:#137333;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem}.completed-section h3{margin:0 0 .5rem;font-size:1.5rem;color:#137333}.completed-section>p{color:#666;margin-bottom:1.5rem}.preview-section{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px}.preview-section h4{margin:0 0 .75rem;font-size:1rem;color:#333}.audio-preview{width:100%;max-width:500px}.download-section{margin-bottom:2rem}.btn-download{padding:1rem 2.5rem;background:#137333;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-download:hover{background:#0d5c28}.completed-actions{display:flex;gap:.75rem;justify-content:center}.btn-secondary{padding:.75rem 1.5rem;background:#f0f0f0;color:#333;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.error-message{padding:.75rem 1rem;background:#fce8e6;color:#c5221f;border-radius:4px;margin-bottom:1rem}@media(max-width:600px){.error-actions,.completed-actions{flex-direction:column}.btn-start,.btn-download{width:100%}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#2c3e50;color:#fff;padding:1rem;display:flex;align-items:center;gap:1rem}.app-header h1{margin:0;font-size:1.5rem}.app-header .version{font-size:.8rem;opacity:.7}.app-main{flex:1;max-width:1200px;margin:0 auto;padding:1rem;width:100%}.app-footer{background:#2c3e50;color:#fff;padding:1rem;text-align:center;font-size:.9rem;opacity:.8}.app-footer p{margin:0}.session-view{background:#fff;border-radius:8px;padding:2rem}.session-info{margin-bottom:2rem}.session-info h2{margin-top:0;color:#333}.session-info p{margin:.5rem 0;color:#666}.placeholder{padding:2rem;background:#f0f0f0;border-radius:8px;text-align:center}.placeholder p{color:#888;margin-bottom:1rem}.placeholder button{padding:.75rem 1.5rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.placeholder button:hover{background:#3a7bc8}.error-banner{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);background:#c5221f;color:#fff;padding:1rem 2rem;border-radius:8px;box-shadow:0 4px 12px #0003;display:flex;align-items:center;gap:1rem}.error-dismiss{background:transparent;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.uploading-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:#fff;border-radius:8px}.uploading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#4a90d9;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.uploading-view p{color:#666;font-size:1.1rem}.uploaded-view{background:#fff;border-radius:8px;padding:2rem}.uploaded-view h2{margin:0 0 1.5rem;color:#137333}.uploaded-actions{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.placeholder-text{color:#888;margin-bottom:1rem}.button-group{display:flex;gap:.5rem}.btn-primary{padding:.75rem 1.5rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s;margin-bottom:1rem}.btn-primary:hover{background:#3a7bc8}.btn-secondary{padding:.75rem 1.5rem;background:#f0f0f0;color:#333;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#e0e0e0}@media(min-width:600px){.app-header{padding:1rem 2rem}.app-main{padding:2rem}.app-footer{padding:1rem 2rem}}
