@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--primary-900:#0f172a;--primary-800:#1e293b;--primary-700:#334155;--primary-600:#475569;--primary-500:#64748b;--accent-700:#0f766e;--accent-600:#0d9488;--accent-500:#14b8a6;--accent-400:#2dd4bf;--accent-300:#5eead4;--accent-200:#99f6e4;--accent-100:#ccfbf1;--accent-50:#f0fdfa;--rose-500:#f43f5e;--rose-400:#fb7185;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--success-main:#10b981;--success-light:#d1fae5;--warning-main:#f59e0b;--warning-light:#fef3c7;--error-main:#ef4444;--error-light:#fee2e2;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--bg-primary:#c4cdd9;--bg-secondary:#fff;--bg-tertiary:var(--gray-100);--bg-hover:var(--gray-100);--bg-input:var(--gray-50);--bg-card:#fff;--bg-modal-overlay:#0f172a99;--text-primary:var(--gray-800);--text-secondary:var(--gray-600);--text-tertiary:var(--gray-500);--text-muted:var(--gray-400);--text-inverse:#fff;--border-primary:var(--gray-300);--border-secondary:var(--gray-200);--border-focus:var(--accent-500);--card-shadow:0 4px 12px 0 #0000001f,0 2px 6px -1px #00000014}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-hover:#334155;--bg-input:#1e293b;--bg-card:#1e293b;--bg-modal-overlay:#000c;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-tertiary:#94a3b8;--text-muted:#64748b;--text-inverse:#0f172a;--border-primary:#334155;--border-secondary:#475569;--border-focus:var(--accent-400);--success-light:#10b98126;--warning-light:#f59e0b26;--error-light:#ef444426;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #0006,0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #0006,0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #00000080,0 8px 10px -6px #0006;--card-shadow:0 2px 8px 0 #0000004d}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background-color:#1e293b!important;color:#f1f5f9!important}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:#64748b!important}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{background-color:#1e293b!important}[data-theme=dark] input:disabled,[data-theme=dark] select:disabled,[data-theme=dark] textarea:disabled{background-color:#334155!important;color:#94a3b8!important}[data-theme=light] input,[data-theme=light] select,[data-theme=light] textarea{background-color:#f8fafc!important;color:#1e293b!important}[data-theme=light] input:focus,[data-theme=light] select:focus,[data-theme=light] textarea:focus{background-color:#fff!important}[data-theme=light] input:disabled,[data-theme=light] select:disabled,[data-theme=light] textarea:disabled{background-color:#f1f5f9!important;color:#64748b!important}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#c4cdd9;background:var(--bg-primary);color:#1e293b;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;min-height:100vh;transition:background-color .3s ease,color .3s ease}code{font-family:JetBrains Mono,source-code-pro,Menlo,Monaco,Consolas,monospace}html{scroll-behavior:smooth}:focus-visible{outline:2px solid #14b8a6;outline:2px solid var(--border-focus);outline-offset:2px}::selection{background:#5eead4;background:var(--accent-300);color:#0f172a;color:var(--gray-900)}[data-theme=dark] ::selection{background:#0d9488;background:var(--accent-600);color:#fff}[data-theme=light] .announcement-item,[data-theme=light] .auth-form,[data-theme=light] .comment-item,[data-theme=light] .credit-package,[data-theme=light] .custom-character-container,[data-theme=light] .form-section,[data-theme=light] .generation-tabs,[data-theme=light] .history-item,[data-theme=light] .image-options-card,[data-theme=light] .input-form-container,[data-theme=light] .mode-selector,[data-theme=light] .mypage-section,[data-theme=light] .post-content,[data-theme=light] .post-item,[data-theme=light] .profile-section,[data-theme=light] .scene-card,[data-theme=light] .scene-selector,[data-theme=light] .session-card,[data-theme=light] .stats-card,[data-theme=light] .tutorial-container,[data-theme=light] .work-card,[data-theme=light] .work-detail{border:1px solid #cbd5e1!important;border:1px solid var(--border-primary)!important;box-shadow:0 4px 12px 0 #0000001f,0 2px 6px -1px #00000014!important;box-shadow:var(--card-shadow)!important}.App{display:flex;flex-direction:column;min-height:100vh}.App-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:1.25rem 2rem;position:-webkit-sticky;position:sticky;top:0;transition:background-color .3s ease,border-color .3s ease;z-index:100}[data-theme=dark] .App-header{background:#1e293bf7}.App-header h1{color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.App-header p.subtitle{color:var(--accent-500);font-size:1.1rem;font-weight:500;margin-bottom:.5rem}.App-header p.description{color:var(--text-tertiary);font-size:.875rem;font-weight:400;max-width:800px}.user-info{align-items:center;display:flex;gap:.75rem;position:absolute;right:2rem;top:50%;transform:translateY(-50%)}.logout-button,.user-info span{color:var(--text-secondary);font-size:.875rem;font-weight:500}.logout-button{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;padding:.5rem 1rem;transition:all .2s ease}.logout-button:hover{background:var(--bg-hover);border-color:var(--border-secondary);color:var(--text-primary)}.App-main{flex:1 1;margin:0 auto;max-width:1400px;padding:2.5rem 2rem;width:100%}.info-panel{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);border:2px solid var(--accent-500);border-radius:12px;box-shadow:0 4px 12px #00000014;margin:0 auto 1.5rem;max-width:1000px;padding:1.25rem 1.5rem}.info-panel-notice{align-items:center;background:#3b82f61f;border:1px solid #3b82f659;border-radius:6px;display:flex;gap:.5rem;margin-top:.5rem;padding:.6rem .85rem}.info-panel-notice .notice-icon{flex-shrink:0;font-size:1rem}.info-panel-notice span:last-child{color:var(--text-primary);font-size:.85rem;font-weight:500}.browse-mode-prompt{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);margin:2rem auto;max-width:500px;padding:4rem 2rem;text-align:center}.browse-mode-prompt h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.browse-mode-prompt p{color:var(--text-secondary);margin-bottom:2rem}.App-footer{background:var(--bg-secondary);border-top:1px solid var(--border-primary);color:var(--text-tertiary);font-size:.875rem;padding:1.5rem;text-align:center;transition:background-color .3s ease,border-color .3s ease}.error-message{align-items:center;background:var(--error-light);border-radius:var(--radius-md);display:flex;font-size:.925rem;font-weight:500;justify-content:space-between;margin-bottom:1.5rem;padding:1rem 1.25rem}[data-theme=dark] .error-message{border-color:#ef444480}.error-message button{background:none;border:none;border-radius:var(--radius-sm);color:var(--error-main);cursor:pointer;font-size:1.25rem;line-height:1;padding:.25rem;transition:background .2s}.error-message button:hover{background:#ef444426}@media (max-width:768px){.App-header{padding:1rem;text-align:center}.App-header h1{font-size:1.25rem}.App-header p{font-size:.8rem}.user-info{justify-content:center;margin-top:.75rem;position:static;transform:none}.App-main{padding:1.5rem 1rem}}.auth-container{align-items:center;background:linear-gradient(135deg,var(--primary-900) 0,var(--primary-700) 100%);display:flex;justify-content:center;min-height:100vh;padding:1rem}.auth-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:400px;padding:2.5rem;transition:background-color .3s ease,border-color .3s ease;width:100%}.auth-card h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin-bottom:2rem;text-align:center}.form-group{margin-bottom:1.25rem}.form-group label{font-size:.9rem}.form-group input{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-sizing:border-box;color:var(--text-primary);font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.form-group input:focus{background:var(--bg-secondary);border-color:var(--accent-500);box-shadow:0 0 0 3px #14b8a626;outline:none}.auth-button{background:var(--accent-600);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:.875rem;transition:all .2s ease;width:100%}.auth-button:hover:not(:disabled){background:var(--accent-700);box-shadow:var(--shadow-md)}.auth-button:disabled{background:var(--text-muted);cursor:not-allowed}.auth-error{background:var(--error-light);border:1px solid var(--error-main);border-radius:var(--radius-md);color:var(--error-main);font-size:.9rem;font-weight:500;margin-bottom:1.25rem;padding:.875rem;text-align:center}[data-theme=dark] .auth-error{border-color:#ef444480}.auth-toggle{color:var(--text-secondary);font-size:.925rem;margin-top:1.75rem;text-align:center}.toggle-button{background:none;border:none;color:var(--accent-500);cursor:pointer;font-weight:600;margin-left:.25rem;padding:0;text-decoration:none;transition:color .2s ease}.toggle-button:hover{color:var(--accent-400);text-decoration:underline}.google-signin-container{display:flex;justify-content:center;margin-bottom:1.5rem}.google-signin-container>div{width:100%}.divider{align-items:center;display:flex;margin:1.5rem 0}.divider:after,.divider:before{background:var(--border-primary);content:"";flex:1 1;height:1px}.divider span{color:var(--text-muted);font-size:.875rem;font-weight:500;padding:0 1rem}.link-dialog{text-align:center}.link-dialog h3{color:var(--text-primary);font-size:1.25rem;margin-bottom:1rem}.link-message{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:1.5rem}.link-message strong{color:var(--accent-500)}.link-buttons{display:flex;gap:.75rem;margin-top:1rem}.link-buttons .auth-button{flex:1 1}.cancel-button{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem;transition:all .2s ease}.cancel-button:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.cancel-button:disabled{cursor:not-allowed;opacity:.5}.browse-section{margin-top:1rem}.browse-button{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem;transition:all .2s ease;width:100%}.browse-button:hover{background:var(--bg-tertiary);border-color:var(--accent-500);color:var(--accent-500)}.browse-hint{color:var(--text-muted);font-size:.8rem;margin-top:.75rem;text-align:center}.input-form-container{background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:0 auto;max-width:1000px;padding:2rem;transition:background-color .3s ease,border-color .3s ease}.input-form h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.form-group,.input-form h2{margin-bottom:1.5rem}.form-group label{color:var(--text-secondary);display:block;font-size:.925rem;font-weight:600;margin-bottom:.5rem}.label-hint{color:var(--text-muted);font-size:.8rem;font-weight:400;opacity:.8}.form-group textarea{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:1rem;padding:1rem;resize:vertical;transition:all .2s ease;width:100%}.form-group textarea:focus{background:var(--bg-secondary);border-color:var(--accent-500);box-shadow:0 0 0 3px #14b8a626;outline:none}.form-group textarea.warning{background:var(--warning-light);border-color:var(--warning-main)}.form-group textarea.error{background:var(--error-light);border-color:var(--error-main)}.word-count{color:var(--text-tertiary);display:flex;flex-direction:column;font-size:.875rem;gap:.25rem;margin-top:.5rem}.word-count.warning{color:var(--warning-main)}.word-count.error{color:var(--error-main)}.word-count .error-message,.word-count .warning-message{display:block;font-size:.85rem;margin-top:.25rem}.word-count .error-message{color:var(--error-main);font-weight:600}.word-count .warning-message{color:var(--warning-main);font-weight:500}.form-group input[type=number]{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.form-group input[type=number]:focus{background:var(--bg-secondary);border-color:var(--accent-500);box-shadow:0 0 0 3px #14b8a626;outline:none}.form-group small{color:var(--text-tertiary);display:block;font-size:.85rem;margin-top:.5rem}.scene-buttons{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.scene-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:1.1rem;font-weight:600;height:48px;transition:all .2s ease;width:48px}.scene-btn:hover:not(:disabled){background:var(--accent-50);border-color:var(--accent-500);color:var(--accent-500)}[data-theme=dark] .scene-btn:hover:not(:disabled){background:#14b8a61a}.scene-btn.selected{background:var(--accent-600);border-color:var(--accent-600);box-shadow:var(--shadow-sm);color:#fff}.scene-btn:disabled{cursor:not-allowed;opacity:.5}.image-count-info{background:linear-gradient(135deg,#3b82f61a,#6366f11a);border:1px solid #3b82f64d;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;padding:.625rem 1rem}.image-count-info strong{color:#3b82f6;font-weight:700}[data-theme=dark] .image-count-info strong{color:#60a5fa}.credit-cost-info{border-radius:var(--radius-md)}.credit-breakdown{color:var(--text-tertiary)}.button-group{gap:1rem;justify-content:center;margin-top:2rem}.btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.75rem;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:var(--accent-600)}.btn-primary:hover:not(:disabled){background:var(--accent-700);box-shadow:var(--shadow-md)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-secondary);color:var(--text-primary)}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.loading-info{color:var(--text-secondary);font-size:.925rem;margin-top:1.5rem;text-align:center}.loading-info p{margin:.5rem 0}.progress-bar{background-color:var(--bg-tertiary);height:8px;margin-top:1rem;overflow:hidden;width:100%}.progress-fill{background:var(--accent-500);border-radius:4px;height:100%;transition:width .5s ease}.character-descriptions-section{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden;transition:background-color .3s ease,border-color .3s ease}.character-section-toggle{align-items:center;background:#0000;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.75rem;padding:1rem 1.25rem;text-align:left;transition:background-color .2s;width:100%}.character-section-toggle:hover{background:var(--bg-hover)}.toggle-arrow{color:var(--accent-500);display:inline-block;font-size:.75rem;transition:transform .2s}.toggle-arrow.open{transform:rotate(90deg)}.character-count-badge{background:var(--accent-600);border-radius:10px;color:#fff;font-size:.75rem;font-weight:500;margin-left:auto;padding:.2rem .6rem}.character-section-content{border-top:1px solid var(--border-primary);padding:0 1.25rem 1.25rem}.character-hint{background:var(--warning-light);border-left:3px solid var(--warning-main);border-radius:var(--radius-sm);color:var(--warning-main);display:block;font-size:.875rem;font-weight:500;margin:1rem 0;padding:.75rem 1rem}.character-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.character-entry{align-items:flex-start;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);display:flex;gap:.75rem;padding:1rem;transition:background-color .3s ease,border-color .3s ease}.character-inputs{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.character-name-input{background:var(--bg-input);border-radius:var(--radius-sm);font-size:.925rem;font-weight:600;padding:.625rem .875rem;transition:all .2s ease}.character-name-input:focus{background:var(--bg-secondary);box-shadow:0 0 0 3px #14b8a626}.character-name-input::placeholder{font-weight:400}.character-description-input{background:var(--bg-input);border-radius:var(--radius-sm);font-size:.875rem;min-height:60px;padding:.625rem .875rem;resize:vertical;transition:all .2s ease}.character-description-input:focus{background:var(--bg-secondary);box-shadow:0 0 0 3px #14b8a626}.btn-remove-character{background:var(--error-main);border:none;border-radius:50%;color:#fff;cursor:pointer;flex-shrink:0;font-size:1rem;font-weight:700;height:32px;padding:0;transition:all .2s ease;width:32px}.btn-remove-character:hover:not(:disabled){background:#dc2626;transform:scale(1.05)}.btn-remove-character:disabled{cursor:not-allowed;opacity:.4}.btn-add-character{background:var(--bg-secondary);border:1px dashed var(--accent-500);border-radius:var(--radius-md);color:var(--accent-500);cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1rem;transition:all .2s ease;width:100%}.btn-add-character:hover:not(:disabled){background:var(--accent-50);border-color:var(--accent-600);border-style:solid}[data-theme=dark] .btn-add-character:hover:not(:disabled){background:#14b8a61a}.btn-add-character:disabled{cursor:not-allowed;opacity:.4}.episode-type-section{margin-bottom:1.5rem}.episode-type-buttons{display:flex;gap:1rem;margin-bottom:.5rem}.episode-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;padding:.875rem 1.25rem;transition:all .2s ease}.episode-btn:hover:not(:disabled){background:var(--accent-50);border-color:var(--accent-500);color:var(--accent-500)}[data-theme=dark] .episode-btn:hover:not(:disabled){background:#14b8a61a}.episode-btn.selected{background:var(--accent-600);border-color:var(--accent-600);box-shadow:var(--shadow-sm);color:#fff}.episode-btn:disabled{cursor:not-allowed;opacity:.5}.previous-session-section{background:var(--accent-50);border:1px solid #14b8a633;border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1.25rem;transition:background-color .3s ease}[data-theme=dark] .previous-session-section{background:#14b8a61a}.session-select{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:.95rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.session-select:focus{border-color:var(--accent-500);box-shadow:0 0 0 3px #14b8a626;outline:none}.session-select:disabled{cursor:not-allowed;opacity:.5}.selected-session-info{background:var(--success-light);border-left:3px solid var(--success-main);border-radius:var(--radius-sm);margin-top:.75rem;padding:.75rem 1rem}.selected-session-info small{color:var(--success-main);font-size:.85rem;font-weight:500}.text-highlighter{width:100%}.highlight-container{margin-bottom:1rem;position:relative;width:100%}.highlight-layer{word-wrap:break-word;border:2px solid #0000;border-radius:8px;color:#0000;font-family:inherit;font-size:1rem;height:100%;left:0;line-height:1.5;overflow:hidden;padding:1rem;pointer-events:none;position:absolute;top:0;white-space:pre-wrap;width:100%}.highlight-layer .highlight{border-radius:2px}.highlight-container textarea{background:#0000;border:2px solid #ddd;border-radius:8px;font-family:inherit;font-size:1rem;line-height:1.5;padding:1rem;position:relative;resize:vertical;transition:border-color .3s;width:100%}.highlight-container textarea:focus{background:#ffffffe6;border-color:#667eea;outline:none}.highlight-container textarea:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.scene-markers{align-items:center;background:#f8f9fa;border:2px dashed #ddd;border-radius:8px;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:.75rem}.marker-label{color:#333}.marker-btn,.marker-label{font-size:.9rem;font-weight:600}.marker-btn{border:2px solid;border-radius:6px;cursor:pointer;padding:.5rem 1rem;transition:all .2s}.marker-btn:hover:not(:disabled){box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.marker-btn:disabled{cursor:not-allowed;opacity:.5}.selections-list{background:#f8f9fa;border-radius:8px;margin-top:1rem;padding:1rem}.list-header{color:#333;font-size:.95rem;font-weight:600;margin-bottom:.75rem}.selection-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;gap:.75rem;margin-bottom:.5rem;padding:.75rem;transition:all .2s}.selection-item:hover{box-shadow:0 2px 8px #00000014;transform:translateX(2px)}.scene-badge{border-radius:4px;color:#fff;flex-shrink:0;font-size:.85rem;font-weight:700;padding:.35rem .65rem;white-space:nowrap}.selection-preview{color:#555;flex:1 1;font-size:.9rem;line-height:1.4;overflow:hidden;text-overflow:ellipsis}.remove-btn{align-items:center;background:#f44;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:28px;justify-content:center;line-height:1;transition:all .2s;width:28px}.remove-btn:hover:not(:disabled){background:#c00;transform:scale(1.1)}.remove-btn:disabled{cursor:not-allowed;opacity:.5}.scene-selector{background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem;transition:background-color .3s ease,border-color .3s ease}.selector-header{margin-bottom:2rem}.selector-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}.selector-header p{color:var(--text-tertiary);font-size:.925rem;margin-bottom:1rem}.session-info-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.session-tag{align-items:center;border-radius:9999px;display:inline-flex;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.session-tag.model-tag{background:var(--accent-100);color:var(--accent-700)}.session-tag.style-tag{background:#fef3c7;color:#92400e}[data-theme=dark] .session-tag.model-tag{background:#6366f133;color:var(--accent-400)}[data-theme=dark] .session-tag.style-tag{background:#fbbf2433;color:#fbbf24}.header-actions{align-items:center;border-top:1px solid var(--border-secondary);display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem}.selection-count{color:var(--accent-500);font-size:1rem;font-weight:600}.scenes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;margin-bottom:2rem}.selector-footer{border-top:1px solid var(--border-secondary);padding:2rem 0;text-align:center}.btn-large,.btn-success{font-size:1rem;padding:.875rem 2rem}.btn-success{align-items:center;background:var(--success-main);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:inline-flex;font-weight:600;gap:.5rem;text-decoration:none;transition:all .2s ease}.btn-success:hover:not(:disabled){background:#059669;box-shadow:var(--shadow-md)}.btn-success:disabled{background:var(--text-muted);cursor:not-allowed}.btn-info{align-items:center;background:#3b82f6;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.875rem 2rem;text-decoration:none;transition:all .2s ease}.btn-info:hover:not(:disabled){background:#2563eb;box-shadow:var(--shadow-md)}.btn-info:disabled{background:var(--text-muted);cursor:not-allowed}.pdf-ready{margin-bottom:1.5rem;text-align:center}.pdf-ready h3{color:var(--success-main);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--bg-modal-overlay);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{animation:scaleIn .2s ease-out;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:460px;padding:2rem;width:90%}.modal h3{color:var(--text-primary);font-size:1.25rem;font-weight:700;letter-spacing:-.01em}.modal .form-group,.modal h3{margin-bottom:1.5rem}.modal .form-group label{color:var(--text-secondary);display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.modal .form-group input{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.modal .form-group input:focus{background:var(--bg-secondary);border-color:var(--accent-500);box-shadow:0 0 0 3px #14b8a626;outline:none}.modal .form-group textarea{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:1rem;padding:.75rem 1rem;resize:vertical;transition:all .2s ease;width:100%}.modal .form-group textarea:focus{background:var(--bg-secondary);border-color:var(--accent-500);box-shadow:0 0 0 3px #14b8a626;outline:none}.modal-buttons{display:flex;gap:.75rem;justify-content:flex-end}.footer-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.save-hint{color:var(--text-tertiary);font-size:.875rem;line-height:1.5;margin-bottom:1.25rem}.board-type-selector{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.board-type-radio{align-items:center;background:var(--bg-card);border:2px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;display:flex;padding:.75rem 1rem;transition:all .2s ease}.board-type-radio:hover{background:var(--bg-tertiary);border-color:var(--accent-400)}.board-type-radio.selected{background:#14b8a61a;border-color:var(--accent-500)}.board-type-radio input[type=radio]{accent-color:var(--accent-500);margin-right:.75rem}.board-type-info{display:flex;flex-direction:column;gap:.125rem}.board-type-info strong{color:var(--text-primary);font-size:.9rem}.board-type-info small{color:var(--text-tertiary);font-size:.75rem}@media (max-width:768px){.header-actions{align-items:stretch;flex-direction:column;gap:1rem}.selector-header h2{font-size:1.25rem}.btn-large{font-size:.95rem;padding:.75rem 1.5rem}.footer-buttons{flex-direction:column}.footer-buttons .btn{justify-content:center;width:100%}}.scene-card{background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem;position:relative;transition:all .2s ease}.scene-card:hover{border-color:var(--border-primary);box-shadow:var(--shadow-md)}.scene-header{border-bottom:1px solid var(--border-secondary);margin-bottom:1.5rem;padding-bottom:1rem}.scene-title-row{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.5rem}.scene-header h3{align-items:center;color:var(--text-primary);display:flex;flex:1 1;flex-wrap:wrap;font-size:1.25rem;font-weight:700;gap:.75rem;letter-spacing:-.01em;margin:0}.auto-badge,.manual-badge{border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.03em;padding:.25rem .75rem;text-transform:uppercase}.manual-badge{background:var(--accent-100);color:var(--accent-700)}[data-theme=dark] .manual-badge{background:#14b8a633;color:var(--accent-400)}.auto-badge{background:var(--bg-tertiary);color:var(--text-tertiary)}.scene-actions{align-items:center;display:flex;gap:.5rem}.btn-download-all{background:var(--success-main);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-download-all:hover{background:#059669;box-shadow:var(--shadow-sm)}.btn-regenerate{align-items:center;background:var(--accent-600);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:1.1rem;height:38px;justify-content:center;min-width:44px;padding:.5rem 1rem;transition:all .2s ease}.btn-regenerate:hover:not(:disabled){background:var(--accent-700);box-shadow:var(--shadow-sm)}.btn-regenerate:disabled{cursor:not-allowed;opacity:.5}.btn-regenerate-full{align-items:center;background:var(--primary-700);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:.35rem;justify-content:center;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-regenerate-full:hover:not(:disabled){background:var(--primary-800);box-shadow:var(--shadow-sm)}.btn-regenerate-full:disabled{cursor:not-allowed;opacity:.5}.regenerating-message{animation:pulse 2s ease-in-out infinite;background:var(--warning-light);border-radius:var(--radius-md);color:var(--warning-main);font-size:.9rem;font-weight:600;margin-top:.75rem;padding:.75rem 1rem;text-align:center}[data-theme=dark] .regenerating-message{color:#fbbf24}.scene-summary{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.scene-images{gap:1.5rem}.aspect-group,.scene-images{display:flex;flex-direction:column}.aspect-group{gap:.75rem}.aspect-title{border-left:3px solid var(--accent-500);color:var(--accent-600);font-size:1rem;font-weight:600;margin-bottom:.5rem;padding-left:.75rem}[data-theme=dark] .aspect-title{color:var(--accent-400)}.focus-group{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.image-option{background:var(--bg-secondary);border:2px solid #0000;border-radius:var(--radius-md);cursor:pointer;overflow:hidden;transition:all .2s ease}.image-option:hover{border-color:var(--border-primary);box-shadow:var(--shadow-sm)}.image-option.selected{border-color:var(--accent-500);box-shadow:0 0 0 3px #14b8a626}.new-badge{animation:pulse-badge 2s infinite;background:var(--error-main)}.new-badge,.regenerated-badge{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);font-weight:700;left:.5rem;position:absolute;text-transform:uppercase;top:.5rem;z-index:20}.regenerated-badge{background:var(--primary-700);color:#fff;font-size:.7rem;padding:.2rem .5rem}.regenerated-image{border:2px solid var(--primary-700)}@keyframes pulse-badge{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.image-option.new-image{border-color:var(--error-main);box-shadow:0 0 0 3px #ef444426}.image-option.new-image .image-label{background:var(--error-light);color:var(--error-main)}.image-wrapper{background:var(--bg-tertiary);overflow:hidden;padding-top:100%;position:relative;width:100%}.image-wrapper img{height:100%;left:0;object-fit:contain;position:absolute;top:0;width:100%}.selected-badge{background:var(--accent-600);border-radius:50%;font-size:1rem;font-weight:700;height:28px;right:.5rem;top:.5rem;width:28px}.crop-btn,.selected-badge{align-items:center;box-shadow:var(--shadow-sm);color:#fff;display:flex;justify-content:center;position:absolute}.crop-btn{background:#0d9488e6;border:none;border-radius:50%;bottom:.5rem;cursor:pointer;font-size:.9rem;height:30px;left:.5rem;opacity:0;transition:all .2s ease;width:30px}.image-wrapper:hover .crop-btn{opacity:1}.crop-btn:hover{background:var(--accent-600);transform:scale(1.1)}.crop-btn:active{transform:scale(.95)}.image-wrapper .download-btn{align-items:center;background:#1e293be6;border:none;border-radius:50%;bottom:.5rem;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:30px;justify-content:center;opacity:0;padding:0;position:absolute;right:.5rem;transition:all .2s ease;width:30px}.image-wrapper:hover .download-btn{opacity:1}.image-wrapper .download-btn:hover{background:var(--primary-800);transform:scale(1.1)}.image-wrapper .download-btn:active{transform:scale(.95)}.regen-btn{background:#0d9488f2;border:none;border-radius:20px;bottom:.5rem;box-shadow:var(--shadow-md);color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;opacity:0;padding:.4rem .9rem;position:absolute;right:calc(50% + 2rem);top:auto;transform:scale(.9);transition:all .2s ease;white-space:nowrap;z-index:100}.image-wrapper:hover .regen-btn{opacity:1;transform:scale(1)}.regen-btn:hover{background:var(--accent-600);transform:scale(1.05)}.regen-btn:active{transform:scale(.95)}.image-label{background:var(--bg-tertiary);color:var(--text-secondary);font-size:.85rem;font-weight:500;padding:.5rem;text-align:center;transition:background-color .3s ease}.image-option.selected .image-label{background:var(--accent-50);color:var(--accent-700)}[data-theme=dark] .image-option.selected .image-label{background:#14b8a626;color:var(--accent-400)}.selected-preview{background:var(--accent-50);border:1px solid #14b8a64d;border-radius:var(--radius-md);margin-top:1rem;padding:1rem;text-align:center;transition:background-color .3s ease}[data-theme=dark] .selected-preview{background:#14b8a61a}.selected-preview strong{color:var(--accent-600);margin-right:.5rem}[data-theme=dark] .selected-preview strong{color:var(--accent-400)}.preview-info{color:var(--text-secondary);font-weight:600}@media (max-width:768px){.focus-group{grid-template-columns:1fr}.scene-header h3{font-size:1.1rem}.aspect-title{font-size:.925rem}}@media (min-width:1200px){.focus-group{grid-template-columns:repeat(2,1fr)}}.wait-modal-overlay{animation:fadeIn .2s ease-out;background:var(--bg-modal-overlay);height:100vh;width:100vw;z-index:9999}.wait-modal-content{align-items:center;animation:scaleIn .2s ease-out;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:1.5rem;min-width:360px;padding:2.5rem 3rem}.wait-modal-content h3{font-size:1.15rem;font-weight:600;margin:0}.spinner-large{animation:spin .8s linear infinite;border-top:4px solid var(--bg-tertiary);border:4px solid var(--bg-tertiary);height:52px;width:52px}.edit-btn{background:#6366f1f2;border:none;border-radius:20px;bottom:.5rem;box-shadow:var(--shadow-md);color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;left:50%;opacity:0;padding:.4rem .9rem;position:absolute;top:auto;transform:translateX(-50%) scale(.9);transition:all .2s ease;white-space:nowrap;z-index:100}.image-wrapper:hover .edit-btn{opacity:1;transform:translateX(-50%) scale(1)}.edit-btn:hover{background:#4f46e5;transform:translateX(-50%) scale(1.05)}.edit-btn:active{transform:translateX(-50%) scale(.95)}.edit-btn:disabled{background:#6366f180;cursor:not-allowed}.edit-modal-overlay{z-index:1000}.edit-modal{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.edit-image-reference-guide{border-radius:var(--radius-md)}.edit-reference-item img{border-radius:var(--radius-sm)}.edit-reference-remove{background:var(--error-main)}.edit-reference-base .edit-reference-label{color:var(--accent-600)}[data-theme=dark] .edit-reference-base .edit-reference-label{color:var(--accent-400)}.edit-prompt-input{background:var(--bg-secondary);border-radius:var(--radius-md)}.edit-prompt-input::placeholder{color:var(--text-tertiary)}.edit-modal-cancel,.edit-modal-submit{border-radius:var(--radius-md)}.edit-modal-submit{background:linear-gradient(135deg,#6366f1,#4f46e5)}.edit-modal-submit:hover:not(:disabled){box-shadow:var(--shadow-md)}.edit-quality-select{background:var(--bg-secondary)}.edit-additional-image-section,.edit-quality-select{border-radius:var(--radius-md)}.edit-additional-description{color:var(--text-tertiary)}.edit-additional-upload-btn{border-radius:var(--radius-md)}.edit-additional-previews{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.edit-additional-preview{display:inline-block;position:relative}.edit-additional-preview img{border:1px solid var(--border-primary);border-radius:var(--radius-md);height:100px;object-fit:cover;width:100px}.edit-additional-remove{align-items:center;background:var(--error);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;position:absolute;right:-8px;top:-8px;transition:transform .2s ease;width:24px}.edit-additional-remove:hover{transform:scale(1.1)}.edit-additional-clear-btn{border:1px solid var(--error);border-radius:var(--radius-md);color:var(--error);margin-left:.5rem}.edit-additional-clear-btn:hover{background:var(--error)}.editing-message{animation:pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#6366f1f2,#4f46e5f2);border-radius:var(--radius-lg) var(--radius-lg) 0 0;color:#fff;font-size:.9rem;font-weight:600;left:0;padding:.75rem 1rem;position:absolute;right:0;text-align:center;top:0;z-index:10}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.error-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.error-modal{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--error-main);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:400px;padding:2rem;text-align:center;width:90%}.error-modal-icon{font-size:3rem;margin-bottom:1rem}.error-modal h3{color:var(--error-main);font-size:1.25rem;margin-bottom:1rem}.error-modal-message{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:1.5rem}.error-modal-close{background:var(--error-main);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .2s ease}.error-modal-close:hover{background:#dc2626;transform:scale(1.02)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.variation-limit-notice{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem;text-align:center}.variation-limit-notice strong{color:var(--accent-500)}.variation-limit-notice.limit-reached{background:#ef44441a;border-color:var(--error);color:var(--error)}.cropper-modal-overlay{align-items:center;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.cropper-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;max-height:95vh;max-width:95vw;overflow-y:auto}.cropper-header{border-bottom:2px solid #eee;padding:1.5rem;text-align:center}.cropper-header h3{color:#667eea;font-size:1.5rem;margin:0 0 .5rem}.cropper-header p{color:#666;font-size:.9rem;margin:0}.cropper-container{background:#f5f5f5;margin:1.5rem auto;overflow:hidden;position:relative;-webkit-user-select:none;user-select:none}.cropper-image{display:block;object-fit:contain;pointer-events:none}.crop-overlay{background:#00000080;bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0}.crop-box{border:2px solid #11998e;box-shadow:0 0 0 9999px #00000080}.crop-box,.crop-move-area{cursor:move;position:absolute}.crop-move-area{bottom:0;left:0;right:0;top:0}.crop-handle{background:#11998e;border:2px solid #fff;border-radius:50%;height:12px;position:absolute;width:12px;z-index:10}.crop-handle-nw{cursor:nw-resize;left:-6px;top:-6px}.crop-handle-n{cursor:n-resize;left:50%;top:-6px;transform:translateX(-50%)}.crop-handle-ne{cursor:ne-resize;right:-6px;top:-6px}.crop-handle-e{cursor:e-resize;right:-6px;top:50%;transform:translateY(-50%)}.crop-handle-se{bottom:-6px;cursor:se-resize;right:-6px}.crop-handle-s{bottom:-6px;cursor:s-resize;left:50%;transform:translateX(-50%)}.crop-handle-sw{bottom:-6px;cursor:sw-resize;left:-6px}.crop-handle-w{cursor:w-resize;left:-6px;top:50%;transform:translateY(-50%)}.cropper-actions{border-top:2px solid #eee;display:flex;gap:1rem;justify-content:center;padding:1.5rem}.btn-cropper-cancel,.btn-cropper-save{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s}.btn-cropper-cancel{background:#e0e0e0;color:#333}.btn-cropper-cancel:hover{background:#d0d0d0;transform:translateY(-2px)}.btn-cropper-save{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.btn-cropper-save:hover{box-shadow:0 4px 12px #11998e66;transform:translateY(-2px)}@media (max-width:768px){.cropper-container{max-height:50vh;max-width:90vw}.cropper-header h3{font-size:1.2rem}.crop-handle{height:16px;width:16px}}.theme-toggle{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.theme-toggle:hover{background:var(--bg-hover);border-color:var(--accent-500);color:var(--text-primary)}.theme-toggle:active{transform:scale(.95)}.theme-toggle-icon{align-items:center;display:flex;justify-content:center;transition:transform .3s ease}.theme-toggle:hover .theme-toggle-icon{transform:rotate(15deg)}[data-theme=dark] .theme-toggle{background:var(--bg-tertiary);border-color:var(--border-secondary)}[data-theme=dark] .theme-toggle:hover{background:var(--accent-600);border-color:var(--accent-500);color:#fff}[data-theme=dark] .theme-toggle:hover .theme-toggle-icon{transform:rotate(-15deg)}.main-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);justify-content:space-between;padding:.75rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.main-nav,.nav-logo a{align-items:center;display:flex}.nav-logo a{color:var(--accent-500);font-size:1.25rem;font-weight:700;gap:.5rem;text-decoration:none}.nav-logo-icon{border-radius:6px;height:32px;width:32px}.nav-logo a:hover{color:var(--accent-400)}.nav-links{display:flex;gap:.5rem}.nav-link{border-radius:.5rem;color:var(--text-secondary);font-size:.875rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{background:#14b8a61a;background:var(--accent-500-alpha,#14b8a61a);color:var(--accent-500)}.nav-dropdown{position:relative}.nav-dropdown-trigger{align-items:center;background:#0000;border:none;border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:.35rem;padding:.5rem 1rem;transition:all .2s ease}.nav-dropdown-trigger:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-dropdown-trigger.active{background:#14b8a61a;background:var(--accent-500-alpha,#14b8a61a);color:var(--accent-500)}.dropdown-arrow{font-size:.7rem;transition:transform .2s ease}.nav-dropdown.open .dropdown-arrow{transform:rotate(180deg)}.nav-dropdown-menu{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.5rem;box-shadow:var(--shadow-lg);left:0;min-width:160px;opacity:0;padding:.5rem 0;position:absolute;top:calc(100% + .25rem);transform:translateY(-10px);transition:all .2s ease;visibility:hidden;z-index:10000}.nav-dropdown.open .nav-dropdown-menu{opacity:1;transform:translateY(0);visibility:visible}.dropdown-item{color:var(--text-secondary);display:block;font-size:.875rem;padding:.6rem 1rem;text-decoration:none;transition:all .15s ease;white-space:nowrap}.dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.dropdown-item.active{background:#14b8a61a;background:var(--accent-500-alpha,#14b8a61a);color:var(--accent-500)}.nav-user{align-items:center;display:flex;gap:1rem}.nav-credits{background:linear-gradient(135deg,var(--accent-500),var(--accent-400));border-radius:1rem;color:#fff;white-space:nowrap}.nav-charge-btn,.nav-credits{font-size:.8rem;font-weight:600;padding:.35rem .75rem}.nav-charge-btn{background:#0000;border:1px solid var(--success-main);border-radius:1rem;color:var(--success-main);text-decoration:none;transition:all .2s ease}.nav-charge-btn:hover{background:var(--success-main);color:#fff}.nav-username{color:var(--text-secondary);font-size:.875rem;font-weight:500}.nav-mypage-btn{background:#0000;border:1px solid var(--accent-500);border-radius:.5rem;color:var(--accent-500);font-size:.875rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.nav-mypage-btn:hover{background:var(--accent-500);color:#fff}.nav-logout-btn{background:#0000;border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.nav-logout-btn:hover{background:var(--error-main);border-color:var(--error-main);color:#fff}.nav-browse-hint{color:var(--text-muted);font-size:.8rem;font-style:italic}.nav-login-btn{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1.25rem;transition:all .2s ease}.nav-login-btn:hover{background:var(--accent-600);box-shadow:var(--shadow-md)}@media (max-width:768px){.main-nav{flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem}.nav-links{flex-wrap:wrap;justify-content:center;order:3;width:100%}.nav-dropdown-trigger,.nav-link{font-size:.8rem;padding:.4rem .75rem}.nav-dropdown-menu{left:50%;min-width:200px;position:fixed;transform:translateX(-50%) translateY(-10px)}.nav-dropdown.open .nav-dropdown-menu{transform:translateX(-50%) translateY(0)}.nav-username{display:none}}.pagination{gap:.25rem;margin:2rem 0}.pagination,.pagination-btn{align-items:center;display:flex;justify-content:center}.pagination-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.375rem;color:var(--text-secondary);cursor:pointer;font-size:.875rem;height:2.25rem;min-width:2.25rem;padding:0 .5rem;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-500);color:var(--text-primary)}.pagination-btn.active{background:var(--accent-500);border-color:var(--accent-500);color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-ellipsis{color:var(--text-tertiary);padding:0 .5rem}.mypage{margin:0 auto;max-width:1200px;padding:2rem}.mypage-header{margin-bottom:2rem}.mypage-header h1{color:var(--text-primary);font-size:1.75rem;margin-bottom:.5rem}.mypage-header p{color:var(--text-secondary)}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;padding:1.25rem;text-align:center}.stat-value{color:var(--accent-500);font-size:1.75rem;font-weight:700}.stat-label{color:var(--text-tertiary);font-size:.875rem;margin-top:.25rem}.mypage-tabs{border-bottom:1px solid var(--border-primary);display:flex;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.tab-btn{border-radius:.5rem .5rem 0 0;padding:.75rem 1.5rem}.tab-btn.active,.tab-btn:hover{background:var(--bg-tertiary)}.tab-btn.active{border-bottom:2px solid var(--accent-500);color:var(--accent-500)}.sessions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.session-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.session-card.clickable{cursor:pointer}.session-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.session-card.clickable:hover{border-color:var(--accent-500)}.session-thumbnail{align-items:center;background:var(--bg-tertiary);display:flex;height:160px;justify-content:center}.session-thumbnail img{height:100%;object-fit:cover;width:100%}.session-info{padding:1rem}.session-info h3{color:var(--text-primary);font-size:1rem;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-preview{color:var(--text-tertiary);font-size:.8rem;height:2.8em;line-height:1.4;margin-bottom:.75rem;overflow:hidden}.session-meta{color:var(--text-tertiary);display:flex;font-size:.75rem;gap:.75rem;margin-bottom:.5rem}.session-meta .status{border-radius:1rem;font-size:.7rem;font-weight:500;padding:.125rem .5rem}.status.completed{background:#10b9811a;color:var(--success-main)}.status.processing{background:#f59e0b1a;color:var(--warning-main)}.status.error{background:#ef44441a;color:var(--error-main)}.session-date{color:var(--text-tertiary);font-size:.75rem}.session-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.session-tags .tag{border-radius:.75rem;font-size:.65rem;font-weight:500;padding:.125rem .5rem}.session-tags .tag-model{background:#6366f11a;color:#6366f1}.session-tags .tag-style{background:#ec48991a;color:#ec4899}.settings-section{max-width:600px}.settings-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;margin-bottom:1.5rem;padding:1.5rem}.settings-card h3{border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-size:1.125rem;padding-bottom:.75rem}.settings-card .form-group,.settings-card h3{margin-bottom:1rem}.settings-card label{color:var(--text-secondary);display:block;font-size:.875rem;margin-bottom:.375rem}.settings-card input,.settings-card textarea{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;padding:.625rem;width:100%}.settings-card input:focus,.settings-card textarea:focus{border-color:var(--accent-500);outline:none}.settings-card input:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 1.25rem;transition:background .2s ease}.btn-primary:hover{background:var(--accent-400)}.settings-message{border-radius:.5rem;font-size:.875rem;margin-bottom:1rem;padding:.75rem 1rem}.settings-message.success{background:#10b9811a;border:1px solid var(--success-main);color:var(--success-main)}.settings-message.error{background:#ef44441a;border:1px solid var(--error-main);color:var(--error-main)}.account-info p{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.empty-state{padding:3rem}.loading{padding:2rem}.settings-card.danger-zone{border-color:var(--error-main)}.settings-card.danger-zone h3{border-bottom-color:#ef44444d;color:var(--error-main)}.danger-warning{line-height:1.5;margin-bottom:.5rem}.danger-warning,.danger-warning-list{color:var(--text-secondary);font-size:.875rem}.danger-warning-list{line-height:1.6;margin:0 0 1rem 1.25rem;padding:0}.danger-warning-list li{margin-bottom:.25rem}.danger-warning-list strong{color:var(--error-main)}.btn-danger{background:var(--error-main);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 1.25rem;transition:background .2s ease}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;font-weight:500;padding:.625rem 1.25rem;transition:all .2s ease}.btn-secondary:hover{background:var(--bg-card);color:var(--text-primary)}.delete-form{border-top:1px solid #ef44444d;margin-top:1rem;padding-top:1rem}.delete-actions{display:flex;gap:.75rem;margin-top:1rem}.credits-section{max-width:800px}.credits-balance-card{align-items:center;background:linear-gradient(135deg,var(--accent-500),var(--accent-400));border-radius:1rem;color:#fff;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:2rem}.credits-balance{display:flex;flex-direction:column}.balance-label{font-size:.9rem;opacity:.9}.balance-value{font-size:2.5rem;font-weight:700}.credits-balance-card .btn-primary{background:#fff;color:var(--accent-500)}.credits-balance-card .btn-primary:hover{background:#ffffffe6}.credits-history-card,.credits-info-card,.credits-packages-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;margin-bottom:1.5rem;padding:1.5rem}.credits-history-card h3,.credits-info-card h3,.credits-packages-card h3{border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-size:1.1rem;margin-bottom:1rem;padding-bottom:.75rem}.credits-info-list{list-style:none;margin:0;padding:0}.credits-info-list li{color:var(--text-secondary);font-size:.9rem;padding:.5rem 0}.credits-info-list li:before{color:var(--accent-500);content:"•";margin-right:.5rem}.packages-list{display:flex;flex-direction:column;gap:.75rem}.package-item{align-items:center;background:var(--bg-tertiary);border-radius:.5rem;display:flex;gap:1rem;padding:.75rem 1rem;position:relative}.package-item.popular{border:1px solid var(--accent-500)}.popular-tag{background:var(--accent-500);border-radius:.25rem;color:#fff;font-size:.7rem;padding:.125rem .5rem;position:absolute;right:.5rem;top:-.5rem}.package-name{font-weight:500;min-width:80px}.package-credits{color:var(--accent-500);flex:1 1;font-weight:600}.package-price{color:var(--text-secondary);font-size:.9rem}.saved-episodes-section{max-width:100%}.saved-episodes-header{margin-bottom:1.5rem}.saved-episodes-header h2{color:var(--text-primary);font-size:1.25rem;margin-bottom:.5rem}.saved-episodes-description{color:var(--text-secondary);font-size:.9rem}.saved-episodes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.saved-episode-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.saved-episode-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.episode-thumbnail{align-items:center;background:var(--bg-tertiary);display:flex;height:180px;justify-content:center;position:relative}.episode-thumbnail img{height:100%;object-fit:cover;width:100%}.episode-info{padding:1.25rem}.episode-info h3{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-primary);display:-webkit-box;font-size:1.1rem;line-height:1.4;margin-bottom:.75rem;overflow:hidden}.episode-meta{color:var(--text-tertiary);display:flex;font-size:.8rem;gap:1rem;margin-bottom:1rem}.episode-meta span{align-items:center;display:flex;gap:.25rem}.episode-date{color:var(--text-tertiary);font-size:.8rem;margin-bottom:1rem}.episode-actions{display:flex;gap:.75rem}.btn-continue{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;flex:1 1;font-weight:500;padding:.625rem 1rem;transition:background .2s ease}.btn-continue:hover{background:var(--accent-400)}.btn-delete-episode{background:#0000;border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-tertiary);cursor:pointer;font-weight:500;padding:.625rem 1rem;transition:all .2s ease}.btn-delete-episode:hover{background:#ef44440d;border-color:var(--error-main);color:var(--error-main)}.delete-confirm-inline{background:#ef44440d;border:1px solid #ef44444d;border-radius:.5rem;margin-top:1rem;padding:1rem}.delete-confirm-inline p{color:var(--text-secondary);font-size:.85rem;margin-bottom:.75rem}.delete-confirm-inline .delete-actions{display:flex;gap:.5rem;margin-top:0}.btn-confirm-delete{background:var(--error-main);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem 1rem;transition:background .2s ease}.btn-confirm-delete:hover:not(:disabled){background:#dc2626}.btn-confirm-delete:disabled{cursor:not-allowed;opacity:.6}.btn-cancel-delete{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.btn-cancel-delete:hover{background:var(--bg-card);color:var(--text-primary)}.empty-hint{color:var(--text-tertiary);padding:3rem;text-align:center}.empty-hint p{margin-bottom:.5rem}.empty-hint p:first-child{font-size:1rem}.empty-hint p:last-child{font-size:.85rem}.imagegen-section{max-width:100%}.imagegen-header{margin-bottom:1.5rem}.imagegen-header h2{color:var(--text-primary);font-size:1.25rem;margin-bottom:.5rem}.imagegen-description{color:var(--text-secondary);font-size:.9rem}.imagegen-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.imagegen-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.imagegen-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.imagegen-images{background:var(--bg-tertiary);display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem}.imagegen-image-wrapper{flex:1 1;max-width:calc(50% - .25rem);min-width:120px;position:relative}.imagegen-image{aspect-ratio:1;border-radius:.5rem;cursor:pointer;object-fit:cover;transition:transform .2s ease;width:100%}.imagegen-image:hover{transform:scale(1.02)}.btn-download{align-items:center;background:#000000b3;border:none;border-radius:.375rem;bottom:.5rem;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;opacity:0;position:absolute;right:.5rem;transition:opacity .2s ease,background .2s ease;width:32px}.imagegen-image-wrapper:hover .btn-download{opacity:1}.btn-download:hover{background:var(--accent-500)}.imagegen-info{padding:1rem}.imagegen-prompt{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-primary);display:-webkit-box;font-size:.9rem;line-height:1.4;margin-bottom:.75rem;overflow:hidden}.imagegen-meta{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.imagegen-meta .tag{background:#6366f11a;border-radius:.375rem;color:#6366f1;font-size:.7rem;font-weight:500;padding:.2rem .5rem}.imagegen-meta .tag-animation{background:#ec48991a;color:#ec4899}.imagegen-meta .tag-direct{background:#22c55e1a;color:#22c55e}.imagegen-meta .credits{margin-left:auto}.imagegen-date,.imagegen-meta .credits{color:var(--text-tertiary);font-size:.75rem}.imagegen-actions{padding:0 1rem 1rem}.btn-delete-gen{background:#0000;border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-tertiary);cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;width:100%}.btn-delete-gen:hover:not(:disabled){background:#ef44440d;border-color:var(--error-main);color:var(--error-main)}.btn-delete-gen:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.mypage{padding:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.sessions-grid{grid-template-columns:1fr}.credits-balance-card{flex-direction:column;gap:1rem;text-align:center}.credits-balance-card .btn-primary{width:100%}.package-item{flex-wrap:wrap}.history-table td,.history-table th{font-size:.8rem;padding:.5rem .25rem}.saved-episodes-grid{grid-template-columns:1fr}.episode-actions{flex-direction:column}.btn-continue,.btn-delete-episode{width:100%}.imagegen-grid{grid-template-columns:1fr}.imagegen-image-wrapper{max-width:100%}}.board-list{margin:0 auto;max-width:1000px;padding:2rem}.board-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.board-header h1{color:var(--text-primary);font-size:1.5rem}.new-post-btn{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 1.25rem;transition:background .2s ease}.new-post-btn:hover{background:var(--accent-400)}.posts-table{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;overflow:hidden}.table-header,.table-row{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:1fr 120px 100px 60px 60px;padding:.875rem 1rem}.table-header{background:var(--bg-tertiary);color:var(--text-secondary);font-size:.8rem;font-weight:600}.table-header,.table-row{border-bottom:1px solid var(--border-primary)}.table-row{cursor:pointer;transition:background .2s ease}.table-row:last-child{border-bottom:none}.table-row:hover{background:var(--bg-tertiary)}.col-title{color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-count{color:var(--accent-500);font-size:.8rem;margin-left:.5rem}.col-author{color:var(--text-secondary);font-size:.875rem}.col-date,.col-likes,.col-views{color:var(--text-tertiary);font-size:.8rem;text-align:center}@media (max-width:768px){.board-list{padding:1rem}.table-header,.table-row{grid-template-columns:1fr 80px 60px}.col-likes,.col-views{display:none}}.like-button{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:1.5rem;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;gap:.375rem;padding:.5rem .75rem;transition:all .2s ease}.like-button.liked,.like-button:hover:not(:disabled){border-color:var(--error-main);color:var(--error-main)}.like-button.liked{background:#ef44441a}.like-button:disabled{cursor:not-allowed;opacity:.6}.like-icon{align-items:center;display:flex;height:1.125rem;justify-content:center;width:1.125rem}.like-icon svg{height:100%;width:100%}.like-count{font-weight:500}.like-button.animating .like-icon{animation:heartBeat .3s ease-in-out}@keyframes heartBeat{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.comment-section{border-top:1px solid var(--border-primary);margin-top:2rem;padding-top:2rem}.comment-section-title{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.comment-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.comment-form textarea{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;min-height:80px;padding:.75rem;resize:vertical;width:100%}.comment-form textarea:focus{border-color:var(--accent-500);outline:none}.comment-form button{align-self:flex-end;background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background .2s ease}.comment-form button:hover:not(:disabled){background:var(--accent-400)}.comment-form button:disabled{cursor:not-allowed;opacity:.6}.comment-login-hint{background:var(--bg-tertiary);border-radius:.5rem;color:var(--text-tertiary);font-size:.875rem;margin-bottom:1.5rem;padding:1rem;text-align:center}.comments-list{display:flex;flex-direction:column;gap:1rem}.no-comments{color:var(--text-tertiary);padding:2rem;text-align:center}.comment{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.5rem;padding:1rem}.comment-reply{background:var(--bg-tertiary);border-left:3px solid var(--accent-500);margin-left:1.5rem}.comment-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.comment-author{color:var(--text-primary);font-size:.875rem;font-weight:600}.comment-date{color:var(--text-tertiary);font-size:.75rem}.comment-delete-btn{background:#0000;border:1px solid var(--error-main);border-radius:.25rem;color:var(--error-main);cursor:pointer;font-size:.75rem;margin-left:auto;padding:.25rem .5rem;transition:all .2s ease}.comment-delete-btn:hover{background:var(--error-main);color:#fff}.comment-content{color:var(--text-primary);font-size:.875rem;line-height:1.5;white-space:pre-wrap}.comment-reply-btn{background:#0000;border:none;color:var(--accent-500);cursor:pointer;font-size:.75rem;margin-top:.5rem;padding:.25rem .5rem}.comment-reply-btn:hover{text-decoration:underline}.reply-form{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.reply-form textarea{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.375rem;color:var(--text-primary);font-size:.8rem;padding:.5rem;resize:vertical;width:100%}.reply-form button{align-self:flex-end;background:var(--accent-500);border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.8rem;padding:.375rem .75rem}.reply-form button:disabled{cursor:not-allowed;opacity:.6}.comment-replies{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.post-view{margin:0 auto;max-width:800px;padding:2rem}.post-view.error,.post-view.loading{color:var(--text-tertiary);padding:4rem 2rem;text-align:center}.post-view.error button{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;margin-top:1rem;padding:.75rem 1.5rem}.post-article{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;overflow:hidden}.post-header{border-bottom:1px solid var(--border-primary);padding:1.5rem}.post-header h1{color:var(--text-primary);font-size:1.5rem;line-height:1.4;margin-bottom:.75rem}.post-meta{color:var(--text-tertiary);display:flex;font-size:.875rem;gap:1rem}.post-meta .author{color:var(--text-secondary);font-weight:500}.post-content{min-height:200px;padding:1.5rem}.post-content p{color:var(--text-primary);line-height:1.8;margin-bottom:.5rem}.post-footer{background:var(--bg-tertiary);border-top:1px solid var(--border-primary);padding:1rem 1.5rem}.post-actions{align-items:center;display:flex;justify-content:space-between}@media (max-width:768px){.post-view{padding:1rem}.post-meta{flex-wrap:wrap;gap:.5rem}}.post-editor{margin:0 auto;max-width:800px;padding:2rem}.post-editor .form-group{margin-bottom:1.25rem}.post-editor label{color:var(--text-secondary);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.post-editor input,.post-editor textarea{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-primary);font-size:1rem;padding:.75rem;transition:border-color .2s ease;width:100%}.post-editor input:focus,.post-editor textarea:focus{border-color:var(--accent-500);outline:none}.post-editor textarea{line-height:1.6;min-height:300px;resize:vertical}@media (max-width:768px){.post-editor{padding:1rem}.button-group{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.works-list{margin:0 auto;max-width:1200px;padding:2rem}.works-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.works-header-text{display:flex;flex-direction:column;gap:.25rem}.works-header h1{color:var(--text-primary);font-size:1.5rem;margin:0}.works-header .works-description{color:var(--text-tertiary);font-size:.875rem;margin:0}.new-work-btn{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 1.25rem;transition:background .2s ease}.new-work-btn:hover{background:var(--accent-400)}.works-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.work-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.work-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.work-thumbnail{align-items:center;background:var(--bg-tertiary);display:flex;height:180px;justify-content:center}.work-thumbnail img{height:100%;object-fit:cover;width:100%}.no-thumbnail{color:var(--text-tertiary);font-size:.875rem}.work-info{padding:1rem}.work-info h3{color:var(--text-primary);font-size:1rem}.work-description,.work-info h3{margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.work-description{color:var(--text-secondary);font-size:.8rem}.work-preview{color:var(--text-tertiary);font-size:.8rem;height:2.8em;line-height:1.4;margin-bottom:.75rem;overflow:hidden}.work-meta{align-items:center;font-size:.75rem;justify-content:space-between;margin-bottom:.5rem}.work-meta .stats{color:var(--text-tertiary);display:flex;gap:.5rem}.work-date{font-size:.75rem}.empty-state,.work-date{color:var(--text-tertiary)}.empty-state{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;padding:4rem 2rem;text-align:center}.empty-state button{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem}@media (max-width:768px){.works-list{padding:1rem}.works-grid{grid-template-columns:1fr}}.text-image-renderer{-webkit-touch-callout:none}.text-image-line,.text-image-renderer{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;width:100%}.text-image-line{-webkit-user-drag:none;display:block;height:auto;pointer-events:none}.text-image-renderer ::selection,.text-image-renderer::selection{background:#0000}.text-image-renderer ::-moz-selection,.text-image-renderer::-moz-selection{background:#0000}.work-view{margin:0 auto;max-width:900px;padding:2rem}.work-view.error,.work-view.loading{color:var(--text-tertiary);padding:4rem 2rem;text-align:center}.work-view.error button{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;margin-top:1rem;padding:.75rem 1.5rem}.back-btn{align-items:center;background:#0000;border:none;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;gap:.25rem;margin-bottom:1rem;padding:.5rem 0}.back-btn:hover{color:var(--accent-500)}.work-article{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;overflow:hidden}.work-header{border-bottom:1px solid var(--border-primary);padding:1.5rem}.work-header h1{color:var(--text-primary);font-size:1.75rem;line-height:1.4;margin-bottom:.5rem}.work-header .work-description{color:var(--text-secondary);font-size:1rem;margin-bottom:1rem}.work-meta{color:var(--text-tertiary);display:flex;font-size:.875rem;gap:1rem}.work-meta .author{color:var(--text-secondary);font-weight:500}.work-gallery{background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);padding:1.5rem}.gallery-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.gallery-item{border-radius:.5rem;cursor:pointer;overflow:hidden;position:relative;transition:transform .2s ease}.gallery-item:hover{transform:scale(1.02)}.gallery-item img{height:200px;object-fit:cover;width:100%}.image-caption{background:#000000b3;bottom:0;color:#fff;font-size:.75rem;left:0;padding:.5rem;position:absolute;right:0;text-align:center}.work-content{min-height:200px;padding:1.5rem}.work-content .content-paragraph,.work-content p{color:var(--text-primary);line-height:1.8;margin-bottom:.5rem}.inline-image-container{margin:1.5rem 0;text-align:center}.inline-image{border-radius:.5rem;box-shadow:0 4px 12px #00000026;cursor:pointer;max-height:500px;max-width:100%;transition:transform .2s ease}.inline-image:hover{transform:scale(1.01)}.inline-image-caption{color:var(--text-tertiary);font-size:.875rem;font-style:italic;margin-top:.5rem}.work-footer{background:var(--bg-tertiary);border-top:1px solid var(--border-primary);padding:1rem 1.5rem}.work-actions{align-items:center;display:flex;justify-content:space-between}.owner-actions{display:flex;gap:.5rem}.owner-actions button{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.375rem;color:var(--text-secondary);cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.owner-actions button:hover{background:var(--bg-card);color:var(--text-primary)}.owner-actions .delete-btn:hover{background:var(--error-main);border-color:var(--error-main);color:#fff}.image-modal{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{max-height:90vh;max-width:90vw;position:relative}.modal-content img{border-radius:.5rem;max-height:85vh;max-width:100%;object-fit:contain}.modal-content .close-btn{background:#0000;border:none;color:#fff;cursor:pointer;font-size:2rem;padding:.5rem;position:absolute;right:0;top:-2.5rem}.modal-caption{color:#fff;font-size:.875rem;margin-top:1rem;text-align:center}.admin-actions{align-items:center;display:flex;gap:.5rem}.admin-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.25rem;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase}.admin-actions button,.move-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.375rem;color:var(--text-secondary);cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.admin-actions button:hover,.move-btn:hover{background:var(--bg-card);color:var(--text-primary)}.admin-actions .move-btn:hover,.move-btn:hover{background:#667eea;border-color:#667eea;color:#fff}.admin-actions .delete-btn:hover{background:var(--error-main);border-color:var(--error-main);color:#fff}.move-modal{background:var(--bg-card);border-radius:.75rem;max-width:400px;min-width:320px;padding:1.5rem}.move-modal h3{color:var(--text-primary);font-size:1.25rem;margin-bottom:.5rem}.move-modal .move-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.move-modal .current-board{background:var(--bg-tertiary);border-radius:.5rem;color:var(--text-tertiary);font-size:.875rem;margin-bottom:1.5rem;padding:.75rem}.move-modal .current-board strong{color:var(--text-primary)}.move-options{display:flex;flex-direction:column;gap:.5rem}.move-option{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:.5rem;color:var(--text-primary);cursor:pointer;font-size:.9375rem;padding:.75rem 1rem;text-align:left;transition:all .2s ease}.move-option:hover:not(:disabled){background:#14b8a61a;border-color:var(--accent-500)}.move-option.current{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.move-option:disabled{cursor:not-allowed;opacity:.6}.moving-status{color:var(--accent-500);font-size:.875rem;margin-top:1rem;text-align:center}@media (max-width:768px){.work-view{padding:1rem}.work-meta{flex-wrap:wrap;gap:.5rem}.gallery-grid{grid-template-columns:repeat(2,1fr)}.gallery-item img{height:150px}.work-actions{flex-wrap:wrap;gap:.75rem}.admin-actions{justify-content:flex-end;width:100%}}.work-editor{margin:0 auto;max-width:800px;padding:2rem}.editor-container h1{color:var(--text-primary);font-size:1.5rem;margin-bottom:1.5rem}.work-editor .form-group{margin-bottom:1.25rem}.work-editor label{color:var(--text-secondary);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.work-editor input,.work-editor textarea{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-primary);font-size:1rem;padding:.75rem;transition:border-color .2s ease;width:100%}.work-editor input:focus,.work-editor textarea:focus{border-color:var(--accent-500);outline:none}.work-editor textarea{font-family:inherit;line-height:1.6;min-height:300px;resize:vertical}.help-text{color:var(--text-tertiary);display:block;font-size:.8rem;margin-top:.5rem}.content-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.content-header label{margin-bottom:0}.content-actions{display:flex;gap:.5rem}.insert-image-btn{background:var(--bg-card);border:1px solid var(--accent-500);border-radius:.375rem;color:var(--accent-500);cursor:pointer;font-size:.8rem;padding:.4rem .75rem;transition:all .2s ease}.insert-image-btn:hover:not(:disabled){background:var(--accent-500);color:#fff}.insert-image-btn:disabled{cursor:not-allowed;opacity:.6}.preview-toggle-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.375rem;color:var(--text-secondary);cursor:pointer;font-size:.8rem;padding:.4rem .75rem;transition:all .2s ease}.preview-toggle-btn:hover{background:var(--bg-card);color:var(--text-primary)}.preview-toggle-btn.active{background:var(--accent-500);border-color:var(--accent-500);color:#fff}.content-preview{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-primary);font-size:1rem;line-height:1.8;min-height:300px;overflow-y:auto;padding:.75rem;width:100%}.preview-image-container{margin:1rem 0;text-align:center}.preview-inline-image{border-radius:.5rem;box-shadow:0 2px 8px #0000001a;max-height:400px;max-width:100%}.preview-image-missing{background:var(--bg-tertiary);border:1px dashed var(--border-primary);border-radius:.5rem;color:var(--text-tertiary);margin:1rem 0;padding:1rem;text-align:center}.inserted-images-panel{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;display:flex;flex-wrap:wrap;gap:.75rem;padding:1rem}.inserted-image-item{border-radius:.375rem;height:80px;overflow:hidden;position:relative;width:80px}.inserted-image-item img{height:100%;object-fit:cover;width:100%}.remove-image-btn{background:#ef4444e6;display:flex;font-size:.875rem;height:1.25rem;right:.25rem;top:.25rem;width:1.25rem}.remove-image-btn:hover{background:var(--error-main)}.button-group{margin-top:1.5rem}@media (max-width:768px){.work-editor{padding:1rem}.content-header{align-items:flex-start;flex-direction:column;gap:.5rem}.content-actions{width:100%}.insert-image-btn,.preview-toggle-btn{flex:1 1}.button-group{flex-direction:column}.cancel-btn,.submit-btn{width:100%}.inserted-image-item{height:60px;width:60px}}.work-publisher{margin:0 auto;max-width:600px;padding:2rem}.work-publisher.error,.work-publisher.loading{color:var(--text-tertiary);padding:4rem 2rem;text-align:center}.work-publisher.error button{background:var(--accent-500);border:none;border-radius:.5rem;color:#fff;cursor:pointer;margin-top:1rem;padding:.75rem 1.5rem}.publisher-container h1{color:var(--text-primary);font-size:1.5rem;margin-bottom:.5rem}.subtitle{color:var(--text-tertiary);margin-bottom:1.5rem}.error-message{border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.session-preview{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.session-preview h3{color:var(--text-secondary);font-size:.875rem;margin-bottom:.75rem}.preview-info{font-size:.875rem}.preview-info p{color:var(--text-primary);margin-bottom:.5rem}.preview-info strong{color:var(--text-secondary)}.text-preview{color:var(--text-tertiary);display:block;font-size:.8rem;line-height:1.4;margin-top:.25rem}.work-publisher .form-group{margin-bottom:1.25rem}.work-publisher label{color:var(--text-secondary);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.work-publisher input,.work-publisher textarea{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-primary);font-size:1rem;padding:.75rem;transition:border-color .2s ease;width:100%}.work-publisher input:focus,.work-publisher textarea:focus{border-color:var(--accent-500);outline:none}.board-type-options{display:flex;flex-direction:column;gap:.75rem}.board-type-option{align-items:center;background:var(--bg-card);border:2px solid var(--border-primary);border-radius:.5rem;cursor:pointer;display:flex;padding:.875rem 1rem;transition:all .2s ease}.board-type-option:hover{background:var(--bg-tertiary);border-color:var(--accent-400)}.board-type-option.selected{background:#14b8a61a;border-color:var(--accent-500)}.board-type-option input[type=radio]{accent-color:var(--accent-500);margin-right:.75rem;width:auto}.board-type-content{display:flex;flex-direction:column;gap:.125rem}.board-type-label{color:var(--text-primary);font-size:.9rem;font-weight:600}.board-type-desc{color:var(--text-tertiary);font-size:.75rem}.info-box{background:#14b8a61a;border:1px solid var(--accent-500);border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.info-box p{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.info-box ul{color:var(--text-primary);font-size:.875rem;margin:0;padding-left:1.25rem}.info-box li{margin-bottom:.25rem}.button-group{display:flex;gap:.75rem;justify-content:flex-end}.cancel-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.cancel-btn:hover{background:var(--bg-card);color:var(--text-primary)}.submit-btn{background:var(--accent-500);border-radius:.5rem;font-weight:500;padding:.75rem 1.5rem;transition:background .2s ease}.submit-btn:hover:not(:disabled){background:var(--accent-400)}.submit-btn:disabled{opacity:.6}@media (max-width:768px){.work-publisher{padding:1rem}.button-group{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.credit-purchase{margin:0 auto;max-width:900px;padding:2rem}.credit-header{margin-bottom:2rem;text-align:center}.credit-header h1{color:var(--text-primary);font-size:1.75rem;margin-bottom:.5rem}.credit-header p{color:var(--text-secondary);margin-bottom:1rem}.current-credits{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:2rem;color:var(--text-secondary);display:inline-block;font-size:.95rem;padding:.75rem 1.5rem}.current-credits strong{color:var(--accent-500);font-size:1.1rem}.message{border-radius:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem;text-align:center}.message.error{background:#ef44441a;border:1px solid var(--error-main);color:var(--error-main)}.message.success{background:#10b9811a;border:1px solid var(--success-main);color:var(--success-main)}.plan-tabs{background:var(--bg-tertiary);border-radius:.75rem;margin-bottom:1.5rem;padding:.25rem}.plan-tabs,.tab-btn{display:flex;gap:.5rem}.tab-btn{align-items:center;background:#0000;border:none;border-radius:.5rem;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;justify-content:center;padding:.875rem 1.5rem;transition:all .2s ease}.tab-btn.active,.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{background:var(--bg-card);box-shadow:0 1px 3px #0000001a}.tab-badge{background:var(--accent-500);border-radius:1rem;color:#fff;font-size:.7rem;font-weight:600;padding:.2rem .5rem}.plan-description{color:var(--text-secondary);font-size:.95rem;margin-bottom:1.5rem;text-align:center}.packages-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;margin-bottom:2rem}.subscription-grid{grid-template-columns:repeat(3,1fr)}.onetime-grid{grid-template-columns:repeat(4,1fr)}.package-card{background:var(--bg-card);border:2px solid var(--border-primary);border-radius:1rem;cursor:pointer;padding:1.5rem;position:relative;text-align:center;transition:all .2s ease}.package-card:hover{border-color:var(--accent-400);transform:translateY(-2px)}.package-card.selected{background:linear-gradient(135deg,#3b82f61a,#2563eb1a);border-color:var(--accent-500)}.package-card.popular{border-color:var(--accent-400)}.package-card.best-value{border-color:#10b981}.popular-badge{background:var(--accent-500)}.best-value-badge,.popular-badge{border-radius:1rem;color:#fff;font-size:.75rem;font-weight:600;left:50%;padding:.25rem .75rem;position:absolute;top:-.75rem;transform:translateX(-50%)}.best-value-badge{background:#10b981}.package-name{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.package-credits{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.package-subinfo{color:var(--text-tertiary);font-size:.8rem;margin-bottom:.75rem}.package-price{color:var(--accent-500);font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.price-period{color:var(--text-tertiary);font-size:.85rem;font-weight:400}.package-monthly{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.package-unit{color:var(--text-tertiary);font-size:.8rem}.subscription-card .package-credits{font-size:1.5rem}.purchase-info{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem;text-align:center}.purchase-info .info-small{color:var(--text-tertiary);font-size:.8rem;margin-top:.5rem}.purchase-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.btn-purchase{background:var(--accent-500);border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2.5rem;transition:all .2s ease}.btn-purchase:hover:not(:disabled){background:var(--accent-400);transform:translateY(-1px)}.btn-purchase:disabled{cursor:not-allowed;opacity:.6}.btn-back{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.75rem;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:.875rem 2rem;transition:all .2s ease}.btn-back:hover{background:var(--bg-card);color:var(--text-primary)}.history-section{border-top:1px solid var(--border-primary);padding-top:1.5rem}.btn-toggle-history{background:#0000;border:1px solid var(--border-primary);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:block;padding:.75rem;transition:all .2s ease;width:100%}.btn-toggle-history:hover{background:var(--bg-tertiary);color:var(--text-primary)}.payment-history{margin-top:1.5rem}.payment-history h3{color:var(--text-primary);font-size:1.1rem;margin-bottom:1rem}.no-history{color:var(--text-tertiary);padding:1.5rem;text-align:center}.history-table{border-collapse:collapse;width:100%}.history-table td,.history-table th{border-bottom:1px solid var(--border-primary);padding:.75rem;text-align:left}.history-table th{color:var(--text-secondary);font-size:.85rem;font-weight:600}.history-table td{color:var(--text-primary);font-size:.9rem}.status-badge{border-radius:.25rem;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.status-badge.approved{background:#10b9811a;color:var(--success-main)}.status-badge.pending{background:#f59e0b1a;color:var(--warning-main)}.status-badge.failed{background:#ef44441a;color:var(--error-main)}.status-badge.cancelled{background:#9ca3af1a;color:var(--text-tertiary)}.loading{color:var(--text-tertiary);padding:3rem;text-align:center}@media (max-width:900px){.subscription-grid{grid-template-columns:repeat(3,1fr)}.onetime-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.credit-purchase{padding:1rem}.onetime-grid,.subscription-grid{gap:1rem;grid-template-columns:1fr}.package-card{padding:1.25rem}.package-credits{font-size:1.5rem}.plan-tabs{flex-direction:column}.tab-btn{padding:.75rem 1rem}.purchase-actions{flex-direction:column}.btn-back,.btn-purchase{width:100%}.history-table{font-size:.85rem}.history-table td,.history-table th{padding:.5rem .25rem}}.custom-character-page{margin:0 auto;max-width:1400px;padding:2.5rem 2rem;width:100%}.custom-character-page .info-panel{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);border:2px solid var(--accent-500);border-radius:12px;box-shadow:0 4px 12px #00000014;margin:0 auto 1.5rem;max-width:1000px;padding:1.25rem 1.5rem}.info-panel-main{margin-bottom:.75rem}.info-panel-main p{color:var(--text-primary);font-size:.95rem;font-weight:500;line-height:1.7;margin:0}.info-panel-warning{align-items:center;background:#f59e0b26;border:1px solid #f59e0b66;border-radius:6px;display:flex;gap:.5rem;margin-top:.5rem;padding:.6rem .85rem}.info-panel-warning .warning-icon{flex-shrink:0;font-size:1rem}.info-panel-warning span:last-child{color:var(--text-primary);font-size:.85rem;font-weight:500}.info-panel p{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0}.page-header{margin-bottom:2rem;text-align:center}.page-header h1{color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:.5rem}.page-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.custom-character-form{align-items:stretch;display:flex;flex-direction:column;gap:2rem;margin:0 auto;max-width:1000px;width:100%}.form-section{align-self:stretch;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;box-sizing:border-box;display:block;max-width:100%!important;min-width:100%!important;padding:1.5rem;width:100%!important}.form-section h2{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.section-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.section-notice{background:var(--bg-tertiary);border-left:3px solid var(--accent-500);border-radius:6px;color:var(--text-muted);font-size:.8rem;margin-bottom:1rem;padding:.5rem .75rem}.episode-type-selector{display:flex;gap:.75rem;margin-bottom:1rem}.episode-type-btn{background:var(--bg-tertiary);border:2px solid var(--border-secondary);border-radius:8px;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:.75rem 1rem;transition:all .2s ease}.episode-type-btn:hover{border-color:var(--accent-500);color:var(--text-primary)}.episode-type-btn.active{background:#14b8a61a;background:var(--accent-500-alpha,#14b8a61a);border-color:var(--accent-500);color:var(--accent-500);font-weight:600}.previous-session-selector{border-top:1px solid var(--border-secondary);margin-top:1rem;padding-top:1rem}.previous-session-selector label{color:var(--text-secondary);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.previous-session-selector select{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.875rem;padding:.75rem;width:100%}.previous-session-selector select:focus{border-color:var(--accent-500);outline:none}.session-hint{color:var(--text-muted);font-size:.75rem;margin-top:.5rem}.loading-text,.no-sessions-text{color:var(--text-muted);font-size:.875rem;padding:.5rem 0}.saved-characters-preview{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px;margin-top:1rem;padding:1rem}.saved-characters-preview h4{color:var(--text-primary);font-size:.9rem;font-weight:600;margin-bottom:.75rem}.saved-characters-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.saved-character-card{background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:8px;overflow:hidden}.saved-character-image{object-fit:contain}.saved-character-image,.saved-character-no-image{aspect-ratio:1;background:var(--bg-tertiary);width:100%}.saved-character-no-image{align-items:center;color:var(--text-muted);display:flex;font-size:.75rem;justify-content:center}.saved-character-info{display:flex;flex-direction:column;gap:.25rem;padding:.5rem}.saved-character-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.saved-character-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box;font-size:.75rem;line-height:1.3;overflow:hidden}.inherited-characters-section{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px;margin-top:1.5rem;padding:1rem}.inherited-characters-section h4{color:var(--text-primary);font-size:.95rem;font-weight:600;margin-bottom:.5rem}.inherited-hint{color:var(--text-muted);font-size:.75rem;margin-bottom:1rem}.inherited-characters-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.inherited-character-card{background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:8px;overflow:hidden;transition:all .2s ease}.inherited-character-card:hover{border-color:var(--accent-500)}.inherited-character-card.deleted{border-color:#ef4444;border-color:var(--error-color,#ef4444);opacity:.5}.inherited-character-image-wrapper{aspect-ratio:3/4;position:relative;width:100%}.inherited-character-image{background:var(--bg-tertiary);height:100%;object-fit:contain;width:100%}.inherited-character-no-image{background:var(--bg-tertiary);color:var(--text-muted);font-size:.75rem;height:100%;width:100%}.deleted-overlay,.inherited-character-no-image{align-items:center;display:flex;justify-content:center}.deleted-overlay{background:#ef4444b3;bottom:0;font-size:.85rem;left:0;right:0;top:0}.deleted-overlay,.replaced-badge{color:#fff;font-weight:600;position:absolute}.replaced-badge{background:var(--accent-500);border-radius:4px;font-size:.65rem;padding:2px 6px;right:4px;top:4px}.inherited-character-info{border-top:1px solid var(--border-secondary);padding:.35rem .5rem;text-align:center}.inherited-character-name{color:var(--text-primary);font-size:.75rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inherited-character-actions{border-top:1px solid var(--border-secondary);display:flex;gap:4px;justify-content:center;padding:.35rem .5rem}.inherited-character-actions button{border:none;border-radius:4px;cursor:pointer;font-size:.7rem;padding:4px 8px;transition:all .2s ease}.btn-download{background:#3b82f6;color:#fff}.btn-download:hover{background:#2563eb}.btn-replace{background:var(--accent-500);color:#fff}.btn-replace:hover{background:#0d9488;background:var(--accent-600,#0d9488)}.btn-revert{background:var(--bg-tertiary);border:1px solid var(--border-secondary)!important;color:var(--text-secondary)}.btn-revert:hover{background:var(--bg-secondary)}.btn-delete-inherited{background:#0000;border:1px solid #ef4444!important;border:1px solid var(--error-color,#ef4444)!important;color:#ef4444;color:var(--error-color,#ef4444)}.btn-delete-inherited:hover{background:#ef4444;background:var(--error-color,#ef4444);color:#fff}.btn-permanent-delete{background:#7f1d1d;border:1px solid #991b1b!important;color:#fff;font-size:.7rem;padding:2px 6px}.btn-permanent-delete:hover{background:#991b1b}.btn-restore{background:#22c55e;background:var(--success-color,#22c55e);color:#fff;flex:1 1}.btn-restore:hover{background:#16a34a}.characters-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.character-card{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:10px;padding:1rem;transition:all .2s ease}.character-card:hover{border-color:var(--accent-500)}.character-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.character-number{color:var(--accent-500);font-size:.8rem;font-weight:600}.remove-character-btn{background:#0000;border:none;border-radius:4px;color:var(--error-main);cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:background .2s ease}.remove-character-btn:hover{background:#ef44441a;background:var(--error-bg,#ef44441a)}.character-content{display:flex;flex-direction:column;gap:.75rem}.image-upload-area{align-items:center;aspect-ratio:1;background:var(--bg-primary);border:2px dashed var(--border-secondary);border-radius:8px;cursor:pointer;display:flex;justify-content:center;overflow:visible;position:relative;transition:all .2s ease}.image-upload-area:hover:not(.has-image){background:#14b8a60d;background:var(--accent-500-alpha,#14b8a60d);border-color:var(--accent-500)}.image-upload-area.has-image{border-color:var(--accent-500);border-style:solid;cursor:default}.upload-placeholder{color:var(--text-secondary);gap:.5rem}.upload-text{font-size:.875rem}.image-preview-container{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.image-preview{background:var(--bg-tertiary);height:100%;object-fit:contain;width:100%}.remove-image-btn{background:#ef4444f2;border:none;border-radius:6px;bottom:10px;box-shadow:0 2px 8px #0000004d;color:#fff;font-size:.9rem;font-weight:600;left:50%;line-height:1.2;min-width:90px;padding:8px 16px;pointer-events:auto;text-align:center;transform:translateX(-50%);transition:all .2s ease;white-space:nowrap;z-index:10}.image-preview-container:hover .remove-image-btn{opacity:1}.remove-image-btn:hover{background:#dc2626;box-shadow:0 4px 12px #ef444466;transform:translateX(-50%) scale(1.05)}@media (max-width:768px){.remove-image-btn{opacity:1}}.remove-image-btn-standalone{background:#ef4444e6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;margin-top:8px;padding:8px 16px;transition:all .2s ease;width:100%}.remove-image-btn-standalone:hover{background:#dc2626}.character-name-input{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.875rem;padding:.6rem .75rem;transition:border-color .2s ease;width:100%}.character-name-input:focus{border-color:var(--accent-500);outline:none}.character-name-input::placeholder{color:var(--text-muted)}.character-names-container{display:flex;flex-direction:column;gap:.5rem;width:100%}.alias-input-row{align-items:center;display:flex;gap:.5rem}.character-alias-input{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-primary);flex:1 1;font-size:.8rem;padding:.5rem .75rem;transition:border-color .2s ease}.character-alias-input:focus{border-color:var(--accent-500);outline:none}.character-alias-input::placeholder{color:var(--text-muted)}.remove-alias-btn{align-items:center;background:#ef4444;background:var(--error-500,#ef4444);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:24px;justify-content:center;line-height:1;transition:all .2s ease;width:24px}.remove-alias-btn:hover{background:#dc2626;background:var(--error-600,#dc2626);transform:scale(1.1)}.add-alias-btn{align-items:center;background:#0000;border:1px dashed var(--border-secondary);border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;font-size:.75rem;gap:.25rem;padding:.35rem .6rem;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.add-alias-btn:hover{background:#14b8a60d;background:var(--accent-500-alpha,#14b8a60d);border-color:var(--accent-500);color:var(--accent-500)}.add-alias-btn span{font-weight:600}.character-description-input{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:.8rem;padding:.5rem .75rem;resize:none;transition:border-color .2s ease;width:100%}.character-description-input:focus{border-color:var(--accent-500);outline:none}.character-description-input::placeholder{color:var(--text-muted);font-size:.75rem}.add-character-btn{align-items:center;background:#0000;border:2px dashed var(--border-secondary);border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:column;gap:.5rem;justify-content:center;min-height:200px;transition:all .2s ease}.add-character-btn:hover{background:#14b8a60d;background:var(--accent-500-alpha,#14b8a60d);border-color:var(--accent-500);color:var(--accent-500)}.add-icon{font-size:2rem}.text-input-container{position:relative}.story-textarea{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:.95rem;line-height:1.6;min-height:200px;padding:1rem;resize:vertical;transition:border-color .2s ease;width:100%}.story-textarea:focus{border-color:var(--accent-500);outline:none}.story-textarea.over-limit{border-color:var(--error-main)}.word-count{background:var(--bg-secondary);border-radius:4px;bottom:.75rem;color:var(--text-muted);font-size:.75rem;padding:.25rem .5rem;position:absolute;right:.75rem}.word-count.over-limit{color:var(--error-main);font-weight:600}.word-count-inline{color:var(--text-muted);font-size:.75rem;margin-top:.5rem;text-align:right}.word-count-inline.over-limit{color:var(--error-main);font-weight:600}.model-selection{margin-bottom:1.5rem;width:100%}.model-selection-label{color:var(--text-primary);display:block;font-size:.875rem;font-weight:600;margin-bottom:.75rem}.model-options{box-sizing:border-box;display:flex;flex-direction:column;gap:.75rem;width:100%}.model-options>*{flex-shrink:0}.model-option{align-items:flex-start;background:var(--bg-tertiary);border:2px solid var(--border-secondary);border-radius:10px;box-sizing:border-box;cursor:pointer;display:flex;gap:.75rem;padding:1rem;transition:all .2s ease;width:100%}.model-option:hover{background:#14b8a60d;background:var(--accent-500-alpha,#14b8a60d);border-color:var(--accent-500)}.model-option.selected{background:#14b8a61a;background:var(--accent-500-alpha,#14b8a61a);border-color:var(--accent-500)}.model-option input[type=radio]{accent-color:var(--accent-500);margin-top:.25rem}.model-option-content{display:flex;flex-direction:column;gap:.25rem}.model-name{font-size:.95rem}.model-description{color:var(--text-secondary);font-size:.8rem}.model-selection-section{margin-bottom:1rem}.model-selection-toggle{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:25px;box-shadow:0 2px 8px #10b9814d;cursor:pointer;display:inline-flex;gap:.6rem;padding:.6rem 1.2rem;transition:all .2s ease}.model-selection-toggle:hover{box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.model-selection-toggle .toggle-icon{color:#fff;font-size:1rem}.model-selection-toggle .toggle-label{color:#fff;font-size:1.1rem;font-weight:600}.current-model-badge{background:#ffffff40;border:1px solid #fff6;border-radius:12px;color:#fff;font-size:.85rem;font-weight:500;margin-left:.5rem;padding:.25rem .6rem}.model-selection-content{margin-top:.75rem;padding-left:.5rem}.art-style-section-wrapper{min-height:auto;padding:.75rem 1.5rem}.art-style-section-wrapper .art-style-section{border-top:none;display:flex;flex-direction:column;justify-content:center;margin-top:0;padding-top:0}.art-style-section{border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1rem}.art-style-toggle{align-items:center;background:linear-gradient(135deg,var(--accent-500),var(--accent-600));border:none;border-radius:8px;box-shadow:0 2px 8px #6366f14d;cursor:pointer;display:inline-flex;gap:.6rem;padding:.75rem 1.25rem;text-align:left;transition:all .2s ease}.art-style-toggle:hover{box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.art-style-toggle .toggle-icon{color:#fff;font-size:1rem}.art-style-toggle .toggle-label{color:#fff;font-size:1.1rem;font-weight:600}.selected-style-badge{background:#ffffff40;border:1px solid #fff6;border-radius:12px;color:#fff;font-size:.85rem;font-weight:500;margin-left:.5rem;padding:.25rem .6rem}.art-style-content{margin-top:.75rem;padding-left:1.5rem}.art-style-warning{align-items:flex-start;background:#fff8e6;border:1px solid #ffc107;border-radius:8px;display:flex;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.art-style-warning .warning-icon{flex-shrink:0;font-size:1rem}.art-style-warning .warning-text{color:#856404;font-size:.85rem;line-height:1.4}.art-style-grid{display:flex;flex-wrap:wrap;gap:.5rem}.art-style-option{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;cursor:pointer;display:flex;padding:.5rem 1rem;transition:all .2s ease}.art-style-option:hover{background:var(--bg-secondary);border-color:var(--accent-500)}.art-style-option.selected{background:var(--accent-500);border-color:var(--accent-500);color:#fff}.art-style-option input[type=radio]{display:none}.art-style-name{font-size:.85rem;font-weight:500}.art-style-option.selected .art-style-name{color:#fff}.art-style-option.disabled{cursor:not-allowed;opacity:.5}.art-style-option.disabled:hover{background:var(--bg-primary);border-color:var(--border-color)}.gpt-only-badge{background:#6366f1;border-radius:4px;color:#fff;font-size:.6rem;font-weight:600;margin-left:.25rem;padding:.1rem .3rem}.art-style-option.disabled .gpt-only-badge{background:#9ca3af}.skip-transform-option{background:#6366f11a;border:1px solid #6366f14d;border-radius:8px;margin-top:1rem;padding:1rem}.skip-transform-option .checkbox-label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.skip-transform-option .checkbox-label input[type=checkbox]{accent-color:#6366f1;cursor:pointer;height:18px;width:18px}.skip-transform-option .checkbox-text{color:var(--text-primary);font-size:.9rem;font-weight:500}.skip-transform-option .checkbox-description{color:var(--text-secondary);font-size:.8rem;line-height:1.5;margin-left:26px;margin-top:.5rem}.settings-section{width:100%}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.setting-item,.settings-grid{min-width:0;width:100%}.setting-item label{font-size:.875rem}.setting-item select{box-sizing:border-box;font-size:.875rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;width:100%}.setting-note{color:var(--text-muted);font-size:.75rem}.setting-warning{color:#ef4444;font-size:.75rem;font-weight:500;margin:.25rem 0 0}.scene-info-box{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.credit-cost-info{align-items:center;background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);border:1px solid #fbbf244d;border-radius:8px;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:.875rem;gap:.5rem;padding:.625rem 1rem}.credit-cost-info strong{color:#d97706;font-weight:700}[data-theme=dark] .credit-cost-info strong{color:#fbbf24}.credit-breakdown{color:var(--text-muted);font-size:.8rem}.credits-label{color:var(--text-secondary);font-size:.875rem}.credits-value{color:var(--accent-500);font-size:1rem;font-weight:600}.credits-note{color:var(--text-muted);font-size:.75rem}.error-message{background:var(--error-bg,#ef44441a);border:1px solid var(--error-main);color:var(--error-main)}.progress-section{background:var(--bg-secondary);border-radius:8px;padding:1rem}.progress-bar-container{background:var(--bg-tertiary);border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden}.progress-bar{background:linear-gradient(90deg,var(--accent-500),var(--accent-400));border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:var(--text-secondary);font-size:.875rem;text-align:center}.submit-btn{background:linear-gradient(135deg,var(--accent-500),var(--accent-400));border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem;transition:all .2s ease;width:100%}.submit-btn:hover:not(:disabled){box-shadow:var(--shadow-lg);transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.custom-character-page{padding:1rem}.characters-grid{grid-template-columns:repeat(2,1fr)}.settings-grid{grid-template-columns:1fr}}@media (max-width:480px){.characters-grid{grid-template-columns:1fr}}.image-generation-page{margin:0 auto;max-width:1600px;padding:2rem;width:100%}.mode-tabs{background:var(--bg-tertiary);border-radius:.75rem;display:flex;gap:.5rem;margin-bottom:1.5rem;max-width:500px;padding:.25rem}.mode-tab{align-items:center;background:#0000;border:none;border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.95rem;font-weight:500;gap:.25rem;padding:.75rem 1.25rem;transition:all .2s ease}.mode-tab.active,.mode-tab:hover{color:var(--text-primary)}.mode-tab.active{background:var(--bg-card);box-shadow:0 1px 3px #0000001a}.mode-tab-desc{color:var(--text-muted);font-size:.7rem;font-weight:400}.mode-tab.active .mode-tab-desc{color:var(--accent-500)}.direct-mode-notice{background:#fbbf241a;border:1px solid #fbbf244d;border-radius:8px;color:#fbbf24;font-size:.85rem;margin-top:1rem;padding:.75rem 1rem}.generation-container{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.input-panel{display:flex;flex-direction:column;gap:1.5rem;overflow:visible}.input-panel .form-section{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;overflow:visible;padding:1.5rem}.input-panel .form-section h2{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1rem}.prompt-textarea{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:.95rem;line-height:1.6;min-height:120px;padding:1rem;resize:vertical;width:100%}.prompt-textarea:focus{border-color:var(--accent-500);outline:none}.prompt-textarea::placeholder{color:var(--text-muted)}.prompt-options{display:flex;gap:1.5rem;margin-top:1rem}.checkbox-option{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.checkbox-option input[type=checkbox]{accent-color:var(--accent-500);cursor:pointer;height:16px;width:16px}.preview-buttons{display:flex;gap:.75rem;margin-top:1rem}.preview-btn{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .2s}.preview-btn:hover:not(:disabled){border-color:var(--accent-500);color:var(--accent-500)}.preview-btn:disabled{cursor:not-allowed;opacity:.5}.preview-display{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px;margin-top:1rem;padding:1rem}.preview-item{margin-bottom:.75rem}.preview-item:last-child{margin-bottom:0}.preview-label{color:var(--accent-500);display:block;font-size:.75rem;font-weight:600;margin-bottom:.25rem}.preview-text{color:var(--text-primary);font-size:.85rem;line-height:1.5;margin:0}.model-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.model-card{background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:10px;cursor:pointer;padding:1rem;transition:all .2s}.model-card:hover{border-color:var(--accent-400)}.model-card.selected{background:rgba(var(--accent-500-rgb),.05);border-color:var(--accent-500)}.model-card input[type=radio]{display:none}.model-card-content{display:flex;flex-direction:column;gap:.25rem}.model-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.model-credits{color:var(--accent-500);font-size:.8rem;font-weight:500}.model-description{color:var(--text-muted);font-size:.75rem}.settings-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.setting-item{display:flex;flex-direction:column;gap:.5rem}.setting-item label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.setting-item select{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.85rem;padding:.6rem .75rem}.setting-item select:focus{border-color:var(--accent-500);outline:none}.credits-info{background:rgba(var(--accent-500-rgb),.1);border-radius:8px;color:var(--text-primary);font-size:.9rem;margin-top:1rem;padding:.75rem 1rem;text-align:center}.credits-info strong{color:var(--accent-500)}.error-message{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#ef4444;font-size:.875rem;padding:1rem}.generate-btn{background:linear-gradient(135deg,var(--accent-500) 0,var(--accent-600) 100%);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .3s;width:100%}.generate-btn:hover:not(:disabled){box-shadow:0 8px 20px rgba(var(--accent-500-rgb),.3);transform:translateY(-2px)}.generate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.results-panel{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;min-height:500px;padding:1.5rem}.results-panel h2{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1rem}.results-info{background:var(--bg-tertiary);border-radius:6px;color:var(--text-secondary);font-size:.85rem;margin-bottom:1rem;padding:.5rem .75rem;text-align:center}.results-info strong{color:var(--accent-500)}.loading-indicator{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.spinner{animation:spin 1s linear infinite;border:4px solid var(--border-primary);border-radius:50%;border-top-color:var(--accent-500);height:50px;margin-bottom:1rem;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.empty-results{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.images-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.image-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:10px;overflow:hidden}.generated-image{background:var(--bg-tertiary);display:block;object-fit:contain;width:100%}.image-actions{align-items:center;display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.download-btn{background:var(--accent-500);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;padding:.5rem 1.5rem;transition:background .2s;width:100%}.download-btn:hover{background:var(--accent-600)}.use-as-reference-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .2s;width:100%}.use-as-reference-btn:hover:not(:disabled){background:rgba(var(--accent-500-rgb),.1);border-color:var(--accent-500);color:var(--accent-500)}.use-as-reference-btn:disabled{cursor:not-allowed;opacity:.5}.section-description{color:var(--text-muted);font-size:.8rem;margin:0 0 1rem}.reference-images-container{display:flex;flex-direction:column;gap:1rem;overflow:visible}.upload-area{align-items:center;background:var(--bg-primary);border:2px dashed var(--border-primary);border-radius:10px;cursor:pointer;display:flex;height:100px;justify-content:center;transition:all .2s;width:100%}.upload-area:hover:not(.disabled){background:rgba(var(--accent-500-rgb),.05);border-color:var(--accent-500)}.upload-area.disabled{cursor:not-allowed;opacity:.5}.upload-placeholder{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:.25rem}.upload-icon{color:var(--accent-500);font-size:2rem;font-weight:300}.upload-text{font-size:.9rem;font-weight:500}.upload-hint{color:var(--text-muted);font-size:.75rem}.reference-images-grid{display:flex;flex-wrap:wrap;gap:1.5rem;overflow:visible!important;padding:20px}.reference-image-item{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;flex-shrink:0;max-height:200px;max-width:150px;overflow:visible!important;position:relative}.reference-image-item img{border-radius:8px;display:block;height:auto;max-height:200px;max-width:150px;object-fit:contain;width:auto}.remove-image-btn{align-items:center;background:#ef4444!important;border:3px solid #fff!important;border-radius:50%;box-shadow:0 2px 8px #00000080;color:#fff!important;cursor:pointer;display:flex!important;font-size:18px;font-weight:700;height:28px;justify-content:center;line-height:1;min-height:28px;min-width:28px;opacity:0;pointer-events:none;position:absolute;right:-10px;top:-10px;transition:all .2s;width:28px;z-index:9999!important}.reference-image-item:hover .remove-image-btn{opacity:1!important;pointer-events:auto!important}.remove-image-btn:hover:not(:disabled){background:#dc2626!important}.remove-image-btn:disabled{cursor:not-allowed;opacity:.5}.clear-all-btn{align-self:flex-start;background:#0000;border:1px solid var(--border-primary);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .2s}.clear-all-btn:hover:not(:disabled){border-color:#ef4444;color:#ef4444}.clear-all-btn:disabled{cursor:not-allowed;opacity:.5}.edit-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.edit-modal{animation:scaleIn .2s ease-out;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;min-width:400px;overflow-y:auto;padding:2rem}.edit-modal h3{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.edit-modal-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin-bottom:1rem}.edit-image-reference-guide{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;padding:.75rem}.edit-reference-item{align-items:center;display:flex;flex-direction:column;gap:.25rem;position:relative}.edit-reference-item img{border:2px solid var(--border-primary);border-radius:6px;height:60px;object-fit:cover;width:60px}.edit-reference-base img{border-color:var(--accent-500);box-shadow:0 0 0 2px #6366f133}.edit-reference-additional{position:relative}.edit-reference-remove{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:20px;justify-content:center;position:absolute;right:-6px;top:-6px;transition:transform .2s ease;width:20px;z-index:1}.edit-reference-remove:hover{transform:scale(1.1)}.edit-reference-label{color:var(--text-secondary);font-size:.7rem;font-weight:600;text-align:center;white-space:nowrap}.edit-reference-base .edit-reference-label{color:var(--accent-500)}.edit-prompt-input{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:.95rem;min-height:100px;padding:.75rem 1rem;resize:vertical;transition:border-color .2s ease;width:100%}.edit-prompt-input:focus{border-color:var(--accent-500);box-shadow:0 0 0 3px #6366f126;outline:none}.edit-prompt-input::placeholder{color:var(--text-muted)}.edit-modal-buttons{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.edit-modal-cancel{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:500;padding:.6rem 1.25rem;transition:all .2s ease}.edit-modal-cancel:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.edit-modal-submit{background:linear-gradient(135deg,var(--accent-500),var(--accent-600));border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.6rem 1.25rem;transition:all .2s ease}.edit-modal-submit:hover:not(:disabled){box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.edit-modal-submit:disabled{cursor:not-allowed;opacity:.5}.edit-quality-section{align-items:center;display:flex;gap:.75rem;margin-top:1rem}.edit-quality-label{color:var(--text-secondary);font-size:.9rem;font-weight:500;white-space:nowrap}.edit-quality-select{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);cursor:pointer;flex:1 1;font-size:.9rem;padding:.5rem .75rem;transition:border-color .2s ease}.edit-quality-select:focus{border-color:var(--accent-500);outline:none}.edit-additional-image-section{background:var(--bg-tertiary);border:1px dashed var(--border-primary);border-radius:8px;margin-top:1rem;padding:1rem}.edit-additional-label{color:var(--text-secondary);display:block;font-size:.9rem;font-weight:500;margin-bottom:.25rem}.edit-additional-description{color:var(--text-muted);font-size:.8rem;margin-bottom:.75rem}.edit-additional-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.edit-additional-upload-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:.85rem;padding:.6rem 1rem;transition:all .2s ease}.edit-additional-upload-btn:hover:not(:disabled){background:var(--bg-primary);border-color:var(--accent-500)}.edit-additional-upload-btn:disabled{background:var(--bg-tertiary);cursor:not-allowed;opacity:.5}.edit-additional-clear-btn{background:#0000;border:1px solid #ef4444;border-radius:8px;color:#ef4444;cursor:pointer;font-size:.85rem;padding:.6rem 1rem;transition:all .2s ease}.edit-additional-clear-btn:hover{background:#ef4444;color:#fff}.wait-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10001}.wait-modal-content{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:3rem;text-align:center}.wait-modal-content h3{color:var(--text-primary);font-size:1.1rem;line-height:1.6;margin:1rem 0 0}.spinner-large{animation:spin 1s linear infinite;border:4px solid var(--border-primary);border-radius:50%;border-top-color:var(--accent-500);height:60px;margin:0 auto;width:60px}@media (max-width:1200px){.generation-container{grid-template-columns:1fr}.results-panel{min-height:auto}}@media (max-width:768px){.image-generation-page{padding:1rem}.model-grid{grid-template-columns:1fr}.prompt-options{gap:.75rem}.preview-buttons,.prompt-options{flex-direction:column}}.tutorial-main{margin:0 auto;max-width:1200px;padding:2rem}.tutorial-container{display:flex;flex-direction:column;gap:2rem}.video-placeholder{align-items:center;background:var(--bg-secondary);border:2px dashed var(--border-primary);border-radius:16px;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:4rem 2rem;text-align:center}.placeholder-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.8}.video-placeholder h2{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0 0 1rem}.video-placeholder p{color:var(--text-secondary);font-size:1rem;margin:0 0 .5rem}.placeholder-hint{color:var(--text-muted);font-size:.875rem;margin-top:1rem!important}.video-section{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;margin:0 auto;max-width:900px;padding:2rem;width:100%}.video-section h2{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 1rem}.video-wrapper{background:var(--bg-tertiary);border-radius:12px;overflow:hidden}.video-wrapper video{border-radius:12px;display:block;width:100%}.video-wrapper.youtube-wrapper{height:0;padding-bottom:56.25%;position:relative}.video-wrapper iframe{border-radius:12px;height:100%;left:0;position:absolute;top:0;width:100%}.video-youtube-link{color:red;display:block;font-size:.95rem;font-weight:500;margin-top:1rem;text-align:center;text-decoration:none;transition:all .2s ease}.video-youtube-link:hover{opacity:.8;text-decoration:underline}@media (max-width:768px){.tutorial-main{padding:1rem}.video-placeholder{min-height:300px;padding:3rem 1.5rem}.placeholder-icon{font-size:3rem}.video-placeholder h2{font-size:1.25rem}}.announcement-page{background:var(--bg-primary);min-height:calc(100vh - 60px);padding:2rem}.announcement-container{margin:0 auto;max-width:1200px}.welcome-section{background:linear-gradient(135deg,var(--accent-500) 0,var(--accent-600) 100%);border-radius:16px;color:#fff;margin-bottom:2rem;padding:3rem;text-align:center}.welcome-content h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.welcome-content p{font-size:1.1rem;opacity:.9}.quick-links-section{margin-bottom:2rem}.quick-links-section h2{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.quick-links-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr)}.quick-link-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;padding:1.5rem;text-align:center;transition:all .2s ease}.quick-link-card:hover{border-color:var(--accent-500);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.quick-link-icon{display:block;font-size:2rem;margin-bottom:.75rem}.quick-link-card h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:.5rem}.quick-link-card p{color:var(--text-secondary);font-size:.85rem;margin:0}.announcements-section h2{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.announcements-list{display:flex;flex-direction:column;gap:.5rem}.announcement-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;padding:1rem 1.25rem;transition:all .2s ease}.announcement-item:hover{border-color:var(--accent-400)}.announcement-item.expanded{border-color:var(--accent-500)}.announcement-header{align-items:center;display:flex;justify-content:space-between}.announcement-title-row{align-items:center;display:flex;gap:.5rem}.new-badge{background:var(--accent-500);border-radius:4px;color:#fff;font-size:.7rem;font-weight:600;padding:.2rem .5rem}.announcement-header h3{color:var(--text-primary);font-size:1rem;font-weight:500;margin:0}.announcement-date{color:var(--text-muted);font-size:.85rem}.announcement-content{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.announcement-content p{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin:0}@media (max-width:1024px){.quick-links-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.announcement-page{padding:1rem}.welcome-section{padding:2rem 1.5rem}.welcome-content h1{font-size:1.5rem}.quick-links-grid{grid-template-columns:1fr}.announcement-header{align-items:flex-start;flex-direction:column;gap:.5rem}}
/*# sourceMappingURL=main.a2737e87.css.map*/