*,*: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:Noto Sans KR,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);overflow-x:hidden;min-height:100vh}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a25;--bg-elevated: #222230;--bg-glass: rgba(26, 26, 37, .6);--bg-glass-hover: rgba(34, 34, 48, .8);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--accent-tertiary: #a78bfa;--accent-success: #10b981;--accent-warning: #f59e0b;--accent-danger: #ef4444;--accent-info: #3b82f6;--accent-pink: #ec4899;--accent-cyan: #06b6d4;--accent-rose: #f43f5e;--border-color: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--border-active: rgba(99, 102, 241, .5);--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a78bfa 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-warning: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-glass: linear-gradient(135deg, rgba(99, 102, 241, .15) 0%, rgba(139, 92, 246, .1) 100%);--gradient-dark: linear-gradient(180deg, rgba(26, 26, 37, 0) 0%, rgba(10, 10, 15, .8) 100%);--gradient-shine: linear-gradient(90deg, transparent, rgba(255,255,255,.1), transparent);--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-xs: var(--spacing-1);--spacing-sm: var(--spacing-2);--spacing-md: var(--spacing-4);--spacing-lg: var(--spacing-6);--spacing-xl: var(--spacing-8);--spacing-2xl: var(--spacing-12);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 8px 10px -6px rgba(0, 0, 0, .4);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .7);--shadow-glow: 0 0 20px rgba(99, 102, 241, .4);--shadow-glow-lg: 0 0 40px rgba(99, 102, 241, .3);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .3);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--z-dropdown: 1000;--z-sticky: 1020;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg)}.glass{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0003,inset 0 1px #ffffff0d}.glass-strong{background:var(--bg-glass-hover);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid var(--border-hover)}.card{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md);transition:all var(--transition-base);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl),var(--shadow-glow);border-color:var(--border-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--gradient-shine);transition:left var(--transition-slow)}.btn:hover:before{left:100%}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),0 0 #6366f166}.btn-primary:hover{box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--border-hover);transform:translateY(-2px)}.btn-success{background:var(--gradient-success);color:#fff;box-shadow:0 0 #10b98166}.btn-success:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon{padding:var(--spacing-sm);border-radius:var(--radius-lg)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;border:1px solid transparent}.badge-agent{background:linear-gradient(135deg,#6366f133,#8b5cf633);color:var(--accent-tertiary);border-color:#6366f14d}.badge-draft{background:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--border-color)}.badge-in-progress{background:#f59e0b26;color:var(--accent-warning);border-color:#f59e0b4d}.badge-completed{background:#10b98126;color:var(--accent-success);border-color:#10b9814d}.badge-info{background:#3b82f626;color:var(--accent-info);border-color:#3b82f64d}.app{min-height:100vh;background:var(--bg-primary)}.spinner{display:inline-block;width:24px;height:24px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:40px;height:40px;border-width:4px}input,textarea,select{width:100%;padding:var(--spacing-3) var(--spacing-4);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-family:inherit;font-size:var(--font-size-base);transition:all var(--transition-base)}input:hover,textarea:hover,select:hover{border-color:var(--border-hover)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}input[type=radio],input[type=checkbox]{width:auto;height:auto;padding:0;border:none;background:none;box-shadow:none}select option{background:var(--bg-tertiary);color:var(--text-primary)}textarea{resize:vertical;min-height:120px;line-height:1.8}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%2394A3B8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;padding-right:40px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-full);border:2px solid var(--bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 8px #6366f100}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{animation:fadeIn var(--transition-base)}.fade-in-scale{animation:fadeInScale var(--transition-base)}.slide-in-right{animation:slideInRight var(--transition-base)}.slide-in-up{animation:slideInUp var(--transition-base)}.pulse{animation:pulse 2s ease-in-out infinite}.pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.float{animation:float 3s ease-in-out infinite}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.container{padding:0 var(--spacing-md)}.form-row{grid-template-columns:1fr}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.p-2{padding:var(--spacing-2)}.p-4{padding:var(--spacing-4)}.p-6{padding:var(--spacing-6)}.p-8{padding:var(--spacing-8)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-2)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--border-color),transparent);margin:var(--spacing-lg) 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:var(--spacing-8)}.empty-state-icon{font-size:4rem;margin-bottom:var(--spacing-4);opacity:.5}.empty-state h2{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-2);color:var(--text-primary)}.empty-state p{color:var(--text-secondary);margin-bottom:var(--spacing-6);max-width:400px}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:var(--z-modal);padding:var(--spacing-lg);animation:fadeIn var(--transition-fast)}.modal{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:fadeInScale var(--transition-base)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-6)}.modal-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.modal-close{background:none;border:none;color:var(--text-tertiary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-8);padding-top:var(--spacing-6);border-top:1px solid var(--border-color)}.toast{position:fixed;bottom:var(--spacing-6);right:var(--spacing-6);padding:var(--spacing-4) var(--spacing-6);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--spacing-3);animation:slideInRight var(--transition-base);z-index:var(--z-tooltip)}.toast-success{border-color:#10b9814d;background:linear-gradient(135deg,rgba(16,185,129,.1),var(--bg-secondary))}.toast-error{border-color:#ef44444d;background:linear-gradient(135deg,rgba(239,68,68,.1),var(--bg-secondary))}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,rgba(99,102,241,.15) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(139,92,246,.1) 0%,transparent 50%),var(--bg-primary);position:relative;overflow:hidden;padding:var(--spacing-6)}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.3) 0%,transparent 70%);top:-300px;right:-300px;animation:float 8s ease-in-out infinite}.login-page:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.2) 0%,transparent 70%);bottom:-200px;left:-200px;animation:float 10s ease-in-out infinite reverse}.login-container{position:relative;z-index:1;width:100%;max-width:420px}.login-card{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--spacing-10);box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d inset;animation:fadeInScale .5s ease-out}.login-logo{text-align:center;margin-bottom:var(--spacing-8)}.login-icon{width:72px;height:72px;margin:0 auto var(--spacing-4);background:var(--gradient-primary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:var(--shadow-glow);animation:pulse-glow 3s ease-in-out infinite}.login-logo h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-2)}.login-logo p{font-size:var(--font-size-sm);color:var(--text-secondary)}.login-error{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-lg);color:var(--accent-danger);font-size:var(--font-size-sm);margin-bottom:var(--spacing-6);animation:shake .5s ease-out}.login-error:before{content:"⚠️";flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.btn-google:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-base)}.btn-google:hover{background:var(--bg-elevated);border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-google:hover:before{opacity:1}.btn-google:active{transform:translateY(0)}.btn-google:disabled{opacity:.6;cursor:not-allowed;transform:none}.google-icon{width:20px;height:20px;flex-shrink:0}.btn-google.loading{pointer-events:none}.btn-google.loading .btn-text{opacity:.7}.login-divider{display:flex;align-items:center;gap:var(--spacing-4);margin:var(--spacing-8) 0;color:var(--text-tertiary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-color),transparent)}.login-features{display:flex;flex-direction:column;gap:var(--spacing-3)}.login-feature{display:flex;align-items:center;gap:var(--spacing-3);font-size:var(--font-size-sm);color:var(--text-secondary)}.login-feature-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.875rem}.login-footer{text-align:center;margin-top:var(--spacing-8);padding-top:var(--spacing-6);border-top:1px solid var(--border-color)}.login-footer p{font-size:var(--font-size-xs);color:var(--text-tertiary)}@media(max-width:480px){.login-page{padding:var(--spacing-4)}.login-card{padding:var(--spacing-8) var(--spacing-6)}.login-icon{width:60px;height:60px;font-size:1.75rem}.login-logo h1{font-size:var(--font-size-xl)}}.project-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-6);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%;animation:fadeInScale .4s ease-out backwards}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base)}.project-card:hover:before{opacity:1}.project-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0006,0 0 30px #6366f126;border-color:#6366f14d}.project-card:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.03) 50%,transparent 70%);transform:translate(-100%) rotate(45deg);transition:transform .8s ease;pointer-events:none}.project-card:hover:after{transform:translate(100%) rotate(45deg)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.project-card-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);flex:1;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.genre-badge{background:linear-gradient(135deg,#6366f126,#8b5cf61a);color:var(--accent-tertiary);border:1px solid rgba(99,102,241,.2);flex-shrink:0}.project-description{font-size:var(--font-size-sm);line-height:1.6;color:var(--text-secondary);margin-bottom:var(--spacing-4);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.project-meta{display:flex;gap:var(--spacing-6);padding:var(--spacing-4) 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-4)}.meta-item{display:flex;flex-direction:column;gap:var(--spacing-1)}.meta-label{font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.meta-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.project-stage{margin-bottom:var(--spacing-4)}.stage-badge-small{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);border:1px solid;background:#ffffff0d}.stage-brainstorming{color:#a78bfa;border-color:#a78bfa4d;background:#a78bfa1a}.stage-planning{color:#60a5fa;border-color:#60a5fa4d;background:#60a5fa1a}.stage-writing{color:#34d399;border-color:#34d3994d;background:#34d3991a}.project-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.update-time{display:flex;align-items:center;gap:var(--spacing-1);font-size:var(--font-size-xs);color:var(--text-tertiary)}.update-time:before{content:"🕐";font-size:.75rem}.btn-delete{background:var(--bg-tertiary);border:1px solid var(--border-color);cursor:pointer;font-size:var(--font-size-base);padding:var(--spacing-2);border-radius:var(--radius-md);opacity:.6;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;width:32px;height:32px}.btn-delete:hover{opacity:1;background:#ef44441a;border-color:#ef44444d;transform:scale(1.1)}.project-progress{margin-bottom:var(--spacing-4)}.progress-header{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-bottom:var(--spacing-1)}.progress-bar{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.quick-actions{position:absolute;top:var(--spacing-4);right:var(--spacing-4);display:flex;gap:var(--spacing-2);opacity:0;transform:translateY(-10px);transition:all var(--transition-fast)}.project-card:hover .quick-actions{opacity:1;transform:translateY(0)}.quick-action-btn{width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.quick-action-btn:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-hover)}@media(max-width:640px){.project-card{padding:var(--spacing-4)}.project-meta{gap:var(--spacing-4)}.meta-item{flex:1}}.dashboard{min-height:100vh;padding:var(--spacing-8) 0 var(--spacing-12);background:radial-gradient(ellipse at top right,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(ellipse at bottom left,rgba(139,92,246,.05) 0%,transparent 50%),var(--bg-primary)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-10);padding:var(--spacing-6) 0;border-bottom:1px solid var(--border-color)}.dashboard-header-content h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-2);letter-spacing:-.02em}.dashboard-header-content p{font-size:var(--font-size-lg);color:var(--text-secondary)}.dashboard-header-actions{display:flex;gap:var(--spacing-3);align-items:center}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-8)}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-5);display:flex;align-items:center;gap:var(--spacing-4);transition:all var(--transition-base)}.stat-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stat-icon.purple{background:linear-gradient(135deg,#6366f133,#8b5cf633)}.stat-icon.green{background:linear-gradient(135deg,#10b98133,#05966933)}.stat-icon.blue{background:linear-gradient(135deg,#3b82f633,#2563eb33)}.stat-icon.orange{background:linear-gradient(135deg,#f59e0b33,#d9770633)}.stat-content{display:flex;flex-direction:column;gap:var(--spacing-1)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:1}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--spacing-5)}.empty-state{display:flex;justify-content:center;align-items:center;min-height:400px;text-align:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);border-style:dashed}.empty-state-content{padding:var(--spacing-8)}.empty-state-content .empty-icon{width:80px;height:80px;margin:0 auto var(--spacing-6);background:var(--bg-tertiary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2.5rem}.empty-state-content h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--spacing-2)}.empty-state-content p{color:var(--text-secondary);margin-bottom:var(--spacing-6);font-size:var(--font-size-base)}.loading-state p{font-size:var(--font-size-base)}.modal{width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:fadeInScale var(--transition-base);padding:var(--spacing-6)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--border-color)}.modal-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.modal-close{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);font-size:1.25rem;cursor:pointer;padding:var(--spacing-2);border-radius:var(--radius-lg);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;width:36px;height:36px}.modal-close:hover{background:var(--bg-elevated);border-color:var(--border-hover);color:var(--text-primary)}.form-group input,.form-group textarea,.form-group select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);transition:all var(--transition-base)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4)}.stage-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);border:1px solid;background:#ffffff0d}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:var(--spacing-4);align-items:flex-start}.dashboard-header-content h1{font-size:var(--font-size-3xl)}.dashboard-header-actions{width:100%;flex-wrap:wrap}.projects-grid,.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}@media(max-width:480px){.dashboard{padding:var(--spacing-4) 0 var(--spacing-8)}.dashboard-stats{grid-template-columns:repeat(2,1fr)}.stat-card{padding:var(--spacing-4)}.stat-icon{width:40px;height:40px;font-size:1.25rem}.stat-value{font-size:var(--font-size-xl)}}.episode-card{display:flex;gap:var(--spacing-5);padding:var(--spacing-5);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden;animation:fadeIn .3s ease-out}.episode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base)}.episode-card:hover:before{opacity:1}.episode-card:hover{transform:translate(8px);box-shadow:0 10px 15px -3px #0006,0 0 20px #6366f11a;border-color:#6366f14d}.episode-number{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);min-width:70px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.episode-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-3);min-width:0}.episode-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--spacing-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.episode-card:hover .episode-title{color:var(--accent-tertiary)}.episode-meta{display:flex;align-items:center;gap:var(--spacing-4);flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:var(--spacing-1);font-size:var(--font-size-sm)}.episode-stage{color:var(--text-secondary);display:flex;align-items:center;gap:var(--spacing-1)}.episode-stage:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent-primary)}.episode-wordcount{color:var(--text-tertiary);font-weight:var(--font-weight-medium)}.episode-status{display:flex;gap:var(--spacing-2)}.status-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);border:1px solid}.status-draft{background:#94a3b81a;color:var(--text-secondary);border-color:#94a3b833}.status-review{background:#f59e0b1a;color:var(--accent-warning);border-color:#f59e0b33}.status-complete{background:#10b9811a;color:var(--accent-success);border-color:#10b98133}.episode-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:var(--spacing-3);border-top:1px solid var(--border-color)}.episode-date{font-size:var(--font-size-xs);color:var(--text-tertiary);display:flex;align-items:center;gap:var(--spacing-1)}.episode-date:before{content:"🕐"}.btn-delete-episode{background:var(--bg-tertiary);border:1px solid var(--border-color);cursor:pointer;font-size:var(--font-size-base);padding:var(--spacing-2);border-radius:var(--radius-md);opacity:.5;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;width:32px;height:32px}.btn-delete-episode:hover{opacity:1;background:#ef44441a;border-color:#ef44444d;transform:scale(1.1)}.episode-progress-bar{position:absolute;bottom:0;left:0;height:3px;background:var(--gradient-primary);border-radius:0 0 0 var(--radius-xl);transition:width var(--transition-slow)}@media(max-width:640px){.episode-card{flex-direction:column;gap:var(--spacing-4);padding:var(--spacing-4)}.episode-number{min-width:auto;justify-content:flex-start;font-size:var(--font-size-2xl)}.episode-content{gap:var(--spacing-2)}.episode-title{font-size:var(--font-size-base)}.episode-meta{gap:var(--spacing-2)}.episode-footer{padding-top:var(--spacing-2)}}.project-stage-selector{margin-top:var(--spacing-6);padding:var(--spacing-5);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-xl);position:relative;overflow:hidden}.project-stage-selector:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.project-stage-selector h3{margin:0 0 var(--spacing-4) 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:var(--spacing-2)}.project-stage-selector h3:before{content:"📊"}.stage-options{display:flex;align-items:stretch;gap:var(--spacing-3)}.stage-option-wrapper{display:contents}.stage-option{flex:1;padding:var(--spacing-4);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:left;position:relative;overflow:hidden}.stage-option:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(135deg,#6366f11a,#8b5cf60d);opacity:0;transition:opacity var(--transition-base)}.stage-option:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stage-option:hover:before{opacity:1}.stage-option.active{border-color:var(--accent-primary);background:linear-gradient(135deg,#6366f126,#8b5cf61a);box-shadow:0 0 20px #6366f133}.stage-option.active:after{content:"✓";position:absolute;top:var(--spacing-2);right:var(--spacing-2);width:20px;height:20px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff}.stage-option.active .stage-label{color:var(--text-primary)}.stage-option.active .stage-description{color:var(--text-secondary)}.stage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-2)}.stage-label{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-2)}.stage-icon{font-size:1.25rem}.current-badge{background:var(--gradient-primary);color:#fff;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.stage-description{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0;line-height:1.5}.stage-arrow{font-size:1.5rem;color:var(--text-tertiary);opacity:.3;display:flex;align-items:center;flex-shrink:0}@media(max-width:768px){.project-stage-selector{padding:var(--spacing-4)}.stage-options{flex-direction:column}.stage-option{padding:var(--spacing-3)}.stage-arrow{transform:rotate(90deg);padding:var(--spacing-1) 0}.stage-option.active:after{top:var(--spacing-3);right:var(--spacing-3)}}@media(max-width:480px){.project-stage-selector h3{font-size:var(--font-size-xs)}.stage-label{font-size:var(--font-size-sm)}.stage-description{font-size:var(--font-size-xs)}}.project-detail{min-height:100vh;padding:var(--spacing-6) 0 var(--spacing-12);background:radial-gradient(ellipse at top right,rgba(99,102,241,.06) 0%,transparent 50%),radial-gradient(ellipse at bottom left,rgba(139,92,246,.04) 0%,transparent 50%),var(--bg-primary)}.project-detail-header{display:flex;flex-direction:column;gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.btn-back{display:inline-flex;align-items:center;gap:var(--spacing-2);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-lg);transition:all var(--transition-base);align-self:flex-start}.btn-back:before{content:"←";font-size:1rem}.btn-back:hover{background:var(--bg-elevated);border-color:var(--border-hover);color:var(--text-primary);transform:translate(-4px)}.project-info{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-8);position:relative;overflow:hidden}.project-info:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.project-info h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-3);line-height:1.3}.project-info>p{font-size:var(--font-size-base);color:var(--text-secondary);margin-bottom:var(--spacing-5);line-height:1.7}.project-badges{display:flex;gap:var(--spacing-2);flex-wrap:wrap;margin-bottom:var(--spacing-6)}.project-badges .badge{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.project-badges .badge:first-child{background:linear-gradient(135deg,#6366f126,#8b5cf61a);color:var(--accent-tertiary);border-color:#6366f133}.header-actions{display:flex;gap:var(--spacing-3);flex-wrap:wrap}.header-actions .btn{display:inline-flex;align-items:center;gap:var(--spacing-2)}.btn-agent-active{background:var(--gradient-success)!important;animation:pulse-glow 2s ease-in-out infinite}.episodes-section{margin-top:var(--spacing-8)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-6)}.section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.section-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.episodes-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-10)}.empty-state-content{max-width:400px}.empty-state-content h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--spacing-2)}.empty-state-content p{color:var(--text-secondary);margin-bottom:var(--spacing-6)}.empty-state-content .btn{display:inline-flex;align-items:center;gap:var(--spacing-2)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;gap:var(--spacing-6)}.error-state h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-4);color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:var(--z-modal);padding:var(--spacing-4);animation:fadeIn var(--transition-fast)}.modal{width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:fadeInScale var(--transition-base)}.modal h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--border-color)}.form-group{margin-bottom:var(--spacing-5)}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin-bottom:var(--spacing-2)}.form-group input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);width:100%;color:var(--text-primary);transition:all var(--transition-base)}.form-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}.form-group .text-sm{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:var(--spacing-2)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-3);margin-top:var(--spacing-8);padding-top:var(--spacing-6);border-top:1px solid var(--border-color)}.project-status{margin-top:var(--spacing-6);padding:var(--spacing-5);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.project-status h3{margin:0 0 var(--spacing-4) 0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-3)}@media(max-width:768px){.project-detail{padding:var(--spacing-4) 0 var(--spacing-8)}.project-info{padding:var(--spacing-6)}.project-info h1{font-size:var(--font-size-2xl)}.header-actions{flex-direction:column;width:100%}.header-actions .btn{width:100%;justify-content:center}.project-detail-header{gap:var(--spacing-4)}}@media(max-width:480px){.project-info{padding:var(--spacing-5)}.project-info h1{font-size:var(--font-size-xl)}.project-badges{margin-bottom:var(--spacing-4)}.modal{margin:var(--spacing-4)}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%;justify-content:center}}.project-pages{padding:2rem 0;min-height:100vh;position:relative}.pages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.pages-header-left{display:flex;align-items:center;gap:1.5rem}.pages-header-actions{display:flex;gap:.75rem}.pages-layout{display:grid;grid-template-columns:280px 1fr;gap:2rem}.pages-sidebar{min-height:70vh}.pages-tree{background:#ffffff0d;border-radius:12px;padding:1rem;border:1px solid rgba(255,255,255,.1);min-height:70vh;overflow-y:auto;max-height:80vh}.page-tree-node{-webkit-user-select:none;user-select:none}.page-tree-item{display:flex;align-items:center;gap:.4rem;padding:.45rem .75rem;border-radius:6px;cursor:pointer;transition:background .15s;position:relative}.page-tree-item:hover{background:#ffffff14}.page-tree-item.active{background:#6366f133}.page-tree-toggle{background:none;border:none;color:inherit;font-size:.7rem;cursor:pointer;padding:0;width:16px;flex-shrink:0;opacity:.6}.page-tree-title{flex:1;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-tree-actions{display:flex;gap:.2rem;opacity:0;transition:opacity .15s;flex-shrink:0}.page-tree-item:hover .page-tree-actions{opacity:1}.page-action-btn{background:none;border:none;color:inherit;cursor:pointer;font-size:.8rem;padding:2px 4px;border-radius:4px;line-height:1;transition:background .15s}.page-action-btn:hover{background:#ffffff26}.page-action-delete:hover{background:#ff505040}.page-tree-children{margin-left:.5rem}.pages-content-area{background:#ffffff0d;border-radius:12px;padding:2rem;border:1px solid rgba(255,255,255,.1);min-height:70vh}.page-editor{display:flex;flex-direction:column;height:100%}.page-editor-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem;gap:1rem}.page-title-input{background:transparent;border:none;font-size:2rem;font-weight:700;color:#fff;flex:1;outline:none;min-width:0}.page-editor-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.page-editor-tabs{display:flex;gap:0;margin-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.12)}.page-editor-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;font-size:.9rem;padding:.4rem 1rem .5rem;margin-bottom:-1px;transition:color .15s,border-color .15s}.page-editor-tab:hover{color:var(--text-primary)}.page-editor-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-primary, #6366f1)}.page-editor-textarea{width:100%;flex:1;min-height:50vh;background:transparent;border:none;color:#fff;font-size:1.05rem;line-height:1.7;resize:none;outline:none}.page-editor-preview{flex:1;min-height:50vh;font-size:1.05rem;line-height:1.8;color:var(--text-primary);overflow-y:auto}.page-editor-preview-empty{color:var(--text-muted);font-style:italic}.page-editor-preview h1,.page-editor-preview h2,.page-editor-preview h3,.page-editor-preview h4,.page-editor-preview h5,.page-editor-preview h6{margin:1.2em 0 .4em;font-weight:700;line-height:1.3}.page-editor-preview h1{font-size:1.8rem}.page-editor-preview h2{font-size:1.4rem}.page-editor-preview h3{font-size:1.2rem}.page-editor-preview p{margin:.6em 0}.page-editor-preview ul,.page-editor-preview ol{margin:.6em 0;padding-left:1.6em}.page-editor-preview li{margin:.25em 0}.page-editor-preview blockquote{border-left:3px solid rgba(255,255,255,.25);margin:.8em 0;padding:.4em 1em;color:var(--text-secondary)}.page-editor-preview code{background:#ffffff1a;border-radius:4px;font-family:monospace;font-size:.9em;padding:.1em .4em}.page-editor-preview pre{background:#ffffff12;border-radius:8px;overflow-x:auto;padding:1em;margin:.8em 0}.page-editor-preview pre code{background:none;padding:0}.page-editor-preview hr{border:none;border-top:1px solid rgba(255,255,255,.15);margin:1.2em 0}.page-editor-preview a{color:var(--accent-primary, #6366f1);text-decoration:underline}.page-editor-preview strong{font-weight:700}.page-editor-preview em{font-style:italic}.empty-page-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center}.empty-page-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}@media(max-width:1024px){.pages-layout{grid-template-columns:1fr}}.page-editor-body{flex:1;position:relative;display:flex;flex-direction:column;min-height:0}.selection-split-bar{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;gap:.75rem;background:#141423eb;border-top:1px solid rgba(99,102,241,.4);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:.5rem .75rem;font-size:.85rem;z-index:10}.selection-split-info{color:var(--text-secondary);flex:1}.selection-split-dismiss{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.1rem;line-height:1;padding:0 .2rem}.selection-split-dismiss:hover{color:var(--text-primary)}.split-modal{width:520px!important;max-width:92%!important}.split-preview{display:flex;flex-direction:column;gap:.4rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);max-height:280px;overflow-y:auto}.split-preview-item{display:flex;align-items:baseline;gap:.5rem;font-size:.875rem}.split-preview-parent{color:var(--text-primary);font-weight:600}.split-preview-child{color:var(--text-secondary);padding-left:.5rem}.split-preview-icon{flex-shrink:0;font-size:.8rem}.split-preview-title{font-weight:500;flex-shrink:0}.split-preview-title em{font-style:normal;font-weight:400;color:var(--text-muted);font-size:.8rem}.split-preview-content-hint{color:var(--text-muted);font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.split-title-input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);width:100%}.split-title-input:focus{outline:none;border-color:var(--accent-primary, #6366f1)}.project-pages .summarize-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.project-pages .summarize-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);width:440px;max-width:90%;display:flex;flex-direction:column;gap:var(--spacing-md)}.project-pages .summarize-modal h3{margin:0;font-size:var(--font-size-lg);color:var(--text-primary)}.project-pages .summarize-modal-desc{margin:0;font-size:var(--font-size-sm);color:var(--text-secondary)}.project-pages .summarize-no-providers{font-size:var(--font-size-sm);color:var(--text-secondary)}.project-pages .summarize-no-providers a{color:var(--accent-primary);text-decoration:underline}.project-pages .summarize-form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.project-pages .summarize-form-group label{font-size:var(--font-size-sm);color:var(--text-secondary)}.project-pages .summarize-form-group select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.project-pages .summarize-modal-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.fill-progress-log{display:flex;flex-direction:column;gap:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);font-family:monospace;font-size:var(--font-size-sm)}.fill-log-entry{display:flex;align-items:center;gap:var(--spacing-sm);transition:opacity .2s}.fill-log-done{opacity:.5}.fill-log-active{opacity:1;color:var(--text-primary)}.fill-log-error{color:#f87171}.fill-log-icon{width:1rem;text-align:center;flex-shrink:0}.fill-log-text{flex:1}.fill-log-spinner{display:inline-block;width:.75rem;height:.75rem;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:fill-spin .7s linear infinite}@keyframes fill-spin{to{transform:rotate(360deg)}}.content-editor{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-color)}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.editor-status{display:flex;align-items:center;gap:var(--spacing-sm)}.editor-stats{display:flex;align-items:center;gap:var(--spacing-md)}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.editor-textarea{flex:1;padding:var(--spacing-xl);background:transparent;border:none;color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:var(--font-size-base);line-height:2;resize:none;min-height:500px}.editor-textarea:focus{outline:none}.editor-textarea::placeholder{color:var(--text-tertiary);opacity:.5}@media(max-width:640px){.editor-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.editor-stats{width:100%;justify-content:space-between}}.comment-thread{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.comment-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.comment-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.comment-form{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--spacing-md)}.comment-form textarea{min-height:80px}.comment-list{flex:1;overflow-y:auto;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.empty-comments{display:flex;justify-content:center;align-items:center;padding:var(--spacing-2xl);text-align:center}.comment-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);transition:all var(--transition-base)}.comment-item:hover{background:var(--bg-tertiary)}.agent-comment{background:var(--gradient-glass);border:1px solid rgba(99,102,241,.2)}.comment-avatar{font-size:var(--font-size-2xl);flex-shrink:0}.comment-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.comment-meta{display:flex;align-items:center;gap:var(--spacing-md)}.comment-author{font-weight:var(--font-weight-semibold);color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.comment-time{font-size:var(--font-size-xs)}.comment-text{color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.comment-stage{display:inline-block;margin-top:var(--spacing-xs)}.btn-delete-comment{background:none;border:none;cursor:pointer;font-size:var(--font-size-base);padding:var(--spacing-xs);opacity:0;transition:all var(--transition-base);flex-shrink:0}.comment-item:hover .btn-delete-comment{opacity:.5}.btn-delete-comment:hover{opacity:1!important;transform:scale(1.2)}.ml-sm{margin-left:var(--spacing-sm)}.stage-indicator{display:flex;gap:var(--spacing-md);overflow-x:auto;padding:var(--spacing-sm) 0}.stage-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);position:relative;min-width:150px}.stage-item:hover{border-color:var(--stage-color);transform:translateY(-2px)}.stage-item.active{background:var(--gradient-glass);border-color:var(--stage-color);box-shadow:0 0 20px #6366f14d}.stage-item.completed{border-color:var(--accent-success);opacity:.7}.stage-item.completed .stage-number{background:var(--accent-success)}.stage-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--stage-color);color:#fff;border-radius:50%;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);flex-shrink:0}.stage-content{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.stage-name{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-base)}.stage-description{font-size:var(--font-size-xs);color:var(--text-tertiary);line-height:1.2}.stage-indicator-active{position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--stage-color);border-radius:var(--radius-sm)}@media(max-width:640px){.stage-indicator{gap:var(--spacing-sm)}.stage-item{min-width:120px;padding:var(--spacing-sm) var(--spacing-md)}.stage-description{display:none}}.episode-board{min-height:100vh;background:var(--bg-primary)}.board-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--spacing-lg) 0;position:sticky;top:0;z-index:100}.board-header .container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.episode-info{display:flex;flex-direction:column;gap:var(--spacing-md)}.episode-title-section{display:flex;align-items:center;gap:var(--spacing-md)}.episode-number{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--accent-primary);padding:var(--spacing-sm) var(--spacing-md);background:var(--gradient-glass);border-radius:var(--radius-md)}.episode-title-section h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold)}.episode-meta-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-md)}.project-name{font-size:var(--font-size-sm)}.status-controls{display:flex;align-items:center;gap:var(--spacing-md)}.status-select{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base)}.status-select:hover{border-color:var(--accent-primary)}.wordcount{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.board-content{padding:var(--spacing-2xl) 0}.board-layout{display:grid;grid-template-columns:1fr 400px;gap:var(--spacing-xl);align-items:start}.editor-section{min-height:600px}.sidebar-section{position:sticky;top:calc(240px + var(--spacing-lg));max-height:calc(100vh - 280px)}@media(max-width:1024px){.board-layout{grid-template-columns:1fr}.sidebar-section{position:static;max-height:500px}}@media(max-width:640px){.episode-title-section{flex-direction:column;align-items:flex-start}.episode-title-section h1{font-size:var(--font-size-2xl)}.episode-meta-bar{flex-direction:column;align-items:flex-start}.status-controls{width:100%;justify-content:space-between}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.custom-node{padding:var(--spacing-md);border-radius:var(--radius-lg);border:2px solid;min-width:180px;max-width:250px;background:var(--bg-tertiary);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.custom-node.selected{box-shadow:0 0 0 2px var(--accent-primary),var(--shadow-lg);transform:scale(1.05)}.custom-node:hover{box-shadow:var(--shadow-lg)}.node-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.root-badge{font-size:var(--font-size-lg)}.node-title{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-base);line-height:1.4;word-break:break-word}.node-content{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm);line-height:1.4}.node-footer{margin-bottom:var(--spacing-sm)}.click-hint{font-size:var(--font-size-xs);color:var(--text-tertiary);opacity:.6}.custom-node:hover .click-hint{opacity:1;color:var(--accent-primary)}.node-actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end;padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.node-action-btn{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-base)}.node-action-btn:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.node-action-btn.delete:hover{border-color:var(--accent-danger);color:var(--accent-danger)}.node-detail-panel{position:fixed;right:0;top:0;width:400px;height:100vh;background:var(--bg-secondary);border-left:1px solid var(--border-color);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;z-index:1000}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.panel-header h3{Font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.btn-close{background:none;border:none;color:var(--text-secondary);font-size:var(--font-size-xl);cursor:pointer;padding:var(--spacing-xs);transition:color var(--transition-base)}.btn-close:hover{color:var(--text-primary)}.panel-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.form-group input,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-base)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary)}.color-picker{display:flex;gap:var(--spacing-sm)}.color-option{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all var(--transition-base)}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-secondary)}.panel-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.btn-convert{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;transition:opacity .2s}.btn-convert:hover:not(:disabled){opacity:.85}.btn-convert:disabled{opacity:.5;cursor:not-allowed}.always-review-toggle{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--text-secondary);padding:var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-tertiary)}.always-review-toggle input{width:auto}.comments-section{border-top:1px solid var(--border-color);padding-top:var(--spacing-lg);margin-bottom:0}.comments-section h4{margin-bottom:var(--spacing-md);font-size:var(--font-size-lg)}.comments-list{max-height:none}.comment{padding:0 12px 12px;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.comment.agent{background:linear-gradient(135deg,var(--accent-primary)11,var(--accent-secondary)11);border-left:3px solid var(--accent-primary)}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xs)}.comment-meta-left{display:flex;flex-direction:column;gap:2px}.comment-author{font-weight:var(--font-weight-semibold);font-size:13px;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.comment-time{font-size:11px;color:var(--text-tertiary)}.btn-delete-comment{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--spacing-xs);font-size:14px;line-height:1;border-radius:var(--radius-sm);transition:all var(--transition-base);opacity:.3;display:flex;align-items:center;justify-content:center}.comment:hover .btn-delete-comment{opacity:.7}.btn-delete-comment:hover{color:var(--status-danger);background:#ef44441a;opacity:1!important}.comment-content{font-size:14px;line-height:1.5;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word}.comment-form-fixed{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0}.comment-form-fixed textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);resize:none;margin-bottom:var(--spacing-sm)}.comment-form-fixed textarea:focus{outline:none;border-color:var(--accent-primary)}.comment-form-fixed .btn{width:100%}.comment-form textarea{resize:vertical;background:var(--bg-secondary)}@media(max-width:768px){.node-detail-panel{width:100%}}.brainstorm-board{width:100%;height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.board-toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.toolbar-left{display:flex;gap:var(--spacing-md);align-items:center}.drag-option{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-secondary);font-size:var(--font-size-sm)}.drag-option input{width:auto}.lore-context-label{font-size:var(--font-size-sm);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.target-count-input{width:60px;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);text-align:center}.btn-back{background:none;border:none;color:var(--text-secondary);font-size:var(--font-size-base);cursor:pointer;padding:var(--spacing-sm);transition:all var(--transition-base)}.btn-back:hover{color:var(--accent-primary);transform:translate(-4px)}.toolbar-info{display:flex;gap:var(--spacing-md);align-items:center}.node-count{font-size:var(--font-size-sm);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.help-text{font-size:var(--font-size-xs);color:var(--text-tertiary);font-style:italic}.flow-container{flex:1;position:relative}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:var(--spacing-md)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.summarize-modal-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.summarize-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);width:420px;max-width:90%;display:flex;flex-direction:column;gap:var(--spacing-md)}.summarize-modal h3{margin:0;font-size:var(--font-size-lg);color:var(--text-primary)}.summarize-modal-desc{margin:0;font-size:var(--font-size-sm);color:var(--text-secondary)}.summarize-no-providers{font-size:var(--font-size-sm);color:var(--text-secondary)}.summarize-no-providers a{color:var(--accent-primary);text-decoration:underline}.summarize-form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.summarize-form-group label{font-size:var(--font-size-sm);color:var(--text-secondary)}.summarize-form-group select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.summarize-modal-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.react-flow{background:var(--bg-primary)}.react-flow__attribution{opacity:.3}.react-flow__controls{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.react-flow__controls-button{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.react-flow__controls-button:hover{background:var(--bg-secondary)}.react-flow__minimap{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.session-list-page{min-height:100vh;background:#0f0f1a;color:#e2e8f0;padding:2rem}.session-list-loading{text-align:center;padding:4rem;color:#94a3b8}.session-list-header{margin-bottom:2rem}.btn-back{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:.9rem;padding:.25rem 0;margin-bottom:1rem;display:inline-block}.btn-back:hover{color:#e2e8f0}.session-list-title-row{display:flex;align-items:center;gap:1rem}.session-list-title-row h2{margin:0;font-size:1.5rem;color:#e2e8f0}.session-page-name{font-size:.95rem;color:#94a3b8;background:#1e1e2e;padding:.25rem .75rem;border-radius:6px}.session-list-content{max-width:800px}.session-list-empty{text-align:center;padding:3rem;color:#64748b;background:#1e1e2e;border-radius:10px;margin-bottom:1.5rem}.session-list-empty p{margin:.25rem 0}.session-cards{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.session-card{display:flex;align-items:center;justify-content:space-between;background:#1e1e2e;border:1px solid #2a2a3e;border-radius:10px;padding:1rem 1.25rem;cursor:pointer;transition:border-color .15s,background .15s}.session-card:hover{border-color:#6366f1;background:#23233a}.session-card-body{flex:1;min-width:0}.session-card-title{font-size:1rem;font-weight:600;color:#e2e8f0;margin-bottom:.35rem}.session-rename-input{background:#2a2a3e;border:1px solid #6366f1;border-radius:5px;color:#e2e8f0;font-size:1rem;padding:.2rem .5rem;width:100%;max-width:400px;margin-bottom:.35rem;outline:none}.session-card-meta{display:flex;gap:1rem;font-size:.8rem;color:#64748b}.session-card-actions{display:flex;gap:.4rem;flex-shrink:0;margin-left:1rem}.session-action-btn{background:none;border:none;cursor:pointer;padding:.3rem .4rem;border-radius:5px;font-size:.9rem;opacity:.5;transition:opacity .15s,background .15s}.session-action-btn:hover{opacity:1;background:#2a2a3e}.session-action-delete:hover{background:#ef444426}.session-create-btn{margin-top:.5rem}.btn{padding:.6rem 1.2rem;border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:background .15s}.btn-primary{background:#6366f1;color:#fff}.btn-primary:hover{background:#4f46e5}.admin-page{min-height:100vh;padding:var(--spacing-8) 0 var(--spacing-12);background:radial-gradient(900px 420px at 8% -20%,rgba(99,102,241,.22),transparent 60%),radial-gradient(800px 380px at 92% -18%,rgba(16,185,129,.16),transparent 58%),var(--bg-primary)}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.admin-title-block h1{margin:var(--spacing-2) 0 var(--spacing-1);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-nav-row{display:flex;align-items:center;gap:var(--spacing-2)}.admin-tag{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:#c7d2fe;background:#6366f133;border:1px solid rgba(99,102,241,.4)}.admin-header-actions{display:flex;gap:var(--spacing-2)}.btn-back{display:inline-flex;align-items:center;gap:var(--spacing-2);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-lg);transition:all var(--transition-base)}.btn-back:before{content:none}.btn-back:hover{background:var(--bg-elevated);border-color:var(--border-hover);color:var(--text-primary);transform:translate(-2px)}.admin-tabs{margin-top:var(--spacing-4);display:flex;gap:var(--spacing-2);flex-wrap:wrap}.admin-tab{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);padding:var(--spacing-2) var(--spacing-4);text-decoration:none;border:1px solid var(--border-color);color:var(--text-secondary);background:var(--bg-tertiary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);transition:all var(--transition-base)}.admin-tab:hover{background:var(--bg-elevated);border-color:var(--border-hover);color:var(--text-primary)}.admin-tab.is-active{color:#fff;border-color:var(--accent-primary);background:linear-gradient(135deg,#6366f1cc,#8b5cf6cc);box-shadow:var(--shadow-glow)}.admin-kpis{margin-top:var(--spacing-4);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-3)}.admin-kpi-card{border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-4);background:var(--bg-secondary);transition:all var(--transition-base)}.admin-kpi-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.admin-kpi-card strong{display:block;margin-top:var(--spacing-1);font-size:var(--font-size-2xl);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.kpi-label{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.admin-status{position:sticky;top:var(--spacing-2);z-index:var(--z-sticky);margin-top:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);border:1px solid rgba(59,130,246,.35);background:#3b82f61f;color:#bfdbfe;font-size:var(--font-size-sm);display:flex;align-items:center;gap:var(--spacing-2)}.admin-status:before{content:"ℹ️"}.admin-section{margin-top:var(--spacing-6);padding:var(--spacing-5);border-radius:var(--radius-xl);border:1px solid var(--border-color);background:var(--bg-secondary);box-shadow:var(--shadow-lg)}.admin-section h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-3);color:var(--text-primary)}.permission-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-2);margin-top:var(--spacing-3)}.permission-toolbar{margin-top:var(--spacing-3);display:flex;gap:var(--spacing-2);flex-wrap:wrap;align-items:center}.permission-search{min-height:40px;min-width:260px;flex:1;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);padding:0 var(--spacing-3);font-size:var(--font-size-base);transition:all var(--transition-base)}.permission-search:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}.permission-search::placeholder{color:var(--text-tertiary)}.permission-toolbar-actions{display:flex;gap:var(--spacing-2)}.permission-star-box{margin-top:var(--spacing-2)}.permission-groups{margin-top:var(--spacing-2);display:grid;gap:var(--spacing-2)}.permission-group{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-tertiary);padding:var(--spacing-3);transition:all var(--transition-base)}.permission-group:hover{border-color:var(--border-hover)}.permission-group-header{display:flex;justify-content:space-between;gap:var(--spacing-2);align-items:center;margin-bottom:var(--spacing-2)}.group-toggle{border:none;background:transparent;color:var(--text-primary);cursor:pointer;font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);transition:color var(--transition-fast)}.group-toggle:hover{color:var(--accent-tertiary)}.group-actions{display:flex;gap:var(--spacing-2)}.permission-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.permission-item:hover{border-color:var(--border-hover)}.permission-item input{width:16px;height:16px;min-width:16px;accent-color:var(--accent-primary)}.permission-star{border-color:#6366f173;background:#6366f129}.admin-form{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.admin-form input,.admin-form select,.role-edit select{min-height:40px;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);padding:0 var(--spacing-3);font-size:var(--font-size-base);transition:all var(--transition-base)}.admin-form input:focus,.admin-form select:focus,.role-edit select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}.admin-form input::placeholder{color:var(--text-tertiary)}.admin-form input{min-width:260px;flex:1}.admin-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%2394A3B8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}.admin-select option{color:var(--text-primary);background-color:var(--bg-secondary)}.admin-section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);margin-bottom:var(--spacing-2)}.admin-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.admin-table{width:100%;border-collapse:separate;border-spacing:0;min-width:640px}.admin-table thead th{text-align:left;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:var(--spacing-3) var(--spacing-3);border-bottom:1px solid var(--border-color);background:var(--bg-tertiary);font-weight:var(--font-weight-semibold)}.admin-table tbody td{padding:var(--spacing-3);border-bottom:1px solid var(--border-color)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr{transition:background-color var(--transition-fast)}.admin-table tbody tr:hover{background:#6366f114}.role-row-clickable{cursor:pointer}.role-row-protected{opacity:.9}.role-edit-hint{font-size:var(--font-size-xs);color:var(--text-secondary)}.role-protected-label{font-size:var(--font-size-xs);color:#93c5fd;border:1px solid rgba(59,130,246,.35);background:#3b82f61f;border-radius:var(--radius-full);padding:var(--spacing-1) var(--spacing-2)}.empty-row{text-align:center;color:var(--text-secondary);padding:var(--spacing-8)!important}.role-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold)}.role-badge.user{background:#10b98126;color:#34d399;border:1px solid rgba(16,185,129,.3)}.role-badge.admin{background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.3)}.admin-actions,.role-edit{display:flex;align-items:center;gap:var(--spacing-2)}.role-edit select{min-height:34px;min-width:100px;padding:0 var(--spacing-2)}.api-key-once-box{margin-top:var(--spacing-3);padding:var(--spacing-3);border-radius:var(--radius-lg);background:#10b9811a;border:1px solid rgba(16,185,129,.3)}.api-key-once-box code{display:block;margin-top:var(--spacing-2);color:#6ee7b7;word-break:break-all;font-family:Fira Code,Consolas,monospace;font-size:var(--font-size-sm);background:#0000004d;padding:var(--spacing-2);border-radius:var(--radius-md)}.admin-audit-retention{margin-top:var(--spacing-2);font-size:var(--font-size-sm);color:var(--text-secondary)}.admin-audit-help{margin-bottom:var(--spacing-3);display:grid;gap:var(--spacing-1);font-size:var(--font-size-sm);color:var(--text-secondary)}.audit-setting-field{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:220px;flex:1}.audit-setting-field span{font-size:var(--font-size-xs);color:var(--text-secondary)}.admin-audit-filters{margin-bottom:var(--spacing-3)}.audit-expand-cell{color:var(--text-secondary);font-size:var(--font-size-xs)}.audit-details-row td{background:#0f172a80}.audit-row-details-full summary{cursor:pointer;font-size:var(--font-size-sm);color:var(--text-primary)}.audit-changes{margin-top:var(--spacing-2);padding:var(--spacing-2);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);max-height:220px;overflow:auto;font-size:var(--font-size-xs);font-family:Fira Code,Consolas,monospace}.api-stats-wrap{margin-bottom:var(--spacing-4);display:grid;gap:var(--spacing-3)}.api-stats-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--spacing-2)}.api-stat-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-3);background:var(--bg-secondary);transition:all var(--transition-base)}.api-stat-card:hover{border-color:var(--border-hover)}.api-stat-card span{display:block;font-size:var(--font-size-xs);color:var(--text-secondary)}.api-stat-card strong{display:block;margin-top:var(--spacing-1);font-size:var(--font-size-lg);color:var(--text-primary)}.api-stats-panels{display:grid;grid-template-columns:1.3fr 1fr;gap:var(--spacing-3)}.api-panel{border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-3);background:var(--bg-secondary)}.api-panel h3{margin:0 0 var(--spacing-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.api-hourly-list{display:grid;gap:var(--spacing-1);max-height:340px;overflow-y:auto}.api-hourly-row{display:grid;grid-template-columns:170px 1fr 72px;align-items:center;gap:var(--spacing-2)}.api-hourly-time{font-size:var(--font-size-xs);color:var(--text-secondary)}.api-hourly-bar-bg{width:100%;height:10px;border-radius:var(--radius-full);background:var(--bg-tertiary);overflow:hidden}.api-hourly-bar{height:100%;background:linear-gradient(90deg,#06b6d4,#3b82f6);border-radius:var(--radius-full);transition:width var(--transition-slow)}.api-hourly-num{font-size:var(--font-size-xs);text-align:right;color:var(--text-secondary)}@media(max-width:1024px){.admin-kpis{grid-template-columns:repeat(2,1fr)}.api-stats-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:900px){.permission-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.permission-group-header{flex-direction:column;align-items:flex-start}.api-stats-panels{grid-template-columns:1fr}}@media(max-width:768px){.admin-header{flex-direction:column;gap:var(--spacing-3)}.admin-title-block h1{font-size:var(--font-size-3xl)}.admin-form{flex-direction:column}.admin-form input,.admin-form select,.admin-form button{width:100%}.role-edit{flex-direction:column;align-items:stretch}.permission-grid{grid-template-columns:1fr}.permission-toolbar{flex-direction:column;align-items:stretch}.permission-toolbar-actions{width:100%}.permission-toolbar-actions .btn{flex:1;justify-content:center}.api-hourly-row{grid-template-columns:1fr;gap:var(--spacing-1)}}@media(max-width:480px){.admin-kpis{grid-template-columns:1fr}.admin-tabs{width:100%}.admin-tab{flex:1;min-width:80px}}.llm-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.llm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4)}@media(max-width:640px){.llm-form-row{grid-template-columns:1fr}}.llm-form-group{display:flex;flex-direction:column;gap:var(--spacing-1)}.llm-form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.llm-form-group input,.llm-form-group select{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:var(--font-size-sm)}.llm-label-hint{font-weight:var(--font-weight-normal);color:var(--text-muted);font-size:var(--font-size-xs)}.llm-checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer}.llm-form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-2);padding-top:var(--spacing-2);border-top:1px solid var(--border-color)}.llm-row-default{background:#6366f10d}.llm-badge-default{display:inline-block;margin-left:var(--spacing-2);padding:2px 6px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:#a5b4fc;background:#6366f133;border:1px solid rgba(99,102,241,.4)}.llm-apikey{font-family:var(--font-mono, monospace);font-size:var(--font-size-xs);color:var(--text-secondary);background:#ffffff0d;padding:2px 6px;border-radius:var(--radius-sm)}.llm-empty{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-4);padding:var(--spacing-12) 0;color:var(--text-muted)}.llm-model-disabled,.llm-model-loading{opacity:.45;cursor:not-allowed}.llm-model-error{font-size:var(--font-size-xs);color:#f87171;margin-top:var(--spacing-1)}.llm-label-ok{font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);color:#34d399;margin-left:var(--spacing-2)}.llm-model-list{display:flex;flex-direction:column;gap:2px;max-height:260px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-1);background:var(--bg-secondary)}.llm-model-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-secondary);transition:background .1s;min-width:0}.llm-model-item:hover{background:#ffffff0d}.llm-model-item.is-checked{color:var(--text-primary)}.llm-model-item input[type=checkbox],.llm-checkbox-label input[type=checkbox]{all:revert;flex-shrink:0;width:14px;height:14px;margin:0;cursor:pointer}.llm-model-item-name{flex:1;font-family:var(--font-mono, monospace);font-size:var(--font-size-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.llm-model-default-btn{background:none;border:none;cursor:pointer;font-size:var(--font-size-xs);color:var(--text-muted);padding:2px 6px;border-radius:var(--radius-sm);white-space:nowrap;transition:color .1s}.llm-model-default-btn:hover{color:var(--text-primary)}.llm-model-default-btn.is-active{color:#fbbf24;font-weight:var(--font-weight-bold)}.llm-model-readonly{display:flex;flex-wrap:wrap;gap:var(--spacing-1);align-items:center}.llm-model-hint{width:100%;font-size:var(--font-size-xs);color:var(--text-muted);margin:var(--spacing-1) 0 0}.llm-model-chips{display:flex;flex-wrap:wrap;gap:4px}.llm-model-chip,.llm-model{font-family:var(--font-mono, monospace);font-size:var(--font-size-xs);color:var(--text-secondary);background:#ffffff0d;padding:2px 6px;border-radius:var(--radius-sm)}.llm-model-chip.is-default,.llm-model.is-default{color:#fbbf24;background:#fbbf241a}.llm-oauth-device-flow,.llm-oauth-manual-flow{display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4);background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md)}.llm-oauth-step{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.llm-oauth-hint{font-size:var(--font-size-xs);color:var(--text-muted, #6b7280)}.llm-oauth-link{font-size:var(--font-size-sm);color:var(--color-accent, #60a5fa);word-break:break-all}.llm-oauth-user-code{font-family:var(--font-mono, monospace);font-size:2rem;font-weight:700;letter-spacing:.2em;text-align:center;padding:var(--spacing-3);background:#ffffff0f;border-radius:var(--radius-sm);color:var(--text-primary)}.llm-oauth-pending{font-size:var(--font-size-sm);color:var(--text-muted, #6b7280);text-align:center;margin:0;animation:pulse 2s infinite}.llm-oauth-paste-input{width:100%;font-family:var(--font-mono, monospace);font-size:var(--font-size-xs)}.llm-oauth-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end}.llm-oauth-error{font-size:var(--font-size-sm);color:#f87171;margin:0}.llm-oauth-badge{display:inline-block;font-size:var(--font-size-xs);padding:2px 8px;background:#60a5fa26;color:#60a5fa;border-radius:var(--radius-sm);font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.scene-card-list-wrapper{display:flex;flex-direction:column;height:100%;overflow:hidden}.scene-card-list{display:flex;flex-direction:row;align-items:flex-start;gap:.75rem;padding:1rem;overflow-x:auto;overflow-y:hidden;height:100%;min-height:0}.scene-card{flex:0 0 220px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;cursor:default;transition:border-color .15s;min-height:200px}.scene-card:hover{border-color:#fff3}.scene-card.completed{opacity:.5}.scene-card.completed .scene-card-title{text-decoration:line-through}.scene-card-drag-handle{cursor:grab;text-align:center;color:#ffffff40;font-size:1rem;-webkit-user-select:none;user-select:none;line-height:1;margin-bottom:-.25rem}.scene-card-drag-handle:active{cursor:grabbing}.scene-card-header{display:flex;align-items:center;gap:.4rem}.scene-card-checkbox{flex-shrink:0;width:15px;height:15px;accent-color:#7c6ef7;cursor:pointer}.scene-card-title{flex:1;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.12);color:#fff;font-size:.88rem;font-weight:600;padding:.15rem 0;outline:none;min-width:0}.scene-card-title::placeholder{color:#ffffff4d}.scene-card-title:focus{border-bottom-color:#7c6ef7}.scene-card-delete{flex-shrink:0;background:none;border:none;color:#ffffff40;font-size:1rem;cursor:pointer;padding:0;line-height:1;transition:color .15s}.scene-card-delete:hover{color:#ff6b6b}.scene-card-fields{display:flex;flex-direction:column;gap:.4rem;flex:1}.scene-card-field{display:flex;flex-direction:column;gap:.2rem}.scene-card-field-label{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.scene-card-field-label.goal{color:#6fcf97}.scene-card-field-label.conflict{color:#eb5757}.scene-card-field-label.outcome{color:#f2c94c}.scene-card-textarea{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:5px;color:#fffc;font-size:.8rem;line-height:1.4;padding:.3rem .4rem;resize:none;outline:none;width:100%;box-sizing:border-box;transition:border-color .15s}.scene-card-textarea::placeholder{color:#fff3}.scene-card-textarea:focus{border-color:#ffffff40;background:#ffffff12}.scene-divider-card{flex:0 0 40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;position:relative;min-height:200px}.scene-divider-line{width:2px;flex:1;background:#ffffff26;border-radius:1px}.scene-divider-card .scene-card-delete{position:absolute;top:.5rem}.scene-card-add-group{flex:0 0 auto;display:flex;flex-direction:column;gap:.4rem;justify-content:flex-start;padding-top:.25rem}.scene-card-add-btn{background:#ffffff0d;border:1px dashed rgba(255,255,255,.2);border-radius:8px;color:#ffffff80;font-size:.82rem;padding:.5rem .75rem;cursor:pointer;white-space:nowrap;transition:all .15s}.scene-card-add-btn:hover{background:#ffffff1a;color:#fff;border-color:#fff6}.scene-card-add-btn.divider{border-style:dotted;font-size:.78rem}.scene-card-empty{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffffff40;font-size:.9rem;pointer-events:none}.scene-card-loading,.scene-card-error{padding:2rem;text-align:center;color:#fff6;font-size:.9rem}.scene-card-error{color:#ff6b6b}.act-detail-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.act-detail-section{display:flex;flex-direction:column;gap:.4rem}.act-detail-label{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#ffffff73}.act-detail-textarea{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffd9;font-family:inherit;font-size:.92rem;line-height:1.65;padding:.75rem 1rem;resize:none;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.act-detail-textarea::placeholder{color:#fff3}.act-detail-textarea:focus{border-color:#ffffff40;background:#ffffff0f}.act-detail-gen-row{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.25rem}.act-detail-gen-btn{font-size:.88rem}.act-detail-gen-panel{background:#ffffff0a;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.act-detail-gen-section{display:flex;flex-direction:column;gap:.5rem}.act-detail-gen-label{font-size:.78rem;font-weight:600;color:#ffffff73;text-transform:uppercase;letter-spacing:.05em;display:flex;justify-content:space-between;align-items:center}.act-detail-select-all{background:none;border:none;color:#6366f1cc;font-size:.8rem;cursor:pointer;padding:0;transition:color .15s}.act-detail-select-all:hover{color:#6366f1;text-decoration:underline}.act-detail-gen-empty{font-size:.85rem;color:#ffffff4d;margin:0}.act-detail-page-list{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.4rem;max-height:150px;overflow-y:auto}.act-detail-page-item{display:flex;align-items:center;gap:.5rem;padding:.3rem .5rem;border-radius:4px;cursor:pointer;font-size:.88rem;color:#fffc;transition:background .1s;-webkit-user-select:none;user-select:none}.act-detail-page-item:hover{background:#ffffff0f}.act-detail-page-item input[type=checkbox]{cursor:pointer;accent-color:rgb(99,102,241);flex-shrink:0}.act-detail-provider-row{display:flex;gap:.6rem;align-items:center}.act-detail-provider-row select{flex:1;background:#ffffff12;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:inherit;font-size:.88rem;padding:.4rem .6rem;outline:none;cursor:pointer;font-family:inherit;transition:border-color .15s}.act-detail-provider-row select:focus{border-color:#6366f199}.act-detail-gen-log{font-size:.88rem;color:#86eface6;padding:.5rem .75rem;background:#ffffff0a;border-radius:6px;border:1px solid rgba(255,255,255,.08)}.act-detail-gen-log.error{color:#fca5a5f2}.act-detail-gen-actions{display:flex;justify-content:flex-end;gap:.5rem}.act-detail-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.1rem}.act-detail-add-small{background:none;border:none;color:#6366f1cc;font-size:.78rem;cursor:pointer;padding:0;transition:color .15s}.act-detail-add-small:hover{color:#6366f1;text-decoration:underline}.act-char-list{display:flex;flex-direction:column;gap:.75rem}.act-char-row{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.65rem .75rem;display:flex;flex-direction:column;gap:.5rem}.act-char-row-top{display:flex;align-items:center;gap:.5rem;min-width:0}.act-char-identity{flex:1;min-width:0}.act-char-name-input{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffffe6;font-family:inherit;font-size:.88rem;font-weight:500;padding:.3rem .6rem;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.act-char-name-input:focus{border-color:#6366f180}.act-char-chip{display:inline-flex;align-items:center;gap:.3rem;background:#6366f12e;border:1px solid rgba(99,102,241,.35);border-radius:999px;padding:.2rem .5rem .2rem .75rem;font-size:.84rem;font-weight:500;color:#ffffffe6;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.act-char-chip-remove{background:none;border:none;color:#fff6;cursor:pointer;font-size:.9rem;line-height:1;padding:0;flex-shrink:0;transition:color .1s}.act-char-chip-remove:hover{color:#ff6464e6}.act-char-link-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#ffffff73;font-size:.75rem;cursor:pointer;padding:.2rem .5rem;white-space:nowrap;flex-shrink:0;transition:all .15s;font-family:inherit}.act-char-link-btn:hover,.act-char-link-btn.active{border-color:#6366f180;color:#6366f1e6;background:#6366f114}.act-char-picker{background:#14141ef2;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:.35rem;display:flex;flex-direction:column;gap:.1rem;max-height:160px;overflow-y:auto}.act-char-picker-item{background:none;border:none;color:#ffffffbf;font-size:.88rem;text-align:left;padding:.3rem .6rem;border-radius:4px;cursor:pointer;transition:background .1s;font-family:inherit}.act-char-picker-item:hover{background:#6366f126;color:#fffffff2}.act-char-role-input{margin-top:0}.act-ep-empty{font-size:.84rem;color:#ffffff40;margin:0}.act-ep-list{display:flex;flex-direction:column;gap:.6rem}.act-ep-row{display:flex;align-items:flex-start;gap:.6rem}.act-ep-num{font-size:.78rem;color:#ffffff4d;min-width:1.4rem;text-align:right;padding-top:.5rem;flex-shrink:0}.act-ep-inputs{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.act-ep-title-input{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffffe6;font-family:inherit;font-size:.88rem;font-weight:500;padding:.35rem .6rem;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.act-ep-title-input:focus{border-color:#6366f180}.act-ep-desc-input{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px;color:#ffffffbf;font-family:inherit;font-size:.85rem;line-height:1.55;padding:.35rem .6rem;resize:none;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.act-ep-desc-input::placeholder{color:#fff3}.act-ep-desc-input:focus{border-color:#fff3}.act-ep-remove-btn{background:none;border:none;color:#ffffff40;font-size:1rem;cursor:pointer;padding:.3rem .2rem;line-height:1;flex-shrink:0;margin-top:.25rem;transition:color .1s}.act-ep-remove-btn:hover{color:#ff6464cc}.plot-board{padding:2rem 0;min-height:100vh}.plot-board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.plot-board-header-left{display:flex;align-items:center;gap:1.5rem}.plot-board-layout{display:grid;grid-template-columns:280px 1fr;gap:2rem}.plot-sidebar{min-height:70vh}.plot-tree{background:#ffffff0d;border-radius:12px;padding:1rem;border:1px solid rgba(255,255,255,.1);min-height:70vh;overflow-y:auto;max-height:80vh;display:flex;flex-direction:column;gap:.25rem}.plot-tree-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none}.plot-tree-item:hover{background:#ffffff14}.plot-tree-item.active{background:#6366f133}.plot-tree-item-title{flex:1;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plot-tree-item-actions{display:flex;gap:.2rem;opacity:0;transition:opacity .15s;flex-shrink:0}.plot-tree-item:hover .plot-tree-item-actions{opacity:1}.plot-tree-action-btn{background:none;border:none;color:#ffffff80;font-size:.8rem;cursor:pointer;padding:2px 4px;border-radius:4px;line-height:1}.plot-tree-action-btn:hover{background:#ffffff1a;color:#ffffffe6}.plot-tree-divider{font-size:.75rem;color:#ffffff4d;padding:.5rem .75rem .25rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}.plot-tree-add-btn{background:none;border:1px dashed rgba(255,255,255,.2);color:#fff6;font-size:.82rem;cursor:pointer;padding:.4rem .75rem;border-radius:6px;width:100%;text-align:left;margin-top:.25rem;transition:all .15s}.plot-tree-add-btn:hover{border-color:#6366f180;color:#ffffffb3;background:#6366f114}.plot-act-group{display:flex;flex-direction:column}.plot-tree-act-item{gap:.35rem}.plot-act-chevron{background:none;border:none;color:#fff6;font-size:.75rem;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0;transition:color .15s}.plot-act-chevron:hover{color:#fffc}.plot-act-episodes{display:flex;flex-direction:column;gap:.1rem;padding-left:1.25rem;border-left:1px solid rgba(255,255,255,.07);margin-left:1rem;margin-bottom:.25rem}.plot-tree-episode-item{font-size:.85rem;padding:.35rem .6rem;gap:.4rem}.plot-episode-dot{font-size:.7rem;color:#ffffff4d;flex-shrink:0}.plot-episode-add-btn{font-size:.78rem;padding:.3rem .6rem;margin-top:.1rem}.plot-editor-area{display:flex;flex-direction:column;gap:1rem}.plot-editor-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.plot-editor-title{font-size:1.25rem;font-weight:600;flex:1}.plot-editor-title-input{font-size:1.25rem;font-weight:600;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.2);color:inherit;padding:.2rem 0;flex:1;outline:none}.plot-editor-title-input:focus{border-bottom-color:#6366f199}.plot-editor-tabs{display:flex;gap:0;background:#ffffff0d;border-radius:8px;padding:3px;flex-shrink:0}.plot-editor-tab{background:none;border:none;color:#ffffff80;font-size:.82rem;cursor:pointer;padding:.3rem .75rem;border-radius:6px;transition:all .15s}.plot-editor-tab.active{background:#6366f14d;color:#ffffffe6}.plot-editor-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;flex:1;min-height:60vh;display:flex;flex-direction:column}.plot-editor-card.scenes-mode{overflow:hidden;padding:0}.plot-editor-card.project-plot-mode{overflow-y:auto}.project-plot-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.project-plot-field{display:flex;flex-direction:column;gap:.4rem}.project-plot-label{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#ffffff73}.project-plot-textarea{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffd9;font-family:inherit;font-size:.92rem;line-height:1.65;padding:.75rem 1rem;resize:none;outline:none;transition:border-color .15s}.project-plot-textarea::placeholder{color:#fff3}.project-plot-textarea:focus{border-color:#ffffff40;background:#ffffff0f}.project-plot-acts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:-.5rem}.plot-editor-textarea{flex:1;background:transparent;border:none;color:inherit;font-family:inherit;font-size:.95rem;line-height:1.7;padding:1.5rem;resize:none;outline:none;min-height:55vh}.plot-editor-preview{padding:1.5rem;flex:1;overflow-y:auto;font-size:.95rem;line-height:1.7;color:#ffffffd9}.plot-editor-preview h1,.plot-editor-preview h2,.plot-editor-preview h3{color:#fffffff2;margin-top:1.5em;margin-bottom:.5em}.plot-editor-preview p{margin-bottom:.75em}.plot-editor-preview ul,.plot-editor-preview ol{padding-left:1.5em;margin-bottom:.75em}.plot-editor-preview li{margin-bottom:.3em}.plot-editor-preview strong{color:#fffffff2}.plot-editor-preview hr{border-color:#ffffff26;margin:1.5em 0}.plot-editor-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-top:1px solid rgba(255,255,255,.08);font-size:.8rem;color:#ffffff59;flex-shrink:0}.plot-editor-footer-actions{display:flex;gap:.5rem}.plot-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#ffffff4d;gap:.75rem}.plot-empty-state h3{font-size:1rem;font-weight:500}.plot-generator-modal{max-width:640px!important;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.plot-generator-section{display:flex;flex-direction:column;gap:.6rem}.plot-generator-section-label{font-size:.82rem;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em;display:flex;justify-content:space-between;align-items:center}.plot-page-tree{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem;max-height:180px;overflow-y:auto;width:100%;box-sizing:border-box}.plot-page-tree-node{display:flex;align-items:center;gap:.6rem;padding:.35rem .6rem;border-radius:4px;cursor:pointer;transition:background .1s;font-size:.88rem;min-width:0}.plot-page-tree-node:hover{background:#ffffff0f}.plot-page-tree-node input[type=checkbox]{cursor:pointer;accent-color:rgb(99,102,241);flex-shrink:0;width:15px;height:15px}.plot-page-tree-node-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffffd9}.plot-select-all-btn{background:none;border:none;color:#6366f1cc;font-size:.8rem;cursor:pointer;padding:0;flex-shrink:0}.plot-select-all-btn:hover{color:#6366f1;text-decoration:underline}.plot-radio-group{display:flex;flex-direction:column;gap:.5rem}.plot-radio-label{display:flex;align-items:flex-start;gap:.5rem;font-size:.9rem;cursor:pointer;line-height:1.4}.plot-radio-label input[type=radio]{cursor:pointer;accent-color:rgb(99,102,241);margin-top:2px;flex-shrink:0}.plot-radio-desc{font-size:.78rem;color:#ffffff59;display:block;margin-top:1px}.plot-generator-modal input[type=number],.plot-generator-modal input[type=text],.plot-generator-modal select{background:#ffffff12;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:inherit;font-size:.9rem;padding:.45rem .75rem;outline:none;transition:border-color .15s;font-family:inherit}.plot-generator-modal input[type=number]:focus,.plot-generator-modal input[type=text]:focus,.plot-generator-modal select:focus{border-color:#6366f199}.plot-generator-modal select{cursor:pointer;flex:1}.plot-wordcount-row{display:flex;align-items:center;gap:.6rem;margin-top:.4rem;padding-left:1.4rem}.plot-provider-row{display:flex;gap:.75rem;align-items:center}.plot-generate-log{background:#0006;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;min-height:80px;max-height:240px;overflow-y:auto;font-size:.88rem;font-family:inherit}.plot-log-line{display:flex;align-items:center;gap:.6rem;line-height:1.5}.plot-log-line.active{color:#fffc}.plot-log-line.done{color:#86eface6}.plot-log-line.error{color:#fca5a5f2}.plot-log-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.2);border-top-color:#fffc;border-radius:50%;animation:plot-spin .6s linear infinite;flex-shrink:0}@keyframes plot-spin{to{transform:rotate(360deg)}}
