.illustration-settings-panel{padding:var(--space-4)}.settings-section-title{margin:0 0 var(--space-4);font-size:.9375rem;font-weight:600;color:var(--text-primary)}.setting-item{margin-bottom:var(--space-5)}.setting-label{display:block;margin-bottom:var(--space-2);font-size:.875rem;font-weight:500;color:var(--text-primary)}.setting-description{margin:var(--space-1) 0 0;font-size:.75rem;color:var(--text-tertiary)}.setting-checkbox{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.setting-checkbox input{display:none}.checkbox-mark{width:18px;height:18px;border:2px solid var(--border-color);border-radius:var(--radius-sm);transition:all .2s;position:relative}.setting-checkbox input:checked+.checkbox-mark{background:var(--primary-500);border-color:var(--primary-500)}.setting-checkbox input:checked+.checkbox-mark:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-label{font-size:.875rem;color:var(--text-primary)}.slider-container{display:flex;align-items:center;gap:var(--space-3)}.setting-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:2px;outline:none}.setting-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--primary-500);border-radius:50%;cursor:pointer;transition:transform .2s}.setting-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.setting-slider::-moz-range-thumb{width:16px;height:16px;background:var(--primary-500);border:none;border-radius:50%;cursor:pointer}.setting-slider:disabled{opacity:.5}.slider-value{min-width:50px;font-size:.875rem;font-weight:500;color:var(--text-secondary);text-align:right}.position-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.position-btn{padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.8125rem;color:var(--text-secondary);cursor:pointer;transition:all .2s}.position-btn:hover{background:var(--bg-tertiary);border-color:var(--primary-300)}.position-btn.active{background:var(--primary-100);border-color:var(--primary-500);color:var(--primary-700)}[data-theme=dark] .position-btn.active{background:#8b5cf633;color:var(--primary-300)}.loading-portal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;overflow:hidden}.portal-background{position:absolute;inset:0}.bg-gradient{position:absolute;inset:0;background:radial-gradient(ellipse at center,#667eea80,#1e1e3cfa,#0a0a15);animation:bg-pulse 4s ease-in-out infinite}@keyframes bg-pulse{0%,to{opacity:1}50%{opacity:.8}}.nebula-layer{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(138,43,226,.2) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(75,0,130,.2) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(102,126,234,.15) 0%,transparent 60%);animation:nebula-drift 20s ease-in-out infinite}@keyframes nebula-drift{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.1) rotate(5deg)}}.stars-layer{position:absolute;inset:0}.star{position:absolute;left:var(--x);top:var(--y);width:var(--size);height:var(--size);background:#fff;border-radius:50%;animation:twinkle var(--duration) var(--delay) ease-in-out infinite;box-shadow:0 0 calc(var(--size) * 2) #ffffff80}@keyframes twinkle{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.magic-circle-container{position:absolute;width:400px;height:400px;display:flex;align-items:center;justify-content:center}.magic-circle{position:absolute;border:2px solid;border-radius:50%;opacity:.6}.magic-circle.outer{width:380px;height:380px;border-color:#a78bfa66;border-style:dashed;animation:rotate-cw 30s linear infinite}.magic-circle.middle{width:300px;height:300px;border-color:#8b5cf680;animation:rotate-ccw 20s linear infinite}.magic-circle.inner{width:220px;height:220px;border-color:#c4b5fd99;border-width:3px;animation:rotate-cw 15s linear infinite;box-shadow:0 0 30px #8b5cf64d,inset 0 0 30px #8b5cf633}@keyframes rotate-cw{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes rotate-ccw{0%{transform:rotate(360deg)}to{transform:rotate(0)}}.magic-runes{position:absolute;width:340px;height:340px}.rune{position:absolute;left:50%;top:50%;font-size:20px;color:#c4b5fdcc;text-shadow:0 0 10px rgba(139,92,246,.8);transform-origin:0 170px;transform:rotate(calc(var(--index) * 45deg)) translateY(-170px);animation:rune-glow 2s ease-in-out infinite;animation-delay:calc(var(--index) * .2s)}@keyframes rune-glow{0%,to{opacity:.5;text-shadow:0 0 10px rgba(139,92,246,.5)}50%{opacity:1;text-shadow:0 0 20px rgba(139,92,246,1)}}.vortex-container{position:absolute;width:200px;height:200px}.vortex-ring{position:absolute;inset:0;border:3px solid transparent;border-radius:50%;border-top-color:#a78bfa99;animation:vortex-spin 3s linear infinite}.vortex-ring.ring-1{animation-duration:3s}.vortex-ring.ring-2{inset:15px;animation-duration:2.5s;animation-direction:reverse;border-top-color:#8b5cf6b3}.vortex-ring.ring-3{inset:30px;animation-duration:2s;border-top-color:#c4b5fdcc}@keyframes vortex-spin{to{transform:rotate(360deg)}}.particles-container{position:absolute;width:1px;height:1px}.particle{position:absolute;width:4px;height:4px;background:linear-gradient(135deg,#a78bfa,#818cf8);border-radius:50%;box-shadow:0 0 10px #a78bfacc;animation:particle-orbit 4s ease-in-out infinite;animation-delay:var(--delay);transform:rotate(var(--angle)) translate(var(--distance))}@keyframes particle-orbit{0%,to{opacity:.3;transform:rotate(var(--angle)) translate(var(--distance)) scale(.5)}50%{opacity:1;transform:rotate(calc(var(--angle) + 180deg)) translate(calc(var(--distance) * .7)) scale(1.5)}}.floating-pages{position:absolute;inset:0;pointer-events:none}.page{position:absolute;left:var(--x-start);top:-50px;font-size:24px;opacity:0;animation:page-fall 8s ease-in-out infinite;animation-delay:var(--delay);filter:drop-shadow(0 0 5px rgba(255,255,255,.3))}@keyframes page-fall{0%{opacity:0;transform:translateY(-50px) translate(0) rotate(0)}10%{opacity:.8}90%{opacity:.8}to{opacity:0;transform:translateY(100vh) translate(var(--drift)) rotate(var(--rotation))}}.center-glow{position:absolute;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.glow-core{width:60px;height:60px;background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(167,139,250,.6) 40%,transparent 70%);border-radius:50%;animation:core-pulse 2s ease-in-out infinite}.glow-pulse{position:absolute;width:100px;height:100px;border:2px solid rgba(255,255,255,.3);border-radius:50%;animation:pulse-expand 2s ease-out infinite}@keyframes core-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.2);opacity:1}}@keyframes pulse-expand{0%{transform:scale(.5);opacity:1}to{transform:scale(2);opacity:0}}.portal-content{position:relative;z-index:10;text-align:center;color:#fff;max-width:400px;padding:20px}.portal-title{font-size:32px;font-weight:700;margin-bottom:16px;letter-spacing:4px}.title-char{display:inline-block;animation:char-float 1s ease-out forwards;animation-delay:var(--delay);opacity:0;transform:translateY(20px)}@keyframes char-float{to{opacity:1;transform:translateY(0)}}.portal-loading-text{font-size:14px;color:#ffffffb3;margin-bottom:24px;animation:text-fade 2s ease-in-out infinite}@keyframes text-fade{0%,to{opacity:.7}50%{opacity:1}}.portal-progress{display:flex;align-items:center;gap:12px;padding:0 20px}.progress-track{flex:1;height:6px;background:#ffffff1a;border-radius:3px;overflow:visible;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#818cf8,#a78bfa,#c4b5fd);border-radius:3px;transition:width .3s ease-out;box-shadow:0 0 10px #a78bfa80}.progress-glow{position:absolute;top:50%;width:20px;height:20px;background:radial-gradient(circle,rgba(255,255,255,.8) 0%,transparent 70%);border-radius:50%;transform:translate(-50%,-50%);animation:glow-pulse 1s ease-in-out infinite}.progress-particles{position:absolute;inset:0;overflow:hidden}.progress-particle{position:absolute;left:var(--left);top:50%;width:4px;height:4px;background:#fff;border-radius:50%;animation:particle-float 1s ease-out infinite;animation-delay:var(--delay)}@keyframes particle-float{0%{opacity:1;transform:translate(-50%,-50%) translateY(0)}to{opacity:0;transform:translate(-50%,-50%) translateY(-20px)}}.progress-percent{font-size:14px;font-weight:600;color:#ffffffe6;min-width:45px;text-align:right}.missing-resources{margin-top:30px;padding:20px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.missing-title{font-size:14px;font-weight:600;color:#fca5a5;margin-bottom:12px}.missing-list{list-style:none;padding:0;margin:0 0 16px;text-align:left}.missing-list li{font-size:13px;color:#ffffffb3;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.1)}.missing-list li:last-child{border-bottom:none}.missing-list li:before{content:"⚠ ";color:#fbbf24}.goto-creation-btn{width:100%;padding:12px 24px;background:linear-gradient(135deg,#818cf8,#a78bfa);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.goto-creation-btn:hover{background:linear-gradient(135deg,#a78bfa,#c4b5fd);transform:translateY(-2px);box-shadow:0 4px 15px #a78bfa66}.entering-flash{position:fixed;inset:0;background:radial-gradient(circle,#fff,#fff0 70%);display:flex;align-items:center;justify-content:center;animation:flash-in 1.5s ease-out forwards;z-index:100}.entering-flash span{font-size:24px;font-weight:700;color:#1a1a2e;animation:welcome-text 1.5s ease-out forwards}@keyframes flash-in{0%{opacity:0}30%{opacity:1}to{opacity:0}}@keyframes welcome-text{0%{opacity:0;transform:scale(.8)}30%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.1)}}@media(max-width:768px){.magic-circle-container{width:280px;height:280px}.magic-circle.outer{width:260px;height:260px}.magic-circle.middle{width:200px;height:200px}.magic-circle.inner{width:140px;height:140px}.magic-runes{width:230px;height:230px}.rune{font-size:16px;transform-origin:0 115px;transform:rotate(calc(var(--index) * 45deg)) translateY(-115px)}.portal-title{font-size:24px}.portal-content{padding:16px}}.loading-portal.creation-mode{animation:portal-fade-in .3s ease-out}.creation-bg{background:radial-gradient(ellipse at center,#ffc8964d,#281e32fa,#0a0a15)!important}.creation-circle{width:250px;height:250px}.creation-circle .magic-circle.middle{width:200px;height:200px;border-color:#ffb47880}.creation-circle .magic-circle.inner{width:140px;height:140px;border-color:#ffc89699;box-shadow:0 0 30px #ffb4784d,inset 0 0 30px #ffb47833}.creation-core{background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(255,180,120,.6) 40%,transparent 70%)!important}.creation-content{margin-top:60px}.creation-content .portal-loading-text{font-size:16px;margin-bottom:20px}.creation-flash{background:radial-gradient(circle,#ffdcb4e6,#fff0 70%)!important}.creation-flash span{color:#3d2a1f!important}.loading-portal.experience-mode .bg-gradient{background:radial-gradient(ellipse at center,#667eea80,#1e1e3cfc,#0a0a15)}.loading-portal.experience-mode:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 30%,rgba(138,43,226,.15) 0%,transparent 40%),radial-gradient(ellipse at 80% 70%,rgba(75,0,130,.15) 0%,transparent 40%),radial-gradient(ellipse at 50% 20%,rgba(255,255,255,.05) 0%,transparent 30%);pointer-events:none;z-index:1}.loading-portal.experience-mode:after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 40%,rgba(139,92,246,.03) 50%,transparent 60%);animation:light-flow 8s ease-in-out infinite;pointer-events:none;z-index:1}@keyframes light-flow{0%,to{background-position:-100% 0}50%{background-position:200% 0}}.creation-dashboard{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.creation-dashboard.loading{display:flex;align-items:center;justify-content:center;min-height:400px}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-muted)}.dashboard-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem}.section-title{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.section-title .title-icon{display:flex;align-items:center;color:var(--primary-500)}.project-info-card{display:flex;align-items:center;gap:1rem}.project-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:color-mix(in srgb,var(--primary-500) 10%,transparent);border-radius:var(--radius-lg, 12px);color:var(--primary-500)}.project-meta{flex:1}.project-meta h2{margin:0 0 .25rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.project-desc{margin:0;font-size:.85rem;color:var(--text-muted)}.project-stats{display:flex;gap:1.5rem}.project-stats .stat{text-align:center}.project-stats .stat strong{display:block;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.project-stats .stat span{font-size:.75rem;color:var(--text-muted)}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.status-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px}.status-item.ready{border-color:var(--success-main);background:var(--success-bg)}.status-item.pending{border-color:var(--warning-main);background:var(--warning-bg)}.status-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:color-mix(in srgb,var(--primary-500) 8%,transparent);border-radius:6px;color:var(--primary-500);flex-shrink:0}.status-content{flex:1;min-width:0}.status-label{display:block;font-size:.85rem;font-weight:500;color:var(--text-primary)}.status-hint{display:block;font-size:.7rem;color:var(--text-muted);margin-top:.15rem}.status-indicator{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%}.status-item.ready .status-indicator{background:var(--success-bg);color:var(--success-main)}.status-item.pending .status-indicator{background:var(--warning-bg);color:var(--warning-main)}.generation-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.generation-btn{display:flex;align-items:center;gap:.5rem;position:relative;overflow:hidden;font-weight:500;padding:.75rem 1.25rem;border-radius:12px;transition:all .3s ease}.generation-btn.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-400));border:1px solid var(--primary-400);color:#fff;box-shadow:0 4px 16px color-mix(in srgb,var(--primary-500) 25%,transparent)}.generation-btn.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);animation:shimmer-sweep 3s ease-in-out infinite}@keyframes shimmer-sweep{0%{left:-100%}50%{left:100%}to{left:100%}}.generation-btn.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px color-mix(in srgb,var(--primary-500) 35%,transparent)}.generation-btn.btn-primary:active{transform:scale(.98)}.generation-btn.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.generation-btn.btn-secondary{background:var(--glass-bg, color-mix(in srgb, var(--bg-secondary) 80%, transparent));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);color:var(--text-primary)}.generation-btn.btn-secondary:hover{background:var(--bg-hover);border-color:var(--primary-400);transform:translateY(-1px)}.generation-btn.btn-secondary:active{transform:scale(.98)}.generation-btn.btn-secondary:disabled{opacity:.5;cursor:not-allowed;transform:none}.generation-btn .btn-badge{background:color-mix(in srgb,var(--bg-quaternary) 80%,transparent);padding:.15rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600;color:var(--text-secondary)}.generation-btn.btn-primary .btn-badge{background:#fff3;color:#fff}.generation-progress{background:var(--bg-tertiary);border-radius:8px;padding:1rem}.progress-header{display:flex;justify-content:space-between;margin-bottom:.75rem}.progress-stage{font-size:.85rem;color:var(--text-primary)}.progress-count{font-size:.85rem;color:var(--text-muted)}.progress-bar{height:6px;background:var(--bg-quaternary);border-radius:3px;overflow:hidden;margin-bottom:.75rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));border-radius:3px;transition:width .3s ease}.stop-btn{display:flex;align-items:center;gap:.4rem}.cost-breakdown{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.cost-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.cost-icon{display:flex;color:var(--text-muted)}.cost-label{flex:1;font-size:.85rem;color:var(--text-secondary)}.cost-count{font-size:.8rem;color:var(--text-muted);margin-right:1rem}.cost-value{font-size:.85rem;font-weight:500;color:var(--text-primary)}.cost-total{display:flex;flex-direction:column;gap:.5rem}.total-row,.balance-row{display:flex;justify-content:space-between;align-items:center}.total-row span{font-size:.9rem;color:var(--text-secondary)}.total-row strong{display:flex;align-items:center;gap:.35rem;font-size:1.1rem}.total-row strong.ok{color:var(--success-main)}.total-row strong.warn{color:var(--error-main)}.balance-row span{font-size:.8rem;color:var(--text-muted)}.balance-row .balance{color:var(--text-secondary)}.nav-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.nav-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:left;flex:1 1 auto;min-width:200px;max-width:100%}.nav-btn:hover{background:var(--bg-hover);border-color:var(--primary-400)}.nav-btn svg{flex-shrink:0;color:var(--text-muted)}.nav-btn span{flex:1;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-count{flex-shrink:0;padding:.2rem .5rem;background:var(--bg-quaternary);border-radius:8px;font-size:.75rem;color:var(--text-muted)}@media(max-width:768px){.project-info-card{flex-direction:column;text-align:center}.project-stats{justify-content:center}.status-grid{grid-template-columns:1fr}.generation-buttons{flex-direction:column}}.confirm-modal-overlay{position:fixed;inset:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fade-in .2s ease}.confirm-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;width:90%;max-width:440px;box-shadow:0 20px 60px #0000004d;animation:modal-slide-up .3s ease}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.75rem}.confirm-modal-header .modal-icon{font-size:1.5rem}.confirm-modal-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.confirm-modal-body{padding:1.25rem 1.5rem}.cost-preview{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;padding:1rem;margin-bottom:1rem}.cost-preview-title{font-size:.8rem;color:var(--text-muted);margin-bottom:.75rem}.cost-preview-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;font-size:.85rem}.cost-preview-row .row-label{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.cost-preview-row .row-value{color:var(--text-primary);font-weight:500}.cost-preview-divider{height:1px;background:var(--border-color);margin:.5rem 0}.cost-preview-total{display:flex;justify-content:space-between;padding-top:.5rem;font-weight:600}.cost-preview-total .total-label{color:var(--text-secondary)}.cost-preview-total .total-value{color:var(--primary-500)}.cost-preview-total .total-value.insufficient{color:var(--error-main)}.cost-preview-balance{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.modal-tips{background:var(--info-bg, color-mix(in srgb, var(--primary-500) 10%, transparent));border:1px solid var(--info-border, color-mix(in srgb, var(--primary-500) 20%, transparent));border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.modal-tips.warning{background:var(--warning-bg);border-color:var(--warning-main)}.modal-tips.error{background:var(--error-bg);border-color:var(--error-main)}.modal-tips p{margin:0;font-size:.8rem;color:var(--text-secondary);line-height:1.6}.modal-tips p+p{margin-top:.35rem}.confirm-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.modal-btn{padding:.6rem 1.25rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.modal-btn-cancel{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary)}.modal-btn-cancel:hover{background:var(--bg-hover)}.modal-btn-confirm{background:linear-gradient(135deg,var(--primary-500),var(--primary-400));border:1px solid var(--primary-400);color:#fff}.modal-btn-confirm:hover{box-shadow:0 4px 12px color-mix(in srgb,var(--primary-500) 30%,transparent)}.modal-btn-confirm:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.video-creation-panel{max-width:960px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.panel-header{display:flex;align-items:center;gap:.75rem}.panel-header.inline-header{justify-content:space-between;padding:.25rem 0;border-bottom:1px solid var(--border-color);margin-bottom:.25rem}.panel-header .header-left{display:flex;align-items:center;gap:.5rem}.panel-header .header-right{display:flex;align-items:center;gap:.75rem}.panel-header.inline-header h2{display:flex;align-items:center;gap:.4rem;margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.selection-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;background:var(--primary-100);color:var(--primary-700);border-radius:var(--radius-full);font-size:.7rem;font-weight:500}.cost-hint{font-size:.75rem;color:var(--warning-600);background:var(--warning-50);padding:.2rem .5rem;border-radius:var(--radius-sm)}.panel-header h2{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.selection-mode-tabs{display:flex;gap:.5rem;padding:.25rem;background:var(--bg-tertiary);border-radius:10px}.selection-mode-tabs button{flex:1;padding:.75rem 1rem;background:transparent;border:none;border-radius:8px;color:var(--text-muted);font-size:.9rem;cursor:pointer;transition:all .2s ease}.selection-mode-tabs button.active{background:var(--ai-bg);color:var(--text-primary)}.selection-mode-tabs button:hover:not(.active){background:var(--bg-hover)}.selection-area{max-height:400px;overflow-y:auto;padding:.5rem;background:var(--bg-tertiary);border-radius:12px}.scene-grid,.node-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.video-card{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;overflow:hidden;cursor:pointer;transition:all .2s ease}.video-card:hover{border-color:var(--primary-400);transform:translateY(-2px)}.video-card.selected{border-color:var(--primary-500);background:var(--ai-bg)}.video-card.has-video{border-color:var(--success-main)}.card-thumbnail{position:relative;width:100%;aspect-ratio:16/9;background:var(--bg-quaternary);overflow:hidden}.card-thumbnail img{width:100%;height:100%;object-fit:cover}.card-thumbnail .no-image{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.video-badge{position:absolute;bottom:6px;right:6px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--success-main);border-radius:50%;color:#fff}.card-info{padding:.6rem}.card-info h4{margin:0;font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-info .node-count{font-size:.7rem;color:var(--text-muted)}.card-info .node-type{display:inline-block;padding:.15rem .4rem;background:var(--bg-quaternary);border-radius:4px;font-size:.65rem;color:var(--text-muted);margin-bottom:.25rem}.card-info .node-text{margin:0;font-size:.75rem;color:var(--text-secondary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.card-select{position:absolute;top:6px;right:6px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--primary-500);border-radius:50%;color:#fff;opacity:0;transform:scale(.8);transition:all .2s ease}.video-card.selected .card-select{opacity:1;transform:scale(1)}.node-groups{display:flex;flex-direction:column;gap:1.25rem}.scene-group{background:var(--bg-secondary);border-radius:10px;padding:.75rem}.scene-group-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.scene-thumb{width:32px;height:32px;border-radius:6px;object-fit:cover}.scene-name{flex:1;font-size:.85rem;font-weight:500;color:var(--text-primary)}.select-all-btn{padding:.3rem .6rem;background:var(--bg-quaternary);border:none;border-radius:6px;font-size:.7rem;color:var(--text-secondary);cursor:pointer}.select-all-btn:hover{background:var(--bg-hover)}.fusion-config{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem}.fusion-config h3{margin:0 0 1rem;font-size:.95rem;font-weight:600;color:var(--text-primary)}.fusion-options{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.fusion-options label{display:flex;padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease}.fusion-options label:hover{border-color:var(--primary-400)}.fusion-options label.selected{border-color:var(--primary-500);background:var(--ai-bg)}.fusion-options input[type=radio]{display:none}.fusion-options .option-content{flex:1}.fusion-options .option-content strong{display:block;font-size:.9rem;color:var(--text-primary);margin-bottom:.25rem}.fusion-options .option-content p{margin:0 0 .5rem;font-size:.75rem;color:var(--text-muted)}.fusion-options .option-content .cost{display:inline-block;padding:.2rem .5rem;background:var(--warning-bg);border-radius:4px;font-size:.7rem;color:var(--warning-main)}.prompt-config-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem}.prompt-config-section h3{margin:0 0 1rem;font-size:.95rem;font-weight:600;color:var(--text-primary)}.prompt-config-panel{display:flex;flex-direction:column;gap:1rem}.config-group label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem}.config-options{display:flex;flex-wrap:wrap;gap:.5rem}.config-option{padding:.4rem .8rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.config-option:hover{background:var(--bg-hover)}.config-option.active{background:var(--ai-bg);border-color:var(--primary-400);color:var(--text-primary)}.generation-controls{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px}.selection-summary{font-size:.9rem;color:var(--text-secondary)}.selection-summary strong{color:var(--text-primary);font-weight:600}.estimated-cost{display:inline-block;margin-left:1rem;padding:.25rem .6rem;background:var(--warning-bg);border-radius:6px;font-size:.8rem;color:var(--warning-main)}.video-task-queue{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1rem}.video-task-queue h4{margin:0 0 .75rem;font-size:.9rem;font-weight:500;color:var(--text-primary)}.task-list{display:flex;flex-direction:column;gap:.5rem}.task-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--bg-tertiary);border-radius:8px}.task-thumbnail{width:48px;height:27px;border-radius:4px;overflow:hidden;background:var(--bg-quaternary)}.task-thumbnail img{width:100%;height:100%;object-fit:cover}.task-info{flex:1;display:flex;flex-direction:column;gap:.15rem}.task-name{font-size:.8rem;color:var(--text-primary)}.task-status{display:flex;align-items:center;gap:.35rem;font-size:.7rem;color:var(--text-muted)}.task-item.status-completed .task-status{color:var(--success-main)}.task-item.status-failed .task-status{color:var(--error-main)}.task-progress{width:80px}.task-progress .progress-bar{height:4px;background:var(--bg-quaternary);border-radius:2px;overflow:hidden}.task-progress .progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));border-radius:2px;transition:width .3s ease}@media(max-width:768px){.fusion-options{grid-template-columns:1fr}.generation-controls{flex-direction:column;gap:1rem;text-align:center}.estimated-cost{display:block;margin:.5rem 0 0}}.publish-panel{padding:var(--space-4);max-width:680px;margin:0 auto}.panel-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.panel-header>svg{width:20px;height:20px;color:var(--primary-500);flex-shrink:0}.panel-header-content{display:flex;flex-direction:column;gap:2px}.panel-header h2{font-size:1.15rem;font-weight:700;color:var(--text-primary);letter-spacing:.01em;margin:0}.panel-header p{font-size:.8rem;color:var(--text-muted);margin:0}.panel-header .novel-title-badge{font-weight:500;color:var(--text-secondary)}.panel-header .novel-title-badge:before{content:"《"}.panel-header .novel-title-badge:after{content:"》"}.panel-header .novel-title-empty{color:var(--text-muted);font-style:italic}.config-section{margin-bottom:var(--space-3);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md)}.config-section h3{display:flex;align-items:center;gap:var(--space-2);font-size:.9rem;font-weight:600;margin-bottom:var(--space-2);color:var(--text-secondary)}.config-section h3 svg{color:var(--primary-500);width:16px;height:16px}.section-desc{font-size:.75rem;color:var(--text-muted);margin-bottom:var(--space-3)}.pricing-options{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.pricing-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem}.pricing-option:hover{background:var(--bg-hover);border-color:var(--primary-300)}.pricing-option.active{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700)}.option-icon{font-size:1rem}.option-label{font-weight:500}.option-price{font-size:.75rem;color:var(--text-muted);background:var(--bg-tertiary);padding:1px 6px;border-radius:var(--radius-sm)}.custom-price-input{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.custom-price-input input{width:100px;padding:var(--space-2);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg-primary);color:var(--text-primary)}.custom-price-input span{color:var(--text-muted);font-size:.85rem}.ai-cost-hint{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--primary-50);border-radius:var(--radius-md);font-size:.8rem;color:var(--primary-700)}.ai-cost-hint small{color:var(--text-muted)}.access-options{display:flex;flex-direction:column;gap:var(--space-2)}.access-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.access-option:hover{background:var(--bg-hover)}.access-option.active{background:var(--primary-50);border-color:var(--primary-500)}.access-option svg{flex-shrink:0;color:var(--text-muted)}.access-option.active svg{color:var(--primary-600)}.access-option .option-label{font-weight:500;color:var(--text-primary)}.access-option .option-desc{font-size:.75rem;color:var(--text-muted);margin-left:auto}.advanced-options{margin:var(--space-4) 0;padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md)}.advanced-options summary{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-weight:500;font-size:.9rem;color:var(--text-secondary);list-style:none}.advanced-options summary::-webkit-details-marker{display:none}.advanced-options[open] summary svg{transform:rotate(180deg)}.option-group{margin-top:var(--space-3)}.option-group label{display:flex;align-items:center;gap:var(--space-1);font-size:.8rem;color:var(--text-muted);margin-bottom:var(--space-1)}.option-group select,.option-group input,.option-group textarea{width:100%;padding:var(--space-2);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);font-size:.85rem;color:var(--text-primary)}.option-group textarea{resize:vertical;min-height:60px}.toggle-option{margin-bottom:var(--space-3)}.toggle-label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-600)}.toggle-text{font-size:.9rem;color:var(--text-primary)}.reshare-options{margin-top:var(--space-3);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md)}.reshare-permission-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}.permission-option{display:flex;flex-direction:column;padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.permission-option:hover{background:var(--bg-hover)}.permission-option.active{background:var(--primary-50);border-color:var(--primary-500)}.perm-label{font-weight:500;font-size:.85rem;color:var(--text-primary)}.perm-desc{font-size:.75rem;color:var(--text-muted)}.reshare-warning{font-size:.8rem;color:var(--warning-600);padding:var(--space-2);background:var(--warning-50);border-radius:var(--radius-sm)}.plaza-options{margin-top:var(--space-3);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md)}.publish-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.publish-success{text-align:center}.success-header{margin-bottom:var(--space-5)}.success-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--success-100);border-radius:50%;margin-bottom:var(--space-3)}.success-icon svg{color:var(--success-600)}.success-header h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:var(--space-1)}.success-header p{color:var(--text-muted)}.share-link-section{margin-bottom:var(--space-4);text-align:left}.share-link-section label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:var(--space-2)}.link-input-group{display:flex;gap:var(--space-2)}.link-input-group input{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-tertiary);font-size:.85rem;color:var(--text-primary)}.btn-copy{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--primary-600);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;transition:background var(--transition-fast)}.btn-copy:hover{background:var(--primary-700)}.share-info{display:flex;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-5);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md)}.info-item{display:flex;align-items:center;gap:var(--space-1);font-size:.85rem;color:var(--text-secondary)}.info-item svg{color:var(--text-muted)}.share-actions{display:flex;justify-content:center;gap:var(--space-3)}.confirm-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-5);max-width:420px;width:90%;box-shadow:0 20px 60px #0000004d}.confirm-modal h3{font-size:1.1rem;margin-bottom:var(--space-4);text-align:center;color:var(--text-primary)}.novel-summary-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-4)}.summary-header{display:flex;align-items:flex-start;gap:var(--space-3)}.novel-icon{font-size:1.5rem}.summary-title h4{font-size:1rem;font-weight:600;color:var(--text-primary)}.summary-title p{font-size:.8rem;color:var(--text-muted)}.summary-stats{display:flex;gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border-color)}.summary-stats .stat{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.confirm-info-grid{margin-bottom:var(--space-4)}.info-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--border-color);font-size:.85rem}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-muted)}.info-value{font-weight:500;color:var(--text-primary)}.info-value.highlight{color:var(--primary-600)}.confirm-actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.creation-hub{display:flex;flex-direction:column;height:100%;background:var(--bg-primary, #fff)}.creation-header{display:flex;align-items:center;justify-content:center;padding:0 16px;height:52px;background:var(--bg-secondary, #f8f9fa);border-bottom:1px solid var(--border-color, #eee);flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary, #666);cursor:pointer;transition:all .2s ease}.back-btn:hover{background:var(--bg-hover, rgba(0, 0, 0, .05));color:var(--text-primary, #333)}.novel-title{font-size:14px;font-weight:600;color:var(--text-primary, #333);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-right{width:44px}.creation-nav{display:flex;align-items:center;gap:4px;padding:4px;background:var(--bg-tertiary, rgba(0, 0, 0, .03));border-radius:10px}.nav-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:none;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary, #666);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.nav-tab:hover:not(.active){background:var(--bg-hover, rgba(0, 0, 0, .05));color:var(--text-primary, #333)}.nav-tab.active{background:var(--bg-card, #fff);color:var(--primary-600, #5a67d8);box-shadow:0 1px 3px #00000014}.nav-tab svg{flex-shrink:0;opacity:.7;transition:opacity .2s ease}.nav-tab.active svg,.nav-tab:hover svg{opacity:1}.creation-main{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px;background:var(--bg-primary, #fff)}[data-theme=dark] .creation-hub{background:var(--bg-primary, #1a1a2e)}[data-theme=dark] .creation-header{background:#ffffff05;border-bottom-color:#ffffff14}[data-theme=dark] .back-btn{color:#fff9}[data-theme=dark] .back-btn:hover{background:#ffffff14;color:#fff}[data-theme=dark] .novel-title{color:#fff}[data-theme=dark] .creation-nav{background:#ffffff08}[data-theme=dark] .nav-tab{color:#fff9}[data-theme=dark] .nav-tab:hover:not(.active){background:#ffffff14;color:#ffffffe6}[data-theme=dark] .nav-tab.active{background:#ffffff1a;color:#a5b4fc;box-shadow:0 1px 4px #0000004d}[data-theme=dark] .creation-main{background:var(--bg-primary, #1a1a2e)}@media(max-width:1024px){.nav-tab span{display:none}.nav-tab{padding:8px 10px}.nav-tab.active span{display:inline}}@media(max-width:768px){.creation-header{padding:0 12px;height:48px}.creation-nav{position:fixed;bottom:0;left:0;right:0;justify-content:space-around;padding:8px 12px;background:var(--bg-card, #fff);border-top:1px solid var(--border-color, #eee);border-radius:0;z-index:100}.nav-tab{flex-direction:column;gap:2px;padding:6px 10px;font-size:10px}.nav-tab span{display:inline}.creation-main{padding:16px 16px 80px}[data-theme=dark] .creation-nav{background:#1e1e28fa;border-top-color:#ffffff14}}.character-reveal-card{position:fixed;z-index:1000;width:360px;max-width:95vw;max-height:85vh;overflow-y:auto;background:var(--bg-glass, rgba(255, 255, 255, .95));backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-radius:20px;box-shadow:0 8px 32px #0000001f,0 2px 8px #0000000f,inset 0 1px #ffffff80;border:1px solid rgba(255,255,255,.3);padding:0;animation:cardSlideIn .3s ease-out}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}[data-theme=dark] .character-reveal-card{background:#1e202cf2;border-color:#ffffff1a;box-shadow:0 8px 32px #0006,0 2px 8px #0003,inset 0 1px #ffffff0d}.card-close{position:absolute;top:12px;right:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#0000000d;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;z-index:10;color:var(--text-secondary, #666)}.card-close:hover{background:#0000001a;transform:scale(1.1)}.card-header{display:flex;gap:16px;padding:20px 20px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:grab;-webkit-user-select:none;user-select:none;transition:background .2s ease}.card-header:hover{background:#00000005}.card-header.dragging{cursor:grabbing;background:#6366f10d}[data-theme=dark] .card-header{border-bottom-color:#ffffff0f}[data-theme=dark] .card-header:hover{background:#ffffff05}.character-reveal-card.dragging{box-shadow:0 16px 48px #0003,0 4px 16px #0000001a;transition:none}.character-portrait{position:relative;width:80px;height:80px;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,var(--accent-light, #e0e7ff),var(--accent-lighter, #f0f4ff));flex-shrink:0}.character-portrait img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:filter .5s ease}.portrait-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary, #999)}.portrait-veil{position:absolute;inset:0;background:linear-gradient(135deg,#fff9,#c8c8dc66);pointer-events:none}.character-name{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:var(--text-main, #1a1a2e);line-height:1.3}.personality-tags{display:flex;flex-wrap:wrap;gap:6px}.trait-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;border-radius:12px;transition:all .3s ease}.trait-tag.revealed{background:linear-gradient(135deg,var(--accent-primary, #6366f1),var(--accent-secondary, #8b5cf6));color:#fff;box-shadow:0 2px 8px #6366f14d}.trait-tag.hidden{background:#0000000f;color:var(--text-tertiary, #999);font-style:italic}[data-theme=dark] .trait-tag.hidden{background:#ffffff14}.appearance-section{padding:12px 20px;background:#00000005}[data-theme=dark] .appearance-section{background:#ffffff05}.appearance-text{margin:0;font-size:.875rem;line-height:1.6;color:var(--text-secondary, #555);font-style:italic}.interaction-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:16px 20px}.trigger-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#00000008;border:1px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.trigger-btn:hover:not(:disabled):not(.locked){background:#6366f114;border-color:#6366f133;transform:translateY(-2px);box-shadow:0 4px 12px #6366f126}.trigger-btn.selected{background:linear-gradient(135deg,#6366f11f,#8b5cf614);border-color:var(--accent-primary, #6366f1)}.trigger-btn.locked{opacity:.5;cursor:not-allowed}.trigger-btn:disabled{opacity:.6;cursor:wait}.trigger-icon{font-size:1.5rem;line-height:1}.trigger-name{font-size:.75rem;font-weight:500;color:var(--text-main, #1a1a2e)}.trigger-cost{font-size:.65rem;color:var(--text-tertiary, #999);display:flex;align-items:center;gap:2px}.dialogue-section{padding:16px 20px;background:linear-gradient(180deg,#6366f10a,#8b5cf605);border-top:1px solid rgba(99,102,241,.08)}.history-dots{display:flex;justify-content:center;gap:8px;margin-bottom:12px}.history-dots .dot{width:8px;height:8px;border-radius:50%;background:#6366f133;cursor:pointer;transition:all .2s ease}.history-dots .dot:hover{background:#6366f166}.history-dots .dot.active{background:var(--accent-primary, #6366f1);transform:scale(1.3);box-shadow:0 0 8px #6366f166}.dialogue-content{margin-bottom:12px}.character-feedback{margin:0 0 8px;font-size:.8rem;color:var(--text-tertiary, #888);font-style:italic}.dialogue-text{margin:0;font-size:.95rem;line-height:1.7;color:var(--text-main, #1a1a2e);padding:12px 16px;background:#fff9;border-radius:12px;border-left:3px solid var(--accent-primary, #6366f1)}[data-theme=dark] .dialogue-text{background:#ffffff0d}.dialogue-controls{display:flex;gap:8px}.control-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;font-size:.85rem;font-weight:500;background:#0000000d;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;color:var(--text-main, #1a1a2e)}.control-btn:hover:not(:disabled){background:#00000014}.control-btn:disabled{opacity:.6;cursor:wait}.control-btn.playing{background:var(--accent-primary, #6366f1);color:#fff}.control-btn.re-interact{background:linear-gradient(135deg,var(--accent-primary, #6366f1),var(--accent-secondary, #8b5cf6));color:#fff}.control-btn.re-interact:hover:not(:disabled){box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.progress-section{padding:12px 20px 16px;border-top:1px solid rgba(0,0,0,.04)}[data-theme=dark] .progress-section{border-top-color:#ffffff0a}.progress-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;color:var(--text-tertiary, #888);font-size:.8rem}.progress-toggle:hover{background:#00000008;color:var(--text-secondary, #666)}.toggle-hint{font-style:italic}.progress-detail{margin-top:12px;padding:12px;background:#00000005;border-radius:10px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.progress-bar{height:4px;background:#00000014;border-radius:2px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary, #6366f1),var(--accent-secondary, #8b5cf6));border-radius:2px;transition:width .5s ease}.progress-hint{margin:0;font-size:.75rem;color:var(--text-tertiary, #888);text-align:center}@media(max-width:480px){.character-reveal-card{width:100%;max-width:100%;border-radius:20px 20px 0 0;max-height:80vh}.interaction-grid{grid-template-columns:repeat(3,1fr);gap:6px}.trigger-btn{padding:10px 6px}.trigger-icon{font-size:1.25rem}}.character-reveal-card::-webkit-scrollbar{width:4px}.character-reveal-card::-webkit-scrollbar-track{background:transparent}.character-reveal-card::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:2px}.character-reveal-card::-webkit-scrollbar-thumb:hover{background:#6366f180}.text-selection-menu{position:fixed;z-index:10000;display:flex;align-items:center;gap:2px;padding:4px;background:var(--bg-elevated, #1a1a2e);border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 8px 24px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform:translate(-50%) translateY(-100%);animation:menu-fade-in .15s ease}@keyframes menu-fade-in{0%{opacity:0;transform:translate(-50%) translateY(-90%)}to{opacity:1;transform:translate(-50%) translateY(-100%)}}.text-selection-menu:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--bg-elevated, #1a1a2e)}.text-selection-menu .menu-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:#fffc;font-size:11px;cursor:pointer;transition:all .15s;white-space:nowrap}.text-selection-menu .menu-item:hover{background:#ffffff1a;color:#fff}.text-selection-menu .menu-item:active{transform:scale(.95)}.text-selection-menu .menu-item svg{opacity:.9}.text-selection-menu .menu-close{position:absolute;top:-8px;right:-8px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary, #2a2a3e);border:1px solid rgba(255,255,255,.1);border-radius:50%;color:#fff9;cursor:pointer;transition:all .15s}.text-selection-menu .menu-close:hover{background:#ff64644d;color:#fff}@media(max-width:640px){.text-selection-menu{position:fixed;left:50%!important;bottom:20px!important;top:auto!important;transform:translate(-50%)}.text-selection-menu:after{display:none}.text-selection-menu .menu-item{padding:10px 14px;font-size:12px}}.scene-illustration-card{position:fixed;bottom:0;left:0;right:0;height:220px;z-index:90;background:#0a0a14eb;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.08);border-bottom:none;border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:0 -10px 40px -10px #00000080,inset 0 1px #ffffff0d;transform:translateY(100%);opacity:0;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s ease;display:flex;flex-direction:row;overflow:hidden;cursor:pointer;-webkit-user-select:none;user-select:none;padding-bottom:env(safe-area-inset-bottom)}.scene-illustration-card.visible{transform:translateY(0);opacity:1}.scene-illustration-card.dragging{cursor:grabbing;transition:none}.scene-illustration-card.ai-generated{border-color:#8b5cf64d;animation:ai-pulse 3s ease-in-out infinite}@keyframes ai-pulse{0%,to{box-shadow:0 -10px 40px -10px #00000080,0 0 #8b5cf633,inset 0 1px #ffffff0d}50%{box-shadow:0 -10px 40px -10px #00000080,0 0 25px 5px #8b5cf626,inset 0 1px #ffffff0d}}.drag-handle{display:none}.card-media{position:relative;width:160px;min-width:160px;height:100%;overflow:hidden;border-radius:var(--radius-lg) 0 0 0}.card-image,.card-video{width:100%;height:100%;object-fit:cover}.card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf633,#3b82f633);font-size:2rem}.video-indicator{position:absolute;bottom:var(--space-2);right:var(--space-2);width:24px;height:24px;background:#0009;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.video-indicator.playing{background:var(--primary-500)}.card-info{flex:1;padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;justify-content:center;overflow:hidden}.scene-name{margin:0 0 var(--space-1);font-size:.9375rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#e0e7ff,#c4b5fd,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-description{margin:0;font-size:.8125rem;color:#fff9;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-actions{position:absolute;top:var(--space-2);right:var(--space-2);display:flex;gap:var(--space-1);opacity:1;transition:opacity .2s}.action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#00000080;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fffc;cursor:pointer;transition:all .2s}.action-btn:hover{background:#ffffff26;color:#fff}.action-btn:active{transform:scale(.95)}.action-btn.close-btn:hover{background:#ef44444d;border-color:#ef444480}.ai-badge{position:absolute;top:var(--space-2);left:var(--space-2);padding:2px 6px;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-sm);font-size:.625rem;font-weight:700;color:#fff;letter-spacing:.05em}@media(min-width:768px){.scene-illustration-card{width:280px;height:auto;min-height:200px;bottom:auto;left:auto;right:auto;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.08);flex-direction:column;cursor:grab;position:fixed;transform:translateY(30px) scale(.95)}.scene-illustration-card.visible{transform:translateY(0) scale(1)}.scene-illustration-card.dragging{cursor:grabbing;box-shadow:0 25px 50px -12px #0009,inset 0 1px #ffffff0d}.drag-handle{display:flex;align-items:center;justify-content:center;height:20px;color:#ffffff4d;cursor:grab}.card-media{width:100%;height:140px;min-width:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.card-info{padding:var(--space-3)}.card-actions{opacity:0}.card-actions.visible{opacity:1}}@media(min-width:1024px){.scene-illustration-card{width:320px}.card-media{height:160px}.scene-name{font-size:1rem}.scene-description{font-size:.875rem;-webkit-line-clamp:3;line-clamp:3}}.scene-illustration-card.exiting{transform:translateY(100%)!important;opacity:0!important}@media(min-width:768px){.scene-illustration-card.exiting{transform:translate(50px) scale(.9)!important}}.contextual-annotation{position:fixed;z-index:9999;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-4);min-width:280px;max-width:360px;transform:translate(-50%);animation:annotation-enter .2s ease}@keyframes annotation-enter{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.annotation-close{position:absolute;top:var(--space-2);right:var(--space-2);width:20px;height:20px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.annotation-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.annotation-selected-text{font-size:.875rem;color:var(--text-secondary);font-style:italic;padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-bottom:var(--space-3);line-height:1.5;max-height:80px;overflow:hidden}.annotation-types{display:flex;gap:var(--space-2);margin-bottom:var(--space-3)}.annotation-types .type-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-2);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:all .2s}.annotation-types .type-btn:hover{background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border-default)}.annotation-types .type-btn.active{background:rgba(var(--primary-rgb),.1);color:var(--primary-500);border-color:var(--primary-300)}.annotation-types .type-btn:disabled{opacity:.5;cursor:not-allowed}.annotation-result{min-height:80px;max-height:200px;overflow-y:auto}.annotation-result .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4);color:var(--text-muted);gap:var(--space-2)}.annotation-result .loading-state svg{animation:spin 1s linear infinite;color:var(--primary-500)}.annotation-result .result-content{font-size:.875rem;line-height:1.7;color:var(--text-secondary);padding:var(--space-2)}.annotation-result .empty-state{display:flex;align-items:center;justify-content:center;padding:var(--space-4);color:var(--text-muted);font-size:.8rem}.story-whisper{position:absolute;left:50%;top:0;transform:translate(-50%) translateY(calc(-100% - 8px));display:inline-flex;align-items:stretch;background:#fdfcfa;border-radius:8px;box-shadow:0 0 0 1px #c8b4a01f,0 1px 3px #8c78640f,0 4px 12px #64503c0a;opacity:0;pointer-events:none;z-index:200;overflow:hidden;transition:all .25s ease-out}.story-whisper.entering{opacity:0;transform:translate(-50%) translateY(calc(-100% - 4px))}.story-whisper.visible{opacity:1;transform:translate(-50%) translateY(calc(-100% - 8px))}.story-whisper.exiting{opacity:0;transform:translate(-50%) translateY(calc(-100% - 12px))}.whisper-badge{display:flex;align-items:center;justify-content:center;width:36px;background:linear-gradient(180deg,#c8b8a8,#a89888);border-right:1px solid rgba(255,255,255,.3)}.whisper-symbol{font-size:.9rem;color:#fff;opacity:.95}.whisper-label,.whisper-divider{display:none}.whisper-main{display:flex;align-items:center;gap:8px;padding:8px 12px}.whisper-row{display:flex;align-items:center;gap:6px}.whisper-avatar{width:18px;height:18px;border-radius:50%;object-fit:cover;border:1px solid rgba(180,160,140,.2)}.whisper-speaker{font-size:.72rem;font-weight:600;color:#6b5b4b;letter-spacing:.02em}.whisper-dot{font-size:3px;color:#c8b8a8;margin:0 2px}.whisper-mood{font-size:.72rem;font-weight:500;color:#8b7b6b}.whisper-intensity{font-size:.6rem;color:#a89888;margin-left:2px}.whisper-hint{display:none}.whisper-stats{display:flex;align-items:center;padding:8px 10px;background:#c8b4a00f;border-left:1px solid rgba(200,180,160,.1)}.stat-chars{font-size:.65rem;font-weight:500;color:#9b8b7b;font-variant-numeric:tabular-nums}.stat-keywords{display:none}@media(max-width:640px){.story-whisper{max-width:calc(100vw - 24px)}.whisper-badge{width:32px}.whisper-main{padding:6px 10px}.whisper-speaker,.whisper-mood{font-size:.68rem}.whisper-stats{padding:6px 8px}}@media(prefers-color-scheme:dark){.story-whisper{background:#2a2520;box-shadow:0 0 0 1px #645a5033,0 1px 3px #00000026,0 4px 12px #0000001a}.whisper-badge{background:linear-gradient(180deg,#6b5b4b,#5b4b3b)}.whisper-speaker{color:#e8ddd0}.whisper-mood{color:#c8b8a8}.whisper-stats{background:#ffffff08;border-left-color:#ffffff0d}.stat-chars{color:#a89888}}[data-theme=dark] .story-whisper{background:#2a2520;box-shadow:0 0 0 1px #645a5033,0 1px 3px #00000026,0 4px 12px #0000001a}[data-theme=dark] .whisper-badge{background:linear-gradient(180deg,#6b5b4b,#5b4b3b)}[data-theme=dark] .whisper-speaker{color:#e8ddd0}[data-theme=dark] .whisper-mood{color:#c8b8a8}[data-theme=dark] .whisper-stats{background:#ffffff08;border-left-color:#ffffff0d}[data-theme=dark] .stat-chars{color:#a89888}.mobile-selection-menu{position:fixed;display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2);background:rgba(var(--bg-secondary-rgb, 30, 30, 40),.98);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(var(--border-subtle-rgb, 255, 255, 255),.12);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000059;transform:translate(-50%) scale(.9);opacity:0;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:200}.mobile-selection-menu.visible{opacity:1;transform:translate(-50%) scale(1)}.menu-action-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.menu-action-btn:hover,.menu-action-btn:active{background:rgba(var(--primary-rgb, 59, 130, 246),.15)}.action-icon{font-size:1.25rem;line-height:1}.action-label{font-size:.65rem;color:var(--text-muted);font-weight:500}.menu-close-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:rgba(var(--text-muted-rgb, 150, 150, 150),.15);border:none;border-radius:50%;color:var(--text-muted);font-size:.75rem;cursor:pointer;margin-left:var(--space-1);transition:all .15s}.menu-close-btn:hover,.menu-close-btn:active{background:#ef444433;color:#ef4444}.text-sync-toggle-btn{position:fixed;right:0;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#1e1e2dd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-right:none;border-radius:8px 0 0 8px;color:#fffc;cursor:pointer;z-index:150;transition:all .3s ease}.text-sync-toggle-btn:hover{background:#28283cf2;padding-right:12px;color:#fff}.text-sync-toggle-btn .toggle-label{font-size:.625rem;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:2px}.original-text-sync-panel{position:fixed;right:0;top:0;bottom:0;width:380px;max-width:50vw;display:flex;flex-direction:column;background:linear-gradient(135deg,#0f0f19f7,#191928fa);border-left:1px solid rgba(255,255,255,.12);z-index:160;animation:panel-slide-in .3s cubic-bezier(.22,1,.36,1)}@keyframes panel-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.sync-panel-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.sync-panel-header .header-title{display:flex;align-items:center;gap:var(--space-2);color:#fff;font-size:.9rem;font-weight:500}.view-mode-toggle{display:flex;background:#ffffff14;border-radius:var(--radius-md);padding:2px}.view-mode-toggle .mode-btn{padding:4px 12px;font-size:.75rem;color:#fff9;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.view-mode-toggle .mode-btn:hover{color:#fffc}.view-mode-toggle .mode-btn.active{background:rgba(var(--primary-rgb),.3);color:#fff}.sync-panel-header .close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;border-radius:50%;color:#fff9;cursor:pointer;transition:all .2s ease}.sync-panel-header .close-btn:hover{background:#ffffff26;color:#fff}.sync-progress-bar{height:3px;background:#ffffff1a;overflow:hidden}.sync-progress-bar .progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));transition:width .3s ease}.sync-panel-content{flex:1;overflow-y:auto;padding:var(--space-4);font-size:.9rem;line-height:1.8;color:#ffffffd9;scroll-behavior:smooth}.sync-panel-content::-webkit-scrollbar{width:6px}.sync-panel-content::-webkit-scrollbar-track{background:#ffffff0d}.sync-panel-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.original-text-view{padding:var(--space-2)}.original-paragraph{margin-bottom:var(--space-4);line-height:1.9;text-indent:2em;color:#ffffffbf;transition:all .3s ease}.original-paragraph.current-highlight{background:linear-gradient(135deg,rgba(var(--primary-rgb),.2),rgba(var(--primary-rgb),.1));color:#fff;padding:var(--space-4);margin:var(--space-4) calc(-1 * var(--space-4));border-radius:var(--radius-md);border-left:4px solid var(--primary-500);box-shadow:0 0 30px rgba(var(--primary-rgb),.2);text-indent:2em}.original-paragraph.has-mapping{position:relative;cursor:pointer}.original-paragraph.has-mapping:hover,.original-paragraph.hovered{background:#ffffff0f;border-radius:var(--radius-sm)}.mapping-indicator{position:absolute;left:-8px;top:2px;display:inline-flex;align-items:center;gap:2px;padding:2px 6px;font-size:.65rem;font-weight:600;background:rgba(var(--primary-rgb),.3);color:var(--primary-300);border-radius:var(--radius-sm);opacity:0;transition:opacity .2s ease}.original-paragraph.has-mapping:hover .mapping-indicator,.original-paragraph.hovered .mapping-indicator{opacity:1}.node-link-indicator{margin-left:auto;padding:4px 8px;color:rgba(var(--primary-rgb),.6);opacity:0;transition:opacity .2s ease}.node-item:hover .node-link-indicator{opacity:1;color:var(--primary-400)}.empty-hint .hint-sub{font-size:.8rem;margin-top:var(--space-2);color:#ffffff4d}.node-item{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);margin-bottom:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;border-left:3px solid transparent}.node-item:hover{background:#ffffff14}.node-item .node-number{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;background:#ffffff1a;border-radius:50%;color:#ffffff80}.node-item .node-speaker{flex-shrink:0;padding:2px 8px;font-size:.75rem;font-weight:500;background:rgba(var(--primary-rgb),.2);color:var(--primary-300);border-radius:4px}.node-item .node-text{flex:1;min-width:0;line-height:1.7}.node-item.played{opacity:.6}.node-item.played .node-number{background:#ffffff14}.node-item.current{background:linear-gradient(135deg,rgba(var(--primary-rgb),.2),rgba(var(--primary-rgb),.1));border-left-color:var(--primary-500);box-shadow:0 0 20px rgba(var(--primary-rgb),.15)}.node-item.current .node-number{background:var(--primary-500);color:#fff}.node-item.current .node-text{color:#fff}.node-item.future{opacity:.5}.node-item.future:hover{opacity:.7}.node-item.dialogue .node-text{font-weight:500}.node-item.narration{font-style:normal}.empty-hint{text-align:center;color:#fff6;padding:var(--space-8)}.content-spacer{height:100px}.sync-panel-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#0000004d;border-top:1px solid rgba(255,255,255,.1)}.sync-panel-footer .nav-btn{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-md);color:#ffffffb3;font-size:.75rem;cursor:pointer;transition:all .2s ease}.sync-panel-footer .nav-btn:hover:not(:disabled){background:#ffffff26;color:#fff}.sync-panel-footer .nav-btn:disabled{opacity:.4;cursor:not-allowed}.sync-panel-footer .scroll-to-current{background:rgba(var(--primary-rgb),.2);border-color:rgba(var(--primary-rgb),.3);color:var(--primary-300)}.sync-panel-footer .scroll-to-current:hover{background:rgba(var(--primary-rgb),.3)}@media(max-width:768px){.original-text-sync-panel{width:100%;max-width:100%}.text-sync-toggle-btn{top:auto;bottom:100px;transform:none}}@media(prefers-color-scheme:dark){.original-text-sync-panel{background:linear-gradient(135deg,#0a0a12fa,#141423fa)}}.immersive-reader{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg-primary);z-index:1100}.immersive-reader.empty{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-4);color:var(--text-muted)}.empty-state-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8);max-width:400px}.empty-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.8}.empty-state-content h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-3)}.empty-state-content>p{color:var(--text-secondary);margin:0 0 var(--space-4);line-height:1.6}.empty-hints{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-5);text-align:left;width:100%}.empty-hints p{font-size:.875rem;color:var(--text-muted);margin:0;padding:var(--space-1) 0}.reader-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.reader-progress{flex:1;display:flex;align-items:center;gap:var(--space-3)}.progress-bar{flex:1;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));transition:width .3s ease}.progress-text{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.reader-content{flex:1;overflow-y:auto;padding:var(--space-8) var(--space-6);display:flex;justify-content:center;scroll-behavior:smooth}.reader-article-container{max-width:720px;width:100%}.reader-node{position:relative;margin-bottom:var(--space-6);padding:var(--space-4);padding-left:var(--space-6);border-radius:var(--radius-md);transition:background .2s}.reader-node:hover{background:var(--bg-secondary)}.reader-node.expanded{background:rgba(var(--primary-rgb),.05);border-left:2px solid var(--primary-500)}.node-marker{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:var(--primary-400);opacity:.3;transition:all .2s}.reader-node:hover .node-marker{opacity:1;width:6px;height:6px;box-shadow:0 0 8px var(--primary-400)}.node-action-bar{display:flex;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-default);animation:action-bar-slide-in .2s ease}@keyframes action-bar-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.action-btn{padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s}.action-btn:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.chapter-divider{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6) 0;margin:var(--space-4) 0}.divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-default),transparent)}.divider-text{color:var(--text-secondary);font-size:.875rem;white-space:nowrap}.speaker-tag{display:inline-block;font-weight:600;color:var(--primary-500);margin-bottom:var(--space-2);font-size:.875rem;padding:var(--space-1) var(--space-2);background:rgba(var(--primary-rgb),.1);border-radius:var(--radius-sm)}.audio-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);margin-top:var(--space-2);background:transparent;border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .2s}.audio-btn:hover{background:var(--bg-secondary);color:var(--primary-500)}.audio-btn.playing{color:var(--primary-500);border-color:var(--primary-500)}.audio-btn.playing svg{animation:pulse 1s infinite}.reader-article{max-width:680px;width:100%}.scene-transition-indicator{text-align:center;padding:var(--space-4) var(--space-6);margin-bottom:var(--space-6);background:linear-gradient(90deg,transparent,var(--bg-secondary),transparent);color:var(--text-muted);font-size:.875rem;border-radius:var(--radius-md)}.speaker-indicator{font-weight:600;color:var(--primary-500);margin-bottom:var(--space-2);font-size:.875rem}.reader-text{font-size:1.125rem;line-height:2;color:var(--text-primary);text-align:justify;letter-spacing:.02em}.node-type-dialogue{cursor:pointer;padding:var(--space-4);border-left:3px solid transparent;transition:all .3s ease;margin-left:-var(--space-4)}.node-type-dialogue:hover{border-left-color:var(--primary-400);background:var(--bg-secondary);border-radius:0 var(--radius-md) var(--radius-md) 0}.audio-indicator{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);font-size:.75rem;color:var(--text-muted);opacity:.7;transition:opacity .3s}.audio-indicator.playing{color:var(--primary-500);opacity:1}.audio-indicator.playing svg{animation:pulse 1.5s infinite}.hotspot{position:relative;cursor:pointer}.hotspot-character:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--primary-400),transparent);opacity:0;transition:opacity .5s ease}.hotspot-character:hover:after{opacity:.6}.hotspot-character:hover{color:var(--primary-500)}.hotspot-scene:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--success),transparent);opacity:0;transition:opacity .5s ease}.hotspot-scene:hover:after{opacity:.6}.hotspot-scene:hover{color:var(--success)}.reader-nav{position:fixed;bottom:50%;left:0;right:0;display:flex;justify-content:space-between;padding:0 var(--space-4);pointer-events:none}.nav-btn{width:48px;height:48px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;pointer-events:auto;opacity:.7}.nav-btn:hover{opacity:1;background:var(--bg-tertiary);color:var(--text-primary)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.reader-nav{display:none}.reader-content{padding:var(--space-6) var(--space-4)}}.character-popup,.scene-popup{position:fixed;z-index:1100;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-4);min-width:280px;max-width:320px;animation:popup-enter .2s ease}@keyframes popup-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.popup-close{position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.popup-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.popup-header{display:flex;gap:var(--space-3);margin-bottom:var(--space-3)}.character-avatar{width:64px;height:64px;border-radius:var(--radius-lg);overflow:hidden;flex-shrink:0;background:var(--bg-tertiary)}.character-avatar img{width:100%;height:100%;object-fit:cover;object-position:top}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.character-info{flex:1;min-width:0}.character-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2)}.character-traits{display:flex;flex-wrap:wrap;gap:var(--space-1)}.trait-tag{font-size:.7rem;padding:2px 6px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius-sm)}.contextual-dialogue-section{padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.cached-dialogue .dialogue-text{font-style:italic;color:var(--text-primary);margin-bottom:var(--space-2)}.btn-ai-generate{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all .2s}.btn-ai-generate:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-rgb),.3)}.fusion-section{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border-subtle)}.btn-fusion{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all .2s}.btn-fusion:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.character-speech-style{font-size:.75rem;color:var(--text-muted)}.character-speech-style .label{margin-right:var(--space-1)}.scene-preview{height:120px;margin:calc(-1 * var(--space-4));margin-bottom:var(--space-3);border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow:hidden}.scene-preview img{width:100%;height:100%;object-fit:cover}.scene-name{display:flex;align-items:center;gap:var(--space-2);font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2)}.scene-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 var(--space-2);line-height:1.5}.scene-meta{display:flex;gap:var(--space-3)}.meta-item{display:flex;align-items:center;gap:var(--space-1);font-size:.75rem;color:var(--text-muted)}.ai-prompt-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1200;animation:overlay-enter .2s ease}@keyframes overlay-enter{0%{opacity:0}to{opacity:1}}.ai-prompt-card{position:relative;background:var(--bg-secondary);border-radius:var(--radius-xl);padding:var(--space-6);width:90%;max-width:360px;text-align:center;animation:card-enter .3s ease}@keyframes card-enter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.ai-prompt-close{position:absolute;top:var(--space-3);right:var(--space-3);width:28px;height:28px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center}.ai-prompt-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ai-prompt-icon{width:56px;height:56px;margin:0 auto var(--space-4);border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;display:flex;align-items:center;justify-content:center}.ai-prompt-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2)}.ai-prompt-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 var(--space-4)}.ai-prompt-cost{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-3);color:var(--warning)}.ai-prompt-cost strong{color:var(--text-primary)}.ai-prompt-note{display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:.75rem;color:var(--text-muted);margin-bottom:var(--space-4)}.ai-prompt-actions{display:flex;gap:var(--space-3)}.ai-prompt-actions .btn{flex:1}.dialogue-player{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-4)}.dialogue-speaker{font-weight:600;color:var(--primary-500);margin-bottom:var(--space-2);font-size:.875rem}.dialogue-text{font-size:1rem;line-height:1.8;color:var(--text-primary);cursor:pointer}.typing-cursor{animation:blink .8s infinite;color:var(--primary-500)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.dialogue-controls{display:flex;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-color)}.share-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);background:var(--bg-primary);color:var(--text-muted)}.share-loading .spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.reader-paragraph{position:relative;margin-bottom:var(--space-6);padding:var(--space-4);border-radius:var(--radius-md);transition:background .2s;cursor:pointer}.reader-paragraph:hover{background:var(--bg-secondary)}.reader-paragraph.active{background:rgba(var(--primary-rgb, 59, 130, 246),.08)}.reader-paragraph .text-hotspot{color:var(--primary-600);font-weight:500;cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-decoration-color:var(--primary-300);text-underline-offset:3px;transition:all .2s;padding:0 2px;border-radius:2px}.reader-paragraph .text-hotspot:hover{background:rgba(var(--primary-rgb),.15);text-decoration-style:solid;text-decoration-color:var(--primary-500)}.reader-paragraph .text-hotspot[data-type=character]:after{content:"👤";font-size:.75em;margin-left:2px;opacity:0;transition:opacity .2s}.reader-paragraph .text-hotspot[data-type=character]:hover:after{opacity:1}.render-mode-indicator{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-muted)}.render-mode-indicator.original{background:rgba(var(--success-rgb),.1);color:var(--success-600)}.render-mode-indicator.nodes{background:rgba(var(--warning-rgb),.1);color:var(--warning-600)}.popup-mode-tabs{display:flex;gap:var(--space-1);padding:var(--space-2);margin-bottom:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md)}.popup-mode-tabs .mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.popup-mode-tabs .mode-tab:hover{background:var(--bg-secondary);color:var(--text-secondary)}.popup-mode-tabs .mode-tab.active{background:var(--bg-primary);color:var(--primary-500);box-shadow:var(--shadow-sm)}.popup-mode-tabs .mode-tab.active svg{color:var(--primary-500)}.cinematic-cutscene{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000fa;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);cursor:pointer;-webkit-user-select:none;user-select:none;opacity:0;transition:opacity .3s ease}.cinematic-cutscene.phase-flash,.cinematic-cutscene.phase-flash .flash-overlay,.cinematic-cutscene.phase-reveal{opacity:1}.cinematic-cutscene.phase-reveal .cutscene-media-container{opacity:1;transform:scale(1);filter:blur(0)}.cinematic-cutscene.phase-hold{opacity:1}.cinematic-cutscene.phase-hold .cutscene-media-container{opacity:1;transform:scale(1);filter:blur(0)}.cinematic-cutscene.phase-hold .cutscene-caption,.cinematic-cutscene.phase-hold .cutscene-skip-hint{opacity:1;transform:translateY(0)}.cinematic-cutscene.phase-exit{opacity:0}.cinematic-cutscene.phase-exit .cutscene-media-container{transform:scale(1.05)}.flash-overlay{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:10;animation:flash-animation .3s ease-out forwards}@keyframes flash-animation{0%{opacity:0}30%{opacity:1}to{opacity:0}}.cutscene-media-container{position:relative;max-width:90vw;max-height:70vh;border-radius:var(--radius-xl);overflow:hidden;opacity:0;transform:scale(.85);filter:blur(20px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1),filter .6s ease-out;box-shadow:0 0 100px 30px #8b5cf626,0 50px 100px -20px #000c}.cutscene-image,.cutscene-video{display:block;max-width:100%;max-height:70vh;width:auto;height:auto;object-fit:contain}.cutscene-caption{margin-top:var(--space-8);max-width:600px;padding:0 var(--space-4);text-align:center;opacity:0;transform:translateY(20px);transition:opacity .6s ease .3s,transform .6s ease .3s}.cutscene-caption p{margin:0;font-size:1.25rem;font-weight:300;letter-spacing:.05em;line-height:1.8;background:linear-gradient(135deg,#e0e7ff,#c4b5fd,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.cutscene-skip-hint{position:absolute;bottom:calc(env(safe-area-inset-bottom,0px) + var(--space-8));left:50%;transform:translate(-50%) translateY(10px);color:#fff6;font-size:.75rem;letter-spacing:.05em;opacity:0;transition:opacity .4s ease .8s,transform .4s ease .8s;animation:hint-pulse 2s ease-in-out infinite 1s}@keyframes hint-pulse{0%,to{opacity:.4}50%{opacity:.7}}@media(max-width:768px){.cutscene-media-container{max-width:95vw;max-height:60vh;border-radius:var(--radius-lg)}.cutscene-caption{margin-top:var(--space-6)}.cutscene-caption p{font-size:1rem}.cutscene-skip-hint{bottom:calc(env(safe-area-inset-bottom,0px) + var(--space-6));font-size:.8125rem}}.cutscene-video{-webkit-playsinline:true}.cinematic-cutscene:has(.cutscene-video) .cutscene-skip-hint{opacity:.3}.video-scene-layer{position:absolute;inset:0;z-index:25;overflow:hidden;pointer-events:none}.video-scene-layer.active{opacity:1}.scene-video{width:100%;height:100%;object-fit:cover;filter:brightness(.8) saturate(.9);opacity:0;transition:opacity 1s ease}.scene-video.loaded{opacity:1}.scene-static-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.8) saturate(.9)}.video-overlay-gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 30%,transparent 60%);pointer-events:none}.ambient-overlay{position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;opacity:.6}.ambient-overlay.scene-day{background:linear-gradient(to bottom,rgba(255,250,240,.1) 0%,transparent 40%)}.ambient-overlay.scene-night{background:radial-gradient(ellipse at 30% 20%,rgba(100,120,200,.3) 0%,transparent 50%),linear-gradient(to bottom,rgba(30,40,80,.4) 0%,transparent 100%)}.ambient-overlay.scene-sunset{background:radial-gradient(ellipse at 80% 10%,rgba(255,150,100,.4) 0%,transparent 40%),linear-gradient(to bottom,rgba(255,180,120,.2) 0%,transparent 60%)}.ambient-overlay.scene-dawn{background:radial-gradient(ellipse at 20% 30%,rgba(255,200,150,.3) 0%,transparent 50%),linear-gradient(to top,rgba(80,60,100,.3) 0%,transparent 50%)}.ambient-overlay.scene-rain{background:linear-gradient(to bottom,#3c465a66,#2832464d)}.video-scene-layer{animation:scene-fade-in 1s ease forwards}@keyframes scene-fade-in{0%{opacity:0}to{opacity:1}}.key-moment-overlay{position:fixed;inset:0;z-index:1200;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}.key-moment-overlay.phase-entering{animation:moment-enter .6s cubic-bezier(.22,1,.36,1) forwards}.key-moment-overlay.phase-exiting{animation:moment-exit .4s ease-out forwards}@keyframes moment-enter{0%{opacity:0}to{opacity:1}}@keyframes moment-exit{0%{opacity:1}to{opacity:0}}.moment-background{position:absolute;inset:0;z-index:1}.moment-media{position:absolute;inset:0;z-index:2;overflow:hidden}.moment-image,.moment-video{width:100%;height:100%;object-fit:cover;opacity:.4;filter:blur(2px);animation:media-reveal 1.2s ease-out forwards}.phase-entering .moment-image,.phase-entering .moment-video{transform:scale(1.1)}.phase-revealing .moment-image,.phase-revealing .moment-video,.phase-holding .moment-image,.phase-holding .moment-video{transform:scale(1);opacity:.5;filter:blur(0)}@keyframes media-reveal{0%{transform:scale(1.15);opacity:0;filter:blur(10px)}to{transform:scale(1);opacity:.5;filter:blur(0)}}.media-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(0,0,0,.7) 100%);pointer-events:none}.moment-particles{position:absolute;inset:0;z-index:3;pointer-events:none;overflow:hidden}.moment-particles .particle{position:absolute;bottom:-10px;left:var(--x, 50%);width:4px;height:4px;background:#fff9;border-radius:50%;animation:particle-float var(--duration, 4s) ease-in-out infinite;animation-delay:var(--delay, 0s);opacity:0}@keyframes particle-float{0%{transform:translateY(0) scale(0);opacity:0}10%{opacity:.8;transform:scale(1)}90%{opacity:.3}to{transform:translateY(-100vh) scale(.5);opacity:0}}.type-revelation .particle{background:#ffdc64cc;box-shadow:0 0 6px #ffdc6480}.type-battle_scene .particle{background:#ff6464b3;box-shadow:0 0 6px #ff646480}.type-loving .particle,.type-emotional_peak .particle{background:#ff96c8b3;box-shadow:0 0 6px #ff96c880}.moment-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;text-align:center;max-width:800px;padding:var(--space-8);animation:content-slide-up .8s cubic-bezier(.22,1,.36,1) .3s backwards}@keyframes content-slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.moment-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:linear-gradient(135deg,#ffc8644d,#ff963233);border:1px solid rgba(255,200,100,.4);border-radius:var(--radius-full);color:#ffdc96f2;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-4);animation:badge-glow 2s ease-in-out infinite}.moment-badge svg{animation:spin-slow 3s linear infinite}@keyframes badge-glow{0%,to{box-shadow:0 0 10px #ffc8644d}50%{box-shadow:0 0 20px #ffc86480}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.moment-header{margin-bottom:var(--space-6)}.moment-title{font-size:2rem;font-weight:700;color:#fff;margin:0 0 var(--space-2);text-shadow:0 2px 20px rgba(0,0,0,.5);animation:title-reveal .8s cubic-bezier(.22,1,.36,1) .5s backwards}.moment-subtitle{font-size:1rem;color:#ffffffb3;margin:0;font-style:italic}@keyframes title-reveal{0%{opacity:0;transform:translateY(10px);letter-spacing:.2em}to{opacity:1;transform:translateY(0);letter-spacing:.05em}}.moment-character{margin-bottom:var(--space-4)}.character-label{padding:var(--space-1) var(--space-4);background:rgba(var(--primary-rgb),.3);border:1px solid rgba(var(--primary-rgb),.5);border-radius:var(--radius-md);color:var(--primary-300);font-size:.875rem;font-weight:500}.moment-text-container{max-width:650px}.moment-main-text{font-size:1.5rem;line-height:2;color:#fff;margin:0;word-break:break-word}.glow-char{display:inline;animation:char-glow .5s ease-out forwards;animation-delay:var(--char-delay, 0s);opacity:0}.glow-char.latest{color:#ffe696;text-shadow:0 0 20px rgba(255,200,100,.8)}@keyframes char-glow{0%{opacity:0;color:#ffe696;text-shadow:0 0 30px rgba(255,200,100,1)}50%{opacity:1;color:#ffe696;text-shadow:0 0 15px rgba(255,200,100,.6)}to{opacity:1;color:#fff;text-shadow:0 0 5px rgba(255,255,255,.3)}}.text-cursor{display:inline-block;color:#ffc864cc;animation:cursor-blink .8s steps(1) infinite;margin-left:2px}.moment-inner-voice{display:flex;align-items:flex-start;gap:var(--space-2);margin-top:var(--space-6);padding:var(--space-4) var(--space-6);background:#ffffff0d;border-left:3px solid rgba(var(--primary-rgb),.5);border-radius:0 var(--radius-md) var(--radius-md) 0;animation:inner-voice-appear .5s ease-out}.inner-voice-mark{font-size:2rem;color:rgba(var(--primary-rgb),.5);line-height:1}.moment-inner-voice p{margin:0;font-size:1rem;font-style:italic;color:#fffc;line-height:1.8}@keyframes inner-voice-appear{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.moment-actions{position:absolute;bottom:var(--space-8);left:50%;transform:translate(-50%);z-index:20}.continue-hint,.skip-hint{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);color:#fffc;font-size:.875rem;animation:hint-pulse 2s ease-in-out infinite}.continue-hint svg{animation:play-bounce 1s ease-in-out infinite}@keyframes hint-pulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes play-bounce{0%,to{transform:translate(0)}50%{transform:translate(3px)}}.moment-close-btn{position:absolute;top:var(--space-4);right:var(--space-4);z-index:30;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;color:#ffffffb3;cursor:pointer;transition:all .2s ease}.moment-close-btn:hover{background:#fff3;color:#fff;transform:scale(1.1)}@media(max-width:768px){.moment-content{padding:var(--space-4)}.moment-title{font-size:1.5rem}.moment-main-text{font-size:1.125rem;line-height:1.8}.moment-actions{bottom:var(--space-6)}}.dialogue-history-panel{position:fixed;inset:0;z-index:1150;display:flex;justify-content:flex-start}.history-backdrop{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:backdrop-fade-in .3s ease}@keyframes backdrop-fade-in{0%{opacity:0}to{opacity:1}}.history-content{position:relative;width:380px;max-width:90vw;height:100%;background:linear-gradient(135deg,#141423fa,#1e1e32fa);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;animation:panel-slide-in .3s cubic-bezier(.22,1,.36,1)}@keyframes panel-slide-in{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.history-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid rgba(255,255,255,.1)}.history-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#fff}.history-header .close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#ffffffb3;cursor:pointer;transition:all .2s ease}.history-header .close-btn:hover{background:#fff3;color:#fff}.history-filters{padding:var(--space-4) var(--space-5);border-bottom:1px solid rgba(255,255,255,.08)}.search-box{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.search-box svg{color:#ffffff80;flex-shrink:0}.search-box input{flex:1;background:transparent;border:none;color:#fff;font-size:.875rem;outline:none}.search-box input::placeholder{color:#fff6}.character-filter{display:flex;flex-wrap:wrap;gap:var(--space-2)}.filter-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-full);color:#ffffffb3;font-size:.75rem;cursor:pointer;transition:all .2s ease}.filter-chip:hover{background:#ffffff26;color:#fff}.filter-chip.active{background:rgba(var(--primary-rgb),.3);border-color:var(--primary-500);color:var(--primary-300)}.filter-chip .chip-avatar{width:18px;height:18px;border-radius:50%;object-fit:cover}.history-list{flex:1;overflow-y:auto;padding:var(--space-3)}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track{background:#ffffff0d}.history-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.history-list .empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:#fff6;font-size:.875rem}.history-item{display:flex;gap:var(--space-3);padding:var(--space-3);background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);margin-bottom:var(--space-2);cursor:pointer;transition:all .2s ease}.history-item:hover{background:#ffffff14;border-color:#ffffff1f}.history-item.current{background:rgba(var(--primary-rgb),.15);border-color:rgba(var(--primary-rgb),.3)}.history-item.emotion-happy{border-left:3px solid rgba(255,200,100,.6)}.history-item.emotion-sad{border-left:3px solid rgba(100,150,220,.6)}.history-item.emotion-angry{border-left:3px solid rgba(220,80,80,.6)}.history-item.emotion-loving{border-left:3px solid rgba(255,150,180,.6)}.history-item .item-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;color:#fff9;flex-shrink:0}.item-content{flex:1;min-width:0}.speaker-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.speaker-avatar-small{width:20px;height:20px;border-radius:50%;object-fit:cover}.speaker-name-small{font-size:.75rem;font-weight:600;color:var(--primary-400)}.emotion-badge{font-size:.75rem}.item-text{margin:0;font-size:.875rem;color:#ffffffd9;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.item-action{display:flex;align-items:center;color:#ffffff4d;transition:color .2s ease}.history-item:hover .item-action{color:var(--primary-400)}.history-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-5);border-top:1px solid rgba(255,255,255,.08);font-size:.75rem;color:#ffffff80}.history-footer .clear-filter{padding:var(--space-1) var(--space-2);background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);color:#fff9;font-size:.75rem;cursor:pointer;transition:all .2s ease}.history-footer .clear-filter:hover{background:#ffffff1a;color:#fff}@media(max-width:480px){.history-content{width:100%;max-width:100%}}.story-theater{position:fixed;inset:0;background:#000;overflow:hidden;-webkit-user-select:none;user-select:none;z-index:1100}.story-theater.empty{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-4);color:#fff}.story-theater.empty .empty-state-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8);max-width:400px}.story-theater.empty .empty-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.8}.story-theater.empty h3{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 var(--space-3)}.story-theater.empty>.empty-state-content>p{color:#ffffffb3;margin:0 0 var(--space-4);line-height:1.6}.story-theater.empty .empty-hints{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-5);text-align:left;width:100%}.story-theater.empty .empty-hints p{font-size:.875rem;color:#fff9;margin:0;padding:var(--space-1) 0}.story-theater.fullscreen{background:#000;z-index:9999}.click-ripple{position:absolute;width:60px;height:60px;margin-left:-30px;margin-top:-30px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.4) 0%,transparent 70%);pointer-events:none;z-index:200;animation:click-ripple-expand .6s cubic-bezier(0,.5,.5,1) forwards}@keyframes click-ripple-expand{0%{transform:scale(.3);opacity:1}to{transform:scale(3);opacity:0}}.theater-layer{position:absolute;inset:0;pointer-events:none}.theater-layer>*{pointer-events:auto}.layer-scene{z-index:20}.scene-background{width:100%;height:100%;object-fit:cover;object-position:center}.scene-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#16213e)}.layer-characters{z-index:40;display:flex;align-items:flex-end;justify-content:center;padding-bottom:180px}.layer-effects{z-index:60}.layer-ui{z-index:80;pointer-events:none}.layer-ui>*{pointer-events:auto}.layer-controls{z-index:100;transition:opacity .3s}.layer-controls.hidden{opacity:0;pointer-events:none}.scene-transition{position:absolute;inset:0;z-index:30;pointer-events:none}.transition-fade{background:#000;animation:fade-in-out var(--transition-duration, .5s) ease-in-out}.transition-crossfade{background:#000;animation:crossfade var(--transition-duration, .5s) ease-in-out}.transition-whiteout{background:#fff;animation:fade-in-out var(--transition-duration, .5s) ease-in-out}.transition-blackout{background:#000;animation:hold-fade var(--transition-duration, .5s) ease-in-out}@keyframes fade-in-out{0%{opacity:0}50%{opacity:1}to{opacity:0}}@keyframes crossfade{0%{opacity:0}20%{opacity:1}80%{opacity:1}to{opacity:0}}@keyframes hold-fade{0%{opacity:0}10%{opacity:1}90%{opacity:1}to{opacity:0}}.transition-cinematic-bars{background:transparent;animation:none}.cinematic-bar{position:absolute;left:0;right:0;height:0;background:#000;animation:cinematic-bar-animate var(--transition-duration, .5s) ease-in-out}.cinematic-bar.bar-top{top:0}.cinematic-bar.bar-bottom{bottom:0}@keyframes cinematic-bar-animate{0%{height:0}40%{height:15%}60%{height:15%}to{height:0}}.transition-page-flip{background:linear-gradient(135deg,#1e1e28f2,#14141efa);transform-origin:left center;animation:page-flip-animate var(--transition-duration, .6s) ease-in-out}@keyframes page-flip-animate{0%{transform:rotateY(0);opacity:0}30%{transform:rotateY(-5deg);opacity:1}70%{transform:rotateY(5deg);opacity:1}to{transform:rotateY(0);opacity:0}}.transition-ink-wash{background:radial-gradient(ellipse at center,rgba(10,10,15,.95) 0%,transparent 70%);animation:ink-wash-animate var(--transition-duration, .8s) cubic-bezier(.4,0,.2,1)}@keyframes ink-wash-animate{0%{transform:scale(0);opacity:0}50%{transform:scale(2);opacity:1}to{transform:scale(3);opacity:0}}.transition-blur{background:#0000004d;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);animation:blur-animate var(--transition-duration, .5s) ease-in-out}@keyframes blur-animate{0%{-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);opacity:0}50%{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);opacity:1}to{-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);opacity:0}}.transition-glitch{background:#000;animation:glitch-animate var(--transition-duration, .4s) steps(4)}@keyframes glitch-animate{0%{opacity:0;transform:translate(0)}25%{opacity:1;transform:translate(-5px);filter:hue-rotate(90deg)}50%{opacity:1;transform:translate(5px);filter:hue-rotate(180deg)}75%{opacity:1;transform:translate(-3px);filter:hue-rotate(270deg)}to{opacity:0;transform:translate(0);filter:hue-rotate(0deg)}}.transition-caption{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffffffe6;font-size:1.5rem;font-weight:300;letter-spacing:.2em;text-shadow:0 2px 10px rgba(0,0,0,.5);animation:caption-fade var(--transition-duration, .5s) ease-in-out}@keyframes caption-fade{0%,to{opacity:0}30%,70%{opacity:1}}.character-sprite{position:absolute;bottom:0;height:80%;max-height:600px;transition:left .5s cubic-bezier(.34,1.56,.64,1),right .5s cubic-bezier(.34,1.56,.64,1),transform .5s cubic-bezier(.34,1.56,.64,1);z-index:1}.character-sprite:hover{z-index:10}.character-sprite .emotion-aura{position:absolute;bottom:-20%;left:-30%;right:-30%;height:80%;pointer-events:none;filter:blur(30px);transition:opacity .5s ease;z-index:-1}.sprite-image{height:100%;width:auto;object-fit:contain;transition:filter .4s ease,transform .4s ease,opacity .3s ease;will-change:transform,filter}.sprite-image.dimmed{filter:brightness(.6) saturate(.8)}.sprite-image.highlight{filter:brightness(1.05) saturate(1.1);transform:scale(1.03)}.sprite-image.transitioning{opacity:1}.sprite-image.sprite-prev{position:absolute;top:0;left:0;opacity:.5;animation:sprite-crossfade .3s ease forwards}@keyframes sprite-crossfade{0%{opacity:.8}to{opacity:0}}.character-sprite.breathing .sprite-image{animation:gentle-breathing 4s ease-in-out infinite}.character-sprite.speaking.breathing .sprite-image{animation:speaking-bounce 1.5s ease-in-out infinite}@keyframes gentle-breathing{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.005)}}@keyframes speaking-bounce{0%,to{transform:translateY(0) scale(1.03)}25%{transform:translateY(-4px) scale(1.035)}75%{transform:translateY(-2px) scale(1.025)}}.sprite-entrance-fade{animation:entrance-fade .6s cubic-bezier(.22,1,.36,1) forwards}.sprite-entrance-slide-left{animation:entrance-slide-left .6s cubic-bezier(.22,1,.36,1) forwards}.sprite-entrance-slide-right{animation:entrance-slide-right .6s cubic-bezier(.22,1,.36,1) forwards}.sprite-entrance-zoom{animation:entrance-zoom .5s cubic-bezier(.34,1.56,.64,1) forwards}.sprite-entrance-bounce{animation:entrance-bounce .7s cubic-bezier(.34,1.56,.64,1) forwards}.sprite-entrance-glitch{animation:entrance-glitch .6s steps(8) forwards}@keyframes entrance-fade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes entrance-slide-left{0%{opacity:0;transform:translate(-80px)}to{opacity:1;transform:translate(0)}}@keyframes entrance-slide-right{0%{opacity:0;transform:translate(80px)}to{opacity:1;transform:translate(0)}}@keyframes entrance-zoom{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}@keyframes entrance-bounce{0%{opacity:0;transform:translateY(60px) scale(.9)}60%{opacity:1;transform:translateY(-15px) scale(1.02)}to{transform:translateY(0) scale(1)}}@keyframes entrance-glitch{0%{opacity:0;transform:translate(-10px);filter:hue-rotate(90deg) saturate(200%)}25%{opacity:.7;transform:translate(8px);filter:hue-rotate(-90deg) saturate(150%)}50%{opacity:.5;transform:translate(-5px);filter:hue-rotate(45deg)}75%{opacity:.9;transform:translate(3px);filter:hue-rotate(-45deg)}to{opacity:1;transform:translate(0);filter:none}}.sprite-exit-fade{animation:exit-fade .4s ease-out forwards}.sprite-exit-slide-left{animation:exit-slide-left .4s ease-out forwards}.sprite-exit-slide-right{animation:exit-slide-right .4s ease-out forwards}.sprite-exit-zoom{animation:exit-zoom .4s ease-out forwards}@keyframes exit-fade{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}@keyframes exit-slide-left{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-80px)}}@keyframes exit-slide-right{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(80px)}}@keyframes exit-zoom{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.7)}}.speaking-effects{position:absolute;bottom:5%;left:50%;transform:translate(-50%);pointer-events:none}.speaking-indicator{position:relative;width:10px;height:10px;background:var(--primary-500);border-radius:50%;animation:speaking-pulse 1.2s ease-in-out infinite;box-shadow:0 0 15px var(--primary-500)}.speaking-ripple{position:absolute;top:50%;left:50%;width:10px;height:10px;border:2px solid var(--primary-400);border-radius:50%;transform:translate(-50%,-50%);animation:ripple-expand 1.5s ease-out infinite;opacity:0}.speaking-ripple.delay-1{animation-delay:.5s}.speaking-ripple.delay-2{animation-delay:1s}@keyframes speaking-pulse{0%,to{transform:scale(1);opacity:1;box-shadow:0 0 10px var(--primary-500)}50%{transform:scale(1.3);opacity:.8;box-shadow:0 0 25px var(--primary-500)}}@keyframes ripple-expand{0%{transform:translate(-50%,-50%) scale(.5);opacity:.8}to{transform:translate(-50%,-50%) scale(4);opacity:0}}.character-name-tag{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);padding:var(--space-1) var(--space-3);background:linear-gradient(135deg,rgba(var(--primary-rgb),.9),rgba(var(--primary-rgb),.7));color:#fff;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);white-space:nowrap;box-shadow:0 2px 10px #0000004d;animation:name-tag-appear .3s ease-out}@keyframes name-tag-appear{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.scene-dawn{--scene-ambient: rgba(255, 200, 150, .15);--scene-filter: sepia(.1) brightness(.95)}.scene-morning{--scene-ambient: rgba(255, 245, 220, .1);--scene-filter: brightness(1.02)}.scene-noon{--scene-ambient: rgba(255, 255, 255, .05);--scene-filter: brightness(1.05) contrast(1.02)}.scene-afternoon{--scene-ambient: rgba(255, 230, 180, .12);--scene-filter: sepia(.05) brightness(1)}.scene-evening{--scene-ambient: rgba(255, 150, 100, .2);--scene-filter: sepia(.15) brightness(.9)}.scene-night{--scene-ambient: rgba(100, 120, 200, .25);--scene-filter: brightness(.7) saturate(.9)}.character-sprite:before{content:"";position:absolute;inset:0;background:var(--scene-ambient, transparent);mix-blend-mode:overlay;pointer-events:none;border-radius:inherit}.character-sprite .sprite-image{filter:var(--scene-filter, none) drop-shadow(0 10px 30px rgba(0,0,0,.4))}.character-sprite:after{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to top,rgba(0,0,0,.3),transparent);pointer-events:none}.dialogue-box{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to bottom,#0000,#000000d9 15%,#000000f2);padding:var(--space-6) var(--space-8);padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom));min-height:180px;overflow:hidden;transition:background .5s ease}.dialogue-emotion-glow{position:absolute;top:-50%;left:-20%;right:-20%;height:150%;pointer-events:none;filter:blur(60px);opacity:.6;animation:emotion-glow-pulse 3s ease-in-out infinite}@keyframes emotion-glow-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.dialogue-box.emotion-happy{background:linear-gradient(to bottom,#ffc8640d,#000000d9 20%,#000000f2)}.dialogue-box.emotion-sad{background:linear-gradient(to bottom,#6478c814,#000000d9 20%,#000000f2)}.dialogue-box.emotion-angry{background:linear-gradient(to bottom,#c832321a,#000000d9 20%,#000000f2)}.dialogue-box.emotion-loving{background:linear-gradient(to bottom,#ff96b414,#000000d9 20%,#000000f2)}.dialogue-box.narration{background:#000c;text-align:center;padding:var(--space-8)}.dialogue-speaker{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.speaker-avatar-wrapper{position:relative;width:52px;height:52px;flex-shrink:0}.speaker-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3);transition:transform .3s ease,border-color .3s ease;position:relative;z-index:1}.avatar-ring{position:absolute;inset:-3px;border:2px solid var(--emotion-accent, rgba(255, 255, 255, .3));border-radius:50%;opacity:0;transition:opacity .3s ease}.speaker-avatar-wrapper.pulsing .avatar-ring{opacity:1;animation:avatar-ring-pulse 1.5s ease-in-out infinite}.speaker-avatar-wrapper.pulsing .speaker-avatar{animation:avatar-breathe 1.5s ease-in-out infinite}@keyframes avatar-ring-pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:.2}}@keyframes avatar-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.speaker-info{display:flex;align-items:center;gap:var(--space-2)}.speaker-name{font-size:1rem;font-weight:600;color:var(--primary-400);text-shadow:0 1px 3px rgba(0,0,0,.5)}.emotion-tag{font-size:.875rem;animation:emotion-tag-bounce 2s ease-in-out infinite}@keyframes emotion-tag-bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-2px) scale(1.1)}}.dialogue-content{max-width:900px;margin:0 auto}.dialogue-box .dialogue-text{font-size:1.125rem;line-height:1.8;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);transition:text-shadow .3s ease}.dialogue-box.narration .dialogue-text{font-style:italic;color:#ffffffe6}.dialogue-box .typing-cursor{color:var(--emotion-accent, var(--primary-400));animation:cursor-blink .7s steps(1) infinite;text-shadow:0 0 10px var(--emotion-glow, var(--primary-400))}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.dialogue-continue{position:absolute;bottom:var(--space-4);right:var(--space-6)}.continue-indicator{color:#fff9;animation:bounce-down 1s ease-in-out infinite}@keyframes bounce-down{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.dialogue-context-section{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid rgba(255,255,255,.1)}.context-toggle-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);color:#fff9;font-size:.75rem;cursor:pointer;transition:all .2s}.context-toggle-btn:hover{background:#ffffff1a;color:#ffffffe6}.context-panel{margin-top:var(--space-3);padding:var(--space-3);background:#0000004d;border-radius:var(--radius-md);max-height:200px;overflow-y:auto}.context-panel p{margin:0;padding:var(--space-2) 0;font-size:.875rem;line-height:1.6}.context-before,.context-after{color:#ffffff80;font-style:italic}.context-current{color:var(--primary-300);font-weight:500;border-left:2px solid var(--primary-500);padding-left:var(--space-3)}.choice-menu{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.choice-container{display:flex;flex-direction:column;gap:var(--space-4);max-width:600px;width:90%}.choice-button{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:#1e1e32e6;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);color:#fff;font-size:1rem;cursor:pointer;transition:all .2s ease;text-align:left}.choice-button:hover,.choice-button.hovered{background:rgba(var(--primary-rgb),.3);border-color:var(--primary-500);transform:translate(8px)}.choice-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--primary-600);border-radius:50%;font-weight:600;flex-shrink:0}.choice-text{flex:1}.choice-hint{font-size:.75rem;color:#ffffff80;font-style:italic}.theater-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);padding-top:calc(var(--space-3) + env(safe-area-inset-top));background:linear-gradient(to bottom,#000000b3,#0000)}.theater-header .btn{color:#fffc}.theater-header .btn:hover{color:#fff;background:#ffffff1a}.theater-header .btn.active{color:var(--primary-400);background:rgba(var(--primary-rgb),.2)}.theater-progress{flex:1;display:flex;align-items:center;gap:var(--space-3)}.theater-progress .progress-bar{flex:1;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.theater-progress .progress-fill{height:100%;background:var(--primary-500);transition:width .3s}.theater-progress>span{font-size:.75rem;color:#fff9;min-width:40px;text-align:right}.theater-actions{display:flex;gap:var(--space-1)}.mode-indicators{position:absolute;top:60px;right:var(--space-4);display:flex;gap:var(--space-2)}.indicator{padding:var(--space-1) var(--space-2);background:var(--primary-600);color:#fff;font-size:.625rem;font-weight:700;border-radius:var(--radius-sm);letter-spacing:.05em}.settings-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#14141ef2;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:var(--space-6);min-width:320px;z-index:200}.settings-panel h3{color:#fff;margin:0 0 var(--space-4);font-size:1.125rem}.setting-item{margin-bottom:var(--space-4)}.setting-item label{display:flex;align-items:center;gap:var(--space-2);color:#fffc;font-size:.875rem;margin-bottom:var(--space-2)}.setting-item input[type=range]{width:100%;accent-color:var(--primary-500)}.setting-item input[type=checkbox]{accent-color:var(--primary-500)}.settings-panel .btn{width:100%;margin-top:var(--space-4)}@media(max-width:768px){.dialogue-box{padding:var(--space-4);min-height:150px}.dialogue-box .dialogue-text{font-size:1rem}.character-sprite{height:60%}.layer-characters{padding-bottom:150px}.theater-header{padding:var(--space-2)}.choice-button{padding:var(--space-3) var(--space-4)}}.exploration-visualizer{position:relative;width:100%;height:200px;border-radius:var(--radius-lg);background:#0a0a1499;border:1px solid rgba(255,255,255,.06);overflow:hidden;display:flex;align-items:center;justify-content:center}.visualizer-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4)}.exploration-portal{position:relative;display:flex;align-items:center;justify-content:center}.portal-ring-outer{position:absolute;width:100%;height:100%;border:2px solid transparent;border-top-color:var(--primary-400);border-right-color:#8b5cf64d;border-radius:50%;animation:portal-spin 2s linear infinite}.portal-ring-inner{position:absolute;width:70%;height:70%;border:2px solid transparent;border-bottom-color:var(--accent-400);border-left-color:#3b82f64d;border-radius:50%;animation:portal-spin 1.5s linear infinite reverse}.portal-glow{width:40%;height:40%;background:radial-gradient(circle,rgba(139,92,246,.8) 0%,rgba(139,92,246,.2) 50%,transparent 70%);border-radius:50%;animation:portal-pulse 2s ease-in-out infinite}@keyframes portal-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes portal-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.3);opacity:1}}.portal-status-text{color:#ffffffb3;font-size:.875rem;text-align:center}.portal-status-text:after{content:"";animation:typing-dots 1.5s infinite}@keyframes typing-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.visualizer-result{position:relative;width:100%;height:100%;cursor:pointer;animation:reveal-from-portal .8s cubic-bezier(.16,1,.3,1) forwards}@keyframes reveal-from-portal{0%{opacity:0;transform:scale(.5);filter:blur(20px)}to{opacity:1;transform:scale(1);filter:blur(0)}}.visualizer-image,.visualizer-video{width:100%;height:100%;object-fit:cover}.visualizer-caption{position:absolute;bottom:0;left:0;right:0;padding:var(--space-4) var(--space-3) var(--space-3);background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%);color:#fff;font-size:.875rem;font-weight:500}.visualizer-expand-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:var(--space-2) var(--space-3);background:#000000b3;border-radius:var(--radius-md);color:#ffffffe6;font-size:.75rem;opacity:0;transition:opacity .2s}.visualizer-result:hover .visualizer-expand-hint{opacity:1}.visualizer-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);color:#fff6}.empty-icon{font-size:2rem;opacity:.5}.visualizer-empty p{margin:0;font-size:.8125rem}.exploration-visualizer.revealed{border-color:#8b5cf64d;box-shadow:0 0 20px 2px #8b5cf61a}.chrono-explorer{position:fixed;inset:0;background:#0a0a12;overflow:hidden;z-index:1100}.chrono-explorer.empty{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-4);color:#fff}.chrono-explorer.empty .empty-state-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8);max-width:400px}.chrono-explorer.empty .empty-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.8}.chrono-explorer.empty h3{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 var(--space-3)}.chrono-explorer.empty>.empty-state-content>p{color:#ffffffb3;margin:0 0 var(--space-4);line-height:1.6}.chrono-explorer.empty .empty-hints{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-5);text-align:left;width:100%}.chrono-explorer.empty .empty-hints p{font-size:.875rem;color:#fff9;margin:0;padding:var(--space-1) 0}.explorer-header{position:absolute;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent)}.explorer-header .btn{display:flex;align-items:center;gap:var(--space-2);color:#fff;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.explorer-header .btn:hover{background:#fff3}.explorer-title{color:#fff;font-size:1rem;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.5)}.exploration-scene{position:absolute;inset:0}.exploration-scene .scene-background{width:100%;height:100%;object-fit:cover;filter:brightness(.8)}.exploration-scene .scene-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;color:#ffffff4d;font-size:2rem}.exploration-zone{position:absolute;cursor:pointer;transition:all .3s ease}.exploration-zone:before{content:"";position:absolute;inset:0;border:2px dashed rgba(255,255,255,.2);border-radius:var(--radius-lg);opacity:0;transition:opacity .3s}.exploration-zone:hover:before,.exploration-zone.selected:before{opacity:1;border-color:var(--primary-400)}.zone-character{position:absolute;bottom:0;left:50%;transform:translate(-50%);height:100%}.zone-character img{height:100%;width:auto;object-fit:contain;filter:drop-shadow(0 4px 20px rgba(0,0,0,.5));transition:filter .3s,transform .3s}.exploration-zone:hover .zone-character img{filter:drop-shadow(0 4px 30px rgba(var(--primary-rgb),.5));transform:translate(-50%) scale(1.02)}.zone-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(10px);background:#000000d9;color:#fff;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:.75rem;white-space:nowrap;display:flex;align-items:center;gap:var(--space-2);opacity:0;pointer-events:none;transition:all .2s}.exploration-zone:hover .zone-tooltip{opacity:1;transform:translate(-50%) translateY(0)}.zone-pulse{position:absolute;top:50%;left:50%;width:20px;height:20px;background:var(--primary-500);border-radius:50%;transform:translate(-50%,-50%);opacity:0;animation:zone-pulse 2s ease-in-out infinite}.zone-character~.zone-pulse{display:none}@keyframes zone-pulse{0%{opacity:.6;transform:translate(-50%,-50%) scale(.5)}to{opacity:0;transform:translate(-50%,-50%) scale(2)}}.timeline-indicator{position:absolute;top:70px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);background:#000000b3;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);color:#fffc;font-size:.75rem;z-index:50}.timeline-bar{width:120px;height:4px;background:#fff3;border-radius:2px;position:relative}.timeline-fill{height:100%;background:var(--primary-500);border-radius:2px}.timeline-marker{position:absolute;top:50%;width:10px;height:10px;background:var(--primary-400);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 10px var(--primary-500)}.exploration-modes{position:absolute;bottom:var(--space-6);left:50%;transform:translate(-50%);display:flex;gap:var(--space-2);background:#000000b3;padding:var(--space-2);border-radius:var(--radius-lg);z-index:50}.mode-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:transparent;border:none;color:#fff9;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-size:.875rem}.mode-btn:hover{color:#fff;background:#ffffff1a}.mode-btn.active{color:var(--primary-400);background:rgba(var(--primary-rgb),.2)}.character-panel{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);background:#000000b3;padding:var(--space-3);border-radius:var(--radius-lg);z-index:50;max-height:60vh;overflow-y:auto}.character-panel h4{color:#fff9;font-size:.75rem;margin:0 0 var(--space-2)}.character-list{display:flex;flex-direction:column;gap:var(--space-2)}.character-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all .2s;font-size:.875rem}.character-btn img{width:32px;height:32px;border-radius:50%;object-fit:cover}.character-btn:hover{background:rgba(var(--primary-rgb),.2);border-color:var(--primary-500)}.character-btn.active{background:rgba(var(--primary-rgb),.3);border-color:var(--primary-400)}.time-controls{position:absolute;bottom:var(--space-6);right:var(--space-4);display:flex;align-items:center;gap:var(--space-2);background:#000000b3;padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);z-index:50}.time-label{color:#fffc;font-size:.75rem;min-width:100px;text-align:center}.ai-dialogue-panel{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);width:360px;max-height:70vh;background:#0f0f19f2;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);display:flex;flex-direction:column;z-index:100;overflow:hidden}.dialogue-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid rgba(255,255,255,.1)}.dialogue-panel-header .character-info{display:flex;align-items:center;gap:var(--space-3)}.dialogue-panel-header .character-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.dialogue-panel-header .character-details h3{margin:0;color:#fff;font-size:.875rem}.dialogue-panel-header .character-traits{font-size:.7rem;color:#ffffff80}.dialogue-messages{flex:1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.dialogue-hint{text-align:center;color:#fff6;padding:var(--space-8) var(--space-4)}.dialogue-hint p{margin:var(--space-2) 0 var(--space-1);color:#fff9}.dialogue-hint span{font-size:.75rem}.dialogue-message{display:flex;gap:var(--space-2);max-width:85%}.dialogue-message.user{margin-left:auto;flex-direction:row-reverse}.dialogue-message .message-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.dialogue-message .message-content{background:#ffffff1a;padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);color:#fff;font-size:.875rem;line-height:1.5}.dialogue-message.user .message-content{background:var(--primary-600)}.dialogue-message.loading .message-content{display:flex;align-items:center;gap:var(--space-2);color:#ffffff80}.dialogue-message .spin{animation:spin 1s linear infinite}.dialogue-input{display:flex;gap:var(--space-2);padding:var(--space-3);border-top:1px solid rgba(255,255,255,.1)}.dialogue-input input{flex:1;background:#ffffff1a;border:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#fff;font-size:.875rem}.dialogue-input input::placeholder{color:#fff6}.timeline-protector{position:absolute;top:var(--space-4);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);background:#1e1432f2;border:1px solid var(--warning);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);z-index:200;animation:slide-down .3s ease}.timeline-protector.exiting{animation:slide-up .3s ease forwards}@keyframes slide-down{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes slide-up{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-20px)}}.protector-icon{width:36px;height:36px;background:rgba(var(--warning-rgb, 234, 179, 8),.2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--warning)}.protector-title{display:flex;align-items:center;gap:var(--space-1);color:var(--warning);font-size:.75rem;font-weight:600}.protector-message{margin:0;color:#fffc;font-size:.875rem}.explorer-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,transparent 100%);z-index:50}.explorer-header .btn{color:#fffc}.explorer-title{display:flex;align-items:center;gap:var(--space-2);color:#fff;font-weight:600}.save-branch-btn{position:absolute;bottom:var(--space-20);left:50%;transform:translate(-50%);z-index:50;animation:pulse-border 2s infinite}@keyframes pulse-border{0%,to{box-shadow:0 0 rgba(var(--primary-rgb),.4)}50%{box-shadow:0 0 0 10px rgba(var(--primary-rgb),0)}}.loading-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:300}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);color:#fff}.loading-spinner svg{animation:spin 2s linear infinite}@media(max-width:768px){.character-panel{left:var(--space-2);padding:var(--space-2)}.ai-dialogue-panel{width:100%;height:50vh;max-height:none;right:0;top:auto;bottom:0;transform:none;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.exploration-modes{width:calc(100% - var(--space-8))}}.experience-selector{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:4rem 2rem 2rem;background:var(--bg-primary)}.selector-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:2.5rem;text-align:center}.header-content h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.header-content .novel-title{margin:.25rem 0 0;font-size:.875rem;color:var(--text-muted)}.mode-grid{display:flex;justify-content:center;gap:1.25rem;width:100%;max-width:900px}.mode-card{flex:1;max-width:260px;min-height:360px;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .25s ease;position:relative;overflow:hidden;text-align:center}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--mode-color, var(--primary-500));opacity:.5;transition:opacity .25s ease}.mode-card:hover{transform:translateY(-4px);border-color:var(--mode-color, var(--primary-400));box-shadow:0 12px 32px var(--shadow-color, rgba(0, 0, 0, .12))}.mode-card:hover:before{opacity:1}.mode-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin-bottom:1.25rem;background:color-mix(in srgb,var(--mode-color, var(--primary-500)) 12%,transparent);border-radius:var(--radius-lg);color:var(--mode-color, var(--primary-500));flex-shrink:0}.mode-card-content{display:flex;flex-direction:column;align-items:center;flex:1;width:100%}.mode-name{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.mode-description{margin:0 0 1rem;font-size:.8rem;color:var(--text-secondary);line-height:1.5}.mode-features{flex:1;margin:0 0 1.25rem;padding:0;list-style:none;text-align:left;width:100%}.mode-features li{font-size:.75rem;color:var(--text-muted);position:relative;padding:.3rem 0 .3rem 1rem}.mode-features li:before{content:"✦";position:absolute;left:0;color:var(--mode-color, var(--primary-500));font-size:.55rem;top:.4rem}.mode-start{width:100%;padding:.625rem 1rem;background:var(--mode-color, var(--primary-500))!important;border-color:var(--mode-color, var(--primary-500))!important;font-size:.875rem}.mode-start:hover{filter:brightness(1.1)}@media(max-width:768px){.experience-selector{padding:2rem 1rem 1.5rem;justify-content:flex-start}.selector-header{margin-bottom:1.5rem}.header-content h1{font-size:1.25rem}.mode-grid{flex-direction:column;align-items:stretch;gap:1rem;width:100%;max-width:400px}.mode-card{flex-direction:row;align-items:flex-start;min-height:auto;max-width:none;padding:1rem 1.25rem;gap:1rem;text-align:left}.mode-card:before{inset:0 auto 0 0;width:3px;height:auto}.mode-icon{width:48px;height:48px;margin-bottom:0;flex-shrink:0}.mode-icon svg{width:22px;height:22px}.mode-card-content{flex:1;min-width:0;align-items:flex-start}.mode-name{font-size:1rem;margin-bottom:.25rem}.mode-description{font-size:.75rem;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mode-features{display:none}.mode-start{padding:.5rem .875rem;font-size:.8rem;width:auto;align-self:flex-start}}.story-world-nav{display:flex;align-items:center;gap:8px;padding:4px 6px;background:var(--bg-secondary, rgba(0, 0, 0, .05));border-radius:10px;border:1px solid var(--border-subtle, rgba(128, 128, 128, .15))}.nav-prefix{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 8px;font-size:12px;font-weight:600;color:var(--text-secondary, #666);white-space:nowrap}.prefix-dot{width:6px;height:6px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.nav-segment-group{display:flex;align-items:center;gap:2px;background:var(--bg-tertiary, rgba(128, 128, 128, .08));border-radius:8px;padding:2px}.nav-segment{display:flex;align-items:center;gap:5px;padding:6px 12px;background:transparent;border:none;border-radius:6px;font-size:12px;font-weight:500;color:var(--text-secondary, #666);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;white-space:nowrap}.nav-segment:hover:not(.locked):not(.active){background:var(--bg-hover, rgba(128, 128, 128, .1));color:var(--text-primary, #333)}.nav-segment.active{background:var(--bg-card, #fff);color:var(--text-primary, #333);box-shadow:0 1px 3px #00000014,0 0 0 1px var(--border-subtle, rgba(128, 128, 128, .1))}.nav-segment.locked{opacity:.5;cursor:not-allowed}.nav-segment .nav-icon{flex-shrink:0;transition:transform .2s ease}.nav-segment:hover:not(.locked) .nav-icon{transform:scale(1.1)}.segment-label{transition:color .2s ease}.lock-indicator{position:absolute;top:-2px;right:-2px;display:flex;align-items:center;justify-content:center;width:14px;height:14px;background:var(--color-warning, #f59e0b);border-radius:50%;color:#fff}.nav-segment.loading{opacity:.7;pointer-events:none}.nav-segment.loading .segment-label{animation:text-pulse 1s ease-in-out infinite}@keyframes text-pulse{0%,to{opacity:.7}50%{opacity:1}}.icon-spin{animation:spin 1s linear infinite}.nav-icon.loading{animation:icon-pulse 1.5s ease-in-out infinite}@keyframes icon-pulse{0%,to{opacity:.5;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}[data-theme=dark] .story-world-nav{background:#ffffff08;border-color:#ffffff14}[data-theme=dark] .nav-prefix{color:#fff9;border-right-color:#ffffff14}[data-theme=dark] .nav-segment-group{background:#ffffff0d}[data-theme=dark] .nav-segment{color:#fff9}[data-theme=dark] .nav-segment:hover:not(.locked):not(.active){background:#ffffff14;color:#ffffffe6}[data-theme=dark] .nav-segment.active{background:#ffffff1a;color:#fff;box-shadow:0 1px 4px #0000004d,0 0 0 1px #ffffff1a}.story-world-fab{position:fixed;z-index:1000;touch-action:none;-webkit-user-select:none;user-select:none}.story-world-fab.dragging{cursor:grabbing}.story-world-fab.dragging .fab-main{transform:scale(1.05);box-shadow:0 8px 24px #667eea80,0 4px 8px #0003}.fab-main{display:flex;align-items:center;gap:4px;padding:8px 12px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:20px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #667eea66,0 2px 4px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1)}.fab-main:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80,0 3px 6px #00000026}.story-world-fab.expanded .fab-main{background:linear-gradient(135deg,#764ba2,#667eea)}.fab-icon{font-size:16px}.fab-text-col{display:flex;flex-direction:column;align-items:flex-start;line-height:1}.fab-subtitle{font-size:9px;opacity:.8;margin-top:2px;font-weight:400}.fab-items{position:absolute;bottom:56px;right:0;display:flex;flex-direction:column;gap:10px;padding:8px}.fab-item{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-card, #fff);border:1px solid var(--border-subtle, rgba(128, 128, 128, .15));border-radius:12px;color:var(--text-primary, #333);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;box-shadow:0 2px 8px #0000001a;animation:fab-item-enter .25s cubic-bezier(.34,1.56,.64,1) forwards;opacity:0;transform:translateY(10px) scale(.9)}@keyframes fab-item-enter{to{opacity:1;transform:translateY(0) scale(1)}}.fab-item:hover:not(.locked){background:var(--bg-hover, #f5f5f5);transform:translate(-4px)}.fab-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea4d}.fab-item.locked{opacity:.5;cursor:not-allowed}.fab-item.loading{opacity:.7;cursor:wait}.fab-item.loading .icon-spin{animation:spin 1s linear infinite}.fab-item-label{flex:1}.fab-overlay{position:fixed;inset:0;background:#0003;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:-1;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}[data-theme=dark] .fab-item{background:#1e1e28f2;border-color:#ffffff1a;color:#fff}[data-theme=dark] .fab-item:hover:not(.locked){background:#32323cf2}[data-theme=dark] .fab-overlay{background:#00000080}@media(max-width:768px){.story-world-nav{padding:3px 4px;gap:4px}.nav-prefix{padding:3px 8px 3px 6px;font-size:11px}.prefix-dot{width:5px;height:5px}.nav-segment{padding:5px 8px;font-size:11px;gap:4px}.segment-label{display:none}.nav-segment.active .segment-label{display:inline}}:root{--primary-50: #f0f3ff;--primary-100: #e4e9ff;--primary-200: #cdd6fe;--primary-300: #adb9fc;--primary-400: #8b94f8;--primary-500: #6b70ef;--primary-600: #5451e0;--primary-700: #4840c5;--primary-800: #3d369f;--primary-900: #36327e;--accent-50: #effcfc;--accent-100: #d5f7f8;--accent-200: #b0eff1;--accent-300: #7ae3e6;--accent-400: #3ccfd4;--accent-500: #1ab5bb;--accent-600: #15939d;--success-light: #e3f9e8;--success-bg: rgba(34, 197, 94, .1);--success-text: #1a7f37;--success-main: #2da44e;--warning-light: #fff8e6;--warning-bg: rgba(245, 158, 11, .1);--warning-text: #9a6700;--warning-main: #d4a106;--error-light: #ffebe9;--error-bg: rgba(239, 68, 68, .1);--error-text: #cf222e;--error-main: #e5484d;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--radius-full: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--header-height: 56px;--sidebar-width: 260px;--right-panel-width: 320px;--collapsed-width: 0px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-serif: "Merriweather", "Source Serif Pro", Georgia, serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, monospace}:root,[data-theme=light]{--bg-primary: #fdfcfa;--bg-secondary: #f8f7f4;--bg-tertiary: #f2f1ed;--bg-quaternary: #e8e6e1;--bg-hover: #f4f3ef;--bg-active: #ebe9e4;--bg-glass: rgba(253, 252, 250, .92);--text-primary: #2d3436;--text-secondary: #5a6268;--text-muted: #8b9298;--text-bright: #1a1d1e;--border-color: #e4e2dd;--border-light: #f0efe9;--border-focus: #6b70ef;--shadow-sm: 0 1px 2px 0 rgba(45, 52, 54, .04);--shadow-md: 0 4px 8px -1px rgba(45, 52, 54, .06), 0 2px 4px -1px rgba(45, 52, 54, .04);--shadow-lg: 0 10px 20px -3px rgba(45, 52, 54, .08), 0 4px 8px -2px rgba(45, 52, 54, .04);--shadow-xl: 0 20px 30px -5px rgba(45, 52, 54, .1), 0 10px 15px -5px rgba(45, 52, 54, .04);--shadow-glow: 0 0 15px rgba(107, 112, 239, .12);--shadow-inner: inset 0 2px 4px 0 rgba(45, 52, 54, .04);--gradient-primary: linear-gradient(135deg, #6b70ef 0%, #8b7cf6 100%);--gradient-accent: linear-gradient(135deg, #1ab5bb 0%, #4b8df8 100%);--editor-bg: #fffffe;--editor-line-highlight: rgba(107, 112, 239, .04);--ai-accent: var(--primary-500);--ai-accent-soft: var(--primary-400);--ai-bg: rgba(107, 112, 239, .08);--ai-bg-hover: rgba(107, 112, 239, .12);--ai-border: rgba(107, 112, 239, .25);--ai-glow: 0 0 12px rgba(107, 112, 239, .2);--ai-gradient: linear-gradient(135deg, rgba(107, 112, 239, .1), rgba(139, 124, 246, .1))}[data-theme=dark]{--bg-primary: #1c1e26;--bg-secondary: #16181f;--bg-tertiary: #252832;--bg-quaternary: #323642;--bg-hover: #282b36;--bg-active: #353945;--bg-glass: rgba(28, 30, 38, .88);--text-primary: #e8e6e3;--text-secondary: #b8b5b0;--text-muted: #7d7a75;--text-bright: #f5f3f0;--border-color: #363a45;--border-light: #282b36;--border-focus: #8b94f8;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .25);--shadow-md: 0 4px 8px -1px rgba(0, 0, 0, .35), 0 2px 4px -1px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 25px -3px rgba(0, 0, 0, .45), 0 4px 8px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 40px -5px rgba(0, 0, 0, .55);--shadow-glow: 0 0 20px rgba(139, 148, 248, .2);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .25);--editor-bg: #1a1c24;--editor-line-highlight: rgba(139, 148, 248, .06);--ai-accent: var(--primary-400);--ai-accent-soft: var(--primary-300);--ai-bg: rgba(139, 148, 248, .12);--ai-bg-hover: rgba(139, 148, 248, .18);--ai-border: rgba(139, 148, 248, .3);--ai-glow: 0 0 16px rgba(139, 148, 248, .25);--ai-gradient: linear-gradient(135deg, rgba(139, 148, 248, .15), rgba(167, 139, 250, .15))}[data-theme=sepia]{--bg-primary: #f9f3e8;--bg-secondary: #f4ece0;--bg-tertiary: #efe5d7;--bg-quaternary: #e5d9c7;--bg-hover: #f6ede1;--bg-active: #ebe0d1;--bg-glass: rgba(249, 243, 232, .92);--text-primary: #4a3f35;--text-secondary: #6b5d51;--text-muted: #9a8b7a;--text-bright: #3a3028;--border-color: #e2d5c3;--border-light: #f0e6d8;--border-focus: #a68b5b;--primary-500: #a68b5b;--primary-600: #8f7548;--primary-400: #c4a875;--shadow-sm: 0 1px 2px 0 rgba(74, 63, 53, .05);--shadow-md: 0 4px 8px -1px rgba(74, 63, 53, .08), 0 2px 4px -1px rgba(74, 63, 53, .05);--shadow-lg: 0 10px 20px -3px rgba(74, 63, 53, .1), 0 4px 8px -2px rgba(74, 63, 53, .06);--shadow-xl: 0 20px 30px -5px rgba(74, 63, 53, .12);--shadow-glow: 0 0 15px rgba(166, 139, 91, .15);--shadow-inner: inset 0 2px 4px 0 rgba(74, 63, 53, .05);--editor-bg: #faf5eb;--editor-line-highlight: rgba(166, 139, 91, .08);--ai-accent: #a68b5b;--ai-accent-soft: #c4a875;--ai-bg: rgba(166, 139, 91, .1);--ai-bg-hover: rgba(166, 139, 91, .15);--ai-border: rgba(166, 139, 91, .3);--ai-glow: 0 0 12px rgba(166, 139, 91, .2);--ai-gradient: linear-gradient(135deg, rgba(166, 139, 91, .1), rgba(196, 168, 117, .1))}[data-theme=green]{--bg-primary: #f0f7f1;--bg-secondary: #e6f2e7;--bg-tertiary: #dceadd;--bg-quaternary: #cfe0d0;--bg-hover: #e9f4ea;--bg-active: #dfeee0;--bg-glass: rgba(240, 247, 241, .94);--text-primary: #1a3a1e;--text-secondary: #3d5c42;--text-muted: #5a7960;--text-bright: #0f2a12;--border-color: #bdd4bf;--border-light: #d4e6d5;--border-focus: #43a047;--primary-500: #43a047;--primary-600: #2e7d32;--primary-400: #66bb6a;--primary-100: #c8e6c9;--success-main: #2e7d32;--success-text: #1b5e20;--warning-main: #f9a825;--warning-text: #e65100;--error-main: #c62828;--error-text: #b71c1c;--shadow-sm: 0 1px 2px 0 rgba(26, 58, 30, .06);--shadow-md: 0 4px 8px -1px rgba(26, 58, 30, .1), 0 2px 4px -1px rgba(26, 58, 30, .06);--shadow-lg: 0 10px 20px -3px rgba(26, 58, 30, .12), 0 4px 8px -2px rgba(26, 58, 30, .08);--shadow-xl: 0 20px 30px -5px rgba(26, 58, 30, .15);--shadow-glow: 0 0 15px rgba(67, 160, 71, .18);--shadow-inner: inset 0 2px 4px 0 rgba(26, 58, 30, .06);--editor-bg: #f3f9f4;--editor-line-highlight: rgba(67, 160, 71, .1);--ai-accent: #43a047;--ai-accent-soft: #66bb6a;--ai-bg: rgba(67, 160, 71, .1);--ai-bg-hover: rgba(67, 160, 71, .15);--ai-border: rgba(67, 160, 71, .3);--ai-glow: 0 0 12px rgba(67, 160, 71, .2);--ai-gradient: linear-gradient(135deg, rgba(67, 160, 71, .1), rgba(102, 187, 106, .1))}[data-theme=custom]{--custom-theme-active: 1;--ai-accent: var(--primary-500);--ai-accent-soft: var(--primary-400);--ai-bg: rgba(107, 112, 239, .08);--ai-bg-hover: rgba(107, 112, 239, .12);--ai-border: rgba(107, 112, 239, .25);--ai-glow: 0 0 12px rgba(107, 112, 239, .2);--ai-gradient: linear-gradient(135deg, rgba(107, 112, 239, .1), rgba(139, 124, 246, .1))}.ai-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--ai-gradient);border-radius:var(--radius-full);font-size:10px;font-weight:600;color:var(--ai-accent);border:1px solid var(--ai-border)}.ai-button{background:var(--ai-bg)!important;border:1px solid var(--ai-border)!important;color:var(--ai-accent)!important;transition:all var(--transition-fast)}.ai-button:hover{background:var(--ai-bg-hover)!important;box-shadow:var(--ai-glow)}.ai-indicator{width:6px;height:6px;border-radius:50%;background:var(--ai-accent);animation:ai-pulse 2s ease-in-out infinite}@keyframes ai-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.ai-card{background:var(--ai-gradient);border:1px solid var(--ai-border);border-radius:var(--radius-md)}.ai-icon{color:var(--ai-accent)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:var(--app-height, 100vh);width:100%;overflow:hidden}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;transition:background-color var(--transition-normal),color var(--transition-normal)}.mobile-only{display:none!important}.desktop-only{display:contents!important}@media(max-width:900px){.mobile-only{display:flex!important}.desktop-only{display:none!important}.scene-item{flex-direction:column;justify-content:flex-start;align-items:flex-start!important}.edit-btn{opacity:1!important;border:0!important;background:transparent!important}}::selection{background:var(--primary-500);color:#fff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-quaternary);border-radius:var(--radius-full);transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-container{display:flex;height:var(--app-height, 100vh);overflow:hidden;position:relative;background:var(--bg-primary)}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;position:relative;z-index:10;transition:width var(--transition-normal),background-color var(--transition-normal);overflow:hidden}.sidebar.collapsed{width:0;border-right:none}.sidebar:before{display:none}.sidebar-header{padding:var(--space-4) var(--space-4);border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:var(--space-3);position:relative;background:var(--bg-secondary)}.sidebar-brand-icon{width:48px;height:48px;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:transform var(--transition-normal)}.sidebar-brand-icon:hover{transform:translateY(-2px)}.logo-hex-base{transition:filter .3s ease}.sidebar-header:hover .logo-hex-base{filter:drop-shadow(0 4px 8px rgba(79,70,229,.4))}.logo-pen-nib{transition:transform .4s cubic-bezier(.34,1.56,.64,1);transform-origin:50% 60%}.sidebar-header:hover .logo-pen-nib{transform:translateY(-2px)}.logo-ink-channel{transition:stroke .3s ease}.sidebar-header:hover .logo-ink-channel{stroke:var(--primary-500)}.sidebar-logo{font-size:1.125rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;display:flex;align-items:center;gap:12px}.sidebar-brand-text{display:flex;flex-direction:column;justify-content:center;gap:1px}.sidebar-brand-name{font-family:"Noto Serif SC",Songti SC,SimSun,serif;font-size:1.25rem;font-weight:900;color:var(--text-primary);line-height:1;letter-spacing:.02em;margin-bottom:2px}.sidebar-brand-tagline{font-family:"Noto Serif SC",Songti SC,SimSun,serif;font-size:.72rem;font-weight:600;color:var(--text-muted);letter-spacing:.05em;opacity:.8}.sidebar-brand-icon{width:44px;height:44px}.sidebar-brand-btn{display:flex;align-items:center;gap:var(--space-3);padding:0;margin:0;background:transparent;border:none;cursor:pointer;text-align:left;border-radius:var(--radius-md);transition:all var(--transition-fast)}.sidebar-brand-btn:hover{background:var(--bg-hover)}.sidebar-brand-btn:active{transform:scale(.98)}@media(max-width:900px){.sidebar-brand-btn{padding:var(--space-2);margin:calc(var(--space-2) * -1)}}.sidebar-content{flex:1;overflow-y:auto;padding:var(--space-3)}.sidebar-section-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);padding:var(--space-3) var(--space-2) var(--space-2);letter-spacing:.08em}.project-list{display:flex;flex-direction:column;gap:2px}.project-item{display:flex;align-items:center;padding:10px 10px 10px 2px;margin:0 2px 1px 0;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);border:1px solid transparent;position:relative;gap:0}.project-item:hover{background:var(--bg-hover);color:var(--text-primary)}.project-item.active{background:var(--bg-active);color:var(--primary-600);border-color:#6366f11f}[data-theme=dark] .project-item.active{color:var(--primary-400);border-color:#818cf826}.project-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;background:var(--primary-500);border-radius:0 3px 3px 0}.project-item-left{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-right:10px}.project-expand-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.project-expand-btn:hover{background:var(--bg-quaternary);color:var(--text-primary)}.project-expand-placeholder{width:18px;flex-shrink:0}.project-item-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0}.project-item:hover .project-item-icon{color:var(--primary-500);background:var(--primary-100)}[data-theme=dark] .project-item:hover .project-item-icon{background:#6366f126}.project-item.active .project-item-icon{color:var(--primary-500);background:var(--primary-100)}[data-theme=dark] .project-item.active .project-item-icon{color:var(--primary-400);background:#6366f133}.project-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.project-item-title{font-weight:500;font-size:.875rem;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary);letter-spacing:-.01em}.project-item:hover .project-item-title,.project-item.active .project-item-title{color:var(--text-primary)}.project-item-meta{font-size:.6875rem;color:var(--text-muted);line-height:1.3;display:flex;align-items:center;gap:3px;opacity:.85}.project-edit-input{padding:4px 8px!important;font-size:.875rem!important;border-radius:var(--radius-sm)!important;height:28px}.project-item-actions{display:flex;align-items:center;gap:2px;margin-left:8px;flex-shrink:0}.project-action-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);opacity:.5}.project-action-btn:hover{opacity:1;background:var(--bg-quaternary);color:var(--text-primary)}.project-item:hover .project-action-btn,.project-item.active .project-action-btn{opacity:.7}.project-action-btn-danger:hover{background:var(--error-bg);color:var(--error-main)}.chapter-list{padding-left:var(--space-4);margin-top:2px;border-left:1px dashed var(--border-color);margin-left:32px;margin-bottom:4px}.chapter-list-item{padding:5px 10px;font-size:.75rem;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;gap:6px;transition:all var(--transition-fast);line-height:1.4}.chapter-list-item:hover{background:var(--bg-hover);color:var(--text-primary)}.chapter-list-item svg{opacity:.5;flex-shrink:0}.sidebar-chapter-list{padding-left:52px;padding-bottom:var(--space-2);padding-right:var(--space-2)}.sidebar-chapter-item{padding:5px 10px;font-size:.75rem;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;gap:6px;transition:all var(--transition-fast);line-height:1.4}.sidebar-chapter-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-chapter-icon{opacity:.45;flex-shrink:0;color:var(--text-muted)}.sidebar-chapter-item:hover .sidebar-chapter-icon{opacity:.7;color:var(--primary-500)}.sidebar-chapter-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-chapter-more{padding:4px 10px;font-size:.6875rem;color:var(--text-muted);opacity:.7}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}.header{height:var(--header-height);background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);flex-shrink:0;position:relative;z-index:1001;transition:background-color var(--transition-normal);-webkit-app-region:drag}.header button,.header a,.header input,.header select,.header .no-drag{-webkit-app-region:no-drag}.header-left{display:flex;align-items:center;gap:var(--space-4)}.header-title{font-size:1.0625rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.header-right{width:auto;display:flex;align-items:center;gap:var(--space-3);position:relative;isolation:isolate;flex-shrink:0;flex-wrap:nowrap}.header-right .btn:before{display:none}.header-right .btn.btn-primary,.header-right .btn.btn-secondary{color:var(--text-primary)!important;background:var(--bg-tertiary)!important;border:1px solid var(--border-color)!important}.header-right .btn.btn-primary{border-color:var(--primary-500)!important;box-shadow:0 0 0 2px #6366f133}.view-tabs{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-6);background:var(--bg-primary);border-bottom:1px solid var(--border-color);align-items:center}.view-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative}.view-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.view-tab.active{background:var(--bg-active);color:var(--primary-600);font-weight:600}[data-theme=dark] .view-tab.active{color:var(--primary-400)}.workspace{flex:1;display:flex;overflow:hidden;position:relative}.workspace-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;width:100%;transition:all var(--transition-normal);background:var(--bg-primary)}.workspace-right{width:var(--right-panel-width);display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary);border-left:1px solid var(--border-color);transition:width var(--transition-normal),opacity var(--transition-normal);flex-shrink:0}.workspace-right.collapsed{width:0;border-left:none;opacity:0}.right-panel-tabs{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-color);background:var(--bg-tertiary);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.right-panel-tabs::-webkit-scrollbar{display:none}.right-tab{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 10px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex:1;min-width:0}.right-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.right-tab.active{background:var(--bg-active);color:var(--primary-500);font-weight:600;box-shadow:none}[data-theme=dark] .right-tab.active{color:var(--primary-400)}.chat-panel{display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden;height:100%;flex:1;min-height:0}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-6);display:flex;flex-direction:column;gap:var(--space-6)}.message{display:flex;gap:var(--space-3);max-width:85%;animation:messageIn .3s cubic-bezier(.2,0,.2,1)}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end;flex-direction:row-reverse}.message-avatar{width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0;color:var(--primary-500);border:1px solid var(--border-color)}.message.user .message-avatar{background:var(--primary-100);color:var(--primary-700);border-color:transparent}[data-theme=dark] .message.user .message-avatar{background:var(--primary-900);color:var(--primary-300)}.message-content{background:var(--bg-secondary);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border-color);position:relative;box-shadow:var(--shadow-sm);color:var(--text-primary)}.message.user .message-content{background:var(--primary-600);border-color:transparent;color:#fff;border-bottom-right-radius:var(--radius-xs)}[data-theme=light] .message.user .message-content{background:var(--primary-600);box-shadow:0 2px 8px #6366f140}.message-text{font-size:.9375rem;line-height:1.6}.message-text p{margin-bottom:var(--space-3)}.message-text p:last-child{margin-bottom:0}.message-text code{background:#0000004d;padding:2px 6px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.875em}.message-text pre{background:#0006;padding:var(--space-3);border-radius:var(--radius-md);overflow-x:auto;margin:var(--space-3) 0}.message-text ol,.message-text ul{padding-left:1.5em;margin:var(--space-2) 0}.message-text ol{list-style-type:decimal}.message-text ul{list-style-type:disc}.message-text li{margin-bottom:var(--space-1)}.chat-input-container{padding:var(--space-3) var(--space-4);background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border-color);margin-top:auto;flex-shrink:0}.chat-input-wrapper{display:flex;align-items:center;gap:var(--space-3);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);transition:all var(--transition-normal);position:relative}.chat-input-wrapper:before{content:"";position:absolute;inset:-3px;background:var(--gradient-primary);border-radius:calc(var(--radius-xl) + 3px);opacity:0;z-index:-1;transition:opacity var(--transition-normal)}.chat-input-wrapper:focus-within{border-color:var(--primary-500);box-shadow:var(--shadow-glow)}.chat-input-wrapper:focus-within:before{opacity:.1}.chat-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.9375rem;resize:none;min-height:24px;max-height:150px;font-family:inherit;line-height:1.5}.chat-input::placeholder{color:var(--text-muted)}.quick-commands-btn{position:relative;width:40px;height:40px;border-radius:var(--radius-lg);border:2px solid var(--border-color);background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.quick-commands-btn:hover{border-color:var(--primary-400);color:var(--primary-500);background:linear-gradient(135deg,var(--primary-50, rgba(99, 102, 241, .1)) 0%,var(--primary-100, rgba(99, 102, 241, .15)) 100%);transform:scale(1.05);box-shadow:0 4px 12px #6366f133}.quick-commands-btn.active{border-color:var(--primary-500);color:var(--primary-600);background:linear-gradient(135deg,var(--primary-100) 0%,var(--primary-200, rgba(99, 102, 241, .25)) 100%);box-shadow:0 4px 16px #6366f159,inset 0 1px 2px #fff3;transform:scale(1.02)}[data-theme=dark] .quick-commands-btn{background:linear-gradient(135deg,#1e1e32cc,#28284699);border-color:#6366f14d}[data-theme=dark] .quick-commands-btn:hover{background:linear-gradient(135deg,#6366f133,#818cf826);border-color:var(--primary-400);color:var(--primary-400)}[data-theme=dark] .quick-commands-btn.active{background:linear-gradient(135deg,#6366f14d,#818cf840);border-color:var(--primary-400);color:var(--primary-300)}@keyframes twinkle{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.outline-panel{background:var(--bg-secondary);display:flex;flex-direction:column;overflow:hidden;height:100%}.outline-header{padding:8px 12px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;background:var(--bg-tertiary);flex-shrink:0;min-height:40px}.outline-title{font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:6px;color:var(--text-primary)}.outline-content{flex:1;overflow-y:auto;padding:8px 12px}.outline-section{margin-bottom:8px}.outline-section-header{display:flex;align-items:center;gap:4px;padding:6px 4px;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;border-radius:var(--radius-sm);transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none}.outline-section-header:hover{background:var(--bg-hover);color:var(--text-primary)}.outline-item{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;border:1px solid transparent;margin-bottom:2px;position:relative}.outline-item:hover{background:var(--bg-hover);color:var(--text-primary)}.outline-item-icon{margin-top:3px;color:var(--text-muted);flex-shrink:0;transition:color var(--transition-normal);width:16px;display:flex;justify-content:center}.outline-item:hover .outline-item-icon{color:var(--primary-500)}.outline-item-content{flex:1;min-width:0}.outline-item-title{font-weight:500;color:var(--text-primary);line-height:1.4}.outline-item-desc{font-size:.75rem;color:var(--text-muted);margin-top:2px;line-height:1.5}.outline-item-actions{position:absolute;right:4px;top:4px;display:flex;gap:2px;opacity:0;transition:opacity .2s ease;background:var(--bg-hover);padding-left:8px;border-radius:var(--radius-sm);z-index:5;box-shadow:-4px 0 8px var(--bg-hover)}.outline-item:hover .outline-item-actions{opacity:1}.tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-md);font-size:.75rem;font-weight:500;letter-spacing:0;transition:all var(--transition-fast)}.tag.character{background:var(--primary-100);color:var(--primary-700)}[data-theme=dark] .tag.character{background:#6366f133;color:var(--primary-300)}.tag.scene{background:var(--accent-100);color:var(--accent-700)}[data-theme=dark] .tag.scene{background:#06b6d433;color:var(--accent-300)}.tag.plot{background:var(--success-light);color:var(--success-text)}[data-theme=dark] .tag.plot{background:#22c55e33;color:var(--success-400)}.tag.foreshadow{background:linear-gradient(135deg,#f59e0b33,#fbbf2433);color:var(--warning-400);border:1px solid rgba(245,158,11,.3)}.tag:hover{transform:scale(1.05)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:before{opacity:1}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 14px #6366f159}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--primary-500)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md);position:relative;overflow:hidden}.btn-icon:before{display:none}.btn-sm{padding:var(--space-1) var(--space-3);font-size:.8125rem;border-radius:var(--radius-md)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:1rem}.modal-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;z-index:1001;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border-radius:var(--radius-2xl);border:1px solid var(--border-color);box-shadow:var(--shadow-xl),0 0 60px #6366f126;width:90%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;animation:modalIn .3s cubic-bezier(.4,0,.2,1);overflow:hidden}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;background:var(--bg-tertiary)}.modal-title{font-size:1.25rem;font-weight:700;display:flex;align-items:center;gap:var(--space-2)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--space-3);background:var(--bg-tertiary)}.form-group{margin-bottom:var(--space-5)}.form-label{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;font-weight:600;margin-bottom:var(--space-2);color:var(--text-secondary)}.form-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.9375rem;font-family:inherit;transition:all var(--transition-normal)}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px #6366f126}.form-input::placeholder{color:var(--text-muted)}textarea.form-input{resize:vertical;min-height:80px;line-height:1.6}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:48px;cursor:pointer}.tabs{display:flex;gap:var(--space-1);background:var(--bg-tertiary);padding:var(--space-1);border-radius:var(--radius-lg)}.tab{flex:1;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:transparent;text-align:center}.tab:hover{color:var(--text-primary);background:var(--bg-hover)}.tab.active{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.version-panel{background:var(--bg-secondary);display:flex;flex-direction:column;overflow:hidden}.diff-viewer{flex:1;overflow-y:auto;padding:var(--space-4)}.diff-line{font-family:var(--font-mono);font-size:.8125rem;padding:var(--space-2) var(--space-3);margin:var(--space-1) 0;border-radius:var(--radius-sm)}.diff-line.added{background:#22c55e26;border-left:3px solid var(--success-500);color:var(--success-400)}.diff-line.removed{background:#ef444426;border-left:3px solid var(--error-500);color:var(--error-400);text-decoration:line-through}.diff-line.unchanged{color:var(--text-muted)}.provider-card{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-4);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.provider-card:before{content:"";position:absolute;inset:0;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-normal)}.provider-card.active{border-color:var(--primary-500);box-shadow:var(--shadow-glow)}.provider-card.active:before{opacity:.05}.provider-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);position:relative;z-index:1}.provider-models{display:flex;flex-wrap:wrap;gap:var(--space-2);position:relative;z-index:1}.loading-dots{display:inline-flex;gap:6px}.loading-dots span{width:8px;height:8px;background:var(--gradient-primary);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center;color:var(--text-muted)}.empty-state-icon{font-size:3.5rem;margin-bottom:var(--space-5);opacity:.4;filter:grayscale(.5)}.empty-state-title{font-size:1.125rem;font-weight:600;margin-bottom:var(--space-2);color:var(--text-secondary)}.empty-state-desc{font-size:.9375rem;line-height:1.6;max-width:280px}.editor-panel{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-1) var(--space-2);background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);gap:var(--space-1);flex-wrap:wrap;min-height:36px;position:relative;z-index:100}.editor-toolbar-left,.editor-toolbar-right{display:flex;align-items:center;gap:1px;flex-wrap:wrap}.editor-toolbar-left>div,.editor-toolbar-right>div{display:flex;align-items:center;gap:0}.editor-toolbar .btn-ghost.btn-icon.btn-sm{width:26px;height:26px;min-width:26px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.editor-toolbar .btn-ghost.btn-icon.btn-sm:hover{background:var(--bg-hover);transform:scale(1.05)}.editor-toolbar .btn-ghost.btn-icon.btn-sm:active{transform:scale(.95)}.editor-stats{font-size:.75rem;color:var(--text-muted);padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-full);white-space:nowrap}.editor-saved{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--success-400);padding:var(--space-1) var(--space-2);background:#22c55e1a;border-radius:var(--radius-full);white-space:nowrap}.editor-content{flex:1;padding:var(--space-6) var(--space-8);overflow-y:auto}.editor-textarea{width:100%;height:100%;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:1.0625rem;line-height:2;resize:none;font-family:var(--font-sans)}.editor-textarea::placeholder{color:var(--text-muted);line-height:1.8}.selection-ai-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.selection-ai-menu .btn:hover{background:var(--primary-50)!important;color:var(--primary-600)}.editor-preview h1,.editor-preview h2,.editor-preview h3{margin-top:1.5em;margin-bottom:.5em;font-weight:600;line-height:1.4}.editor-preview h1{font-size:1.75em}.editor-preview h2{font-size:1.5em}.editor-preview h3{font-size:1.25em}.editor-preview p{margin-bottom:1em;line-height:2}.editor-preview blockquote{border-left:4px solid var(--primary-400);margin:1em 0;color:var(--text-secondary);background:var(--bg-tertiary);padding:.5em 1em;border-radius:0 var(--radius-md) var(--radius-md) 0}.editor-preview ul,.editor-preview ol{margin:1em 0;padding-left:2em}.editor-preview li{margin-bottom:.5em}.editor-preview hr{border:none;border-top:2px solid var(--border-color);margin:2em 0}.editor-preview del{text-decoration:line-through;color:var(--text-muted)}.editor-preview mark{background:linear-gradient(120deg,#ffe6004d,#ffc80066);padding:.1em .3em;border-radius:var(--radius-sm);color:inherit}@media(max-width:1400px){.workspace{grid-template-columns:1fr 280px}.workspace-bottom-chat{height:240px}}@media(max-width:1200px){.workspace{grid-template-columns:1fr}.sidebar{width:260px}}@media(max-width:900px){.sidebar{position:fixed;left:-280px;top:0;height:100%;z-index:1010;transition:left var(--transition-normal);box-shadow:var(--shadow-xl)}.sidebar.open{left:0}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:1009;opacity:0;visibility:hidden;transition:all var(--transition-normal)}.sidebar-overlay.visible{opacity:1;visibility:visible}.header{padding:0 var(--space-3)}.header-left{flex:1;min-width:0}.header-title{font-size:.875rem;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{gap:var(--space-2);flex-shrink:0;overflow:visible}.user-menu-button{padding:4px 8px!important;min-height:36px;border-radius:10px!important}.user-avatar{width:24px!important;height:24px!important;font-size:11px!important}.storage-mode-btn{min-width:auto;min-height:auto;width:36px!important;height:36px!important;padding:0!important;border-radius:10px!important;justify-content:center!important}.storage-mode-btn .mode-text,.storage-mode-btn .chevron{display:none!important}.storage-mode-btn .mode-icon{margin:0}.mobile-model-btn{min-width:auto;min-height:auto;width:36px!important;height:36px!important;border-radius:10px!important}.save-version-btn .save-version-text{display:none}.save-version-btn{width:36px!important;height:36px!important;min-width:36px!important;padding:0!important;border-radius:10px!important;display:flex!important;align-items:center!important;justify-content:center!important}.view-tabs{padding:var(--space-2) var(--space-4);overflow-x:auto;-webkit-overflow-scrolling:touch}.view-tab{white-space:nowrap;flex-shrink:0}.mobile-menu-btn{display:flex!important}.version-dialog-overlay{top:0;padding:20px;align-items:center}.version-dialog-modal{max-width:340px!important;width:100%}.version-dialog-modal .modal-header{padding:var(--space-4)}.version-dialog-modal .modal-title{font-size:1rem}.version-dialog-modal .modal-body{padding:var(--space-4)}.version-dialog-modal .modal-footer{padding:var(--space-3) var(--space-4)}.chat-input-container{padding:var(--space-3)}.editor-toolbar{gap:var(--space-1);padding:var(--space-2);overflow:visible}.editor-toolbar-left{flex:1;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap!important;min-width:0;padding-bottom:2px}.editor-toolbar-left::-webkit-scrollbar{display:none}.editor-toolbar-left>div{flex-shrink:0}.editor-toolbar-right{gap:var(--space-1);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap!important;min-width:0;padding-bottom:2px}.editor-toolbar .ai-button{margin-right:5px!important;flex-shrink:0;width:auto!important;padding-left:10px!important;padding-right:10px!important}.editor-toolbar .ai-button svg{display:none!important}.editor-toolbar .btn span{display:none}.editor-toolbar .btn-sm{min-height:36px;min-width:36px;padding:8px}.editor-content{padding:var(--space-4)}}@media(max-width:768px){:root{--space-4: 14px;--space-5: 16px;--space-6: 20px}.header{height:52px}.view-tabs{gap:var(--space-1)}.view-tab{padding:var(--space-2) var(--space-3);font-size:.8125rem}.chat-messages{padding:var(--space-3);gap:var(--space-3)}.message{max-width:92%}.message-avatar{width:32px;height:32px}.message-content{padding:var(--space-3)}.message-text{font-size:.875rem}.chat-input-wrapper{padding:var(--space-2);border-radius:var(--radius-lg)}.chat-input{font-size:1rem}.btn{padding:var(--space-2) var(--space-3);font-size:.75rem;min-height:40px}.btn-icon{width:40px;height:40px}.btn-sm{min-height:36px}.form-input{padding:var(--space-3);font-size:1rem;min-height:44px}.modal{width:95%;max-width:none;max-height:90vh;margin:var(--space-3)}.modal-header,.modal-body{padding:var(--space-4)}.modal-footer{padding:var(--space-3) var(--space-4);flex-wrap:wrap}.tabs{width:100%}.tab{padding:var(--space-2) var(--space-3);font-size:.8125rem}.editor-textarea{font-size:1rem;line-height:1.8}.editor-toolbar-left,.editor-toolbar-right{flex-wrap:wrap}.project-item{padding:var(--space-3)}.project-item-icon{width:36px;height:36px}.quick-commands{flex-wrap:wrap}.hide-mobile{display:none!important}}@media(max-width:480px){.header-title{font-size:.8125rem;max-width:90px}.header-right{gap:var(--space-1)}.view-tab span{display:none}.view-tab svg{margin-right:0}.message{max-width:95%}.message-avatar{width:28px;height:28px;font-size:.6875rem}.btn{padding:var(--space-2)}.btn-sm{padding:var(--space-1) var(--space-2);font-size:.75rem}.modal-title{font-size:1rem}.provider-card{padding:var(--space-3)}.outline-panel,.version-panel,.editor-toolbar{padding:var(--space-2)}.editor-toolbar-left .btn span,.editor-toolbar-right .btn span{display:none}}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.mobile-menu-btn:hover{background:var(--bg-hover)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:auto;min-height:60px;padding-bottom:env(safe-area-inset-bottom,0px);background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-color);z-index:50;grid-template-columns:repeat(6,1fr);box-sizing:border-box}.mobile-bottom-nav:after{content:"";position:absolute;bottom:0;left:0;right:0;height:env(safe-area-inset-bottom,0px);background:var(--bg-primary);z-index:-1}@media(max-width:900px){.mobile-bottom-nav{display:flex;align-items:center}.chat-panel{padding-bottom:0}.chat-messages{padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}.chat-input-container{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom,0px));left:0;right:0;margin:0;z-index:49;border-radius:0}.editor-panel{padding-bottom:0}.app-container,.main-content{max-width:100vw;overflow-x:hidden}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--space-1);background:transparent;border:none;color:var(--text-muted);font-size:.625rem;cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-sm);min-width:0;width:100%}.mobile-nav-item:hover,.mobile-nav-item.active{color:var(--primary-400);background:#6366f11a}.mobile-nav-item svg{width:22px;height:22px}.mobile-right-panel{display:none}@media(max-width:900px){.mobile-right-panel{display:block;position:fixed;right:-100%;top:0;bottom:0;width:85%;max-width:350px;background:var(--bg-secondary);z-index:1010;transition:right var(--transition-normal);box-shadow:var(--shadow-xl)}.mobile-right-panel.open{right:0}}@media(hover:none)and (pointer:coarse){.btn{min-height:44px}.btn-sm{min-height:38px}.btn-icon{min-width:44px;min-height:44px}.form-input,.form-select{min-height:48px}.tab{min-height:44px}.project-item{min-height:56px}.outline-item{min-height:48px}.project-item:hover,.outline-item:hover,.btn:hover{transform:none}.project-item:active,.outline-item:active{background:var(--bg-hover)}.btn:active{transform:scale(.97)}.btn,.tab,.project-item,.outline-item{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}}@supports (padding-bottom: env(safe-area-inset-bottom)){.mobile-bottom-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(60px + env(safe-area-inset-bottom))}@media(max-width:768px){.chat-panel,.editor-panel{padding-bottom:0}.chat-input-container{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom));left:0;right:0;margin:0;z-index:49}}}@media(max-height:500px)and (orientation:landscape){.header{height:44px}.view-tabs{padding:var(--space-1) var(--space-4)}.chat-messages{padding:var(--space-2)}.mobile-bottom-nav{height:50px}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-bounce{animation:bounceIn .5s cubic-bezier(.68,-.55,.265,1.55)}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}.animate-slide-up{animation:slideUp .3s ease}.animate-fade-in{animation:fadeIn .3s ease}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-gradient-accent{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.75rem;font-weight:500;white-space:pre-wrap;max-width:220px;text-align:center;line-height:1.5;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:1000;box-shadow:var(--shadow-lg);color:var(--text-primary);pointer-events:none}[data-tooltip]:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}[data-tooltip-position=bottom]:after{bottom:auto;top:calc(100% + 8px)}[data-tooltip-position=bottom]:hover:after{transform:translate(-50%) translateY(4px)}[data-tooltip-position=left]:after{bottom:auto;top:50%;left:auto;right:calc(100% + 8px);transform:translateY(-50%) translate(4px)}[data-tooltip-position=left]:hover:after{transform:translateY(-50%) translate(-4px)}[data-tooltip-position=right]:after{bottom:auto;top:50%;left:calc(100% + 8px);right:auto;transform:translateY(-50%) translate(-4px)}[data-tooltip-position=right]:hover:after{transform:translateY(-50%) translate(4px)}.provider-card{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-4);cursor:pointer;transition:all var(--transition-normal);position:relative}.provider-card:hover{border-color:var(--primary-500);transform:translateY(-2px);box-shadow:var(--shadow-md)}.provider-card.active{border-color:var(--primary-500);box-shadow:var(--shadow-glow);background:#6366f10d}.provider-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.provider-name{font-weight:700;font-size:1rem;display:flex;align-items:center;gap:var(--space-2)}.provider-status{display:flex;align-items:center;gap:var(--space-1);font-size:.75rem;font-weight:600;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.provider-status.connected{color:var(--success-400);background:#22c55e26}.provider-status.error{color:var(--error-400);background:#ef444426}.provider-models{display:flex;flex-wrap:wrap;gap:var(--space-2)}.provider-card .form-group{position:relative;z-index:1}.provider-card .form-input{position:relative;z-index:2;cursor:text}.provider-card .form-input:focus{z-index:3}.provider-card .btn{position:relative;z-index:2}.provider-card:before{content:none}.editor-preview{font-family:var(--font-serif);color:var(--text-primary)}.editor-preview h1{font-size:1.75rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-500);color:var(--text-primary)}.editor-preview h2{font-size:1.4rem;font-weight:600;margin-top:1.5rem;margin-bottom:.75rem;color:var(--text-primary)}.editor-preview h3{font-size:1.2rem;font-weight:600;margin-top:1.25rem;margin-bottom:.5rem;color:var(--text-secondary)}.editor-preview p{margin-bottom:1rem;text-indent:2em;text-align:justify}.editor-preview blockquote{border-left:4px solid var(--primary-400);padding-left:1rem;margin:1rem 0;font-style:italic;color:var(--text-secondary);background:var(--bg-tertiary);padding:1rem 1.5rem;border-radius:0 var(--radius-md) var(--radius-md) 0}.editor-preview strong{font-weight:700;color:var(--text-primary)}.editor-preview em{font-style:italic}.editor-preview ul,.editor-preview ol{margin-bottom:1rem;padding-left:2rem}.editor-preview li{margin-bottom:.25rem}.editor-preview hr{border:none;height:2px;background:linear-gradient(90deg,transparent,var(--border-color),transparent);margin:2rem 0}.editor-preview code{background:var(--bg-tertiary);padding:.2em .4em;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.9em}.editor-preview pre{background:var(--bg-tertiary);padding:1rem;border-radius:var(--radius-md);overflow-x:auto;margin:1rem 0}.editor-preview pre code{background:none;padding:0}.position-highlight,.text-highlight{background:#6366f159!important;border-radius:6px;animation:highlightPulse 1.5s ease-out;transition:background .5s ease;box-shadow:0 0 0 2px #6366f14d}@keyframes highlightPulse{0%{background:#6366f199!important;box-shadow:0 0 12px #6366f180}50%{background:#6366f166!important;box-shadow:0 0 6px #6366f14d}to{background:#6366f159!important;box-shadow:0 0 0 2px #6366f14d}}[data-theme=dark] .position-highlight,[data-theme=dark] .text-highlight{background:#8b94f866!important;box-shadow:0 0 0 2px #8b94f859}[data-theme=dark] .position-highlight:not(:hover),[data-theme=dark] .text-highlight:not(:hover){animation:highlightPulseDark 1.5s ease-out}@keyframes highlightPulseDark{0%{background:#8b94f8a6!important;box-shadow:0 0 12px #8b94f880}50%{background:#8b94f880!important;box-shadow:0 0 6px #8b94f84d}to{background:#8b94f866!important;box-shadow:0 0 0 2px #8b94f859}}@media(max-width:768px){.btn,button{min-height:44px;min-width:44px}.btn-sm{min-height:36px;min-width:36px}.btn-icon{padding:10px}.form-input,.form-textarea,input,textarea{font-size:.9rem!important;min-height:44px}.project-item{min-height:52px;padding:10px 8px 10px 4px;gap:0}.project-item-left{gap:2px;margin-right:6px}.project-item-icon{display:none}.project-expand-btn{width:20px;height:20px;min-width:20px;min-height:20px}.project-expand-placeholder{width:20px}.project-item-actions{gap:0;margin-left:4px}.project-action-btn{width:28px;height:28px;min-width:28px;min-height:28px;padding:0;opacity:.6}.chat-input-container{padding:var(--space-3);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px))}.message{max-width:90%}.message-content{padding:var(--space-3)}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:1010;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:70vw;max-width:320px}.sidebar.open{transform:translate(0)}.mobile-right-panel{position:fixed;right:0;top:0;bottom:0;width:85vw;max-width:360px;z-index:1010;background:var(--bg-secondary);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-10px 0 30px #0003}.mobile-right-panel.open{transform:translate(0)}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:1009;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.header{padding:var(--space-2) var(--space-3);min-height:48px}.header-title{font-size:.9375rem}.view-tab{padding:var(--space-2) var(--space-3);font-size:.8125rem}.story-editor-container{padding:var(--space-2)}.story-editor{font-size:1rem;line-height:1.8;padding:var(--space-4)}.fullscreen-container{padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}}@media(max-width:375px){.sidebar,.mobile-right-panel{width:100vw;max-width:none}.header-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.pwa-install-prompt{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom,0px));left:var(--space-4);right:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);box-shadow:var(--shadow-xl);z-index:1001;animation:slideUp .3s ease}@media(hover:none){.btn:active,button:active,.project-item:active,.model-item:active{opacity:.7;transform:scale(.98)}}.story-editor,.message-text{-webkit-user-select:text;user-select:text}@media(max-width:768px){.modal-overlay{padding:0;align-items:flex-end}.modal{width:100%;max-width:100%;height:95vh;max-height:95vh;margin:0;border-radius:var(--radius-2xl);animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--space-4);position:sticky;top:0;z-index:10;background:var(--bg-tertiary)}.modal-title{font-size:1.125rem}.modal-body{padding:var(--space-4);flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-footer{padding:var(--space-3) var(--space-4);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px));flex-direction:column;gap:var(--space-2);position:sticky;bottom:0;z-index:10}.modal-footer .btn{width:100%;justify-content:center}.analysis-config-modal{max-height:85vh!important;height:fit-content!important;margin:auto!important}.modal-overlay:has(.analysis-config-modal){align-items:center!important;padding:var(--space-4)!important}}@media(max-width:768px){.modal[style*="maxWidth: '900px'"],.modal[style*="max-width: 900px"]{height:var(--app-height, 100vh)!important;max-height:var(--app-height, 100vh)!important;border-radius:0!important}div[style*="gridTemplateColumns: '240px"]{display:flex!important;flex-direction:column!important}.tabs{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex-shrink:0}}@media(max-width:520px){.welcome-modal{width:100%!important;max-width:100%!important;height:var(--app-height, 100vh)!important;max-height:var(--app-height, 100vh)!important;border-radius:0!important}.welcome-features{grid-template-columns:1fr!important}.welcome-actions{flex-direction:column!important}.welcome-actions .btn{width:100%!important}}@media(max-width:480px){.auth-modal-container{padding:0;align-items:flex-end}.auth-modal-content{width:100%;max-width:100%;height:95vh;max-height:95vh;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}}@media(max-width:768px){.model-selector-dropdown{position:fixed!important;left:var(--space-2)!important;right:var(--space-2)!important;top:auto!important;bottom:calc(60px + env(safe-area-inset-bottom,0px))!important;width:auto!important;max-height:60vh;border-radius:var(--radius-xl)}}@media(max-width:480px){.confirm-dialog,.alert-dialog{width:calc(100% - 32px)!important;max-width:none!important}}@media(max-width:768px){.toast-container{left:var(--space-2)!important;right:var(--space-2)!important;bottom:calc(70px + env(safe-area-inset-bottom,0px))!important;width:auto!important}}@media(max-width:768px){.form-group{margin-bottom:var(--space-4)}.form-input,.form-textarea,.form-select{font-size:16px!important;min-height:48px;padding:var(--space-3) var(--space-4)}.form-label{font-size:.875rem;margin-bottom:var(--space-2)}input[type=checkbox]{width:20px;height:20px}}@media(max-width:768px){.outline-item{padding:12px 10px;min-height:auto;gap:8px;flex-wrap:wrap}.outline-item-content{flex:1 1 calc(100% - 50px);min-width:0}.outline-item-actions{opacity:1;position:absolute;right:6px;top:50%;transform:translateY(-50%);flex-direction:column;background:transparent;box-shadow:none;padding:0;gap:2px}.outline-item-actions button{min-width:30px;min-height:30px;width:30px;height:30px;padding:6px;border-radius:var(--radius-sm);background:var(--bg-tertiary)}.outline-item-actions button:active{background:var(--bg-quaternary);transform:scale(.95)}.outline-item{position:relative;padding-right:40px}.character-card,.outline-character-item{padding:14px;gap:12px}.tag{min-height:28px;padding:4px 10px;font-size:.8125rem}.outline-header-actions,.outline-quick-actions{display:flex;gap:6px;flex-wrap:wrap}.outline-header-actions .btn,.outline-quick-actions .btn{min-height:40px;min-width:40px;padding:8px 12px;font-size:.8125rem}.analyze-btn,.dedupe-btn,.conflict-btn,.health-btn{min-height:44px;flex:1;justify-content:center;gap:6px}}@media(max-width:768px){.mobile-nav-item{padding:var(--space-2);gap:4px;font-size:.6875rem;font-weight:500}.mobile-nav-item svg{width:24px;height:24px;transition:all var(--transition-fast)}.mobile-nav-item.active{background:#6366f11f;color:var(--primary-500);border-radius:var(--radius-md)}.mobile-nav-item.active svg{transform:scale(1.1)}[data-theme=dark] .mobile-nav-item.active{background:#8b94f826;color:var(--primary-400)}}@media(max-width:768px){.project-item-title{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;max-height:2.8em}.sidebar-chapter-title{max-width:none}.outline-item-title{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.outline-item-desc{-webkit-line-clamp:3;line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}}@media(max-width:768px){.editor-toolbar .btn,.editor-toolbar button{min-width:40px;min-height:40px;padding:10px}.editor-toolbar-left:after{content:"";position:absolute;right:0;top:0;bottom:0;width:24px;background:linear-gradient(to right,transparent,var(--bg-secondary));pointer-events:none;opacity:.8}.editor-toolbar{position:relative}.editor-metadata,.word-count-display{font-size:.75rem;padding:var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-sm);white-space:nowrap}}@media(max-width:480px){.header{gap:var(--space-2)}.header-right{gap:var(--space-1)}.header-right .btn span:not(.btn-icon-only){display:none}.sync-indicator{padding:var(--space-1) var(--space-2);font-size:.6875rem}.header-title{flex:1;min-width:0}}@media(max-width:768px){.quick-command-btn,.quick-commands .btn{min-height:40px;padding:8px 14px;font-size:.8125rem;border-radius:var(--radius-lg)}.chat-input-wrapper .quick-commands-btn,.chat-input-wrapper .btn-primary{width:35px;height:35px;min-width:35px;min-height:35px}.quick-commands-panel{position:fixed!important;bottom:calc(139px + env(safe-area-inset-bottom,0px))!important;left:0!important;right:0!important;z-index:48;max-height:40vh;overflow-y:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 20px #0000001a}.active-command-bar-Sparkles{display:none}.active-command-bar{position:fixed!important;bottom:calc(139px + env(safe-area-inset-bottom,0px))!important;left:0!important;right:0!important;z-index:48}.message-actions button{min-width:36px;min-height:36px}.chat-send-btn,.send-button{min-width:44px;min-height:44px}}@media(max-width:768px){.model-item,.provider-item,.settings-item{min-height:52px;padding:14px 16px}.toggle-switch{min-width:52px;min-height:28px}.select-dropdown option{padding:12px;min-height:44px}}@media(max-width:768px){.right-panel-tabs{padding:var(--space-2);gap:var(--space-1)}.right-tab{min-height:40px;padding:8px 12px;font-size:.8125rem;font-weight:500}.right-tab.active{font-weight:600}}@media(max-width:900px){.app-container{height:var(--app-height, 100vh);min-height:var(--app-height, 100vh);max-height:var(--app-height, 100vh)}.main-content{height:calc(var(--app-height, 100vh) - 64px - env(safe-area-inset-bottom,0px));overflow:hidden}.sidebar,.mobile-right-panel{height:var(--app-height, 100vh)}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0}}@media(max-width:768px){.modal-overlay{height:var(--app-height, 100vh)}.modal{max-height:calc(var(--app-height, 100vh) - 20px)}.modal.fullscreen .modal-header,.settings-modal .modal-header{padding-top:calc(var(--space-3) + env(safe-area-inset-top,0px))}}html.pwa-standalone,html.pwa-standalone body{height:100vh!important;min-height:100vh!important;max-height:100vh!important;overflow:hidden;background:var(--bg-primary);position:fixed;width:100%;top:0;left:0}.pwa-standalone #root{height:100vh!important;overflow:hidden;background:var(--bg-primary)}.pwa-standalone .header{padding-top:env(safe-area-inset-top,0px);min-height:calc(var(--header-height) + env(safe-area-inset-top,0px));box-sizing:border-box}.pwa-standalone .app-container{height:100vh!important;min-height:100vh!important;max-height:100vh!important;overflow:hidden;background:var(--bg-primary)}.pwa-standalone .mobile-bottom-nav{position:fixed!important;bottom:0!important;left:0!important;right:0!important;height:auto!important;min-height:unset!important;padding-top:6px!important;padding-bottom:env(safe-area-inset-bottom,0px)!important;box-sizing:border-box;z-index:100;background:var(--bg-primary)!important;border-top:1px solid var(--border-color)}.pwa-standalone .mobile-bottom-nav:before{content:"";position:absolute;left:0;right:0;bottom:0;height:env(safe-area-inset-bottom,0px);background:var(--bg-primary);z-index:-1}.pwa-standalone .sidebar{padding-top:env(safe-area-inset-top,0px);height:100vh;max-height:100vh;overflow-y:auto}.pwa-standalone .mobile-right-panel{padding-top:env(safe-area-inset-top,0px);height:100vh;max-height:100vh}.pwa-standalone .main-content{height:calc(100vh - var(--header-height) - env(safe-area-inset-top,0px));overflow:hidden}@media(max-width:900px){.pwa-standalone .main-content{height:calc(100vh - var(--header-height) - env(safe-area-inset-top,0px) - 60px - env(safe-area-inset-bottom,0px));overflow-y:auto;overflow-x:hidden}.pwa-standalone .chat-panel,.pwa-standalone .editor-panel{padding-bottom:calc(60px + env(safe-area-inset-bottom,0px))}}.pwa-standalone .modal-overlay.settings-overlay{z-index:10000!important}.pwa-standalone .settings-modal{position:fixed!important;inset:0!important;height:100vh!important;max-height:100vh!important;border-radius:0!important;margin:0!important;z-index:10001!important}.pwa-standalone .settings-modal .modal-header{padding:var(--space-2) var(--space-4);padding-top:calc(var(--space-3) + env(safe-area-inset-top,0px));margin-bottom:0;background:var(--bg-primary);min-height:52px;border-bottom:1px solid var(--border-color)}.pwa-standalone .settings-modal .modal-header h2{font-size:18px;font-weight:600}.pwa-standalone .settings-modal .settings-tabs{margin-top:0;padding:var(--space-2) var(--space-3)}.pwa-standalone .settings-modal .modal-body{height:calc(100vh - 52px - env(safe-area-inset-top,0px));padding-bottom:env(safe-area-inset-bottom,0px)}.pwa-standalone .welcome-modal-overlay{height:100vh;padding:0!important;z-index:10000!important}.pwa-standalone .welcome-modal{height:100vh;max-height:100vh;padding-top:calc(20px + env(safe-area-inset-top,0px));padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));border-radius:0}.ai-confirmation-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;padding:var(--space-4)}.ai-confirmation-modal{width:90%;max-width:420px;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--ai-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl),var(--ai-glow);padding:0;overflow:hidden;animation:ai-modal-enter .25s ease-out}@keyframes ai-modal-enter{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.ai-confirmation-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--ai-gradient);border-bottom:1px solid var(--ai-border)}.ai-confirmation-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--ai-bg);border-radius:var(--radius-md);color:var(--ai-accent);box-shadow:var(--ai-glow)}.ai-confirmation-title{flex:1;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.ai-confirmation-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.ai-confirmation-close:hover{background:var(--bg-hover);color:var(--text-primary)}.ai-confirmation-body{padding:var(--space-5)}.ai-confirmation-message{font-size:1rem;color:var(--text-primary);margin:0 0 var(--space-4);line-height:1.5}.ai-confirmation-notes{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.ai-confirmation-note{display:flex;align-items:flex-start;gap:var(--space-2);font-size:.875rem;color:var(--text-secondary);line-height:1.4}.ai-confirmation-note .note-bullet{color:var(--ai-accent);font-weight:600;flex-shrink:0}.ai-confirmation-footer{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.ai-confirmation-checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.ai-confirmation-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--ai-accent);cursor:pointer}.ai-confirmation-checkbox:hover{color:var(--text-primary)}.ai-confirmation-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.ai-confirmation-actions .btn-secondary{padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.ai-confirmation-actions .btn-secondary:hover{background:var(--bg-quaternary);color:var(--text-primary)}.ai-confirmation-actions .btn-primary.ai-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--ai-bg)!important;border:1px solid var(--ai-border)!important;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--ai-accent)!important;cursor:pointer;transition:all var(--transition-fast)}.ai-confirmation-actions .btn-primary.ai-button:hover{background:var(--ai-bg-hover)!important;box-shadow:var(--ai-glow)}@media(max-width:480px){.ai-confirmation-modal{width:95%;max-width:none;margin:var(--space-4)}.ai-confirmation-header{padding:var(--space-3) var(--space-4)}.ai-confirmation-body{padding:var(--space-4)}.ai-confirmation-footer{padding:var(--space-3) var(--space-4)}.ai-confirmation-actions{flex-direction:column}.ai-confirmation-actions .btn-secondary,.ai-confirmation-actions .btn-primary.ai-button{width:100%;justify-content:center;padding:var(--space-3)}}.ai-confirmation-mode-selection{margin:var(--space-3) 0;padding:var(--space-3);background:var(--surface-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.mode-option-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}.mode-options{display:flex;flex-direction:column;gap:var(--space-2)}.mode-option{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);border:2px solid transparent;background:var(--surface-primary);cursor:pointer;transition:all .2s ease}.mode-option:hover{border-color:var(--ai-border)}.mode-option.selected{border-color:var(--ai-accent);background:var(--ai-bg)}.mode-option input[type=radio]{margin-top:3px;accent-color:var(--ai-accent)}.mode-option-content{display:flex;flex-direction:column;gap:2px}.mode-name{font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.mode-recommended{font-size:var(--font-size-xs);font-weight:500;padding:2px 6px;background:var(--ai-accent);color:#fff;border-radius:var(--radius-sm)}.mode-desc{font-size:var(--font-size-sm);color:var(--text-secondary)}.mode-calls{color:var(--text-tertiary);margin-left:var(--space-1)}.release-notes-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--space-4);animation:fadeIn .2s ease}.release-notes-modal{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:400px;width:100%;max-height:70vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1);border:1px solid var(--border-color)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.release-notes-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--border-color)}.release-notes-header:before{display:none}.release-notes-icon{font-size:1.5rem;flex-shrink:0}.release-notes-header h2{font-size:1rem;font-weight:600;margin:0;color:var(--text-primary);flex:1}.release-notes-version{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:var(--space-1);background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-full)}.release-notes-date{opacity:.8}.release-notes-date:before{content:"·";margin-right:var(--space-1)}.release-notes-content{flex:1;overflow-y:auto;padding:var(--space-4)}.release-notes-section{margin-bottom:var(--space-4)}.release-notes-section:last-child{margin-bottom:0}.release-notes-section h3{font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2);text-transform:uppercase;letter-spacing:.02em}.release-notes-emoji{font-size:.9rem}.release-notes-section ul{list-style:none;padding:0;margin:0}.release-notes-section li{padding:var(--space-2) 0;padding-left:var(--space-4);color:var(--text-primary);font-size:.875rem;line-height:1.5;position:relative}.release-notes-section li:before{content:"";position:absolute;left:0;top:calc(var(--space-2) + .5em);width:5px;height:5px;background:var(--primary-400);border-radius:50%}.release-notes-section li+li{border-top:none}.release-notes-footer{padding:var(--space-3) var(--space-4);background:var(--bg-secondary);text-align:center;border-top:1px solid var(--border-color)}.release-notes-thanks{display:none}.release-notes-close-btn{background:var(--primary-500);color:#fff;border:none;border-radius:var(--radius-md);padding:var(--space-2) var(--space-6);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.release-notes-close-btn:hover{background:var(--primary-600);transform:translateY(-1px)}.release-notes-close-btn:active{transform:translateY(0)}@media(max-width:480px){.release-notes-modal{max-height:80vh;margin:var(--space-2)}.release-notes-header,.release-notes-content,.release-notes-footer{padding:var(--space-3)}}.knowledge-indicator{position:fixed;bottom:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:var(--space-2)}.knowledge-indicator-updating,.knowledge-indicator-success,.knowledge-indicator-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:.75rem;font-weight:500;box-shadow:var(--shadow-md);animation:knowledge-slide-in .3s ease-out}@keyframes knowledge-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.knowledge-indicator-updating{background:var(--ai-bg);border:1px solid var(--ai-border);color:var(--ai-accent)}.knowledge-indicator-updating .spin{animation:spin 1s linear infinite}.knowledge-indicator-success{background:var(--success-bg);border:1px solid rgba(34,197,94,.3);color:var(--success-text)}.knowledge-indicator-error{background:var(--error-bg);border:1px solid rgba(239,68,68,.3);color:var(--error-text)}.knowledge-indicator-dismiss{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;margin-left:var(--space-1);background:transparent;border:none;border-radius:var(--radius-xs);color:inherit;cursor:pointer;opacity:.6;transition:all var(--transition-fast)}.knowledge-indicator-dismiss:hover{opacity:1;background:#0000001a}@media(max-width:600px){.knowledge-indicator{bottom:80px;right:10px;left:10px}.knowledge-indicator-updating,.knowledge-indicator-success,.knowledge-indicator-error{justify-content:center}}.character-view-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--space-4);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.character-view-card{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 0 40px #8b5cf61a;max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}[data-theme=dark] .character-view-card{background:linear-gradient(135deg,#19192dfa,#232341f2);border-color:#8b5cf633;box-shadow:var(--shadow-xl),0 0 60px #8b5cf626}.card-close-btn{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;z-index:10;transition:all var(--transition-fast)}.card-close-btn:hover{background:var(--bg-quaternary);color:var(--text-primary);transform:scale(1.05)}.card-main-layout{display:flex;flex:1;overflow:hidden;padding:var(--space-4);gap:var(--space-4)}.prototype-showcase{width:360px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-3)}.media-switch-tabs{display:flex;gap:var(--space-2);background:var(--bg-tertiary);padding:var(--space-1);border-radius:var(--radius-md)}.media-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);font-size:.8125rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.media-tab:hover:not(:disabled){color:var(--text-primary);background:var(--bg-hover)}.media-tab.active{background:var(--bg-primary);color:var(--primary-600);box-shadow:var(--shadow-sm)}.media-tab:disabled{opacity:.4;cursor:not-allowed}.media-display{flex:1;min-height:300px;background:var(--bg-tertiary);border-radius:var(--radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center}.prototype-image,.prototype-video{width:100%;height:auto;max-height:70vh;object-fit:contain;border-radius:var(--radius-lg)}.prototype-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);width:100%}.image-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-full)}.nav-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.nav-btn:hover:not(:disabled){background:var(--primary-100);border-color:var(--primary-300);color:var(--primary-600)}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.nav-indicator{font-size:.75rem;font-weight:500;color:var(--text-muted);min-width:40px;text-align:center}.media-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);color:var(--text-muted);padding:var(--space-6);text-align:center}.media-placeholder span{font-size:.875rem}.character-info-panel{flex:1;min-width:0;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-4);padding-right:var(--space-2)}.char-header{padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.char-name-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);padding-right:40px}.char-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.char-role-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:.875rem;font-weight:600;margin-bottom:var(--space-2)}.char-description{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin:var(--space-2) 0}.trait-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.trait-tag{font-size:.75rem;padding:var(--space-1) var(--space-2);background:var(--ai-bg);border:1px solid var(--ai-border);border-radius:var(--radius-full);color:var(--ai-accent)}.info-section{background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);font-size:.875rem;font-weight:600;color:var(--text-secondary)}.section-header.clickable{cursor:pointer;transition:background var(--transition-fast)}.section-header.clickable:hover{background:var(--bg-hover)}.attribute-badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-2);padding:0 var(--space-3) var(--space-3)}.attribute-badge{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:all var(--transition-normal);position:relative;min-height:40px}.attribute-badge.filled{border-color:#8b5cf633}.attribute-badge.clickable{cursor:pointer}.attribute-badge.clickable:hover{border-color:#8b5cf666;background:var(--bg-tertiary);box-shadow:var(--shadow-sm)}.attribute-badge.expanded{grid-column:1 / -1;background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(139,92,246,.05) 100%);border-color:#8b5cf64d;animation:badgeExpand .25s ease-out}@keyframes badgeExpand{0%{opacity:.7;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.badge-icon{font-size:1rem;flex-shrink:0;margin-top:1px}.badge-label{font-size:.6875rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.badge-value{font-size:.75rem;font-weight:500;color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:all var(--transition-fast);line-height:1.4}.badge-value.full{white-space:normal;overflow:visible;text-overflow:unset;animation:fadeInText .2s ease-out}@keyframes fadeInText{0%{opacity:.5}to{opacity:1}}.badge-expand-hint{flex-shrink:0;color:var(--text-muted);opacity:.6;transition:opacity var(--transition-fast);display:flex;align-items:center}.attribute-badge.clickable:hover .badge-expand-hint{opacity:1;color:var(--primary-500)}.attribute-badge.empty .badge-value{color:var(--text-muted);font-style:italic}.attribute-badge.inferred{border-left:2px solid var(--warning, #f59e0b)}.attribute-badge.from-text{border-left:2px solid var(--success, #10b981)}.inferred-indicator{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:var(--warning, #f59e0b);color:#fff;border-radius:50%;font-size:.65rem;font-weight:600;flex-shrink:0;margin-left:2px;cursor:help}.from-text-indicator{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:var(--success, #10b981);color:#fff;border-radius:50%;font-size:.6rem;font-weight:600;flex-shrink:0;margin-left:2px;cursor:help}@media(max-width:768px){.attribute-badges{grid-template-columns:repeat(2,1fr);gap:var(--space-1);padding:0 var(--space-2) var(--space-2)}.attribute-badge{padding:var(--space-1) var(--space-2);min-height:36px;flex-wrap:wrap}.attribute-badge.expanded{grid-column:1 / -1;padding:var(--space-2)}.badge-icon{font-size:.875rem}.badge-label{font-size:.625rem}.badge-value{font-size:.6875rem;width:100%;margin-top:2px}}.story-info{padding:0 var(--space-3) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.story-item{display:flex;gap:var(--space-2);padding:var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-sm)}.story-item.full-width{flex-direction:column}.story-icon{font-size:1rem;flex-shrink:0}.story-label{display:block;font-size:.6875rem;color:var(--text-muted);margin-bottom:2px}.story-value{display:block;font-size:.8125rem;color:var(--text-primary);line-height:1.5}.empty-hint{text-align:center;color:var(--text-muted);font-size:.8125rem;font-style:italic;padding:var(--space-3)}.relationship-links{padding:0 var(--space-3) var(--space-3);display:flex;flex-wrap:wrap;gap:var(--space-2)}.relation-item{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:.75rem}.relation-icon{font-size:.875rem}.relation-target{font-weight:500;color:var(--primary-600)}.relation-type{color:var(--text-muted)}.ai-action-bar{display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border-top:1px solid var(--border-color)}.ai-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);background:var(--ai-bg);border:1px solid var(--ai-border);border-radius:var(--radius-md);color:var(--ai-accent);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.ai-action-btn:hover:not(:disabled){background:var(--ai-bg-hover);box-shadow:var(--ai-glow);transform:translateY(-1px)}.ai-action-btn:disabled{opacity:.4;cursor:not-allowed}.step-header-compact{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-3) 0;border-bottom:1px solid var(--border-color);margin-bottom:var(--space-3)}.step-header-left{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.step-header-compact h2{margin:0;font-size:1.125rem;font-weight:600;white-space:nowrap;color:var(--text-primary)}.step-header-desc{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:640px){.step-header-compact{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.step-header-left{flex-direction:column;align-items:flex-start;gap:var(--space-1);width:100%}.step-header-desc{white-space:normal;font-size:.75rem}}@media(min-width:641px)and (max-width:1024px){.step-header-desc{max-width:300px}}@media(min-width:1200px){.step-header-compact h2{font-size:1.25rem}.step-header-desc{font-size:.875rem}}.step-header-actions{display:flex;align-items:center;gap:var(--space-2)}.batch-analyze-toolbar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-md);flex-wrap:wrap;margin-bottom:var(--space-3)}.analyze-btn-group{display:flex;align-items:center;gap:var(--space-2)}.skip-checkbox{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.skip-checkbox input{width:14px;height:14px;margin:0;accent-color:var(--primary-500)}.skip-checkbox:hover{color:var(--text-primary)}.analyze-status{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--success, #10b981)}.progress-inline{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--text-secondary)}.progress-inline .progress-num{font-weight:600;color:var(--ai-accent)}.btn-sm{padding:var(--space-1) var(--space-2);font-size:.75rem}.btn-success{color:var(--success, #10b981);border-color:var(--success, #10b981)}.btn-warning{color:var(--warning, #f59e0b);border-color:var(--warning, #f59e0b)}.batch-analyze-btn{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--ai-bg);border:1px solid var(--ai-border);border-radius:var(--radius-md);color:var(--ai-accent);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.batch-analyze-btn:hover:not(:disabled){background:var(--ai-bg-hover);box-shadow:var(--ai-glow);transform:translateY(-1px)}.batch-analyze-btn:disabled{opacity:.5;cursor:not-allowed}.batch-analyze-btn .spin{animation:spin 1s linear infinite}.batch-progress-bar{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-4)}.batch-progress-bar .progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.batch-progress-bar .progress-text{font-size:.875rem;color:var(--text-secondary)}.batch-progress-bar .progress-count{font-size:.8125rem;font-weight:600;color:var(--ai-accent)}.batch-progress-bar .progress-track{height:6px;background:var(--bg-quaternary);border-radius:var(--radius-full);overflow:hidden}.batch-progress-bar .progress-fill{height:100%;background:linear-gradient(90deg,var(--ai-accent),var(--primary-500));border-radius:var(--radius-full);transition:width .3s ease}.batch-complete-notice{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:.875rem;color:var(--success, #10b981)}.batch-complete-notice .error-count{color:var(--warning, #f59e0b)}.skip-toggle{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.75rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--transition-fast)}.skip-toggle:hover{background:var(--bg-quaternary);border-color:var(--primary-300)}.skip-toggle input{width:14px;height:14px;margin:0;accent-color:var(--primary-500)}.batch-control-btns{display:flex;gap:var(--space-1)}.batch-control-btns .btn{display:flex;align-items:center;gap:4px;padding:var(--space-1) var(--space-2);font-size:.75rem}.batch-control-btns .btn-pause{color:var(--warning, #f59e0b);border-color:var(--warning, #f59e0b)}.batch-control-btns .btn-resume{color:var(--success, #10b981);border-color:var(--success, #10b981)}.batch-control-btns .btn-cancel{color:var(--error-text, #ef4444);border-color:#ef44444d}.batch-progress-bar.paused{border-color:var(--warning, #f59e0b);background:#f59e0b0d}.batch-progress-bar.paused .progress-fill{background:var(--warning, #f59e0b);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.batch-progress-bar .progress-info{margin-top:var(--space-2);font-size:.75rem;color:var(--text-muted)}.batch-progress-bar .skip-info{color:var(--text-secondary)}@media(max-width:767px){.card-main-layout{flex-direction:column;padding:var(--space-3)}.prototype-showcase{width:100%;max-height:50vh}.media-display{min-height:200px}.attribute-badges{grid-template-columns:repeat(2,1fr)}.ai-action-bar{flex-direction:column;gap:var(--space-2)}.char-name{font-size:1.25rem}}.character-editor-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--space-4);animation:fadeIn .2s ease-out}.character-editor-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:640px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border-color)}.editor-header h2{font-size:1.125rem;font-weight:600;margin:0}.editor-tabs{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);overflow-x:auto}.editor-tab{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);font-size:.8125rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.editor-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.editor-tab.active{color:var(--primary-600);background:var(--bg-primary);box-shadow:var(--shadow-sm)}.editor-content{flex:1;overflow-y:auto;padding:var(--space-4)}.tab-panel{display:flex;flex-direction:column;gap:var(--space-4)}.appearance-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.appearance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.appearance-grid .form-group:first-child{grid-column:1}.trait-list{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.trait-item{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--ai-bg);border:1px solid var(--ai-border);border-radius:var(--radius-full);font-size:.75rem;color:var(--ai-accent)}.trait-item button{background:none;border:none;padding:0;color:inherit;cursor:pointer;opacity:.6;display:flex}.trait-item button:hover{opacity:1}.trait-input-row{display:flex;gap:var(--space-2)}.trait-input-row .form-input{flex:1}.relations-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.relation-edit-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md)}.rel-target{font-weight:500;color:var(--primary-600)}.rel-type{flex:1;font-size:.8125rem;color:var(--text-muted)}.empty-text{color:var(--text-muted);font-style:italic;text-align:center;padding:var(--space-4)}.add-relation-form{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--space-3);align-items:end;padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md)}.asset-section{display:flex;flex-direction:column;gap:var(--space-3);align-items:center}.asset-section h4{align-self:flex-start;font-size:.875rem;color:var(--text-secondary);margin:0}.asset-preview{width:100%;max-width:300px;aspect-ratio:3/4;background:var(--bg-tertiary);border-radius:var(--radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center}.asset-preview img{width:100%;height:100%;object-fit:cover}.asset-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--text-muted)}.hint-text{font-size:.75rem;color:var(--text-muted);text-align:center}.editor-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4);border-top:1px solid var(--border-color);background:var(--bg-tertiary)}@media(max-width:600px){.character-editor-modal{max-height:100vh;border-radius:0}.appearance-grid,.add-relation-form{grid-template-columns:1fr}}.view-mode-compact-wrapper{display:inline-flex;gap:2px;padding:2px;background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.view-mode-compact-btn{display:flex;align-items:center;justify-content:center;width:26px;height:22px;padding:0;background:transparent;border:none;border-radius:3px;font-size:12px;line-height:1;cursor:pointer;transition:all var(--transition-fast)}.view-mode-compact-btn:hover:not(.active){background:var(--bg-hover)}.view-mode-compact-btn.active{background:var(--primary-500);color:#fff;box-shadow:0 1px 2px #00000026}.view-mode-switch{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.view-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);font-size:.8125rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.view-mode-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.view-mode-btn.active{color:var(--primary-600);background:var(--bg-primary);box-shadow:var(--shadow-sm)}.character-cards-grid{display:flex;flex-direction:column;gap:var(--space-3)}.character-mini-card{display:flex;gap:var(--space-3);padding:var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.character-mini-card:hover{border-color:var(--primary-500);box-shadow:var(--shadow-md);transform:translateY(-1px)}.mini-card-avatar{width:64px;height:64px;background:var(--bg-quaternary);border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mini-card-avatar img{width:100%;height:100%;object-fit:cover}.mini-card-avatar svg{color:var(--text-muted)}.mini-card-info{flex:1;min-width:0}.mini-card-name{font-weight:600;font-size:.9375rem;color:var(--text-primary);margin-bottom:var(--space-1)}.mini-card-role{font-size:.75rem;color:var(--primary-600);margin-bottom:var(--space-1)}.mini-card-traits{display:flex;flex-wrap:wrap;gap:4px}.mini-trait{font-size:.6875rem;padding:2px 6px;background:var(--ai-bg);border-radius:var(--radius-xs);color:var(--text-muted)}.outline-panel{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.dynamic-view-content{display:flex;flex-direction:column;gap:var(--space-4);overflow-y:auto;min-height:0}.dynamic-section{background:var(--bg-tertiary);border-radius:var(--radius-md);flex-shrink:0}.dynamic-section-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:.8125rem;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.dynamic-count{margin-left:auto;font-size:.75rem;padding:2px 8px;background:var(--bg-quaternary);border-radius:var(--radius-full);color:var(--text-muted)}.dynamic-character-grid{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2)}.dynamic-char-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.dynamic-char-card:hover{border-color:var(--primary-500);background:var(--bg-hover);transform:translate(2px)}.dynamic-avatar{width:48px;height:48px;flex-shrink:0;background:var(--bg-quaternary);border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.dynamic-avatar img{width:100%;height:100%;object-fit:cover;object-position:top center}.dynamic-card-info{flex:1;min-width:0}.dynamic-card-name{font-weight:600;font-size:.875rem;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dynamic-card-role{font-size:.6875rem;font-weight:500;margin-bottom:4px}.dynamic-card-traits{display:flex;flex-wrap:wrap;gap:4px}.dynamic-trait{font-size:.625rem;padding:1px 6px;background:var(--ai-bg);border-radius:var(--radius-xs);color:var(--ai-accent)}.dynamic-trait-more{font-size:.625rem;color:var(--text-muted)}.dynamic-card-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.dynamic-char-card:hover .dynamic-card-actions{opacity:1}.dynamic-action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.dynamic-action-btn:hover{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.dynamic-empty-hint{padding:var(--space-4);text-align:center;color:var(--text-muted);font-size:.8125rem;font-style:italic}.dynamic-scene-list{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2)}.dynamic-scene-item{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-sm)}.dynamic-scene-item .scene-name{width:100%;font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:normal;line-height:1.4}.dynamic-scene-item .scene-tag{font-size:.75rem;padding:2px 8px;background:var(--ai-bg);border-radius:var(--radius-xs);color:var(--ai-accent);align-self:flex-start;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dynamic-scene-more{padding:var(--space-2);text-align:center;font-size:.75rem;color:var(--text-muted)}.scene-selector{padding:var(--space-2)}.scene-list{display:flex;flex-direction:column;gap:var(--space-2)}.scene-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.scene-item:hover{border-color:var(--primary-500);background:var(--bg-hover)}.scene-item.selected{border-color:var(--primary-500);background:var(--primary-bg)}.scene-thumb{width:40px;height:40px;flex-shrink:0;background:var(--bg-quaternary);border-radius:var(--radius-sm);overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.scene-thumb img{width:100%;height:100%;object-fit:cover}.scene-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.scene-info .scene-name{font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-info .scene-atmosphere{font-size:.6875rem;color:var(--text-muted)}.portal-overlay{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1a0a2e,#0a0515,#050208);animation:portalFadeIn .5s ease-out;overflow:hidden}.portal-background{position:absolute;inset:0;z-index:1}.portal-background .bg-gradient{position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(139,92,246,.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(167,139,250,.15) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(196,181,253,.1) 0%,transparent 60%);animation:bgPulse 4s ease-in-out infinite}@keyframes bgPulse{0%,to{opacity:.7}50%{opacity:1}}.stars-layer{position:absolute;inset:0;overflow:hidden}.stars-layer .star{position:absolute;left:var(--x);top:var(--y);width:var(--size);height:var(--size);background:#fff;border-radius:50%;opacity:0;animation:starTwinkle var(--duration) ease-in-out infinite;animation-delay:var(--delay);box-shadow:0 0 6px 2px #ffffff4d}@keyframes starTwinkle{0%,to{opacity:0;transform:scale(.5)}50%{opacity:1;transform:scale(1)}}.magic-circle-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;height:400px;z-index:3}.magic-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:2px solid transparent}.magic-circle.outer{width:100%;height:100%;border-color:#a78bfa66;background:conic-gradient(from 0deg,transparent,rgba(167,139,250,.2),transparent,rgba(196,181,253,.2),transparent);animation:magicSpin 12s linear infinite;filter:drop-shadow(0 0 20px rgba(167,139,250,.3))}.magic-circle.outer:before{content:"";position:absolute;inset:8px;border:1px dashed rgba(167,139,250,.3);border-radius:50%}.magic-circle.middle{width:75%;height:75%;border-color:#8b5cf680;background:conic-gradient(from 180deg,transparent,rgba(139,92,246,.15),transparent,rgba(167,139,250,.15),transparent);animation:magicSpin 8s linear infinite reverse;filter:drop-shadow(0 0 15px rgba(139,92,246,.4))}.magic-circle.middle:after{content:"";position:absolute;inset:15px;border:1px solid rgba(139,92,246,.25);border-radius:50%}.magic-circle.inner{width:45%;height:45%;border-color:#fcd34d99;background:radial-gradient(circle,rgba(252,211,77,.1) 0%,transparent 70%);animation:magicPulse 2s ease-in-out infinite,magicSpin 5s linear infinite;filter:drop-shadow(0 0 25px rgba(252,211,77,.4))}@keyframes magicSpin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes magicPulse{0%,to{transform:translate(-50%,-50%) rotate(0) scale(1);filter:drop-shadow(0 0 25px rgba(252,211,77,.4))}50%{transform:translate(-50%,-50%) rotate(180deg) scale(1.1);filter:drop-shadow(0 0 40px rgba(252,211,77,.6))}}.magic-runes{position:absolute;inset:0;animation:magicSpin 20s linear infinite}.magic-runes .rune{position:absolute;font-size:1.25rem;color:#c4b5fdcc;text-shadow:0 0 10px rgba(167,139,250,.6);top:50%;left:50%;transform-origin:center;transform:translate(-50%,-50%) rotate(calc(var(--index) * 45deg)) translateY(-180px);animation:runeGlow 2s ease-in-out infinite;animation-delay:calc(var(--index) * .25s)}@keyframes runeGlow{0%,to{opacity:.5;text-shadow:0 0 10px rgba(167,139,250,.4)}50%{opacity:1;text-shadow:0 0 20px rgba(167,139,250,.8),0 0 40px rgba(252,211,77,.4)}}.vortex-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;z-index:2}.vortex-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(167,139,250,.2);animation:vortexExpand 3s ease-out infinite}.vortex-ring.ring-1{width:50%;height:50%;animation-delay:0s}.vortex-ring.ring-2{width:50%;height:50%;animation-delay:1s}.vortex-ring.ring-3{width:50%;height:50%;animation-delay:2s}@keyframes vortexExpand{0%{transform:translate(-50%,-50%) scale(.5);opacity:1;border-color:#fcd34d99}to{transform:translate(-50%,-50%) scale(2);opacity:0;border-color:#a78bfa1a}}.particles-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:0;height:0;z-index:4}.particles-container .particle{position:absolute;width:6px;height:6px;background:radial-gradient(circle,#fcd34d,#a78bfa);border-radius:50%;animation:particleOrbit 4s linear infinite;animation-delay:var(--delay);box-shadow:0 0 8px #fcd34d99}@keyframes particleOrbit{0%{transform:rotate(var(--angle)) translate(0) scale(0);opacity:0}20%{opacity:1;transform:rotate(var(--angle)) translate(calc(var(--distance) * .5)) scale(1)}80%{opacity:.8}to{transform:rotate(calc(var(--angle) + 360deg)) translate(var(--distance)) scale(.5);opacity:0}}.floating-pages{position:absolute;inset:0;pointer-events:none;z-index:5;overflow:hidden}.floating-pages .page{position:absolute;left:var(--x-start);top:-40px;font-size:24px;opacity:0;animation:pagesFall 6s ease-in-out infinite;animation-delay:var(--delay);filter:drop-shadow(0 0 10px rgba(255,255,255,.3))}@keyframes pagesFall{0%{transform:translateY(0) translate(0) rotate(0);opacity:0}10%{opacity:.9}50%{transform:translateY(50vh) translate(var(--drift)) rotate(var(--rotation));opacity:.7}to{transform:translateY(110vh) translate(calc(var(--drift) * 1.5)) rotate(calc(var(--rotation) + 180deg));opacity:0}}.center-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:6;pointer-events:none}.center-glow .glow-core{width:80px;height:80px;background:radial-gradient(circle,rgba(252,211,77,.8) 0%,rgba(167,139,250,.4) 50%,transparent 70%);border-radius:50%;animation:glowPulse 2s ease-in-out infinite}.center-glow .glow-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120px;height:120px;background:radial-gradient(circle,rgba(167,139,250,.3) 0%,transparent 70%);border-radius:50%;animation:glowExpand 2s ease-out infinite}@keyframes glowPulse{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.2);filter:brightness(1.3)}}@keyframes glowExpand{0%{transform:translate(-50%,-50%) scale(.8);opacity:.8}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.portal-progress .progress-glow{position:absolute;top:-4px;width:12px;height:12px;background:radial-gradient(circle,#fcd34d 0%,transparent 70%);border-radius:50%;transform:translate(-50%);filter:blur(2px);animation:progressGlow 1s ease-in-out infinite}@keyframes progressGlow{0%,to{opacity:.6;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.3)}}@keyframes portalFadeIn{0%{opacity:0}to{opacity:1}}.portal-overlay.entering{animation:portalFlash 1.2s ease-out forwards}@keyframes portalFlash{0%{background:radial-gradient(ellipse at center,#1e1432f2,#0a0514fa)}50%{background:radial-gradient(ellipse at center,#a78bfacc,#1e1432f2)}to{background:radial-gradient(ellipse at center,#fff 0% 100%);opacity:0}}.portal-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}.portal-particles .particle{position:absolute;left:var(--x);bottom:-10px;width:var(--size);height:var(--size);background:radial-gradient(circle,#fcd34d,#a78bfa);border-radius:50%;animation:particleRise 4s ease-out infinite;animation-delay:var(--delay);opacity:0}@keyframes particleRise{0%{transform:translateY(0) scale(0);opacity:0}10%{opacity:.8}to{transform:translateY(-100vh) scale(1);opacity:0}}.portal-gate{position:relative;width:280px;height:320px;display:flex;align-items:center;justify-content:center}.portal-ring{position:absolute;width:100%;height:100%}.portal-ring.outer{animation:portalSpin 8s linear infinite;filter:drop-shadow(0 0 20px rgba(167,139,250,.5))}.portal-ring.middle{animation:portalSpin 5s linear infinite reverse;filter:drop-shadow(0 0 10px rgba(167,139,250,.3))}.portal-ring.inner{animation:portalPulse 2s ease-in-out infinite}@keyframes portalSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes portalPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}.floating-pages{position:absolute;width:100%;height:100%;pointer-events:none}.floating-pages .page{position:absolute;width:24px;height:32px;opacity:0;animation:pageFloat 4s ease-in-out infinite;animation-delay:var(--delay)}.floating-pages .page:nth-child(1){top:10%;left:20%}.floating-pages .page:nth-child(2){top:20%;right:15%}.floating-pages .page:nth-child(3){top:60%;left:10%}.floating-pages .page:nth-child(4){top:50%;right:20%}.floating-pages .page:nth-child(5){top:80%;left:40%}@keyframes pageFloat{0%{transform:translateY(0) rotate(0) scale(.8);opacity:0}20%{opacity:.9}50%{transform:translateY(-30px) rotate(15deg) scale(1);opacity:.7}80%{opacity:.9}to{transform:translateY(0) rotate(-10deg) scale(.8);opacity:0}}.portal-text{position:absolute;bottom:15%;text-align:center;width:100%;padding:0 var(--space-4);z-index:10}.portal-title{font-size:2.5rem;font-weight:700;color:transparent;background:linear-gradient(135deg,#fcd34d,#a78bfa,#c4b5fd);-webkit-background-clip:text;background-clip:text;margin-bottom:var(--space-4);letter-spacing:.1em}.portal-title .title-char{display:inline-block;animation:charReveal .6s ease-out forwards;animation-delay:var(--delay);opacity:0;transform:translateY(20px)}@keyframes charReveal{to{opacity:1;transform:translateY(0)}}.portal-loading-text{font-size:1rem;color:#fffc;margin-bottom:var(--space-4);animation:textPulse 2s ease-in-out infinite;font-style:italic}@keyframes textPulse{0%,to{opacity:.6}50%{opacity:1}}.portal-progress{display:flex;align-items:center;justify-content:center;gap:var(--space-3);max-width:300px;margin:0 auto}.portal-progress .progress-track{flex:1;height:4px;background:#ffffff26;border-radius:2px;overflow:hidden}.portal-progress .progress-fill{height:100%;background:linear-gradient(90deg,#a78bfa,#fcd34d);border-radius:2px;transition:width .3s ease-out;box-shadow:0 0 10px #a78bfa80}.portal-progress .progress-percent{font-size:.875rem;color:#ffffffb3;font-variant-numeric:tabular-nums;min-width:40px}.entering-flash{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:20;background:#ffffffe6;animation:flashText 1.2s ease-out forwards}.entering-flash span{font-size:3rem;font-weight:700;color:#fff;text-shadow:0 0 40px rgba(255,255,255,.8);animation:flashScale 1.2s ease-out forwards}@keyframes flashText{0%{opacity:0}30%{opacity:1}to{opacity:0}}@keyframes flashScale{0%{transform:scale(.8)}30%{transform:scale(1)}to{transform:scale(1.5)}}@media(max-width:640px){.portal-gate{width:200px;height:240px}.portal-title{font-size:1.75rem}.portal-loading-text{font-size:.875rem}.entering-flash span{font-size:2rem}}
