.chat-page{position:fixed;top:57px;left:0;right:0;bottom:0;display:flex;overflow:hidden;background:#fff}.chat-column{flex:1;min-width:0;display:flex;flex-direction:column;background:#fff}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:.75rem}.chat-header-back{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#374151;font-size:.8125rem;cursor:pointer;transition:all .2s;white-space:nowrap}.chat-header-back:hover{background:#f3f4f6;border-color:#9ca3af}.chat-header-title{font-size:1rem;font-weight:700;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-status{width:8px;height:8px;border-radius:50%;background-color:#d1d5db;flex-shrink:0}.chat-header-status.connected{background-color:#10b981}.chat-messages{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.chat-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#9ca3af;font-size:.875rem;text-align:center;padding:2rem}.chat-msg{max-width:80%;padding:.625rem .875rem;border-radius:1rem;font-size:.875rem;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.chat-msg.user{align-self:flex-end;background-color:#ff6801;color:#fff;border-bottom-right-radius:.25rem}.chat-msg.bot{align-self:flex-start;background-color:#f3f4f6;color:#1f2937;border-bottom-left-radius:.25rem;white-space:normal}.chat-msg.bot p{margin:0}.chat-msg.bot p+p{margin-top:.5em}.chat-msg.bot strong{font-weight:600}.chat-msg.bot ul,.chat-msg.bot ol{margin:.375em 0;padding-left:1.25em}.chat-msg.bot li{margin:.125em 0}.chat-msg.bot li+li{margin-top:.25em}.chat-msg.bot code{background:#0000000f;padding:.125em .3em;border-radius:.25em;font-size:.8125rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.chat-msg.bot pre{background:#1f2937;color:#e5e7eb;padding:.625rem .75rem;border-radius:.5rem;overflow-x:auto;margin:.375em 0;font-size:.8125rem;line-height:1.5}.chat-msg.bot pre code{background:none;padding:0;color:inherit;font-size:inherit}.chat-msg.bot blockquote{border-left:3px solid #d1d5db;padding-left:.625rem;margin:.375em 0;color:#6b7280}.chat-msg.bot h1,.chat-msg.bot h2,.chat-msg.bot h3,.chat-msg.bot h4{margin:.5em 0 .25em;line-height:1.3}.chat-msg.bot h1{font-size:1.125rem}.chat-msg.bot h2{font-size:1rem}.chat-msg.bot h3{font-size:.9375rem}.chat-msg.bot h4{font-size:.875rem}.chat-msg.bot h1:first-child,.chat-msg.bot h2:first-child,.chat-msg.bot h3:first-child,.chat-msg.bot h4:first-child{margin-top:0}.chat-msg.bot table{border-collapse:collapse;margin:.375em 0;font-size:.8125rem;width:100%}.chat-msg.bot th,.chat-msg.bot td{border:1px solid #d1d5db;padding:.25rem .5rem;text-align:left}.chat-msg.bot th{background:#0000000a;font-weight:600}.chat-msg.bot hr{border:none;border-top:1px solid #d1d5db;margin:.5em 0}.chat-msg.bot a{color:#ff6801;text-decoration:underline}.chat-msg.bot.streaming{border-left:3px solid #ff6801;border-bottom-left-radius:.25rem;animation:streamGlow 2s ease-in-out infinite}@keyframes streamGlow{0%,to{box-shadow:-2px 0 8px #ff68011a}50%{box-shadow:-2px 0 18px #ff68014d}}.chat-msg.bot.streaming:after{content:"";display:inline-block;width:6px;height:1.1em;margin-left:4px;vertical-align:text-bottom;border-radius:3px;background:linear-gradient(180deg,#ff6801,#ffb366);animation:cursorPulse 1.5s ease-in-out infinite}@keyframes cursorPulse{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.2;transform:scaleY(.7)}}.chat-typing{align-self:flex-start;display:flex;align-items:center;gap:.625rem;padding:.625rem 1rem;background-color:#f3f4f6;border-radius:1rem 1rem 1rem .25rem;font-size:.8rem;color:#6b7280}.chat-typing-eq{display:flex;align-items:flex-end;gap:2.5px;height:18px}.chat-typing-eq span{width:3px;border-radius:1.5px;background:linear-gradient(to top,#ff6801,#ffb366);transform-origin:bottom;animation:eqBar 1.2s ease-in-out infinite}.chat-typing-eq span:nth-child(1){height:35%;animation-delay:0s}.chat-typing-eq span:nth-child(2){height:65%;animation-delay:.15s}.chat-typing-eq span:nth-child(3){height:90%;animation-delay:.3s}.chat-typing-eq span:nth-child(4){height:50%;animation-delay:.45s}.chat-typing-eq span:nth-child(5){height:75%;animation-delay:.6s}@keyframes eqBar{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}.chat-error{padding:.5rem 1rem;margin:0 1.25rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.8rem;flex-shrink:0}.chat-input-area{display:flex;align-items:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid #e5e7eb;flex-shrink:0}.chat-textarea{flex:1;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:1rem;font-size:.875rem;font-family:inherit;resize:none;max-height:120px;min-height:38px;line-height:1.4;outline:none;transition:border-color .2s}.chat-textarea:focus{border-color:#ff6801;box-shadow:0 0 0 2px #ff680126}.chat-textarea:disabled{background-color:#f9fafb;cursor:not-allowed}.chat-send-btn{width:38px;height:38px;border-radius:50%;background-color:#ff6801;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .2s}.chat-send-btn:hover{background-color:#e05d00}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.project-panel{width:400px;border-left:1px solid #e5e7eb;background:#fafafa;display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.project-panel-header{padding:.75rem 1.25rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.project-panel-title{font-size:1rem;font-weight:700;color:#1f2937;margin:0}.project-panel-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:1.5rem}.panel-section-label{font-size:.8125rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.panel-lines{display:flex;flex-direction:column;gap:.5rem}.panel-line-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.8125rem}.panel-line-index{font-weight:600;color:#9ca3af;flex-shrink:0;min-width:20px}.panel-line-text{flex:1;color:#374151;line-height:1.4;min-width:0;overflow:hidden;text-overflow:ellipsis}.panel-line-speaker{font-size:.6875rem;color:#9ca3af;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem;flex-shrink:0}.panel-line-play{width:28px;height:28px;border-radius:50%;background:#ff6801;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .2s}.panel-line-play:hover{background:#e05d00}.panel-line-play:disabled{background:#d1d5db;cursor:not-allowed}.panel-bg-music{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem}.panel-bg-name{flex:1;font-size:.8125rem;color:#374151}.panel-final{display:flex;flex-direction:column;gap:.5rem}.panel-final-player{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.625rem}.panel-final-play{width:36px;height:36px;border-radius:50%;background:#ff6801;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .2s}.panel-final-play:hover{background:#e05d00}.panel-final-play:disabled{background:#d1d5db;cursor:not-allowed}.panel-final-label{flex:1;font-size:.875rem;font-weight:600;color:#1f2937}.panel-final-download{padding:.375rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#374151;font-size:.75rem;cursor:pointer;transition:all .2s}.panel-final-download:hover{background:#f3f4f6;border-color:#9ca3af}.panel-lyrics-block{padding:.625rem .75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.8125rem;color:#374151;line-height:1.6;max-height:200px;overflow-y:auto}.panel-music-desc{padding:.5rem .75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.8125rem;color:#374151;line-height:1.5}.panel-genres-list{display:flex;flex-wrap:wrap;gap:.375rem}.panel-genre-item{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.75rem;color:#374151;cursor:default}.panel-genre-item:has(.panel-genre-checkbox:checked){background:#fff7ed;border-color:#ff6801;color:#c2410c}.panel-genre-checkbox{width:14px;height:14px;accent-color:#ff6801;pointer-events:none}.panel-genre-name{white-space:nowrap}.panel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;color:#9ca3af;font-size:.875rem;gap:.75rem}.panel-empty-icon{width:48px;height:48px;border-radius:50%;background:#f3f4f6;display:flex;align-items:center;justify-content:center;color:#d1d5db}@media (max-width: 768px){.chat-page{flex-direction:column}.chat-column{flex:1;min-height:0}.project-panel{width:100%;border-left:none;border-top:1px solid #e5e7eb;max-height:50vh;overflow-y:auto}.project-panel.collapsed{max-height:44px;overflow:hidden}.project-panel-header{cursor:pointer;display:flex;align-items:center;justify-content:space-between}.panel-toggle-chevron{display:block;transition:transform .2s}.panel-toggle-chevron.open{transform:rotate(180deg)}}@media (min-width: 769px){.panel-toggle-chevron{display:none}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;min-height:100vh;padding:0 1rem 2rem}#root,.app{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:1.5rem 1rem 0}.section{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem;margin-bottom:2rem}.section-header{text-align:center;margin-bottom:2rem}.section-header h1{font-size:2rem;font-weight:700;color:#1f2937}.section-header h2{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.section-header p{margin-top:.5rem;color:#4b5563}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.25rem;font-size:.875rem;color:#6b7280;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#ff6801;box-shadow:0 0 0 2px #ff680133}.form-group textarea{min-height:200px;resize:vertical}.btn{padding:.5rem 1rem;border-radius:9999px;font-weight:500;transition:all .2s;cursor:pointer;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background-color:#ff6801;color:#fff;border:none;padding:.75rem 1.5rem;font-size:1rem}.btn-primary:hover{background-color:#e05d00;color:#fff}.btn-secondary{background-color:#fff;color:red;border:none;padding:.75rem 1.5rem;font-size:1rem}.btn-secondary:hover{background-color:red;color:#fff}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover{background-color:#059669}.btn-large{padding:1rem 2.5rem;font-size:1.125rem}.btn-full-width{width:100%}.result-buttons{display:flex;justify-content:center;gap:1.5rem;margin-top:2rem}.create-btn{background:#fff;border-radius:9999px;color:#000;padding:.75rem 2rem;cursor:pointer;transition:all .2s;font-weight:500;font-size:1rem;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.create-btn:hover{background-color:#ff6801;color:#fff}.tabs{display:flex;gap:1rem;margin-bottom:1.5rem}.tab{padding:.75rem 1.5rem;font-weight:500;font-size:1rem;color:#6b7280;cursor:pointer;transition:all .2s;border-radius:9999px;background-color:#f3f4f6;border:none;text-align:center;flex:1}.tab:hover{background-color:#e5e7eb}.tab.active{background-color:#ff6801;color:#fff}.block{background-color:#f8fafc;border-radius:.75rem;padding:1.5rem;border:1px solid #e2e8f0;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem}.block label{display:block;font-weight:600;color:#1f2937;margin-bottom:1rem;font-size:1.1rem}.grid{display:grid;gap:2rem}@media (min-width: 768px){.grid{grid-template-columns:1fr 1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:1rem;padding:2rem;width:100%;max-width:420px}.modal-title{text-align:center;font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:1.25rem}.type-selector{display:flex;gap:1rem;margin-bottom:1.25rem}.type-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;border:2px solid #e5e7eb;border-radius:.75rem;background:#fff;cursor:pointer;transition:all .2s}.type-card:hover{border-color:#d1d5db}.type-card.active{border-color:#1f2937}.type-card-icon{width:56px;height:56px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#1f2937}.type-card-icon--voice{background-color:#e9d5ff}.type-card-icon--music{background-color:#fed7aa}.type-card-label{font-size:.875rem;font-weight:500;color:#374151}.btn-create-project{width:100%;padding:.75rem 1.5rem;background-color:#ff6801;color:#fff;border:none;border-radius:9999px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-create-project:hover{background-color:#e05d00}.empty-state{text-align:center;color:#6b7280;padding:2rem}.audio-player{background-color:#f8fafc;border-radius:.5rem;padding:1.5rem;margin-top:1rem}.audio-player audio{width:100%}.audio-player .empty-state{text-align:center;color:#6b7280;padding:2rem}.controls{display:flex;justify-content:flex-end;align-items:center;gap:1rem;margin-bottom:1rem}.projects-grid{display:flex;flex-direction:column;gap:1.5rem}.project-card{position:relative;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;transition:all .3s;overflow:hidden;cursor:pointer;border:1px solid #e5e7eb;display:flex;align-items:flex-start;padding:1rem}.project-card:hover{box-shadow:0 10px 15px -3px #0000001a;transform:translateY(-2px)}.project-image{background-color:#f3f4f6;width:80px;height:80px;display:flex;align-items:center;justify-content:center;font-size:2rem;border-radius:.5rem;flex-shrink:0;margin-right:1rem}.project-info{display:flex;flex-direction:column}.project-name{font-size:1.125rem;font-weight:600;color:#374151;margin-bottom:.5rem}.project-type{font-size:.875rem;color:#6b7280}.delete-btn{position:absolute;top:.5rem;right:.5rem;background:#ffffffe6;border:none;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:#ef4444;transition:all .2s}.delete-btn:hover{background:#ef4444;color:#fff}.modal-actions{display:flex;justify-content:flex-start;gap:1rem;margin-top:1rem}.hidden{display:none}.nav-buttons-container{display:flex;width:100%;justify-content:flex-start;margin-bottom:2rem;padding:0 1rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f9fafb}.auth-card{background:#fff;border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;padding:2.5rem;width:100%;max-width:420px}.auth-title{text-align:center;font-size:1.5rem;font-weight:700;color:#ff6801;margin-bottom:.25rem}.auth-subtitle{text-align:center;font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:.25rem}.auth-error{color:#dc2626;font-size:.875rem;text-align:center;padding:.5rem;background-color:#fef2f2;border-radius:.25rem;margin-bottom:.5rem}.auth-switch{text-align:center;margin-top:1.25rem;font-size:.875rem;color:#6b7280}.auth-switch-btn{background:none;border:none;color:#ff6801;cursor:pointer;font-weight:500;font-size:.875rem;padding:0}.auth-switch-btn:hover{text-decoration:underline}.header{position:sticky;top:0;z-index:100;background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #00000014}.header-inner{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:56px}.header-logo{font-size:1.125rem;font-weight:700;color:#1f2937;cursor:pointer;transition:color .2s;-webkit-user-select:none;user-select:none}.header-logo:hover{color:#ff6801}.header-nav{display:flex;align-items:center;gap:.5rem}.header-nav-btn{background:none;border:none;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;border-radius:9999px;transition:all .2s}.header-nav-btn:hover{background-color:#f3f4f6;color:#ff6801}.header-nav-btn--logout{color:#ef4444}.header-nav-btn--logout:hover{background-color:#fef2f2;color:#dc2626}@media (max-width: 480px){.header-inner{padding:0 .75rem}.header-logo{font-size:.95rem}.header-nav{gap:.25rem}.header-nav-btn{padding:.375rem .625rem;font-size:.8rem}}.project-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.project-page-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.project-page-subtitle{font-size:.875rem;color:#6b7280}.step-section{margin-bottom:1.5rem}.step-label{font-size:1rem;font-weight:600;color:#374151;margin-bottom:.25rem}.step-question{font-size:1.125rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.step-choice-buttons{display:flex;gap:1rem;margin-bottom:1rem}.btn-choice{padding:.625rem 1.5rem;border-radius:9999px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;border:2px solid transparent}.btn-choice--yes{background-color:#d1fae5;color:#065f46;border-color:#a7f3d0}.btn-choice--yes:hover,.btn-choice--yes.active{background-color:#065f46;color:#fff;border-color:#065f46}.btn-choice--no{background-color:#ffedd5;color:#9a3412;border-color:#fed7aa}.btn-choice--no:hover,.btn-choice--no.active{background-color:#9a3412;color:#fff;border-color:#9a3412}.generation-block{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}.generation-block-title{font-size:1.1rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.generation-textarea{width:100%;min-height:120px;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;font-family:inherit;resize:vertical;transition:border-color .2s}.generation-textarea.generation-textarea--small,.generation-block .generation-textarea,.bg-generate-block .generation-textarea{min-height:40px}.generation-textarea:focus{outline:none;border-color:#ff6801;box-shadow:0 0 0 2px #ff680133}.language-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.language-label{font-size:.9rem;font-weight:600;color:#1f2937;white-space:nowrap}.language-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;min-width:160px;cursor:pointer}.language-select:focus{outline:none;border-color:#ff6801}.generate-btn-row{display:flex;justify-content:center}.btn-outline-primary{padding:.625rem 1.5rem;border-radius:9999px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;background-color:#fff;color:#ff6801;border:2px solid #ff6801}.btn-outline-primary:hover{background-color:#ff6801;color:#fff}.btn-outline-primary:disabled{opacity:.5;cursor:not-allowed}.ad-text-section{margin-top:1.5rem}.ad-text-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.ad-text-title{font-size:1.1rem;font-weight:700;color:#1f2937}.help-icon{width:24px;height:24px;border-radius:50%;background-color:#ff6801;color:#fff;border:none;font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.help-icon:hover{background-color:#e05d00}.help-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.help-modal{background-color:#fff;border-radius:1rem;box-shadow:0 20px 60px #00000040;width:560px;max-width:calc(100vw - 2rem);max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.help-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem .75rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.help-modal-content{overflow-y:auto;padding:1rem 1.5rem 1.5rem}.help-modal-title{font-size:1.1rem;font-weight:700;color:#1f2937;margin:0}.help-modal-close{font-size:1.75rem;color:#6b7280;cursor:pointer;line-height:1;transition:color .2s}.help-modal-close:hover{color:#1f2937}.help-modal-content h4{font-size:.95rem;font-weight:700;color:#1f2937;margin:1.25rem 0 .4rem}.help-modal-content h4:first-child{margin-top:0}.help-modal-content p{font-size:.875rem;color:#4b5563;line-height:1.6;margin:0 0 .5rem}.help-modal-content code{background-color:#f3f4f6;padding:.15rem .35rem;border-radius:.25rem;font-size:.8rem;color:#b45309;word-break:break-word}.ad-text-box{margin-bottom:1rem}.ad-text-textarea{width:100%;min-height:120px;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9rem;font-family:inherit;resize:vertical;line-height:1.5;transition:border-color .2s}.ad-text-textarea--large{min-height:240px}.ad-text-textarea:focus{outline:none;border-color:#ff6801;box-shadow:0 0 0 2px #ff680133}.ad-text-actions{display:flex;justify-content:flex-end;align-items:center;gap:1rem}.btn-next{padding:.75rem 2rem;font-size:1rem}.hint-block{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;background-color:#fff7ed;border:1px solid #fed7aa;border-radius:.75rem;margin-bottom:1.5rem}.hint-icon{width:28px;height:28px;border-radius:50%;background-color:#ff6801;color:#fff;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hint-text{font-size:.875rem;color:#9a3412;line-height:1.5;font-style:italic}.genre-grid{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;margin-bottom:1.25rem}.genre-checkbox{display:flex;align-items:center;gap:.4rem;font-size:.875rem;color:#374151;cursor:pointer}.genre-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:#ff6801;cursor:pointer}.collapsible-section{margin-bottom:1.5rem}.collapsible-toggle{display:inline-flex;align-items:center;gap:.5rem;background-color:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem 1rem;border-radius:9999px;transition:all .2s}.collapsible-toggle:hover{background-color:#ffedd5;border-color:#fdba74}.collapsible-toggle.open{background-color:#ff6801;color:#fff;border-color:#ff6801}.collapsible-chevron{transition:transform .2s}.collapsible-toggle.open .collapsible-chevron{transform:rotate(180deg);stroke:#fff}.collapsible-content{margin-top:.75rem;padding:1rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.9rem;color:#374151;line-height:1.6}.section-label{font-size:1rem;font-weight:700;color:#1f2937;margin-bottom:.75rem}.voice-section{margin-bottom:2rem}.voice-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.voice-select{flex:1;padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.9rem;cursor:pointer}.voice-select:focus{outline:none;border-color:#ff6801}.btn-play-circle{width:38px;height:38px;border-radius:50%;background-color:#ff6801;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;flex-shrink:0}.btn-play-circle:hover{background-color:#e05d00}.voice-actions{display:flex;align-items:center;gap:1rem}.btn-outline-dark{padding:.5rem 1.25rem;border-radius:9999px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;background-color:#fff;color:#1f2937;border:2px solid #1f2937}.btn-outline-dark:hover{background-color:#1f2937;color:#fff}.btn-outline-dark:disabled{opacity:.5;cursor:not-allowed}.voice-hint{font-size:.8rem;color:#ff6801;background-color:#fff7ed;padding:.35rem .75rem;border-radius:.375rem;border:1px solid #fed7aa}.voice-loading{display:flex;align-items:center;gap:.75rem;margin-top:.75rem;padding:.75rem 1rem;background-color:#fff7ed;border:1px solid #fed7aa;border-radius:.5rem;color:#c2410c;font-size:.9rem;font-weight:500}.voice-error{margin-top:.75rem;padding:.6rem 1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.85rem}.generation-error-banner{margin-top:.75rem;padding:.75rem 1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.875rem;display:flex;align-items:center;gap:.5rem;line-height:1.4}.generation-error-banner svg{flex-shrink:0;color:#dc2626}.btn-voice-generate{display:flex;align-items:center;gap:.5rem;white-space:nowrap}.spinner-white{border-color:#ffffff4d;border-top-color:#fff}.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,104,1,.25);border-top-color:#ff6801;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.voice-lines{margin-top:1rem}.voice-lines-title{font-size:.95rem;font-weight:600;color:#374151;margin-bottom:.5rem}.voice-line-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid #e5e7eb}.voice-line-row:last-child{border-bottom:none}.voice-line-index{flex-shrink:0;width:1.75rem;font-size:.85rem;font-weight:600;color:#6b7280;text-align:right}.voice-line-text{flex:1;font-size:.9rem;color:#1f2937;line-height:1.4}.voice-line-no-audio{flex-shrink:0;width:28px;text-align:center;color:#9ca3af}.btn-play-line{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:none;background-color:#ff6801;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s}.btn-play-line:hover{background-color:#e55d00}.btn-play-circle:disabled{opacity:.4;cursor:not-allowed}.bg-music-section{margin-bottom:2rem}.bg-music-buttons{display:flex;gap:1rem;margin-bottom:1.25rem}.bg-generate-block{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;margin-bottom:1rem}.bg-generate-title{font-size:1rem;font-weight:700;color:#1f2937;margin-bottom:.75rem}.versions-section{margin-top:1.25rem}.versions-title{font-size:.9rem;font-weight:600;color:#374151;margin-bottom:.75rem}.versions-row{display:flex;gap:1rem;margin-bottom:.75rem}.version-card{display:flex;flex-direction:column;padding:.75rem 1.25rem;border:2px solid #e5e7eb;border-radius:.75rem;background:#fff;cursor:pointer;transition:all .2s;flex:1;margin-bottom:.5rem}.version-card:hover{border-color:#ff6801}.version-card.active{border-color:#ff6801;background-color:#fff7ed}.version-play-icon{width:32px;height:32px;border-radius:50%;background-color:#ff6801;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer}.version-name{font-size:.9rem;font-weight:600;color:#1f2937;flex:1}.version-model{font-weight:400;font-size:.8rem;color:#6b7280}.atp{display:flex;flex-direction:column;gap:6px;width:100%;min-height:32px}.atp-top{display:flex;align-items:center;gap:10px}.atp-btn{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:1.5px solid #d1d5db;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#374151;transition:border-color .15s,background .15s}.atp-btn:hover{border-color:#ff6801;background:#fff7ed;color:#ff6801}.atp-info{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.atp-label{font-size:.9rem;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.atp-sublabel{font-size:.75rem;color:#6b7280;font-weight:400}.atp-bottom{display:flex;align-items:center;gap:8px}.atp-bar{flex:1;height:6px;background:#e5e7eb;border-radius:3px;cursor:pointer;position:relative;overflow:hidden}.atp-bar-fill{height:100%;background:#ff6801;border-radius:3px;transition:width .1s linear}.atp-time{flex-shrink:0;font-size:.75rem;color:#6b7280;font-variant-numeric:tabular-nums;min-width:80px;text-align:right}.atp-compact{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:none;background-color:#ff6801;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s}.atp-compact:hover{background-color:#e55d00}.version-duration{font-size:.8rem;color:#ff6801;font-weight:500}.checkbox-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151;cursor:pointer}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:#ff6801;cursor:pointer}.selected-track-info{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;margin-top:.5rem}.selected-track-label{font-size:.875rem;color:#6b7280}.selected-track-name{font-size:.9rem;font-weight:600;color:#1f2937}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.btn-danger{background-color:#ef4444;color:#fff;border:none;border-radius:9999px;cursor:pointer;font-weight:500}.btn-danger:hover{background-color:#dc2626}.step-bottom-actions{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.link-button{background:none;border:none;color:#6b7280;font-size:.875rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}.link-button:hover{color:#374151}.library-modal{background:#fff;border-radius:1rem;padding:1.5rem;width:100%;max-width:580px;max-height:80vh;display:flex;flex-direction:column}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.library-title{font-size:1.25rem;font-weight:700;color:#1f2937}.library-close{width:32px;height:32px;border-radius:50%;background:#f3f4f6;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s}.library-close:hover{background:#e5e7eb;color:#1f2937}.library-search{position:relative;margin-bottom:1rem}.library-search-input{width:100%;padding:.625rem 2.5rem .625rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem}.library-search-input:focus{outline:none;border-color:#ff6801}.library-search-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none}.library-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;overflow-y:auto;flex:1;margin-bottom:1rem;padding-right:.25rem}.library-track{display:flex;flex-direction:column;padding:.5rem .75rem;border:2px solid #e5e7eb;border-radius:.5rem;background:#fff;cursor:pointer;transition:all .2s}.library-track:hover{border-color:#ff6801}.library-track.active{border-color:#ff6801;background-color:#fff7ed}.track-play-btn{width:28px;height:28px;border-radius:50%;background-color:#ff6801;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.track-info{flex:1;display:flex;flex-direction:column;gap:.15rem;overflow:hidden;text-align:left}.track-name{font-size:.85rem;font-weight:600;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-description{font-size:.75rem;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-footer{display:flex;justify-content:center;padding-top:.5rem}.final-text-section{margin-bottom:1.5rem}.final-text-box{padding:1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9rem;color:#374151;line-height:1.6;background-color:#fff;min-height:80px}.final-player{display:flex;flex-direction:column;padding:.75rem 1.25rem;border:2px solid #e5e7eb;border-radius:.75rem;margin-bottom:1.5rem}.final-player-play{width:36px;height:36px;border-radius:50%;background-color:#ff6801;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .2s}.final-player-play:hover{background-color:#e05d00}.final-player-name{font-size:.9rem;font-weight:700;color:#1f2937;flex:1}.final-player-meta{font-weight:400;color:#9ca3af}.final-player-duration{font-size:.85rem;color:#ff6801;font-weight:500;flex-shrink:0}.final-settings{display:flex;align-items:flex-end;gap:1.5rem;margin-bottom:2rem}.final-settings-fields{display:flex;gap:1.5rem}.final-setting{display:flex;flex-direction:column;gap:.35rem}.final-setting-label{font-size:.8rem;color:#6b7280}.final-setting-input{width:120px;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:9999px;font-size:.9rem;text-align:center}.final-setting-input:focus{outline:none;border-color:#ff6801}.final-bottom{display:flex;justify-content:space-between;align-items:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:2px dashed #d1d5db}.final-bottom-links{display:flex;flex-direction:column;gap:.5rem}.btn-save{padding:1rem 2.5rem;background-color:#d1fae5;color:#065f46;border:2px solid #a7f3d0;border-radius:.5rem;font-size:1.1rem;font-weight:700;letter-spacing:.05em;cursor:pointer;transition:all .2s}.btn-save:hover{background-color:#065f46;color:#fff;border-color:#065f46}.btn-save:disabled{opacity:.5;cursor:not-allowed}.final-loading{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;background-color:#fff7ed;border:1px solid #fed7aa;border-radius:.5rem;color:#c2410c;font-size:.9rem;font-weight:500}.final-error{margin-bottom:1rem;padding:.6rem 1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.85rem}.final-player-play:disabled{opacity:.4;cursor:not-allowed}.project-history-btn{margin-left:auto;margin-right:2.5rem;align-self:center;background:none;border:1px solid #d1d5db;border-radius:9999px;padding:.375rem 1rem;font-size:.8rem;color:#6b7280;cursor:pointer;white-space:nowrap;transition:all .2s}.project-history-btn:hover{border-color:#ff6801;color:#ff6801;background-color:#fff7ed}.versions-modal{background:#fff;border-radius:1rem;padding:1.5rem;width:100%;max-width:620px;max-height:80vh;display:flex;flex-direction:column}.versions-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.versions-modal-list{overflow-y:auto;flex:1}.version-item{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 0;border-bottom:1px solid #f3f4f6}.version-item:last-child{border-bottom:none}.version-item-info{display:flex;justify-content:space-between;align-items:center}.version-item-name{font-size:.9rem;font-weight:600;color:#1f2937}.version-item-date{font-size:.75rem;color:#9ca3af}.version-item-row{display:flex;align-items:center;gap:.75rem}.version-item-player{flex:1;min-width:0}.version-item-row .btn-sm{flex-shrink:0}
