@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Plus+Jakarta+Sans:wght@300;400;500;600&display=swap";:root{--color-bg: #0a0a0b;--color-bg-elevated: #141416;--color-bg-card: #1a1a1e;--color-bg-hover: #222228;--color-text: #f5f5f4;--color-text-secondary: #a1a1aa;--color-text-muted: #52525b;--color-accent: #d4a853;--color-accent-hover: #e4b863;--color-accent-subtle: rgba(212, 168, 83, .1);--color-success: #22c55e;--color-warning: #eab308;--color-error: #ef4444;--color-border: #27272a;--color-border-subtle: #1f1f23;--font-display: "Cormorant Garamond", "Noto Serif JP", serif;--font-body: "Plus Jakarta Sans", "Noto Sans JP", sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(212, 168, 83, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:9999}.app-container{max-width:1000px;margin:0 auto;padding:var(--space-xl) var(--space-lg);min-height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-xl);margin-bottom:var(--space-2xl);border-bottom:1px solid var(--color-border-subtle)}.logo{display:flex;align-items:center;gap:var(--space-md)}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--color-accent),#8b6914);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--color-bg)}.logo-text{font-family:var(--font-display);font-size:28px;font-weight:500;letter-spacing:-.02em;color:var(--color-text)}.logo-text span{color:var(--color-accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-body);font-size:14px;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--color-accent);color:var(--color-bg)}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--color-bg-card);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-text-muted)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--color-text);background:var(--color-bg-card)}.btn-large{padding:var(--space-md) var(--space-xl);font-size:16px;border-radius:var(--radius-lg)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{width:20px;height:20px}.card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card-interactive{cursor:pointer}.card-interactive:hover{background:var(--color-bg-hover);border-color:var(--color-border);transform:translateY(-2px);box-shadow:var(--shadow-md)}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:13px;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.form-input{width:100%;padding:var(--space-md);font-family:var(--font-body);font-size:16px;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.form-input::placeholder{color:var(--color-text-muted)}.form-input-with-action{display:flex;gap:var(--space-sm)}.form-input-with-action .form-input{flex:1}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-sm)}.badge-draft{background:var(--color-text-muted);color:var(--color-bg)}.badge-plot{background:#f59e0b;color:var(--color-bg)}.badge-chapters{background:#3b82f6;color:#fff}.badge-writing{background:#22c55e;color:var(--color-bg)}.badge-completed{background:var(--color-accent);color:var(--color-bg)}.steps{display:flex;gap:var(--space-xs);margin-bottom:var(--space-2xl)}.step{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);transition:all var(--transition-base)}.step-active{background:var(--color-accent-subtle);border-color:var(--color-accent)}.step-completed{background:#22c55e1a;border-color:var(--color-success)}.step-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;border-radius:50%;background:var(--color-bg);color:var(--color-text-muted);border:2px solid var(--color-border)}.step-active .step-number{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent)}.step-completed .step-number{background:var(--color-success);color:#fff;border-color:var(--color-success)}.step-label{font-size:12px;font-weight:500;color:var(--color-text-muted);text-align:center}.step-active .step-label,.step-completed .step-label{color:var(--color-text)}.candidates-grid{display:grid;gap:var(--space-lg)}.candidate-card{background:var(--color-bg-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base)}.candidate-card:hover{border-color:var(--color-border)}.candidate-card-selected{border-color:var(--color-accent);box-shadow:var(--shadow-glow)}.candidate-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border-subtle)}.candidate-title{display:flex;align-items:center;gap:var(--space-md)}.candidate-number{font-family:var(--font-display);font-size:32px;font-weight:600;color:var(--color-accent);line-height:1}.candidate-meta{display:flex;flex-direction:column;gap:var(--space-xs)}.candidate-label{font-size:13px;color:var(--color-text-secondary)}.candidate-score{display:flex;align-items:center;gap:var(--space-sm)}.score-bar{width:100px;height:6px;background:var(--color-bg);border-radius:3px;overflow:hidden}.score-fill{height:100%;background:var(--color-accent);border-radius:3px;transition:width var(--transition-slow)}.score-value{font-size:14px;font-weight:600;color:var(--color-text)}.candidate-content{padding:var(--space-lg);max-height:300px;overflow-y:auto}.candidate-content pre{font-family:var(--font-body);font-size:14px;line-height:1.7;color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word}.candidate-actions{display:flex;gap:var(--space-sm);padding:var(--space-lg);background:var(--color-bg-elevated);border-top:1px solid var(--color-border-subtle)}.candidate-actions .btn{flex:1}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl)}.empty-icon{width:80px;height:80px;margin:0 auto var(--space-lg);background:var(--color-bg-card);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px}.empty-title{font-family:var(--font-display);font-size:24px;font-weight:500;color:var(--color-text);margin-bottom:var(--space-sm)}.empty-description{font-size:15px;color:var(--color-text-muted);margin-bottom:var(--space-xl)}.novel-item{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.novel-item:hover{background:var(--color-bg-hover);border-color:var(--color-border);transform:translate(4px)}.novel-cover{width:60px;height:80px;background:linear-gradient(135deg,var(--color-bg-hover),var(--color-bg));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:24px;color:var(--color-text-muted);flex-shrink:0}.novel-info{flex:1;min-width:0}.novel-title{font-family:var(--font-display);font-size:20px;font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.novel-meta{font-size:14px;color:var(--color-text-muted)}.novel-arrow{color:var(--color-text-muted);transition:transform var(--transition-fast)}.novel-item:hover .novel-arrow{transform:translate(4px);color:var(--color-accent)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);gap:var(--space-lg)}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:15px;color:var(--color-text-secondary)}.loading-dots:after{content:"";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.generate-hero{text-align:center;padding:var(--space-3xl) var(--space-xl);background:linear-gradient(180deg,var(--color-bg-card),var(--color-bg));border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl)}.generate-title{font-family:var(--font-display);font-size:28px;font-weight:500;color:var(--color-text);margin-bottom:var(--space-sm)}.generate-description{font-size:15px;color:var(--color-text-muted);margin-bottom:var(--space-xl);max-width:400px;margin-left:auto;margin-right:auto}.generate-btn{padding:var(--space-md) var(--space-2xl);font-size:16px;font-weight:600;background:linear-gradient(135deg,var(--color-accent),#8b6914);color:var(--color-bg);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md)}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-glow),var(--shadow-lg)}.generate-btn:disabled{opacity:.6;cursor:not-allowed}.page-header{margin-bottom:var(--space-2xl)}.page-title{font-family:var(--font-display);font-size:36px;font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs)}.page-subtitle{font-size:15px;color:var(--color-text-muted)}.back-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;font-size:14px;color:var(--color-text-muted);background:none;border:none;cursor:pointer;transition:color var(--transition-fast);margin-bottom:var(--space-lg)}.back-btn:hover{color:var(--color-text)}.ai-suggest-btn{padding:var(--space-sm) var(--space-md);font-size:12px;font-weight:500;background:var(--color-accent-subtle);color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.ai-suggest-btn:hover:not(:disabled){background:var(--color-accent);color:var(--color-bg)}.ai-suggest-btn:disabled{opacity:.5;cursor:not-allowed}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-up{animation:slideUp var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-base) ease-out}.stagger-children>*{animation:slideUp var(--transition-slow) ease-out backwards}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}.suggestions-container{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-md);background:var(--color-bg);border-radius:var(--radius-md);animation:fadeIn var(--transition-base) ease-out}.suggestions-loading{margin-top:var(--space-md)}.suggestion-chip{display:inline-flex;align-items:center;padding:var(--space-sm) var(--space-md);font-family:var(--font-body);font-size:14px;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:100px;cursor:pointer;transition:all var(--transition-fast);animation:scaleIn var(--transition-base) ease-out backwards}.suggestion-chip:nth-child(1){animation-delay:0ms}.suggestion-chip:nth-child(2){animation-delay:40ms}.suggestion-chip:nth-child(3){animation-delay:80ms}.suggestion-chip:nth-child(4){animation-delay:.12s}.suggestion-chip:nth-child(5){animation-delay:.16s}.suggestion-chip:hover{background:var(--color-accent-subtle);border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.suggestion-chip:active{transform:translateY(0)}.suggestion-chip-loading{background:transparent;border-style:dashed;border-color:var(--color-text-muted);color:var(--color-text-muted);cursor:default;animation:pulse 1.5s ease-in-out infinite}.suggestion-chip-loading:hover{background:transparent;border-color:var(--color-text-muted);color:var(--color-text-muted);transform:none;box-shadow:none}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.generation-status{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#d4a8531a,#d4a8530d);border:1px solid rgba(212,168,83,.3);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);animation:fadeIn var(--transition-base) ease-out}.generation-status-icon{display:flex;align-items:center;justify-content:center}.generation-status span{font-size:14px;color:var(--color-accent);font-weight:500}.tree-candidates-section{margin-top:var(--space-xl)}.tree-candidates-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.tree-candidates-title{font-family:var(--font-display);font-size:24px;font-weight:500;color:var(--color-text)}.tree-candidates-subtitle{font-size:14px;color:var(--color-text-muted)}.tree-candidate-card{background:var(--color-bg-card);border:2px solid var(--color-border-subtle);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);animation:slideUp var(--transition-slow) ease-out}.tree-candidate-card:hover{border-color:var(--color-border);transform:translateY(-2px);box-shadow:var(--shadow-md)}.tree-candidate-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border-subtle);background:var(--color-bg-elevated)}.tree-candidate-info{display:flex;align-items:center;gap:var(--space-md)}.tree-candidate-badge{padding:var(--space-xs) var(--space-md);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-sm);background:var(--color-accent);color:var(--color-bg)}.tree-candidate-badge-plot{background:#f59e0b}.tree-candidate-badge-chapters{background:#3b82f6;color:#fff}.tree-candidate-badge-episode{background:#22c55e}.tree-candidate-episode-num{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--color-text-secondary)}.tree-candidate-score{display:flex;align-items:center;gap:var(--space-sm)}.tree-candidate-score-bar{width:80px;height:6px;background:var(--color-bg);border-radius:3px;overflow:hidden}.tree-candidate-score-fill{height:100%;background:linear-gradient(90deg,var(--color-accent),#e4b863);border-radius:3px;transition:width var(--transition-slow)}.tree-candidate-score-value{font-size:14px;font-weight:600;color:var(--color-text);min-width:32px}.tree-candidate-content{padding:var(--space-lg);max-height:400px;overflow-y:auto}.tree-candidate-content pre{font-family:var(--font-body);font-size:14px;line-height:1.8;color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word}.tree-candidate-reviews{padding:var(--space-lg);background:var(--color-bg);border-top:1px solid var(--color-border-subtle)}.tree-candidate-reviews-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-md)}.tree-candidate-review{padding:var(--space-md);background:var(--color-bg-card);border-radius:var(--radius-md);margin-bottom:var(--space-sm)}.tree-candidate-review:last-child{margin-bottom:0}.tree-candidate-review-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xs)}.tree-candidate-review-perspective{font-size:13px;font-weight:600;color:var(--color-text)}.tree-candidate-review-score{font-size:13px;font-weight:600;color:var(--color-accent)}.tree-candidate-review-feedback{font-size:13px;color:var(--color-text-muted);line-height:1.6}.tree-candidate-actions{display:flex;gap:var(--space-sm);padding:var(--space-lg);background:var(--color-bg-elevated);border-top:1px solid var(--color-border-subtle)}.tree-candidate-actions .btn{flex:1}.waiting-state{text-align:center;padding:var(--space-3xl) var(--space-xl);background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-xl)}.waiting-icon{width:64px;height:64px;margin:0 auto var(--space-lg);border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1.5s linear infinite}.waiting-title{font-family:var(--font-display);font-size:20px;font-weight:500;color:var(--color-text);margin-bottom:var(--space-sm)}.waiting-description{font-size:14px;color:var(--color-text-muted)}.waiting-stats{display:flex;justify-content:center;gap:var(--space-xl);margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--color-border-subtle)}.waiting-stat{text-align:center}.waiting-stat-value{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--color-accent)}.waiting-stat-label{font-size:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}
