*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0E0F13;--surface: #16181F;--surface2: #1E2029;--border: #2A2D38;--border2: #353848;--text: #E8EAF0;--text2: #9297A8;--text3: #5A5F72;--accent: #6C6FFF;--accent2: #8B8EFF;--accent-glow: rgba(108,111,255,.18);--score-good: #10B981;--score-warn: #F59E0B;--score-bad: #EF4444}[data-theme=light]{--bg: #F4F5F9;--surface: #FFFFFF;--surface2: #F0F1F6;--border: #DDE0EA;--border2: #C8CCDB;--text: #1A1C26;--text2: #4B5068;--text3: #8B90A8;--accent: #5558E8;--accent2: #6C6FFF;--accent-glow: rgba(85,88,232,.12)}:root{--po-color: #F59E0B;--po-bg: rgba(245,158,11,.1);--tl-color: #3B82F6;--tl-bg: rgba(59,130,246,.1);--sc-color: #EF4444;--sc-bg: rgba(239,68,68,.1);--cfo-color: #10B981;--cfo-bg: rgba(16,185,129,.1);--syn-color: #8B5CF6;--syn-bg: rgba(139,92,246,.1);--radius: 14px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-lg: 0 8px 48px rgba(0,0,0,.6)}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Plus Jakarta Sans,system-ui,sans-serif;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 40% at 20% 10%,rgba(108,111,255,.07) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 80% 80%,rgba(139,92,246,.05) 0%,transparent 60%),radial-gradient(ellipse 40% 30% at 60% 30%,rgba(59,130,246,.04) 0%,transparent 50%);pointer-events:none;z-index:0}.app{display:flex;min-height:100vh;position:relative;z-index:1}.sidebar{width:280px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow:hidden}.sidebar-logo{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.65rem}.logo-mark{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),#A78BFA);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.85rem;box-shadow:0 0 16px #6c6fff66;flex-shrink:0}.logo-text{font-weight:800;font-size:1.05rem;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text),var(--text2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-badge{font-size:.5rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent2);background:#6c6fff1f;padding:.15rem .4rem;border-radius:4px;margin-left:auto}.sidebar-section{padding:1rem 1rem .5rem;font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text3)}.sidebar-new{margin:.5rem .75rem}.btn-new{width:100%;display:flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,var(--accent),#7C6FFF);color:#fff;border:none;padding:.65rem 1rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 12px #6c6fff4d}.btn-new:hover{transform:translateY(-1px);box-shadow:0 4px 20px #6c6fff73}.btn-new svg{width:15px;height:15px}.history-list{flex:1;overflow-y:auto;padding:.25rem .75rem 1rem}.history-list::-webkit-scrollbar{width:3px}.history-list::-webkit-scrollbar-track{background:transparent}.history-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.history-empty{text-align:center;padding:2rem 1rem;color:var(--text3);font-size:.78rem;line-height:1.6}.history-item{display:flex;align-items:flex-start;gap:.5rem;padding:.6rem .75rem;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;margin-bottom:2px;position:relative}.history-item:hover{background:var(--surface2)}.history-item.active{background:var(--surface2);border:1px solid var(--border2)}.history-item-icon{width:26px;height:26px;border-radius:6px;background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.history-item-icon svg{width:12px;height:12px;color:var(--text3)}.history-item-text{flex:1;min-width:0}.history-item-title{font-size:.75rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.history-item-meta{font-size:.63rem;color:var(--text3);margin-top:.15rem}.history-item-del{opacity:0;background:none;border:none;cursor:pointer;color:var(--text3);padding:2px;border-radius:4px;transition:opacity .15s,color .15s;flex-shrink:0;display:flex;align-items:center}.history-item:hover .history-item-del{opacity:1}.history-item-del:hover{color:#ef4444}.history-item-del svg{width:12px;height:12px}.sidebar-config{padding:.75rem;border-top:1px solid var(--border)}.config-label{font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:.4rem;display:block}.config-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .75rem;font-family:inherit;font-size:.72rem;color:var(--text);outline:none;transition:border-color .2s}.config-input:focus{border-color:var(--accent)}.config-input::placeholder{color:var(--text3)}.main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;max-height:100vh}.main::-webkit-scrollbar{width:4px}.main::-webkit-scrollbar-track{background:transparent}.main::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.topbar{position:sticky;top:0;z-index:50;background:#0e0f13d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:.85rem 2rem;display:flex;align-items:center;gap:1rem}.topbar-title{font-size:.85rem;font-weight:600;color:var(--text2);flex:1}.status-pill{display:flex;align-items:center;gap:.4rem;font-size:.65rem;font-weight:600;letter-spacing:.05em;padding:.3rem .75rem;border-radius:20px;background:var(--surface);border:1px solid var(--border);color:var(--text2)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--text3)}.status-dot.running{background:#10b981;animation:statusPulse 1.2s ease infinite}.status-dot.done{background:#10b981}.status-dot.error{background:#ef4444}@keyframes statusPulse{0%,to{opacity:.5;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.content{flex:1;padding:2rem;max-width:900px;width:100%;margin:0 auto}.hero{text-align:center;padding:4rem 2rem 3rem;animation:fadeUp .5s ease both}.hero-icon{width:64px;height:64px;background:linear-gradient(135deg,#6c6fff26,#8b5cf61a);border:1px solid rgba(108,111,255,.2);border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.hero-icon svg{width:28px;height:28px;color:var(--accent2)}.hero h2{font-family:"Instrument Serif",Georgia,serif;font-size:clamp(1.8rem,4vw,2.4rem);font-weight:400;color:var(--text);line-height:1.15;margin-bottom:.75rem}.hero h2 em{font-style:italic;background:linear-gradient(135deg,var(--accent2),#C084FC);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero p{color:var(--text2);font-size:.92rem;line-height:1.7;max-width:480px;margin:0 auto 2.5rem}.input-area{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:border-color .2s,box-shadow .2s;animation:fadeUp .5s .1s ease both;position:relative;z-index:10}.input-area:focus-within{border-color:#6c6fff66;box-shadow:0 0 0 3px #6c6fff14,var(--shadow)}.board-toggle-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.45rem 1rem;border-top:1px solid var(--border)}.board-toggle-label{font-size:.65rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.board-toggle-pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.65rem;font-weight:600;padding:.25rem .65rem;border-radius:20px;border:1px solid var(--border);background:var(--surface2);color:var(--text3);cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.board-toggle-pill .btp-dot{width:6px;height:6px;border-radius:50%;background:var(--text3);opacity:.4;transition:all .15s}.board-toggle-pill.active{color:var(--text2);border-color:var(--border2);background:var(--surface)}.board-toggle-pill.active .btp-dot{opacity:1}.board-toggle-pill[data-role=po].active .btp-dot{background:#a78bfa}.board-toggle-pill[data-role=tl].active .btp-dot{background:#60a5fa}.board-toggle-pill[data-role=sc].active .btp-dot{background:#34d399}.board-toggle-pill[data-role=cfo].active .btp-dot{background:#fbbf24}.board-toggle-pill:disabled{opacity:.5;cursor:not-allowed}.board-toggle-pill:not(:disabled):hover{border-color:var(--border2);color:var(--text)}.input-label{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.25rem 0;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text3)}.input-label svg{width:12px;height:12px}textarea.story-input{width:100%;background:transparent;border:none;padding:.6rem 1.25rem .75rem;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;line-height:1.7;color:var(--text);resize:none;outline:none;min-height:110px}textarea.story-input::placeholder{color:var(--text3)}.input-toolbar{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-top:1px solid var(--border);background:#00000026}.char-pill{font-size:.65rem;color:var(--text3);background:var(--surface2);padding:.2rem .6rem;border-radius:20px;margin-right:auto}.btn-run{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--accent),#7C6FFF);color:#fff;border:none;padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 2px 12px #6c6fff4d;white-space:nowrap}.btn-run:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #6c6fff80}.btn-run:disabled{opacity:.4;cursor:default;transform:none}.btn-run svg{width:14px;height:14px}.btn-icon{background:var(--surface2);border:1px solid var(--border);color:var(--text2);padding:.55rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-icon:hover{background:var(--surface);border-color:var(--border2);color:var(--text)}.btn-icon svg{width:14px;height:14px}.progress-bar-wrap{margin:1.25rem 0;display:none;animation:fadeUp .3s ease both}.progress-bar-wrap.visible{display:block}.progress-steps{display:flex;align-items:center;gap:.4rem;margin-bottom:.75rem}.step{display:flex;align-items:center;gap:.35rem;font-size:.65rem;font-weight:600;color:var(--text3);padding:.3rem .65rem;border-radius:20px;background:var(--surface);border:1px solid var(--border);transition:all .3s;white-space:nowrap}.step.active{color:var(--accent2);background:#6c6fff1a;border-color:#6c6fff4d}.step.done{color:#10b981;background:#10b98114;border-color:#10b98133}.step svg{width:10px;height:10px}.step-arrow{color:var(--text3);font-size:.6rem}.progress-track{height:3px;background:var(--surface2);border-radius:2px;overflow:hidden}.progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent),#A78BFA);width:0%;transition:width .6s ease}.roles-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.25rem 0}@media(max-width:640px){.roles-grid{grid-template-columns:1fr}}.role-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease,border-color .3s,box-shadow .3s;box-shadow:var(--shadow)}.role-card.visible{opacity:1;transform:translateY(0)}.role-card.skipped{opacity:.45;filter:grayscale(.6)}.role-card.active{box-shadow:0 0 0 1px var(--accent),0 0 24px #6c6fff1f}.role-card[data-role=po].active{box-shadow:0 0 0 1px var(--po-color),0 0 20px #f59e0b1a}.role-card[data-role=tl].active{box-shadow:0 0 0 1px var(--tl-color),0 0 20px #3b82f61a}.role-card[data-role=sc].active{box-shadow:0 0 0 1px var(--sc-color),0 0 20px #ef44441a}.role-card[data-role=cfo].active{box-shadow:0 0 0 1px var(--cfo-color),0 0 20px #10b9811a}.role-card[data-role=po].done{border-top:2px solid var(--po-color)}.role-card[data-role=tl].done{border-top:2px solid var(--tl-color)}.role-card[data-role=sc].done{border-top:2px solid var(--sc-color)}.role-card[data-role=cfo].done{border-top:2px solid var(--cfo-color)}.role-head{display:flex;align-items:center;gap:.75rem;padding:1rem 1.1rem .75rem;border-bottom:1px solid var(--border)}.persona-avatar{width:52px;height:52px;border-radius:14px;overflow:hidden;flex-shrink:0;position:relative;box-shadow:0 2px 8px #0006}.persona-avatar svg{width:52px;height:52px;display:block}.role-info{flex:1;min-width:0}.role-name{font-size:.8rem;font-weight:700;color:var(--text);line-height:1.2}.role-desc{font-size:.65rem;color:var(--text3);margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-status{display:flex;align-items:center;gap:.3rem;font-size:.6rem;font-weight:700;letter-spacing:.06em;padding:.25rem .6rem;border-radius:20px;white-space:nowrap}.rs-idle{color:var(--text3);background:var(--surface2)}.rs-think{color:var(--accent2);background:#6c6fff1a;animation:badgePulse 1.5s ease infinite}.rs-done{color:#10b981;background:#10b9811a}.rs-skip{background:var(--surface2);color:var(--text3)}@keyframes badgePulse{0%,to{opacity:.6}50%{opacity:1}}.role-card.collapsed .role-body{display:none}.btn-collapse{background:none;border:none;cursor:pointer;color:var(--text3);padding:.2rem;display:flex;align-items:center;transition:color .2s;flex-shrink:0}.btn-collapse:hover{color:var(--text2)}.btn-collapse svg{transition:transform .25s ease}.role-card.collapsed .btn-collapse svg{transform:rotate(-90deg)}.btn-copy-card{background:none;border:none;cursor:pointer;color:var(--text3);padding:.2rem .4rem;display:flex;align-items:center;gap:.3rem;font-size:.6rem;font-weight:600;letter-spacing:.04em;border-radius:var(--radius-sm);transition:color .2s,background .2s;flex-shrink:0}.btn-copy-card:hover{color:var(--text);background:var(--surface2)}.btn-copy-card.copied{color:#10b981}.btn-copy-card svg{width:11px;height:11px}.char-pill.warn{color:#f59e0b}.char-pill.danger{color:#ef4444}.elapsed-pill{font-size:.6rem;font-weight:600;color:var(--text3);letter-spacing:.04em;padding:.2rem .5rem;background:var(--surface2);border-radius:20px;display:none;font-variant-numeric:tabular-nums}.elapsed-pill.visible{display:inline-flex;align-items:center;gap:.3rem}.btn-export{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .8rem;font-size:.65rem;font-weight:600;background:var(--surface2);color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.btn-export:hover{background:var(--border);color:var(--text)}.btn-export svg{width:13px;height:13px}.btn-retry{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .9rem;font-size:.65rem;font-weight:700;background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.btn-retry:hover{background:#ef444433}.btn-retry svg{width:13px;height:13px}.btn-clear-history{width:100%;margin-top:.5rem;background:none;border:1px solid var(--border);color:var(--text3);font-size:.6rem;font-weight:600;padding:.35rem;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.04em;transition:all .15s;display:none}.btn-clear-history.visible{display:block}.btn-clear-history:hover{border-color:#ef4444;color:#ef4444}.url-invalid{border-color:#ef4444!important}.context-badge{display:none;align-items:center;gap:.35rem;font-size:.6rem;font-weight:600;padding:.2rem .6rem;border-radius:20px;background:var(--surface2);border:1px solid var(--border2);color:var(--text2);white-space:nowrap;overflow:hidden;max-width:220px;text-overflow:ellipsis}.context-badge.visible{display:inline-flex}.context-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0}.sidebar-section-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-section-toggle svg{transition:transform .2s ease;color:var(--text3)}.sidebar-section-toggle.collapsed svg{transform:rotate(-90deg)}.sidebar-collapsible{overflow:hidden;transition:max-height .25s ease}.config-textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.72rem;font-family:inherit;padding:.5rem .65rem;outline:none;resize:vertical;min-height:52px;transition:border-color .15s;margin-bottom:.5rem}.config-textarea:focus{border-color:var(--accent)}.config-textarea::placeholder{color:var(--text3)}.config-row{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:.5rem}.quality-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.6rem;font-weight:700;letter-spacing:.06em;padding:.2rem .55rem;border-radius:20px;transition:all .3s}.quality-good{color:var(--score-good);background:#10b9811a;border:1px solid rgba(16,185,129,.2)}.quality-warn{color:var(--score-warn);background:#f59e0b1a;border:1px solid rgba(245,158,11,.2)}.quality-bad{color:var(--score-bad);background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.quality-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.template-wrap{position:relative;display:inline-flex}.btn-template{background:var(--surface2);border:1px solid var(--border2);color:var(--text2);font-size:.65rem;font-weight:600;padding:.3rem .65rem;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;transition:all .15s}.btn-template:hover{background:var(--border);color:var(--text)}.template-menu{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:220px;z-index:1000;overflow:hidden;display:none}.template-menu.open{display:block}.template-item{padding:.6rem .9rem;font-size:.72rem;cursor:pointer;color:var(--text2);border-bottom:1px solid var(--border);transition:background .1s,color .1s}.template-item:last-child{border-bottom:none}.template-item:hover{background:var(--surface2);color:var(--text)}.template-item strong{display:block;color:var(--text);font-size:.7rem;margin-bottom:.1rem}.diff-toggle{display:inline-flex;align-items:center;gap:.35rem;font-size:.6rem;font-weight:600;color:var(--text3);background:none;border:1px solid var(--border);padding:.2rem .55rem;border-radius:20px;cursor:pointer;transition:all .15s}.diff-toggle:hover,.diff-toggle.active{color:var(--accent2);border-color:var(--accent)}.diff-view{display:none;gap:0}.diff-view.visible{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.diff-col h4{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:.6rem}.diff-original{color:var(--text2)}ins{background:#10b9811f;color:var(--score-good);text-decoration:none;border-radius:2px}del{background:#ef44441a;color:var(--score-bad);text-decoration:line-through;border-radius:2px}.btn-rerun{background:none;border:none;cursor:pointer;color:var(--text3);padding:.2rem;display:flex;align-items:center;flex-shrink:0;transition:color .15s}.btn-rerun:hover{color:var(--accent2)}.btn-rerun svg{width:12px;height:12px}.btn-rerun.spinning svg{animation:spin .8s linear infinite}.btn-copy-refined{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .8rem;font-size:.65rem;font-weight:600;background:var(--surface2);color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.btn-copy-refined:hover{background:var(--border);color:var(--text)}.btn-copy-refined.copied{color:var(--score-good)}.btn-copy-refined svg{width:13px;height:13px}.session-notes{margin-top:.75rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.notes-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;cursor:pointer;font-size:.65rem;font-weight:600;color:var(--text3);letter-spacing:.06em;text-transform:uppercase}.notes-header:hover{color:var(--text2)}.notes-area{width:100%;padding:.6rem .75rem;background:transparent;border:none;border-top:1px solid var(--border);color:var(--text2);font-size:.78rem;font-family:inherit;resize:vertical;min-height:60px;outline:none;display:none}.notes-area.open{display:block}.notes-area::placeholder{color:var(--text3)}.btn-theme{background:none;border:1px solid var(--border);color:var(--text3);border-radius:var(--radius-sm);padding:.25rem .5rem;cursor:pointer;font-size:.65rem;display:flex;align-items:center;gap:.3rem;transition:all .15s}.btn-theme:hover{color:var(--text);border-color:var(--border2)}.btn-test-url{width:100%;margin-top:.4rem;background:none;border:1px solid var(--border);color:var(--text3);font-size:.6rem;font-weight:600;padding:.3rem;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:all .15s}.btn-test-url:hover{border-color:var(--accent);color:var(--accent2)}.btn-test-url.ok{border-color:var(--score-good);color:var(--score-good)}.btn-test-url.fail{border-color:var(--score-bad);color:var(--score-bad)}.test-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.kbd{display:inline-flex;align-items:center;background:var(--surface2);border:1px solid var(--border2);border-radius:4px;padding:.05rem .3rem;font-size:.55rem;color:var(--text3);font-family:monospace;margin-left:.3rem}.history-item-title{cursor:text}.history-item-title.editing{display:none}.history-title-input{background:var(--surface2);border:1px solid var(--accent);color:var(--text);font-size:.72rem;font-weight:600;border-radius:4px;padding:.1rem .3rem;width:100%;outline:none;font-family:inherit}.history-item-rename{background:none;border:none;cursor:pointer;color:var(--text3);padding:.15rem;display:flex;align-items:center;flex-shrink:0;opacity:0;transition:opacity .15s}.history-item:hover .history-item-rename{opacity:1}.history-item-rename:hover{color:var(--accent2)}.history-item-rename svg{width:11px;height:11px}.role-body{padding:.9rem 1.1rem;font-size:.82rem;line-height:1.7;color:var(--text2);min-height:80px}.body-placeholder{color:var(--text3);font-size:.8rem;display:flex;align-items:center;justify-content:center;height:60px}.thinking-row{display:flex;align-items:center;gap:.5rem;color:var(--text3);font-size:.78rem;padding:.5rem 0}.dots{display:flex;gap:3px}.dots span{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:dot 1.3s ease-in-out infinite}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes dot{0%,80%,to{transform:scale(.5);opacity:.3}40%{transform:scale(1);opacity:1}}.role-body h2,.role-body h3,.synthesis-body h2,.synthesis-body h3{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin:1rem 0 .4rem}.role-body h2,.synthesis-body h2{color:var(--text2)}.role-body h3,.synthesis-body h3{color:var(--text3)}.role-body p,.synthesis-body p{margin-bottom:.4rem}.role-body ul,.synthesis-body ul{padding-left:1.2rem;margin-bottom:.5rem}.role-body li,.synthesis-body li{margin-bottom:.2rem}.role-body strong,.synthesis-body strong{color:var(--text);font-weight:600}.synthesis-card{background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--syn-color);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease;margin:.25rem 0 2rem}.synthesis-card.visible{opacity:1;transform:translateY(0)}.syn-head{display:flex;align-items:center;gap:.85rem;padding:1.1rem 1.4rem;border-bottom:1px solid var(--border);background:#8b5cf60a}.syn-icon{width:40px;height:40px;background:linear-gradient(135deg,#8b5cf633,#a855f71a);border:1px solid rgba(139,92,246,.2);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.syn-icon svg{width:18px;height:18px;color:#a78bfa}.syn-title{font-size:.9rem;font-weight:700;color:var(--text)}.syn-sub{font-size:.68rem;color:var(--text3);margin-top:.1rem}.syn-actions{display:flex;gap:.5rem;margin-left:auto}.btn-copy,.btn-dl{display:flex;align-items:center;gap:.35rem;font-family:inherit;font-size:.68rem;font-weight:600;padding:.4rem .85rem;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.btn-copy{background:var(--surface2);border:1px solid var(--border);color:var(--text2)}.btn-copy:hover{border-color:var(--border2);color:var(--text)}.btn-copy.copied{color:#10b981;border-color:#10b9814d}.btn-copy svg,.btn-dl svg{width:12px;height:12px}.synthesis-body{padding:1.25rem 1.4rem;font-size:.88rem;line-height:1.75;color:var(--text2)}.error-bar{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);padding:.75rem 1rem;display:none;align-items:center;gap:.6rem;font-size:.8rem;color:#fca5a5;margin-bottom:1rem}.error-bar.visible{display:flex}.error-bar svg{width:14px;height:14px;flex-shrink:0}.history-detail{animation:fadeUp .35s ease both}.history-detail-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.history-back{display:flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:600;color:var(--text3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.45rem .85rem;cursor:pointer;transition:all .15s;white-space:nowrap}.history-back:hover{color:var(--text);border-color:var(--border2)}.history-back svg{width:12px;height:12px}.history-detail-title{font-family:"Instrument Serif",Georgia,serif;font-size:1.25rem;font-weight:400;color:var(--text);line-height:1.35}.history-detail-meta{font-size:.68rem;color:var(--text3);margin-top:.3rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.sidebar{display:none}.content{padding:1rem}.topbar{padding:.75rem 1rem}}.story-draft-badge{display:inline-flex;align-items:center;font-size:.52rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#f59e0b;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);padding:.1rem .3rem;border-radius:3px;margin-left:.3rem}.btn-save-draft{display:flex;align-items:center;gap:.4rem;background:var(--surface2);border:1px solid var(--border2);color:var(--text2);padding:.45rem .75rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-save-draft:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-save-draft:disabled{opacity:.35;cursor:default}.btn-save-draft svg{width:13px;height:13px}.history-item-dup,.history-item-edit{opacity:0;background:none;border:none;cursor:pointer;color:var(--text3);padding:2px;border-radius:4px;transition:opacity .15s,color .15s;flex-shrink:0;display:flex;align-items:center}.history-item:hover .history-item-dup,.history-item:hover .history-item-edit{opacity:1}.history-item-dup:hover,.history-item-edit:hover{color:var(--accent2)}.history-item-dup svg,.history-item-edit svg{width:12px;height:12px}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);width:min(560px,92vw);box-shadow:var(--shadow-lg);overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-head h3{font-size:.9rem;font-weight:700;letter-spacing:-.01em}.modal-close{background:none;border:none;cursor:pointer;color:var(--text3);display:flex;align-items:center;padding:3px;border-radius:4px;transition:color .15s}.modal-close:hover{color:var(--text)}.modal-close svg{width:16px;height:16px}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.85rem}.modal-field label{display:block;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:.35rem}.modal-field input,.modal-field textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .75rem;font-family:inherit;font-size:.82rem;color:var(--text);outline:none;transition:border-color .15s;resize:vertical}.modal-field textarea{min-height:130px}.modal-field input:focus,.modal-field textarea:focus{border-color:#6c6fff80;box-shadow:0 0 0 2px #6c6fff14}.modal-foot{display:flex;align-items:center;gap:.5rem;justify-content:flex-end;padding:.85rem 1.25rem;border-top:1px solid var(--border)}.btn-modal-cancel{background:none;border:1px solid var(--border2);color:var(--text2);padding:.45rem 1rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-modal-cancel:hover{border-color:var(--text2);color:var(--text)}.btn-modal-save{background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:.45rem 1rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-modal-save:hover{border-color:var(--accent);color:var(--accent)}.btn-modal-rerun{background:linear-gradient(135deg,var(--accent),#7C6FFF);border:none;color:#fff;padding:.45rem 1.1rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 2px 10px #6c6fff4d;display:flex;align-items:center;gap:.35rem}.btn-modal-rerun:hover{transform:translateY(-1px);box-shadow:0 4px 16px #6c6fff73}.btn-modal-rerun svg{width:12px;height:12px}.sidebar-product-pill{margin:0 .75rem .25rem;padding:.55rem .75rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;gap:.5rem;min-height:36px}.sidebar-product-name{flex:1;min-width:0;font-size:.72rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-product-none{flex:1;font-size:.72rem;color:var(--text3);font-style:italic}.sidebar-product-change{background:none;border:1px solid var(--border2);border-radius:4px;padding:.15rem .45rem;font-family:inherit;font-size:.62rem;font-weight:600;color:var(--text2);cursor:pointer;transition:all .15s;flex-shrink:0}.sidebar-product-change:hover{border-color:var(--accent);color:var(--accent)}.product-select-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;min-height:100vh}.product-select-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:580px;width:100%;padding:2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1.25rem}.product-select-header{display:flex;align-items:flex-start;gap:1rem}.product-select-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.product-select-title{font-size:1.15rem;font-weight:700;color:var(--text);margin-bottom:.2rem}.product-select-subtitle{font-size:.78rem;color:var(--text2)}.product-select-row{display:flex;align-items:center;gap:.5rem}.product-dropdown{flex:1;min-width:0;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .75rem;font-family:inherit;font-size:.82rem;color:var(--text);outline:none;cursor:pointer;transition:border-color .15s}.product-dropdown:focus{border-color:var(--accent)}.btn-ps-icon{display:flex;align-items:center;gap:.35rem;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:.5rem .7rem;font-family:inherit;font-size:.72rem;font-weight:600;color:var(--text2);cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.btn-ps-icon:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-ps-icon:disabled{opacity:.35;cursor:not-allowed}.btn-ps-icon-danger:hover:not(:disabled){border-color:#ef4444;color:#ef4444}.product-empty-state{text-align:center;padding:1.5rem;border:1px dashed var(--border2);border-radius:var(--radius-sm);color:var(--text3)}.product-empty-icon{font-size:1.5rem;margin-bottom:.5rem}.product-empty-state p{font-size:.82rem;font-weight:500;color:var(--text2)}.product-empty-sub{font-size:.72rem;color:var(--text3)!important;font-weight:400!important;margin-top:.25rem}.product-preview{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.85rem 1rem;display:flex;flex-direction:column;gap:.5rem}.product-preview-row{display:flex;align-items:baseline;gap:.6rem;font-size:.82rem;flex-wrap:wrap}.product-preview-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);white-space:nowrap;flex-shrink:0}.product-preview-value{color:var(--text);flex:1}.product-preview-desc{font-size:.78rem;color:var(--text2);white-space:pre-wrap;word-break:break-word}.product-preview-none{color:var(--text3);font-style:italic}.btn-ps-add{display:flex;align-items:center;gap:.5rem;background:none;border:1px dashed var(--border2);border-radius:var(--radius-sm);padding:.6rem 1rem;font-family:inherit;font-size:.78rem;font-weight:500;color:var(--text2);cursor:pointer;transition:all .15s;width:100%;justify-content:center}.btn-ps-add:hover{border-color:var(--accent);color:var(--accent);border-style:solid}.product-select-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:.25rem;border-top:1px solid var(--border)}.btn-ps-skip{background:none;border:none;font-family:inherit;font-size:.78rem;font-weight:500;color:var(--text3);cursor:pointer;transition:color .15s;padding:.45rem 0}.btn-ps-skip:hover{color:var(--text2)}.btn-ps-continue{background:linear-gradient(135deg,var(--accent),#7C6FFF);border:none;color:#fff;padding:.6rem 1.35rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 12px #6c6fff4d}.btn-ps-continue:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #6c6fff73}.btn-ps-continue:disabled{opacity:.4;cursor:not-allowed}.product-form{display:flex;flex-direction:column;gap:1rem}.product-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.product-form-full{grid-column:1/-1}.product-form-field label{display:block;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:.35rem}.product-form-req{color:#ef4444}.product-form-field input,.product-form-field textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .75rem;font-family:inherit;font-size:.82rem;color:var(--text);outline:none;transition:border-color .15s;resize:vertical}.product-form-field textarea{min-height:80px}.product-form-field input:focus,.product-form-field textarea:focus{border-color:#6c6fff80;box-shadow:0 0 0 2px #6c6fff14}.product-form-field input::placeholder,.product-form-field textarea::placeholder{color:var(--text3)}.product-form-actions{display:flex;align-items:center;gap:.5rem;justify-content:flex-end}.btn-ps-secondary{background:none;border:1px solid var(--border2);color:var(--text2);padding:.45rem 1rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-ps-secondary:hover{border-color:var(--text2);color:var(--text)}.btn-ps-primary{background:linear-gradient(135deg,var(--accent),#7C6FFF);border:none;color:#fff;padding:.45rem 1.1rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 2px 10px #6c6fff4d}.btn-ps-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #6c6fff73}.btn-ps-primary:disabled{opacity:.4;cursor:not-allowed}.auth-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.auth-loading-spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--border2);border-top-color:var(--accent);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.user-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.22rem .6rem .22rem .5rem;background:var(--surface2);border:1px solid var(--border);border-radius:20px;text-decoration:none;color:var(--text2);font-size:.68rem;transition:border-color .15s}.user-pill:hover{border-color:var(--border2)}.user-email{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout{color:var(--text3);font-size:.62rem;font-weight:600;padding-left:.35rem;border-left:1px solid var(--border2);margin-left:.1rem}.user-pill:hover .btn-logout{color:var(--text2)}.story-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden}.story-table-header{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1rem;border-bottom:1px solid var(--border);gap:.75rem}.story-table-label{font-size:.68rem;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.45rem;white-space:nowrap}.story-table-count{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:.05rem .45rem;font-size:.62rem;color:var(--text3);font-weight:600}.story-table-search{font-size:.72rem;padding:.22rem .6rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;width:160px;transition:border-color .15s;font-family:inherit}.story-table-search:focus{border-color:var(--border2)}.story-table-search::placeholder{color:var(--text3)}.story-table-new{font-size:.72rem;font-weight:600;padding:.22rem .7rem;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.story-table-new:hover{background:var(--surface);color:var(--text);border-color:var(--accent)}.story-table-body{max-height:200px;overflow-y:auto}.story-table{width:100%;border-collapse:collapse;font-size:.75rem}.story-table thead th{padding:.35rem 1rem;text-align:left;color:var(--text3);font-weight:600;font-size:.63rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap}.story-row{cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.story-row:last-child{border-bottom:none}.story-row:hover{background:var(--surface2)}.story-row.active{background:var(--accent-glow)}.story-row td{padding:.45rem 1rem;vertical-align:middle}.story-row-text{color:var(--text);max-width:380px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.story-status-badge{font-size:.62rem;font-weight:600;padding:.12rem .45rem;border-radius:10px;white-space:nowrap}.story-status-badge.draft{background:#f59e0b1f;color:var(--score-warn)}.story-status-badge.reviewed{background:#10b9811f;color:var(--score-good)}.story-status-badge.closed{background:#94a3b826;color:var(--text3)}.story-table-closed-toggle{font-size:.72rem;font-weight:600;padding:.22rem .7rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);color:var(--text3);cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.story-table-closed-toggle:hover,.story-table-closed-toggle.active{border-color:var(--border2);color:var(--text2)}.story-row-date{color:var(--text3);white-space:nowrap;font-size:.7rem}.story-table-empty{padding:1rem;text-align:center;color:var(--text3);font-size:.75rem}:root{--custom-role-avatar-bg:#6366f1;--custom-role-color:#a5b4fc}.role-card[data-role=custom].active{box-shadow:0 0 0 1px var(--custom-role-color),0 0 20px #6366f11f}.role-card[data-role=custom].done{border-top:2px solid var(--custom-role-color)}.board-toggle-pill[data-role=custom].active .btp-dot{background:var(--custom-role-color)}.sidebar-board-section{margin-bottom:.25rem}.sidebar-section-toggle{width:100%;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:.35rem .75rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);transition:color .15s}.sidebar-section-toggle:hover{color:var(--text2)}.board-members-list{padding:0 .5rem .5rem}.board-member-item{display:flex;align-items:center;gap:.5rem;padding:.3rem .4rem;border-radius:5px;font-size:.72rem}.board-member-item:hover .board-member-actions{opacity:1}.board-member-locked{color:var(--text3)}.board-member-custom{color:var(--text2)}.board-member-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.board-member-lock{color:var(--text3);opacity:.5;flex-shrink:0;display:flex;align-items:center}.board-member-actions{display:flex;gap:.2rem;opacity:0;transition:opacity .15s;flex-shrink:0}.board-member-btn{background:none;border:none;cursor:pointer;padding:.15rem;border-radius:3px;color:var(--text3);display:flex;align-items:center;transition:color .15s}.board-member-btn:hover{color:var(--text)}.board-member-btn-del:hover{color:#f87171}.board-member-add-btn{display:flex;align-items:center;gap:.35rem;width:100%;background:none;border:1px dashed var(--border2);border-radius:5px;padding:.3rem .5rem;margin-top:.2rem;font-family:inherit;font-size:.7rem;color:var(--text3);cursor:pointer;transition:all .15s}.board-member-add-btn:hover{color:var(--accent);border-color:var(--accent)}.modal-optional{font-weight:400;color:var(--text3);font-size:.75em;margin-left:.3em}.modal-error{font-size:.75rem;color:#f87171;padding:.4rem 0}
