@import"https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Nunito+Sans:ital,opsz,wght@0,6..12,300;0,6..12,400;0,6..12,500;0,6..12,600;0,6..12,700;1,6..12,300;1,6..12,400&display=swap";.auth-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 50% 40% at 50% 30%,rgba(212,162,106,.08),transparent 55%),radial-gradient(ellipse 40% 35% at 75% 80%,rgba(212,162,106,.04),transparent 50%),var(--color-bg-primary);color:var(--color-text-primary);padding:24px;font-family:var(--font-body)}body.auth-scroll,body.auth-scroll #root{overflow:auto}.auth-gate-card{max-width:420px;width:100%;max-height:calc(100vh - 48px);background:var(--v5-card-bg);border:1px solid var(--color-surface-border);border-radius:14px;padding:36px;text-align:center;box-shadow:var(--shadow-xl);overflow:auto;backdrop-filter:blur(8px)}.auth-gate-logo{font-size:36px;margin-bottom:18px}.auth-gate-card h1{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:12px}.auth-gate-card p{font-size:.88rem;line-height:1.7;color:var(--color-text-secondary);margin-bottom:24px;font-weight:300}.auth-gate-button{width:100%;justify-content:center}.auth-divider{display:flex;align-items:center;justify-content:center;margin:20px 0;color:var(--color-text-tertiary);font-size:.68rem;text-transform:uppercase;letter-spacing:.18em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-surface-border)}.auth-divider span{padding:0 14px}.auth-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px}.auth-toggle .btn.active{background:var(--v5-amber-soft);border-color:#d4a26a59;color:var(--color-text-primary)}.auth-form{display:grid;gap:14px;text-align:left}.auth-form label{display:grid;gap:6px;font-size:.72rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em}.auth-form input{border-radius:10px;padding:12px 14px;border:1px solid var(--color-surface-border);background:#d4a26a05;color:var(--color-text-primary);font-family:var(--font-body);font-size:.92rem;transition:all .2s}.auth-form input:focus{outline:none;border-color:#d4a26a66;box-shadow:0 0 0 3px #d4a26a14}.auth-error{color:var(--color-error);font-size:.78rem}.auth-hint{color:var(--color-text-tertiary);font-size:.75rem;margin-top:-6px}.onboarding{min-height:100vh;max-height:100vh;display:flex;align-items:flex-start;justify-content:center;position:relative;overflow-y:auto;padding:var(--space-8) 0}.onboarding-background{position:absolute;inset:0;z-index:0}.bg-gradient-1{position:absolute;top:-50%;left:-25%;width:80%;height:80%;background:radial-gradient(ellipse,rgba(244,162,97,.08) 0%,transparent 60%);animation:float 20s ease-in-out infinite}.bg-gradient-2{position:absolute;bottom:-30%;right:-20%;width:60%;height:60%;background:radial-gradient(ellipse,rgba(233,196,106,.06) 0%,transparent 60%);animation:float 25s ease-in-out infinite reverse}.bg-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(5deg)}66%{transform:translate(-20px,20px) rotate(-3deg)}}.onboarding-container{position:relative;z-index:1;width:100%;max-width:640px;padding:var(--space-6)}.onboarding-header{text-align:center;margin-bottom:var(--space-8);animation:fadeInDown .6s ease-out}.onboarding-title{display:flex;align-items:center;justify-content:center;gap:var(--space-3);font-size:var(--text-3xl);font-weight:600;margin-bottom:var(--space-2)}.title-icon{font-size:1.2em}.onboarding-subtitle{color:var(--color-text-tertiary);font-size:var(--text-base)}.onboarding-card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-xl);animation:fadeInUp .6s ease-out}.progress-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-8)}.progress-header .progress-bar{flex:1}.progress-text{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-tertiary);white-space:nowrap}.step-content{min-height:340px;animation:fadeIn .3s ease-out}.step-title{font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-2)}.step-subtitle{color:var(--color-text-tertiary);margin-bottom:var(--space-6)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-family:var(--font-display);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.step-navigation{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-surface-border)}.mentor-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.mentor-card{padding:var(--space-4);background:var(--color-bg-secondary);border:2px solid var(--color-surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:left}.mentor-card:hover{background:var(--color-bg-hover);border-color:var(--color-text-tertiary)}.mentor-card.selected{border-color:var(--color-accent);background:var(--color-accent-subtle)}.mentor-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.mentor-emoji{font-size:1.5rem}.mentor-name{font-family:var(--font-display);font-size:var(--text-base);font-weight:500;color:var(--color-text-primary)}.mentor-suggested{margin-left:auto;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);background:var(--color-bg-active);padding:2px 6px;border-radius:var(--radius-full)}.mentor-description{font-size:var(--text-sm);color:var(--color-text-tertiary);line-height:var(--leading-relaxed)}.summary-card{background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-top:var(--space-6)}.summary-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:500;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.summary-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--color-surface-border)}.summary-row:last-child{border-bottom:none}.summary-label{color:var(--color-text-tertiary);font-size:var(--text-sm)}.summary-value{color:var(--color-text-primary);font-size:var(--text-sm);font-weight:500}.project-hub{min-height:100vh;padding:0 0 80px;background:radial-gradient(ellipse 60% 45% at 20% 0%,rgba(212,162,106,.06),transparent 50%),radial-gradient(ellipse 40% 40% at 85% 85%,rgba(212,162,106,.03),transparent 50%),var(--color-bg-primary);color:var(--color-text-primary);overflow-y:auto;font-family:var(--font-body)}.hub-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 48px;border-bottom:1px solid var(--color-surface-border)}.hub-logo{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--color-text-primary);letter-spacing:.02em}.hub-topbar-actions{display:flex;align-items:center;gap:10px}.hub-credit-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 16px;border-radius:100px;border:1px solid var(--color-surface-border);background:#d4a26a0a;color:var(--color-accent);font-family:var(--font-display);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s}.hub-credit-pill:hover{border-color:#d4a26a4d;background:#d4a26a14}.hub-dashboard{padding:48px 48px 32px;display:flex;flex-direction:column;gap:28px}.hub-greeting{min-width:0}.hub-greeting h1{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);font-weight:700;line-height:1.18;margin:0 0 12px}.hub-greeting p{color:var(--color-text-secondary);font-size:.95rem;font-weight:300;max-width:460px;line-height:1.6}.hub-widgets{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:18px;width:100%}.hub-widget-card{display:flex;flex-direction:column;align-items:center;gap:14px;padding:24px 28px;border:1px solid var(--color-surface-border);border-radius:16px;background:var(--v5-card-bg);min-width:0;transition:all .3s}.hub-widget-card-metric{justify-content:center}.hub-widget-card-heatmap{align-items:stretch;justify-content:flex-start}.hub-widget-card-heatmap .hub-widget-label{align-self:flex-start}.hub-widget-card:hover{border-color:#d4a26a33;box-shadow:0 12px 36px #0000002e}.hub-widget-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.16em;color:var(--color-accent);font-weight:600}.goal-ring{display:block}.goal-ring-fill{transition:stroke-dashoffset .8s cubic-bezier(.34,1.56,.64,1)}.goal-ring-count{font-family:var(--font-display);font-size:26px;font-weight:700;fill:var(--color-text-primary)}.goal-ring-label{font-family:var(--font-body);font-size:10px;fill:var(--color-text-secondary)}.streak-widget{display:flex;flex-direction:column;align-items:center;gap:10px}.streak-flame-row{display:flex;align-items:center;gap:8px}.streak-flame{font-size:26px;animation:flicker 2s ease-in-out infinite}@keyframes flicker{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.08) rotate(-3deg)}75%{transform:scale(1.04) rotate(2deg)}}.streak-count{font-family:var(--font-display);font-size:2.2rem;font-weight:700;color:var(--color-text-primary)}.streak-label{font-size:.78rem;color:var(--color-text-secondary);font-weight:300}.streak-subtext{font-size:.72rem;color:var(--color-text-muted);letter-spacing:.04em}.heatmap-widget{width:100%;overflow-x:auto;padding-bottom:2px}.streak-heatmap-wrapper{display:flex;flex-direction:column;gap:8px;width:100%}.heatmap-widget .streak-heatmap-wrapper{width:max-content;min-width:100%}.streak-heatmap-months{display:grid;column-gap:3px;justify-content:center;min-height:14px}.streak-month-label{font-size:.52rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.streak-heatmap-grid{display:grid;grid-template-rows:repeat(7,10px);grid-auto-flow:column;gap:3px;justify-content:center}.streak-cell{width:10px;height:10px;border-radius:2px;background:#d4a26a1a;border:1px solid rgba(212,162,106,.18)}.streak-cell.empty{opacity:0}.streak-cell.level-0{background:#d4a26a14}.streak-cell.level-1{background:#d4a26a40}.streak-cell.level-2{background:#d4a26a73}.streak-cell.level-3{background:#d4a26ab8}.streak-cell.level-4{background:var(--color-accent)}.streak-heatmap-legend{display:flex;align-items:center;justify-content:center;gap:4px;font-size:.58rem;color:var(--color-text-muted)}.hub-alert{margin:0 48px 16px;border-radius:12px;padding:12px 16px;font-size:.85rem}.hub-alert-error{border:1px solid rgba(248,113,113,.35);background:#f871710f;color:#fecaca}.hub-alert-success{border:1px solid rgba(74,222,128,.3);background:#4ade800f;color:#bbf7d0}.hub-projects-section{padding:0 48px}.hub-projects-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.hub-projects-header h2{font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin:0}.hub-projects-actions{display:flex;gap:10px}.hub-empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:56px 24px}.hub-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.hub-empty-state h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin:0 0 10px}.hub-empty-state p{color:var(--color-text-secondary);font-size:.92rem;margin:0 0 24px;max-width:380px}.hub-empty-actions{display:flex;gap:10px}.hub-project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.hub-project-card{display:flex;border:1px solid var(--color-surface-border);border-radius:14px;background:var(--v5-card-bg);overflow:hidden;cursor:pointer;transition:all .3s;min-height:180px}.hub-project-card:hover{transform:translateY(-3px);border-color:#d4a26a38;box-shadow:0 14px 42px #00000038}.hub-card-accent{width:4px;flex-shrink:0}.hub-card-body{flex:1;padding:26px;display:flex;flex-direction:column;gap:12px;min-width:0}.hub-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.hub-card-top-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.hub-card-pinned{font-size:.8rem}.hub-card-title{font-family:var(--font-display);font-weight:700;font-size:1.1rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.hub-card-status{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);padding:3px 10px;background:var(--v5-amber-soft);border-radius:100px;flex-shrink:0;white-space:nowrap}.hub-card-synopsis{color:var(--color-text-secondary);font-size:.84rem;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin:0}.hub-card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}.hub-card-meta{display:flex;flex-wrap:wrap;gap:6px}.hub-card-meta span{font-size:.68rem;padding:2px 8px;border:1px solid var(--color-surface-border);border-radius:100px;color:var(--color-text-tertiary)}.hub-card-arrow{font-size:1rem;color:var(--color-text-muted);transition:transform .2s,color .2s}.hub-project-card:hover .hub-card-arrow{transform:translate(3px);color:var(--color-accent)}.hub-card-menu-wrapper{position:relative}.hub-card-dots{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:var(--color-text-muted, #6b6760);cursor:pointer;border-radius:8px;transition:all .2s;padding:0}.hub-card-dots:hover{background:#d4a26a14;color:var(--color-text-primary)}.hub-card-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;max-height:min(260px,calc(100vh - 32px));overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:var(--color-bg-primary);border:1px solid rgba(212,162,106,.15);border-radius:12px;padding:6px;z-index:30;box-shadow:0 16px 48px #0006;animation:hub-menu-in .12s ease-out}@keyframes hub-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.hub-card-menu-item{display:block;width:100%;text-align:left;padding:10px 14px;border:none;background:none;color:var(--color-text-secondary);font-family:var(--font-display);font-size:.82rem;font-weight:500;border-radius:8px;cursor:pointer;transition:.15s}.hub-card-menu-item:hover{background:#d4a26a0f;color:var(--color-text-primary)}.hub-card-menu-item:disabled{opacity:.55;cursor:not-allowed}.hub-card-menu-item.danger{color:#e06060;font-weight:600}.hub-card-menu-item.danger:hover{background:#e0606014}.hub-card-rename{display:flex;align-items:center}.hub-card-rename-input{font-family:var(--font-display);font-size:1.05rem;font-weight:700;background:transparent;border:1px solid rgba(212,162,106,.3);border-radius:8px;color:var(--color-text-primary);padding:6px 12px;width:100%;outline:none;transition:border-color .2s}.hub-card-rename-input:focus{border-color:var(--color-accent)}@media (max-width: 1200px){.hub-dashboard{flex-direction:column;gap:28px}.hub-greeting p{max-width:none}.hub-widgets{width:100%;max-width:none;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr)}}@media (max-width: 900px){.hub-topbar{padding:14px 20px}.hub-dashboard{flex-direction:column;padding:32px 20px 24px;gap:28px}.hub-widgets{width:100%;grid-template-columns:1fr}.hub-widget-card{width:100%;min-width:0;padding:22px 20px}.hub-widget-card-heatmap{align-items:stretch}.hub-widget-card-metric{align-items:center;gap:12px}.hub-projects-section,.hub-alert{margin-left:0;margin-right:0;padding-left:20px;padding-right:20px}.hub-projects-header{flex-direction:column;align-items:flex-start}.hub-project-grid{grid-template-columns:1fr}}.hub-streak-inline{display:flex;align-items:center;gap:6px;margin-top:4px;padding:6px 12px;border-radius:999px;border:1px solid rgba(212,162,106,.12);background:#d4a26a0d}.hub-streak-inline__flame{font-size:.9rem}.hub-streak-inline__count{font-family:var(--font-display);font-size:.92rem;font-weight:600}.hub-streak-inline__label{font-size:.76rem;color:var(--color-text-secondary)}.hub-next-ach{display:block;margin-top:12px;padding:14px 18px;border-radius:14px;border:1px solid rgba(212,162,106,.15);background:linear-gradient(135deg,#d4a26a0f,#d4a26a05);width:100%;transition:border-color .2s ease}.hub-next-ach:hover{border-color:#d4a26a4d}.hub-next-ach__top{display:flex;align-items:center;gap:8px;margin-bottom:8px}.hub-next-ach__icon{font-size:1.1rem}.hub-next-ach__title{font-family:var(--font-display);font-size:.88rem;flex:1}.hub-next-ach__credits{font-family:var(--font-display);font-size:.78rem;color:var(--color-accent)}.hub-next-ach__bar{height:4px;border-radius:2px;background:#ffffff0f;overflow:hidden;margin-bottom:6px}.hub-next-ach__fill{height:100%;border-radius:2px;background:var(--color-accent);transition:width .4s ease}.hub-next-ach__sub{font-size:.72rem;color:var(--color-text-tertiary)}.pam-wrapper{position:relative;display:inline-block}.pam-trigger{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .2s;padding:0}.pam-trigger:hover,.pam-trigger.active{background:#d4a26a14;color:var(--color-text-primary);border-color:#d4a26a1a}.pam-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:var(--color-bg-primary);border:1px solid rgba(212,162,106,.15);border-radius:12px;padding:6px;z-index:50;box-shadow:0 16px 48px #00000040;animation:pam-in .1s ease-out;transform-origin:top right}@keyframes pam-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.pam-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:8px 12px;border:none;background:none;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.85rem;font-weight:500;border-radius:8px;cursor:pointer;transition:.15s}.pam-item:hover{background:#d4a26a0f;color:var(--color-text-primary)}.pam-item:disabled{opacity:.5;cursor:not-allowed}.pam-icon{font-size:1rem;width:18px;text-align:center}.pam-divider{height:1px;background:var(--color-surface-border);margin:4px 0}.pam-item.danger{color:#e06060}.pam-item.danger:hover{background:#e0606014}.pam-rename-wrapper{position:relative;display:inline-block;min-width:200px}.pam-rename-input{font-family:var(--font-display);font-size:1.5rem;font-weight:700;background:var(--color-bg-secondary);border:1px solid var(--color-accent);border-radius:8px;color:var(--color-text-primary);padding:4px 12px;width:100%;outline:none;box-shadow:0 0 0 2px #d4a26a33}.pdf-import-overlay{position:fixed;inset:0;z-index:5000;background:#0009;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}.pdf-import-modal{background:var(--color-surface-1, #1a1a1a);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:580px;max-width:92vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.pdf-import-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.06)}.pdf-import-header h2{font-size:1.1rem;font-weight:600;margin:0;color:var(--color-text-primary, #e8e8e8)}.pdf-import-close{background:none;border:none;color:var(--color-text-tertiary);font-size:1.4rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}.pdf-import-close:hover{background:#ffffff0f}.pdf-import-error{padding:10px 24px;color:#e57373;font-size:.82rem;background:#e573730f}.pdf-import-progress{padding:10px 24px;color:var(--color-accent, #d4a26a);font-size:.82rem}.pdf-import-upload{padding:48px 24px;text-align:center}.pdf-import-upload p{color:var(--color-text-secondary, #aaa);margin-bottom:20px;font-size:.88rem}.pdf-import-btn{padding:12px 28px;border:1px dashed rgba(212,162,106,.3);border-radius:10px;background:#d4a26a0a;color:var(--color-accent, #d4a26a);font-weight:600;cursor:pointer;transition:background .15s}.pdf-import-btn:hover{background:#d4a26a14}.pdf-import-preview{display:flex;flex-direction:column;overflow:hidden;flex:1}.pdf-import-summary{display:flex;align-items:center;gap:16px;padding:12px 24px;font-size:.76rem;color:var(--color-text-tertiary);border-bottom:1px solid rgba(255,255,255,.04)}.pdf-import-chapters{flex:1;overflow-y:auto;padding:12px 24px;display:flex;flex-direction:column;gap:8px;max-height:400px}.pdf-import-chapter{padding:12px;border-radius:8px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center}.pdf-import-chapter.excluded{opacity:.4}.pdf-import-check{display:flex}.pdf-import-title-input{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:6px 10px;color:var(--color-text-primary);font-size:.84rem;font-weight:600}.pdf-import-title-input:focus{outline:none;border-color:#d4a26a4d}.pdf-import-wordcount{font-size:.7rem;color:var(--color-text-tertiary);white-space:nowrap}.pdf-import-excerpt{grid-column:1 / -1;font-size:.72rem;color:var(--color-text-tertiary);line-height:1.5;margin:0}.pdf-import-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid rgba(255,255,255,.06)}.pdf-import-importing{padding:48px 24px;text-align:center}.pdf-import-spinner{width:32px;height:32px;border:3px solid rgba(212,162,106,.2);border-top-color:var(--color-accent, #d4a26a);border-radius:50%;margin:0 auto 16px;animation:pdf-spin .8s linear infinite}@keyframes pdf-spin{to{transform:rotate(360deg)}}.project-home{height:100vh;overflow-y:auto;overscroll-behavior:contain;padding:40px 48px 80px;max-width:960px;margin:0 auto;background:radial-gradient(ellipse 50% 35% at 50% 0%,rgba(212,162,106,.05),transparent 50%),var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-body)}@supports (height: 100dvh){.project-home{height:100dvh}}.project-home.loading{display:flex;align-items:center;justify-content:center}.project-home-card{background:var(--v5-card-bg);border:1px solid var(--color-surface-border);border-radius:14px;padding:28px 36px;font-family:var(--font-display)}.ph-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.ph-back{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-display);font-size:.82rem;transition:.2s;letter-spacing:.01em;padding:0}.ph-back:hover{color:var(--color-accent)}.ph-topbar-right{display:flex;gap:8px}.ph-hero-card{border:1px solid var(--color-surface-border);border-radius:14px;background:var(--v5-card-bg);padding:32px 36px 28px;margin-bottom:24px;position:relative;overflow:hidden}.ph-hero-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2.5px;background:linear-gradient(90deg,var(--color-accent),#c8915a,rgba(212,162,106,.2))}.ph-pills-row{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}.ph-pill{display:inline-flex;align-items:center;gap:6px;font-size:.58rem;text-transform:uppercase;letter-spacing:.15em;padding:5px 14px;border-radius:100px;font-weight:600;font-family:var(--font-body)}.ph-pill-genre{color:var(--color-accent);background:var(--v5-amber-soft);border:1px solid rgba(212,162,106,.18)}.ph-stage-wrapper{position:relative}.ph-pill-stage{color:var(--color-text-secondary);border:1px solid var(--color-surface-border);cursor:pointer;transition:all .25s;background:none;font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;padding:6px 16px;border-radius:100px;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body)}.ph-pill-stage:hover{border-color:#d4a26a4d;color:var(--color-text-primary);background:#d4a26a0a}.ph-stage-dot{width:7px;height:7px;border-radius:50%;background:var(--color-accent);flex-shrink:0;box-shadow:0 0 6px #d4a26a66}.ph-stage-chevron{font-size:.5rem;opacity:.6;transition:.2s}.ph-stage-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:180px;background:var(--color-bg-primary);border:1px solid rgba(212,162,106,.15);border-radius:12px;padding:6px;z-index:20;box-shadow:0 16px 48px #00000059;animation:ph-dropdown-in .15s ease-out}@keyframes ph-dropdown-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.ph-stage-option{display:block;width:100%;text-align:left;padding:10px 14px;border:none;background:none;color:var(--color-text-secondary);font-family:var(--font-display);font-size:.84rem;font-weight:500;border-radius:8px;cursor:pointer;transition:.15s}.ph-stage-option:hover{background:#d4a26a0f;color:var(--color-text-primary)}.ph-stage-option.active{color:var(--color-accent);background:var(--v5-amber-soft);font-weight:600}.ph-hero-card h1{font-family:var(--font-display);font-size:clamp(1.7rem,3.5vw,2.2rem);font-weight:700;line-height:1.2;margin:0 0 10px;letter-spacing:-.01em}.ph-synopsis{color:var(--color-text-secondary);font-size:.88rem;line-height:1.65;max-width:600px;font-weight:300;margin:0}.ph-hero-stats{display:flex;gap:24px;margin-top:22px;padding-top:18px;border-top:1px solid var(--color-surface-border)}.ph-stat{text-align:left}.ph-stat+.ph-stat{padding-left:24px;border-left:1px solid var(--color-surface-border)}.ph-stat-value{font-family:var(--font-display);font-size:1.2rem;font-weight:700;letter-spacing:-.01em}.ph-stat-label{font-size:.56rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted, #6b6760);margin-top:2px}.ph-section-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.18em;color:var(--color-text-muted, #6b6760);margin-bottom:14px;font-weight:600}.ph-tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.ph-tool{border:1px solid var(--color-surface-border);border-radius:14px;padding:24px;background:var(--v5-card-bg);display:flex;align-items:flex-start;gap:16px;transition:all .3s;cursor:pointer}.ph-tool:hover{border-color:#d4a26a33;transform:translateY(-2px);box-shadow:0 12px 36px #00000038}.ph-tool.locked{opacity:.4;cursor:default}.ph-tool.locked:hover{transform:none;box-shadow:none;border-color:var(--color-surface-border)}.ph-tool-icon{font-size:1.4rem;flex-shrink:0;padding-top:2px}.ph-tool-body{flex:1;min-width:0}.ph-tool-body h3{font-family:var(--font-display);font-size:.96rem;font-weight:600;margin:0 0 6px;display:flex;align-items:center;gap:8px}.ph-tool-body p{color:var(--color-text-secondary);font-size:.8rem;line-height:1.55;margin:0}.ph-tool-tag{font-size:.52rem;text-transform:uppercase;letter-spacing:.1em;padding:2px 8px;border-radius:100px;font-weight:700}.ph-tool-tag.ready{color:var(--color-accent);background:var(--v5-amber-soft)}.ph-tool-tag.soon{color:var(--color-text-muted, #6b6760);border:1px solid var(--color-surface-border)}.ph-tool-arrow{align-self:center;color:var(--color-text-muted, #6b6760);font-size:1rem;transition:.2s;flex-shrink:0;margin-left:auto}.ph-tool:hover .ph-tool-arrow{color:var(--color-accent);transform:translate(3px)}.ph-sb-banner{border-radius:14px;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:24px}.ph-sb-missing{border:1px solid rgba(212,162,106,.18);background:#d4a26a08}.ph-sb-success{border:1px solid rgba(122,184,122,.15);background:#7ab87a08}.ph-sb-left{display:flex;align-items:center;gap:12px}.ph-sb-check{width:22px;height:22px;border-radius:50%;background:#7ab87a14;border:1.5px solid rgba(122,184,122,.3);display:flex;align-items:center;justify-content:center;color:#7ab87a;font-size:11px;flex-shrink:0}.ph-sb-text{font-size:.84rem;color:var(--color-text-secondary);line-height:1.5}.ph-sb-text strong{font-weight:600}.ph-sb-missing .ph-sb-text strong{color:var(--color-accent)}.ph-sb-success .ph-sb-text strong{color:#7ab87a}.ph-sb-btn{font-family:var(--font-display);font-size:.72rem;font-weight:600;border-radius:24px;padding:8px 20px;cursor:pointer;transition:all .3s;border:1px solid rgba(212,162,106,.2);background:transparent;color:var(--color-accent);flex-shrink:0}.ph-sb-btn:hover{background:var(--v5-amber-soft);border-color:#d4a26a59;transform:translateY(-1px)}@media (max-width: 900px){.project-home{padding:24px 16px 60px}.ph-topbar{flex-direction:column;align-items:flex-start;gap:12px}.ph-tools-grid{grid-template-columns:1fr}.ph-hero-stats{flex-wrap:wrap;gap:16px}.ph-sb-banner{flex-direction:column;align-items:flex-start}}.draft-review-v7{height:100vh;min-height:100vh;max-width:1060px;margin:0 auto;padding:40px 32px 80px;color:var(--color-text-primary);font-family:var(--font-body);overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative}.draft-review-v7:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 80% 50% at 10% 0%,rgba(212,162,106,.1),transparent 50%),radial-gradient(ellipse 60% 40% at 95% 8%,rgba(126,104,73,.12),transparent 40%),radial-gradient(ellipse 50% 50% at 50% 100%,rgba(212,162,106,.04),transparent 50%),linear-gradient(180deg,#0c0f0c,#0e110e);pointer-events:none}.draft-review-v7.loading{display:flex;align-items:center;justify-content:center}@supports (height: 100dvh){.draft-review-v7{height:100dvh;min-height:100dvh}}.dr7-header{margin-bottom:32px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.dr7-header-left{flex:1;min-width:0}.dr7-header h1{margin:0;font-family:var(--font-display);font-size:clamp(1.45rem,2.8vw,1.85rem);font-weight:600;line-height:1.2;color:var(--color-text-primary);font-style:italic}.dr7-header h1 span{color:var(--color-text-secondary);font-style:italic;font-weight:400}.dr7-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.dr7-tabs{display:flex;gap:0;margin-bottom:0;border-bottom:1px solid rgba(212,162,106,.1);position:relative}.dr7-tab{position:relative;cursor:pointer;padding:12px 20px;font-family:var(--font-body);font-size:.82rem;font-weight:500;color:var(--color-text-tertiary);background:none;border:none;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease;letter-spacing:.01em}.dr7-tab:hover{color:var(--color-text-secondary)}.dr7-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.dr7-tab strong{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:.58rem;font-weight:700;margin-left:6px;background:#d4a26a1f;color:var(--color-text-tertiary);vertical-align:middle}.dr7-tab.active strong{background:#d4a26a40;color:var(--color-accent)}.dr7-surface{padding:28px 0 0;min-height:460px}.dr7-panel-fade{animation:dr7-fade-in .26s ease}.dr7-pipeline{display:flex;flex-direction:column;gap:10px}.dr7-step-card{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;transition:border-color .22s ease,background .22s ease,transform .2s ease}.dr7-step-card:hover{border-color:#d4a26a1f;background:#ffffff09}.dr7-step-card.status-completed{border-color:#4ade802e}.dr7-step-card.status-running{border-color:#d4a26a47;background:#d4a26a0a}.dr7-step-card.status-failed{border-color:#f8717138}.dr7-step-icon{flex-shrink:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;font-size:1rem}.dr7-step-icon.icon-completed{color:#4ade80}.dr7-step-icon.icon-running{color:var(--color-accent);animation:dr7-spin 1.4s linear infinite}.dr7-step-icon.icon-pending{color:var(--color-text-tertiary);opacity:.5}.dr7-step-icon.icon-failed{color:#f87171}.dr7-step-label{flex:1;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--color-text-primary)}.dr7-step-actions{display:flex;gap:6px;flex-shrink:0}.dr7-step-actions .btn{padding:7px 16px;font-size:.76rem}.dr7-run-bar{margin-top:16px;display:flex;align-items:center;gap:12px}.dr7-run-bar .btn{border-radius:999px;padding:10px 24px;font-size:.82rem}.dr7-run-bar .btn .dr7-spinner-inline{width:14px;height:14px;border:2px solid rgba(0,0,0,.2);border-top-color:currentColor;border-radius:50%;animation:dr7-spin .8s linear infinite;display:inline-block;vertical-align:middle;margin-right:6px}.dr7-scope-section{margin-top:24px}.dr7-scope-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff05;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.82rem;font-weight:500;cursor:pointer;transition:border-color .2s ease,background .2s ease}.dr7-scope-toggle:hover{border-color:#d4a26a24;background:#ffffff08}.dr7-scope-toggle .dr7-chevron{transition:transform .25s ease;font-size:.7rem;color:var(--color-text-tertiary)}.dr7-scope-toggle .dr7-chevron.open{transform:rotate(90deg)}.dr7-scope-toggle .dr7-scope-count{margin-left:auto;font-size:.72rem;color:var(--color-text-tertiary);font-weight:400}.dr7-scope-body{margin-top:8px;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff04}.dr7-scope-actions{display:flex;gap:8px;margin-bottom:10px}.dr7-scope-actions .btn{padding:6px 14px;font-size:.72rem}.dr7-chapter-list{display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto;padding-right:4px}.dr7-chapter-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;font-size:.8rem;color:var(--color-text-secondary);cursor:pointer;transition:background .17s ease}.dr7-chapter-item:hover{background:#d4a26a0f}.dr7-chapter-item input{accent-color:var(--color-accent)}.dr7-severity-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.dr7-severity-card{border-radius:14px;padding:20px 16px;text-align:center;border:1px solid transparent;transition:transform .2s ease,box-shadow .2s ease}.dr7-severity-card:hover{transform:translateY(-2px)}.dr7-severity-card.sev-critical{background:linear-gradient(145deg,#ef444424,#ef44440f);border-color:#ef444438}.dr7-severity-card.sev-warnings{background:linear-gradient(145deg,#d4a26a24,#d4a26a0f);border-color:#d4a26a38}.dr7-severity-card.sev-info{background:linear-gradient(145deg,#60a5fa1f,#60a5fa0d);border-color:#60a5fa33}.dr7-severity-card .sev-count{display:block;font-family:var(--font-display);font-size:2rem;font-weight:700;line-height:1;margin-bottom:6px}.dr7-severity-card.sev-critical .sev-count{color:#f87171}.dr7-severity-card.sev-warnings .sev-count{color:var(--color-accent)}.dr7-severity-card.sev-info .sev-count{color:#60a5fa}.dr7-severity-card .sev-label{font-size:.62rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-tertiary)}.dr7-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.dr7-filter{display:flex;flex-direction:column;gap:4px}.dr7-filter-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-tertiary);font-weight:600}.dr7-filter select{min-width:160px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;color:var(--color-text-primary);padding:8px 12px;font-family:var(--font-body);font-size:.82rem;transition:border-color .2s ease}.dr7-filter select:focus{outline:none;border-color:#d4a26a59}.dr7-issue-list{display:flex;flex-direction:column;gap:12px}.dr7-issue-card{border-radius:14px;border:1px solid rgba(255,255,255,.05);background:#ffffff05;padding:20px 22px;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.dr7-issue-card:hover{border-color:#d4a26a29;transform:translateY(-1px);box-shadow:0 8px 32px #0003}.dr7-issue-card.severity-high{border-left:3px solid rgba(248,113,113,.5)}.dr7-issue-card.severity-medium{border-left:3px solid rgba(212,162,106,.5)}.dr7-issue-card.severity-low{border-left:3px solid rgba(96,165,250,.4)}.dr7-issue-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.dr7-issue-warn-icon{flex-shrink:0;font-size:1.1rem}.dr7-issue-card.severity-high .dr7-issue-warn-icon{color:#f87171}.dr7-issue-card.severity-medium .dr7-issue-warn-icon{color:var(--color-accent)}.dr7-issue-card.severity-low .dr7-issue-warn-icon{color:#60a5fa}.dr7-issue-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--color-text-primary);line-height:1.3}.dr7-issue-cat{margin-left:auto;flex-shrink:0;display:inline-flex;padding:3px 10px;border-radius:6px;font-size:.58rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--color-text-tertiary);background:#ffffff0f;border:1px solid rgba(255,255,255,.06)}.dr7-issue-desc{font-size:.84rem;line-height:1.7;color:var(--color-text-secondary);margin:0 0 10px}.dr7-issue-evidence{font-size:.82rem;line-height:1.6;color:var(--color-text-secondary);margin:0 0 6px}.dr7-issue-evidence strong,.dr7-issue-fix strong{color:var(--color-text-tertiary);font-weight:600;font-size:.78rem}.dr7-issue-fix{font-size:.82rem;line-height:1.6;color:var(--color-text-secondary);margin:0 0 10px}.dr7-issue-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.74rem;color:var(--color-text-tertiary);margin-top:8px;padding-top:10px;border-top:1px solid rgba(255,255,255,.04)}.dr7-issue-footer-actions{display:flex;align-items:center;gap:6px}.dr7-issue-footer-actions .btn-sm{font-size:.68rem;padding:4px 10px;border-radius:6px}.dr7-issue-file-link{display:inline-flex;align-items:center;gap:5px;color:var(--color-accent);font-weight:500;cursor:pointer;transition:color .17s ease;background:none;border:none;padding:0;font-family:var(--font-body);font-size:.74rem}.dr7-issue-file-link:hover{color:var(--color-accent-hover)}.dr7-issue-file-link svg{width:13px;height:13px}.dr7-conflict-box{margin-top:20px;border-radius:12px;border:1px solid rgba(212,162,106,.22);background:#d4a26a0d;padding:16px 18px}.dr7-conflict-box h3{margin:0 0 10px;font-family:var(--font-display);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.dr7-conflict-box ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}.dr7-conflict-box li{font-size:.82rem;color:var(--color-text-secondary);line-height:1.6}.dr7-fix-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:18px;color:var(--color-text-secondary);font-size:.82rem}.dr7-fix-toolbar-actions{display:flex;gap:8px;flex-wrap:wrap}.dr7-fix-toolbar-actions .btn{padding:8px 16px;font-size:.76rem}.dr7-fix-list{display:flex;flex-direction:column;gap:10px}.dr7-fix-item{border-radius:14px;border:1px solid rgba(255,255,255,.05);background:#ffffff05;padding:16px 20px;transition:border-color .2s ease}.dr7-fix-item:hover{border-color:#d4a26a24}.dr7-fix-selector{display:flex;align-items:center;gap:10px;font-size:.88rem;font-weight:500;color:var(--color-text-primary);cursor:pointer}.dr7-fix-selector input{accent-color:var(--color-accent)}.dr7-fix-item p{margin:8px 0 0;font-size:.82rem;color:var(--color-text-secondary);line-height:1.6}.dr7-fix-item-actions{display:flex;gap:8px;margin-top:12px}.dr7-fix-item-actions .btn{padding:7px 16px;font-size:.76rem}.dr7-story-bible-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.dr7-story-bible-header h2{margin:0;font-family:var(--font-display);font-size:1.1rem}.dr7-bible-meta{margin:4px 0 0;font-size:.78rem;color:var(--color-text-tertiary)}.dr7-manual-pill{display:inline-flex;border-radius:999px;border:1px solid rgba(212,162,106,.2);padding:4px 12px;font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);background:#d4a26a14;margin-bottom:12px}.dr7-bible-preview{border-radius:14px;border:1px solid rgba(255,255,255,.05);background:#ffffff04;padding:24px;max-height:600px;overflow-y:auto}.dr7-bible-preview h1,.dr7-bible-preview h2,.dr7-bible-preview h3,.dr7-bible-preview h4{margin-top:20px;margin-bottom:8px;font-family:var(--font-display)}.dr7-bible-preview p,.dr7-bible-preview li{font-size:.86rem;line-height:1.75;color:var(--color-text-secondary)}.dr7-bible-preview ul,.dr7-bible-preview ol{padding-left:20px}.dr7-history-list{display:flex;flex-direction:column;gap:10px}.dr7-history-item{border-radius:14px;border:1px solid rgba(255,255,255,.05);background:#ffffff05;padding:16px 20px;transition:border-color .2s ease}.dr7-history-item.active{border-color:#d4a26a4d;background:#d4a26a0d}.dr7-history-main{display:flex;justify-content:space-between;align-items:center;gap:12px}.dr7-history-item h3{margin:0;font-family:var(--font-display);font-size:.92rem;font-weight:600}.dr7-history-item .muted-text{margin:4px 0 0;font-size:.78rem;color:var(--color-text-tertiary)}.dr7-overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:28px}.dr7-overview-card{border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff05;padding:20px}.dr7-overview-card h2{margin:0 0 12px;font-family:var(--font-display);font-size:.92rem;font-weight:600;display:flex;align-items:center;gap:8px}.dr7-overview-card h2 .dr7-pill-muted{margin-left:auto}.dr7-pill-muted{display:inline-flex;border:1px solid rgba(212,162,106,.16);border-radius:999px;padding:3px 10px;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-tertiary);background:#d4a26a0f;font-weight:600;font-family:var(--font-body)}.dr7-mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}.dr7-mini-stat{border-radius:10px;border:1px solid rgba(255,255,255,.04);background:#d4a26a08;padding:10px 12px}.dr7-mini-stat span{display:block;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary)}.dr7-mini-stat strong{display:block;margin-top:4px;font-family:var(--font-display);font-size:1.1rem}.dr7-severity-strip{margin-top:12px;display:flex;gap:8px}.dr7-severity-strip span{border-radius:999px;padding:4px 10px;font-size:.62rem;text-transform:uppercase;letter-spacing:.09em;font-weight:600;border:1px solid transparent}.dr7-severity-strip .sev-high{border-color:#f871714d;background:#f871711a;color:#fca5a5}.dr7-severity-strip .sev-medium{border-color:#d4a26a4d;background:#d4a26a1a;color:#f0c48f}.dr7-severity-strip .sev-low{border-color:#60a5fa4d;background:#60a5fa1a;color:#bfdbfe}.dr7-top-actions h3{margin:14px 0 8px;font-size:.68rem;letter-spacing:.11em;text-transform:uppercase;color:var(--color-text-tertiary);font-family:var(--font-body);font-weight:600}.dr7-top-actions ol{margin:0;padding-left:18px}.dr7-top-actions li{margin:6px 0;font-size:.84rem;color:var(--color-text-secondary);line-height:1.6}.dr7-overview-card>p{margin:0;font-size:.84rem;color:var(--color-text-secondary);line-height:1.7}.dr7-error{border-radius:12px;border:1px solid rgba(248,113,113,.35);background:#f8717114;color:#fecaca;padding:12px 16px;font-size:.82rem;margin-bottom:16px;line-height:1.6}.dr7-empty{text-align:center;padding:48px 24px;color:var(--color-text-tertiary);font-size:.88rem;line-height:1.6}.muted-text{color:var(--color-text-secondary);font-size:.82rem}.dr7-modal-backdrop{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;background:#080a09d1;backdrop-filter:blur(6px);padding:24px}.dr7-modal{width:min(580px,100%);max-height:min(80vh,700px);overflow-y:auto;padding:28px;border-radius:20px;border:1px solid rgba(212,162,106,.12);background:linear-gradient(155deg,#ffffff0a,#ffffff03),#111411;box-shadow:0 24px 64px #00000080}.dr7-modal h2{margin:0 0 16px;font-family:var(--font-display);font-size:1.25rem}.dr7-modal p{margin:8px 0;font-size:.88rem;color:var(--color-text-secondary)}.dr7-modal-list{margin:12px 0;padding-left:18px;max-height:220px;overflow-y:auto;color:var(--color-text-tertiary);display:flex;flex-direction:column;gap:5px;font-size:.82rem}.dr7-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.draft-review-v7 code{color:var(--color-accent);border-radius:6px;border:1px solid rgba(212,162,106,.12);background:#d4a26a14;padding:1px 5px;font-size:.78rem}@keyframes dr7-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes dr7-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 900px){.draft-review-v7{padding:24px 18px 50px}.dr7-overview-grid,.dr7-severity-row{grid-template-columns:1fr}}@media (max-width: 640px){.draft-review-v7{padding:18px 14px 40px}.dr7-header{flex-direction:column}.dr7-header-actions{width:100%}.dr7-header-actions .btn{flex:1}.dr7-tabs{overflow-x:auto}.dr7-severity-row{grid-template-columns:1fr}.dr7-fix-toolbar{flex-direction:column;align-items:flex-start}.dr7-fix-toolbar-actions{width:100%}.dr7-fix-toolbar-actions .btn{flex:1}.dr7-history-main{flex-direction:column;align-items:flex-start}.dr7-story-bible-header{flex-direction:column}}@media (prefers-reduced-motion: reduce){.dr7-panel-fade,.dr7-step-card,.dr7-issue-card,.dr7-severity-card{animation:none;transition:none}.dr7-step-icon.icon-running,.dr7-run-bar .btn .dr7-spinner-inline{animation:none}}.csm-overlay{position:fixed;inset:0;z-index:5000;background:#0009;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}.csm-modal{background:var(--color-surface-1, #1a1a1a);border:1px solid rgba(255,255,255,.08);border-radius:14px;width:460px;max-width:92vw}.csm-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.csm-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary)}.csm-close{background:none;border:none;color:var(--color-text-tertiary);font-size:1.3rem;cursor:pointer;padding:4px 8px;border-radius:6px}.csm-close:hover{background:#ffffff0f}.csm-error{padding:8px 20px;color:#e57373;font-size:.8rem;background:#e573730f}.csm-body{padding:16px 20px}.csm-badge{display:inline-block;padding:4px 10px;margin-bottom:10px;border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;background:#d4a26a14;color:var(--color-accent, #d4a26a);border:1px solid rgba(212,162,106,.15)}.csm-textarea{width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:10px 12px;color:var(--color-text-primary);font-size:.86rem;resize:vertical;min-height:80px;font-family:inherit}.csm-textarea:focus{outline:none;border-color:#d4a26a4d}.csm-meta{display:flex;align-items:center;gap:10px;margin-top:8px;font-size:.7rem;color:var(--color-text-tertiary)}.csm-tag{padding:2px 8px;border-radius:4px;background:#ffffff0a}.csm-actions{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid rgba(255,255,255,.06)}.ab-studio{height:100vh;min-height:100vh;max-width:1100px;margin:0 auto;padding:40px 32px 80px;color:var(--color-text-primary);font-family:var(--font-body);overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative}.ab-studio:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 80% 50% at 10% 0%,rgba(212,162,106,.1),transparent 50%),radial-gradient(ellipse 60% 40% at 95% 8%,rgba(178,86,58,.09),transparent 40%),radial-gradient(ellipse 50% 50% at 50% 100%,rgba(212,162,106,.04),transparent 50%),linear-gradient(180deg,#0c0f0c,#0e110e);pointer-events:none}.ab-studio.ab-loading{display:flex;align-items:center;justify-content:center}@supports (height: 100dvh){.ab-studio{height:100dvh;min-height:100dvh}}.ab-header{margin-bottom:32px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.ab-header-left{flex:1;min-width:0}.ab-tag-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.ab-tag{display:inline-flex;align-items:center;border-radius:999px;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:4px 10px}.ab-tag--studio{color:#f0c489;border:1px solid rgba(240,196,137,.2);background:#f0c48914}.ab-tag--model{color:#a8c4e0;border:1px solid rgba(147,197,253,.16);background:#93c5fd0f}.ab-header h1{margin:0;font-family:var(--font-display);font-size:clamp(1.45rem,2.8vw,1.85rem);font-weight:600;line-height:1.2;font-style:italic}.ab-header h1 span{color:var(--color-text-secondary);font-style:italic;font-weight:400}.ab-header-desc{margin:6px 0 0;color:var(--color-text-secondary);font-size:.84rem;line-height:1.6}.ab-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.ab-alert{border-radius:12px;border:1px solid rgba(255,255,255,.06);padding:12px 16px;font-size:.82rem;line-height:1.6;margin-bottom:16px}.ab-alert--error{color:#fecaca;border-color:#f8717159;background:#f8717114}.ab-alert--success{color:#cce4d5;border-color:#6ee7b733;background:#6ee7b70f}.ab-alert--stuck{display:flex;align-items:center;justify-content:space-between;gap:12px}.ab-tabs{display:flex;gap:0;margin-bottom:0;border-bottom:1px solid rgba(212,162,106,.1);position:relative}.ab-tab{position:relative;cursor:pointer;padding:12px 20px;font-family:var(--font-body);font-size:.82rem;font-weight:500;color:var(--color-text-tertiary);background:none;border:none;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease;letter-spacing:.01em}.ab-tab:hover{color:var(--color-text-secondary)}.ab-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.ab-tab strong{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:.58rem;font-weight:700;margin-left:6px;background:#d4a26a1f;color:var(--color-text-tertiary);vertical-align:middle}.ab-tab.active strong{background:#d4a26a40;color:var(--color-accent)}.ab-surface{padding:28px 0 0;min-height:460px}.ab-panel-fade{animation:ab-fade-in .26s ease}@keyframes ab-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ab-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:24px}.ab-stat{border-radius:10px;border:1px solid rgba(255,255,255,.04);background:#d4a26a08;padding:10px 12px;transition:border-color .2s ease}.ab-stat:hover{border-color:#d4a26a1f}.ab-stat__label{display:block;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary)}.ab-stat__value{display:block;margin-top:4px;font-family:var(--font-display);font-size:1.1rem}.ab-stat__sub{display:block;margin-top:2px;font-size:.72rem;color:var(--color-text-tertiary)}.ab-section-label{display:block;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-tertiary);font-weight:600;margin-bottom:10px}.ab-voices{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}.ab-voice{position:relative;padding:16px;border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;color:var(--color-text-primary);text-align:left;cursor:pointer;transition:border-color .22s ease,background .22s ease,transform .2s ease}.ab-voice:hover{border-color:#d4a26a1f;background:#ffffff09;transform:translateY(-1px)}.ab-voice.active{border-color:#d4a26a80;background:#d4a26a0f}.ab-voice.active:after{content:"";position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 6px #d4a26a80}.ab-voice.disabled{opacity:.45;pointer-events:none}.ab-voice__preview{display:inline-flex;align-items:center;gap:4px;margin-top:10px;padding:4px 12px;border-radius:999px;border:1px solid rgba(212,162,106,.2);background:#d4a26a0f;color:var(--color-accent);font-size:.7rem;font-family:var(--font-body);font-weight:600;letter-spacing:.04em;cursor:pointer;transition:all .18s ease}.ab-voice__preview:hover{background:#d4a26a1f;border-color:#d4a26a59}.ab-voice__preview:disabled{opacity:.5;cursor:wait}.ab-voice__name{display:block;font-family:var(--font-display);font-size:.92rem;margin-bottom:4px}.ab-voice__tone{display:block;font-size:.72rem;color:var(--color-accent);margin-bottom:6px}.ab-voice__desc{font-size:.76rem;color:var(--color-text-tertiary);line-height:1.45}.ab-controls{display:flex;gap:24px;margin-bottom:24px;flex-wrap:wrap}.ab-control-group{display:flex;flex-direction:column;gap:8px;min-width:0}.ab-pills{display:flex;gap:6px;flex-wrap:wrap}.ab-pill{padding:7px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff06;color:var(--color-text-secondary);font-size:.82rem;font-family:var(--font-body);cursor:pointer;transition:all .2s ease}.ab-pill:hover{border-color:#d4a26a33;color:var(--color-text-primary)}.ab-pill.active{color:#fff6eb;border-color:#d4a26a8c;background:#d4a26a1a}.ab-pill:disabled{opacity:.45;pointer-events:none}.ab-scope{margin-bottom:24px}.ab-scope-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff05}.ab-scope-bar__left{display:flex;align-items:center;gap:10px}.ab-scope-bar__label{font-size:.82rem;color:var(--color-text-secondary)}.ab-chapter-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.ab-chip{padding:7px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--color-text-secondary);font-size:.78rem;font-family:var(--font-body);cursor:pointer;transition:all .2s ease}.ab-chip:hover{border-color:#d4a26a33}.ab-chip.active{color:#fff6eb;border-color:#d4a26a8c;background:#d4a26a1a}.ab-chip:disabled{opacity:.4;pointer-events:none}.ab-collapse{margin-bottom:12px}.ab-collapse__trigger{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff05;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.82rem;font-weight:500;cursor:pointer;transition:border-color .2s ease,background .2s ease}.ab-collapse__trigger:hover{border-color:#d4a26a24;background:#ffffff08}.ab-collapse__title{font-family:var(--font-body);font-weight:500}.ab-collapse__chevron{font-size:.7rem;color:var(--color-text-tertiary);transition:transform .25s ease}.ab-collapse__chevron.open{transform:rotate(90deg)}.ab-collapse__body{margin-top:8px;padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff04}.ab-textarea{width:100%;min-height:120px;resize:vertical;padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;color:var(--color-text-primary);font:inherit;font-size:.84rem;line-height:1.6;transition:border-color .2s ease}.ab-textarea:focus{outline:none;border-color:#d4a26a59}.ab-textarea::placeholder{color:var(--color-text-muted)}.ab-cast-section{margin-bottom:28px}.ab-cast-section__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.ab-cast-section__head h2{margin:0 0 4px;font-family:var(--font-display);font-size:1.1rem}.ab-cast-section__head p{margin:0;font-size:.82rem;color:var(--color-text-tertiary)}.ab-cast-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.ab-cast-header p{font-size:.82rem;color:var(--color-text-tertiary);margin:0}.ab-cast-list{display:flex;flex-direction:column;gap:4px}.ab-cast-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-top:1px solid rgba(255,255,255,.04)}.ab-cast-row:first-child{border-top:none;padding-top:0}.ab-cast-row__name{font-family:var(--font-display);font-size:.88rem}.ab-cast-row__reason{font-size:.74rem;color:var(--color-text-tertiary);margin-top:2px}.ab-cast-row__pills{display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap}.ab-mini-pill{padding:5px 9px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--color-text-tertiary);font-size:.68rem;font-family:var(--font-body);cursor:pointer;transition:all .18s ease}.ab-mini-pill:hover{border-color:#d4a26a33;color:var(--color-text-secondary)}.ab-mini-pill.active{color:#fff6eb;border-color:#d4a26a8c;background:#d4a26a1a}.ab-mini-pill:disabled{opacity:.4;pointer-events:none}.ab-empty-note{color:var(--color-text-muted);font-size:.82rem;padding:8px 0}.ab-run-select{min-width:200px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;color:var(--color-text-primary);padding:8px 12px;font-family:var(--font-body);font-size:.82rem;transition:border-color .2s ease}.ab-run-select:focus{outline:none;border-color:#d4a26a59}.ab-timeline-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.ab-timeline-header h2{margin:0;font-family:var(--font-display);font-size:1.1rem}.ab-timeline-header__left{display:flex;align-items:center;gap:10px}.ab-status{display:inline-flex;align-items:center;border-radius:999px;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:4px 10px}.ab-status--pending,.ab-status--running{color:#f2d8a9;border:1px solid rgba(242,216,169,.22);background:#f2d8a914}.ab-status--completed{color:#c6f2da;border:1px solid rgba(110,231,183,.22);background:#6ee7b714}.ab-status--failed,.ab-status--partial{color:#ffbbab;border:1px solid rgba(248,113,113,.22);background:#f8717114}.ab-timeline{display:flex;flex-direction:column;gap:10px}.ab-track{padding:16px 20px;border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;transition:border-color .22s ease,transform .2s ease}.ab-track:hover{border-color:#d4a26a1f}.ab-track__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.ab-track__name{font-family:var(--font-display);font-size:.92rem;font-weight:600}.ab-track__meta{font-size:.8rem;color:var(--color-text-secondary);line-height:1.5;margin:0}.ab-track__error{margin-top:6px;font-size:.82rem;color:#fecaca}.ab-track__player{margin-top:12px;display:flex;align-items:center;gap:10px}.ab-track__player audio{flex:1;min-width:0;height:36px;border-radius:8px}.ab-track__player .btn{flex-shrink:0}.ab-track__transcript{margin-top:10px}.ab-track__transcript summary{cursor:pointer;color:var(--color-accent);font-size:.8rem;transition:color .17s ease}.ab-track__transcript summary:hover{color:var(--color-accent-hover)}.ab-track__transcript p{margin-top:8px;color:var(--color-text-secondary);font-size:.84rem;line-height:1.65}.ab-empty{text-align:center;padding:48px 24px;color:var(--color-text-tertiary)}.ab-empty h3{font-family:var(--font-display);font-size:1.1rem;margin-bottom:8px;color:var(--color-text-primary)}.ab-empty p{font-size:.86rem;margin:0}.ab-muted{color:var(--color-text-muted);font-size:.8rem}@media (max-width: 900px){.ab-studio{padding:24px 18px 50px}.ab-voices{grid-template-columns:repeat(2,1fr)}.ab-stats{grid-template-columns:1fr}.ab-controls{flex-direction:column;gap:16px}}@media (max-width: 640px){.ab-studio{padding:18px 14px 40px}.ab-header{flex-direction:column}.ab-actions{width:100%}.ab-actions .btn{flex:1}.ab-tabs{overflow-x:auto}.ab-voices{grid-template-columns:1fr}.ab-scope-bar,.ab-cast-row{flex-direction:column;align-items:flex-start}.ab-track__player{flex-direction:column;align-items:stretch}.ab-run-select{width:100%;min-width:unset}.ab-timeline-header{flex-direction:column;align-items:flex-start}}@media (prefers-reduced-motion: reduce){.ab-panel-fade,.ab-voice,.ab-track,.ab-stat{animation:none;transition:none}}.ts-page{min-height:100vh;max-width:1100px;margin:0 auto;padding:40px 32px 80px;color:var(--text-primary, #e8e4dc);font-family:Nunito Sans,sans-serif}.ts-loading{display:flex;align-items:center;justify-content:center;min-height:60vh;color:var(--text-secondary, #8f8a7e)}.ts-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px}.ts-title{font-family:Lora,Georgia,serif;font-size:1.6rem;font-weight:700;margin:0}.ts-title-project{font-weight:400;color:var(--text-secondary, #8f8a7e)}.ts-subtitle{font-size:.85rem;color:var(--text-secondary, #8f8a7e);margin:4px 0 0}.ts-header-actions{display:flex;gap:8px;flex-shrink:0}.ts-btn{font-family:Lora,Georgia,serif;font-size:.82rem;font-weight:600;padding:8px 18px;border-radius:8px;cursor:pointer;transition:all .2s;border:1px solid rgba(212,162,106,.15);background:transparent;color:var(--text-primary, #e8e4dc)}.ts-btn:hover:not(:disabled){border-color:#d4a26a66}.ts-btn:disabled{opacity:.4;cursor:default}.ts-btn--primary{background:#d4a26a;color:#0a0d12;border-color:transparent}.ts-btn--primary:hover:not(:disabled){box-shadow:0 4px 14px #d4a26a4d;transform:translateY(-1px)}.ts-btn--ghost{background:transparent;border-color:#ffffff14}.ts-btn--danger{color:#e57373;border-color:#e5737333}.ts-btn--danger:hover:not(:disabled){background:#e5737314;border-color:#e5737366}.ts-btn--sm{font-size:.75rem;padding:5px 12px;border-radius:6px}.ts-alert{padding:10px 16px;border-radius:8px;font-size:.84rem;margin-bottom:16px}.ts-alert--error{background:#e5737314;border:1px solid rgba(229,115,115,.2);color:#e57373}.ts-alert--success{background:#81c78414;border:1px solid rgba(129,199,132,.2);color:#81c784}.ts-controls{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;background:#ffffff05;border:1px solid rgba(212,162,106,.08);border-radius:12px;margin-bottom:20px;flex-wrap:wrap}.ts-controls-left,.ts-controls-right{display:flex;align-items:center;gap:10px}.ts-label{font-size:.78rem;color:var(--text-secondary, #8f8a7e);text-transform:uppercase;letter-spacing:.08em}.ts-select{padding:6px 12px;background:#ffffff0a;border:1px solid rgba(212,162,106,.12);border-radius:8px;color:var(--text-primary, #e8e4dc);font-size:.85rem;cursor:pointer;font-family:inherit}.ts-select:focus{outline:none;border-color:#d4a26a66}.ts-progress{font-size:.78rem;color:#d4a26a;font-weight:600}.ts-empty{text-align:center;padding:80px 20px;color:var(--text-secondary, #8f8a7e);font-size:.92rem}.ts-chapters{display:flex;flex-direction:column;gap:2px}.ts-chapter{background:#ffffff05;border:1px solid rgba(212,162,106,.06);border-radius:10px;overflow:hidden;transition:border-color .3s}.ts-chapter:hover{border-color:#d4a26a26}.ts-chapter--expanded{border-color:#d4a26a33;background:#d4a26a05}.ts-chapter-row{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;transition:background .2s}.ts-chapter-row:hover{background:#ffffff05}.ts-chapter-info{flex:1;display:flex;align-items:center;gap:10px;min-width:0}.ts-chapter-name{font-family:Lora,Georgia,serif;font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ts-badge{font-size:.65rem;padding:2px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;flex-shrink:0}.ts-badge--translated{background:#81c7841f;color:#81c784}.ts-badge--stale{background:#ffb74d1f;color:#ffb74d}.ts-badge--failed{background:#e573731f;color:#e57373}.ts-badge--pending,.ts-badge--translating{background:#d4a26a1f;color:#d4a26a}.ts-badge--untranslated{background:#ffffff0a;color:var(--text-secondary, #8f8a7e)}.ts-chapter-actions{display:flex;gap:6px;flex-shrink:0}.ts-chapter-chevron{font-size:.65rem;color:var(--text-secondary, #8f8a7e);flex-shrink:0}.ts-chapter-detail{padding:0 18px 18px}.ts-stale-banner{padding:8px 14px;background:#ffb74d0f;border:1px solid rgba(255,183,77,.15);border-radius:8px;font-size:.8rem;color:#ffb74d;margin-bottom:14px}.ts-detail-panels{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch}.ts-detail-panel{display:flex;flex-direction:column;gap:6px}.ts-detail-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary, #8f8a7e);padding:0 4px}.ts-detail-content{padding:14px;background:#0003;border:1px solid rgba(212,162,106,.06);border-radius:8px;font-size:.82rem;line-height:1.7;color:var(--text-primary, #e8e4dc);min-height:300px;flex:1;overflow-y:auto}.ts-detail-content--source{font-family:inherit;white-space:pre-wrap;word-wrap:break-word}.ts-detail-empty{padding:40px 14px;text-align:center;color:var(--text-secondary, #8f8a7e);font-size:.85rem;background:#0000001a;border-radius:8px;min-height:200px;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.ts-page{padding:16px}.ts-header{flex-direction:column}.ts-controls{flex-direction:column;align-items:flex-start}.ts-detail-panels{grid-template-columns:1fr}.ts-chapter-actions{display:none}}.rw-page{height:100vh;min-height:100vh;max-width:1100px;margin:0 auto;padding:40px 32px 80px;color:var(--color-text-primary);font-family:var(--font-body);overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative}.rw-page:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 80% 50% at 10% 0%,rgba(212,162,106,.1),transparent 50%),radial-gradient(ellipse 60% 40% at 95% 8%,rgba(126,104,73,.08),transparent 40%),radial-gradient(ellipse 50% 50% at 50% 100%,rgba(212,162,106,.04),transparent 50%),linear-gradient(180deg,#0c0f0c,#0e110e);pointer-events:none}.rw-page.rw-loading{display:flex;align-items:center;justify-content:center}@supports (height: 100dvh){.rw-page{height:100dvh;min-height:100dvh}}.rw-header{margin-bottom:32px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.rw-header h1{margin:0;font-family:var(--font-display);font-size:clamp(1.45rem,2.8vw,1.85rem);font-weight:600;line-height:1.2;font-style:italic}.rw-header-desc{margin:6px 0 0;color:var(--color-text-secondary);font-size:.84rem}.rw-challenge{margin-bottom:24px;padding:20px 24px;border-radius:14px;border:1px solid rgba(212,162,106,.25);background:linear-gradient(135deg,#d4a26a14,#d4a26a05);display:flex;align-items:center;justify-content:space-between;gap:16px}.rw-challenge__text{font-family:var(--font-display);font-size:1rem;color:var(--color-accent)}.rw-challenge__sub{display:block;margin-top:4px;font-family:var(--font-body);font-size:.78rem;color:var(--color-text-secondary)}.rw-tabs{display:flex;gap:0;border-bottom:1px solid rgba(212,162,106,.1);margin-bottom:0}.rw-tab{padding:12px 20px;font-family:var(--font-body);font-size:.82rem;font-weight:500;color:var(--color-text-tertiary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .2s ease,border-color .2s ease}.rw-tab:hover{color:var(--color-text-secondary)}.rw-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.rw-surface{padding:28px 0 0;min-height:460px}.rw-fade{animation:rw-fade-in .26s ease}@keyframes rw-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.rw-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:24px}.rw-stat{border-radius:10px;border:1px solid rgba(255,255,255,.04);background:#d4a26a08;padding:10px 12px}.rw-stat__label{display:block;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary)}.rw-stat__value{display:block;margin-top:4px;font-family:var(--font-display);font-size:1.1rem}.rw-stat__sub{display:block;margin-top:2px;font-size:.72rem;color:var(--color-text-tertiary)}.rw-donut-section{display:flex;align-items:center;gap:32px;margin-bottom:32px;padding:24px;border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06}.donut-wrap{position:relative;flex-shrink:0}.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.donut-center strong{font-family:var(--font-display);font-size:1.3rem;line-height:1}.donut-center span{font-size:.68rem;color:var(--color-text-tertiary);margin-top:2px}.rw-donut-legend{display:flex;flex-direction:column;gap:12px}.rw-donut-legend__item{display:flex;align-items:center;gap:10px;font-size:.88rem}.rw-donut-legend__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.rw-donut-legend__dot--user{background:var(--color-accent)}.rw-donut-legend__dot--ai{background:#93c5fd80}.rw-donut-legend__label{color:var(--color-text-secondary)}.rw-donut-legend__count{font-family:var(--font-display);color:var(--color-text-primary)}.rw-ach-section{margin-bottom:28px}.rw-ach-label{display:block;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-tertiary);font-weight:600;margin-bottom:10px}.rw-ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.ach-card{border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;padding:16px;transition:border-color .2s ease}.ach-card--unlocked{border-left:3px solid var(--color-accent)}.ach-card--locked{opacity:.55}.ach-card:hover{border-color:#d4a26a1f}.ach-card__top{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.ach-card__icon{font-size:1.3rem;flex-shrink:0}.ach-card__info{flex:1;min-width:0}.ach-card__title{display:block;font-family:var(--font-display);font-size:.9rem;margin-bottom:2px}.ach-card__desc{display:block;font-size:.74rem;color:var(--color-text-tertiary);line-height:1.4}.ach-card__credits{font-family:var(--font-display);font-size:.78rem;color:var(--color-accent);flex-shrink:0}.ach-card__unlocked-row{display:flex;align-items:center;gap:8px}.ach-card__pill{display:inline-flex;padding:3px 8px;border-radius:999px;font-size:.56rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#c6f2da;border:1px solid rgba(110,231,183,.22);background:#6ee7b714}.ach-card__date{font-size:.72rem;color:var(--color-text-tertiary)}.ach-card__progress{display:flex;flex-direction:column;gap:6px}.ach-card__bar{height:4px;border-radius:2px;background:#ffffff0f;overflow:hidden}.ach-card__fill{height:100%;border-radius:2px;background:var(--color-accent);transition:width .4s ease}.ach-card__remaining{font-size:.7rem;color:var(--color-text-muted)}.rw-history-list{display:flex;flex-direction:column;gap:8px}.rw-history-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff06}.rw-history-item__left{flex:1;min-width:0}.rw-history-item__desc{font-size:.84rem;color:var(--color-text-primary)}.rw-history-item__date{display:block;margin-top:2px;font-size:.72rem;color:var(--color-text-tertiary)}.rw-history-item__amount{font-family:var(--font-display);font-size:.92rem;flex-shrink:0}.rw-history-item__amount--positive{color:#6ee7b7}.rw-history-item__amount--negative{color:var(--color-text-tertiary)}@media (max-width: 900px){.rw-page{padding:24px 18px 50px}.rw-stats,.rw-ach-grid{grid-template-columns:repeat(2,1fr)}.rw-donut-section{flex-direction:column;text-align:center}}@media (max-width: 640px){.rw-page{padding:18px 14px 40px}.rw-header{flex-direction:column}.rw-stats,.rw-ach-grid{grid-template-columns:1fr}.rw-challenge{flex-direction:column;align-items:flex-start}}@media (prefers-reduced-motion: reduce){.rw-fade{animation:none}.ach-card__fill{transition:none}}.ach-toast-container{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.ach-toast{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:12px;background:#1e1e1ef2;border:1px solid rgba(212,162,106,.3);box-shadow:0 8px 32px #00000080;backdrop-filter:blur(12px);animation:ach-toast-in .4s ease-out forwards;pointer-events:auto;min-width:300px}.ach-toast__icon{font-size:1.6rem}.ach-toast__info{display:flex;flex-direction:column;gap:2px;flex:1}.ach-toast__label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent, #d4a26a)}.ach-toast__title{font-size:.88rem;font-weight:600;color:var(--color-text-primary, #e8e8e8)}.ach-toast__credits{font-size:.78rem;font-weight:700;color:var(--color-accent, #d4a26a);white-space:nowrap}@keyframes ach-toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.mkt-studio{height:100vh;min-height:100vh;max-width:1100px;margin:0 auto;padding:36px 32px 80px;color:var(--color-text-primary);font-family:var(--font-body);overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative}.mkt-studio:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 70% 50% at 8% 0%,rgba(212,162,106,.09),transparent 50%),radial-gradient(ellipse 50% 40% at 92% 5%,rgba(167,139,100,.08),transparent 40%),radial-gradient(ellipse 60% 50% at 50% 100%,rgba(212,162,106,.03),transparent 50%),linear-gradient(180deg,#0c0f0c,#0e110e);pointer-events:none}.mkt-studio.loading{display:flex;align-items:center;justify-content:center}@supports (height: 100dvh){.mkt-studio{height:100dvh;min-height:100dvh}}.mkt-header{display:flex;align-items:center;gap:16px;margin-bottom:28px}.mkt-header-icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:#d4a26a1a;border:1px solid rgba(212,162,106,.15);color:var(--color-accent);font-size:1.1rem;flex-shrink:0}.mkt-header h1{margin:0;font-family:var(--font-display);font-size:1.2rem;font-weight:600;flex:1;min-width:0}.mkt-header-actions{display:flex;gap:8px;flex-shrink:0}.mkt-header-actions .btn{padding:8px 18px;font-size:.78rem}.mkt-tabs{display:flex;gap:0;border-bottom:1px solid rgba(212,162,106,.1);margin-bottom:0}.mkt-tab{position:relative;cursor:pointer;padding:11px 18px;font-family:var(--font-body);font-size:.8rem;font-weight:500;color:var(--color-text-tertiary);background:none;border:none;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease;display:inline-flex;align-items:center;gap:6px}.mkt-tab:hover{color:var(--color-text-secondary)}.mkt-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.mkt-tab-icon{font-size:.9rem;opacity:.7}.mkt-tab.active .mkt-tab-icon{opacity:1}.mkt-surface{padding:24px 0 0;min-height:460px}.mkt-fade{animation:mkt-fade-in .26s ease}.mkt-overview-title{margin:0 0 6px;font-family:var(--font-display);font-size:1.15rem;font-weight:600}.mkt-overview-desc{margin:0 0 20px;font-size:.84rem;color:var(--color-text-secondary)}.mkt-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}.mkt-stat-card{border-radius:12px;border:1px solid rgba(255,255,255,.05);background:#ffffff05;padding:16px;transition:border-color .2s ease,transform .2s ease}.mkt-stat-card:hover{border-color:#d4a26a24;transform:translateY(-1px)}.mkt-stat-card .stat-number{display:block;font-family:var(--font-display);font-size:1.6rem;font-weight:700;line-height:1;margin-bottom:4px;color:var(--color-accent)}.mkt-stat-card .stat-label{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-tertiary)}.mkt-actions-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:24px}.mkt-action-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:14px;border:1px solid rgba(255,255,255,.05);background:#ffffff05;cursor:pointer;transition:border-color .22s ease,background .22s ease,transform .2s ease;text-align:left;color:var(--color-text-primary);font-family:var(--font-body)}.mkt-action-card:hover{border-color:#d4a26a2e;background:#d4a26a0a;transform:translateY(-1px)}.mkt-action-icon{width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;background:#d4a26a1a;border:1px solid rgba(212,162,106,.14);color:var(--color-accent)}.mkt-action-text{flex:1;min-width:0}.mkt-action-text strong{display:block;font-size:.88rem;font-weight:600;margin-bottom:2px}.mkt-action-text span{display:block;font-size:.72rem;color:var(--color-text-tertiary)}.mkt-action-arrow{color:var(--color-text-tertiary);font-size:.9rem;flex-shrink:0;transition:transform .2s ease}.mkt-action-card:hover .mkt-action-arrow{transform:translate(3px);color:var(--color-accent)}.mkt-empty-state{border-radius:16px;border:1px dashed rgba(212,162,106,.14);background:#ffffff03;padding:48px 24px;text-align:center}.mkt-empty-icon{font-size:2.4rem;display:block;margin:0 auto 12px;opacity:.4}.mkt-empty-state h3{margin:0 0 8px;font-family:var(--font-display);font-size:1rem;font-weight:600}.mkt-empty-state p{margin:0 0 18px;font-size:.82rem;color:var(--color-text-tertiary)}.mkt-empty-actions{display:flex;gap:8px;justify-content:center}.vs-atelier-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(212,162,106,.08)}.vs-atelier-title-block{display:flex;align-items:center;gap:14px}.vs-atelier-title{margin:0;font-family:var(--font-display);font-size:1.3rem;font-weight:700;letter-spacing:-.01em}.vs-atelier-rule{display:block;width:1px;height:20px;background:#d4a26a40}.vs-atelier-subtitle{margin:0;font-size:.78rem;color:var(--color-text-tertiary);font-style:italic}.vs-engine-toggle{display:flex;gap:4px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:3px}.vs-engine-chip{display:flex;align-items:center;gap:6px;padding:7px 14px;border:none;border-radius:8px;background:transparent;color:var(--color-text-tertiary);font-family:var(--font-body);font-size:.74rem;font-weight:600;cursor:pointer;transition:all .2s ease}.vs-engine-chip:hover{color:var(--color-text-secondary)}.vs-engine-chip.active{background:#d4a26a1f;color:var(--color-accent);box-shadow:0 1px 4px #0003}.vs-engine-dot{width:6px;height:6px;border-radius:50%}.vs-engine-dot.quick{background:#86efac;box-shadow:0 0 6px #86efac66}.vs-engine-dot.studio{background:var(--color-accent);box-shadow:0 0 6px #d4a26a66}.vs-engine-cost{font-size:.62rem;opacity:.6;margin-left:-2px}.vs-atelier-layout{display:grid;grid-template-columns:380px minmax(0,1fr);gap:20px;align-items:start}.vs-palette{display:flex;flex-direction:column;gap:0}.vs-palette-group{padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}.vs-palette-group:first-child{padding-top:0}.vs-palette-group:last-child{border-bottom:none}.vs-palette-label{display:block;font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--color-text-tertiary);margin-bottom:10px}.vs-style-mosaic{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.vs-mosaic-tile{position:relative;padding:10px 10px 8px;border:1px solid rgba(255,255,255,.04);border-radius:8px;background:#ffffff04;text-align:left;cursor:pointer;font-family:var(--font-body);color:var(--color-text-primary);transition:all .18s ease;overflow:hidden}.vs-mosaic-tile:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--color-accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.vs-mosaic-tile:hover{border-color:#d4a26a26;background:#d4a26a08}.vs-mosaic-tile.active{border-color:#d4a26a59;background:#d4a26a14}.vs-mosaic-tile.active:before{transform:scaleX(1)}.vs-mosaic-name{display:block;font-size:.76rem;font-weight:600;margin-bottom:1px}.vs-mosaic-desc{display:block;font-size:.58rem;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vs-format-row{display:flex;gap:5px}.vs-format-btn{flex:1;padding:8px 6px;border:1px solid rgba(255,255,255,.04);border-radius:8px;background:#ffffff04;text-align:center;cursor:pointer;font-family:var(--font-body);color:var(--color-text-primary);transition:all .18s ease}.vs-format-btn:hover{border-color:#d4a26a26}.vs-format-btn.active{border-color:#d4a26a66;background:#d4a26a1a}.vs-format-ratio{display:block;font-size:.82rem;font-weight:700;margin-bottom:1px}.vs-format-desc{display:block;font-size:.56rem;color:var(--color-text-tertiary);text-transform:capitalize}.vs-char-chips{display:flex;flex-wrap:wrap;gap:5px}.vs-char-chip{display:flex;align-items:center;gap:6px;padding:5px 12px 5px 5px;border:1px solid rgba(255,255,255,.06);border-radius:999px;background:#ffffff05;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.72rem;font-weight:500;cursor:pointer;transition:all .2s ease}.vs-char-chip:hover{border-color:#d4a26a40;color:var(--color-text-primary);background:#d4a26a0a}.vs-char-chip.active{border-color:#d4a26a80;background:#d4a26a1f;color:var(--color-accent);box-shadow:0 0 12px #d4a26a14}.vs-char-avatar{width:20px;height:20px;border-radius:50%;background:#d4a26a1f;border:1px solid rgba(212,162,106,.2);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:var(--color-accent);flex-shrink:0}.vs-char-chip.active .vs-char-avatar{background:#d4a26a40;border-color:#d4a26a66}.vs-char-active-note{margin-top:6px;font-size:.62rem;color:var(--color-accent);font-style:italic;opacity:.8}.vs-context-select{width:100%;border:1px solid rgba(255,255,255,.05);border-radius:8px;background:#ffffff06;color:var(--color-text-primary);padding:9px 12px;font-family:var(--font-body);font-size:.78rem;transition:border-color .2s ease}.vs-context-select:focus{outline:none;border-color:#d4a26a4d}.vs-context-attached{margin-top:6px;padding:8px 10px;border-radius:6px;border-left:2px solid rgba(212,162,106,.4);background:#d4a26a08;font-size:.7rem;color:var(--color-text-tertiary);line-height:1.5}.vs-context-attached-tag{display:inline-block;font-size:.54rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent);margin-bottom:3px}.vs-context-attached p{margin:0}.vs-prompt-group{padding-bottom:0!important}.vs-prompt-input{width:100%;border:1px solid rgba(255,255,255,.06);border-radius:10px;background:#ffffff06;color:var(--color-text-primary);padding:12px 14px;font-family:var(--font-body);font-size:.82rem;line-height:1.6;resize:vertical;min-height:80px;transition:border-color .25s ease,box-shadow .25s ease}.vs-prompt-input:focus{outline:none;border-color:#d4a26a4d;box-shadow:0 0 0 3px #d4a26a0f}.vs-prompt-input::placeholder{color:var(--color-text-tertiary);opacity:.6;font-style:italic}.vs-generate-btn{width:100%;margin-top:10px;padding:13px 20px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--color-accent),rgba(190,145,90,.9));color:#0c0f0c;font-family:var(--font-body);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.01em;position:relative;overflow:hidden}.vs-generate-btn:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .6s ease}.vs-generate-btn:hover:not(:disabled):after{transform:translate(100%)}.vs-generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #d4a26a33}.vs-generate-btn:disabled{opacity:.35;cursor:not-allowed}.vs-gen-spinner{width:14px;height:14px;border:2px solid rgba(12,15,12,.2);border-top-color:#0c0f0c;border-radius:50%;animation:vs-spin .7s linear infinite}.vs-canvas{display:flex;flex-direction:column;gap:12px}.vs-canvas-main{border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff03;min-height:480px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.vs-canvas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 28px;text-align:center}.vs-canvas-loader{position:relative;width:48px;height:48px;margin-bottom:20px}.vs-loader-ring{position:absolute;inset:0;border:2px solid rgba(212,162,106,.1);border-top-color:var(--color-accent);border-radius:50%;animation:vs-spin 1.2s cubic-bezier(.5,0,.5,1) infinite}.vs-loader-ring-2{inset:6px;border-top-color:#d4a26a80;animation-duration:1.8s;animation-direction:reverse}.vs-canvas-loading-text{margin:0 0 4px;font-family:var(--font-display);font-size:.92rem;font-weight:600;color:var(--color-text-primary)}.vs-canvas-loading-sub{font-size:.72rem;color:var(--color-text-tertiary)}.vs-canvas-image-wrap{width:100%;position:relative}.vs-canvas-image{width:100%;display:block;border-radius:14px}.vs-canvas-image-overlay{position:absolute;bottom:0;left:0;right:0;padding:16px;background:linear-gradient(transparent,#0009);border-radius:0 0 14px 14px;display:flex;align-items:flex-end;justify-content:flex-start}.vs-canvas-image-badge{font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#ffffffd9;padding:4px 10px;border-radius:6px;background:#00000059;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.vs-canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 28px;text-align:center}.vs-canvas-empty-frame{width:72px;height:72px;border:1px dashed rgba(212,162,106,.12);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.vs-canvas-empty-title{margin:0 0 6px;font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text-primary)}.vs-canvas-empty-desc{margin:0;font-size:.76rem;color:var(--color-text-tertiary);max-width:28ch;line-height:1.5}.vs-history{border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff03;padding:12px}.vs-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.vs-history-label{font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-tertiary)}.vs-history-count{font-size:.6rem;color:var(--color-text-tertiary);opacity:.7}.vs-history-scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}.vs-history-thumb{position:relative;border:1px solid rgba(255,255,255,.04);border-radius:8px;overflow:hidden;cursor:pointer;background:transparent;padding:0;transition:all .2s ease}.vs-history-thumb:hover{border-color:#d4a26a33;transform:translateY(-1px)}.vs-history-thumb.active{border-color:#d4a26a80;box-shadow:0 0 0 1px #d4a26a33}.vs-history-img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.vs-history-meta{padding:5px 6px;display:flex;justify-content:space-between;align-items:center;gap:4px}.vs-history-style{font-size:.56rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vs-history-time{font-size:.52rem;color:var(--color-text-tertiary);flex-shrink:0}@keyframes vs-spin{to{transform:rotate(360deg)}}.cs-header{margin-bottom:20px}.cs-title{margin:0 0 4px;font-family:var(--font-display);font-size:1.2rem;font-weight:700}.cs-subtitle{margin:0;font-size:.78rem;color:var(--color-text-tertiary)}.cs-generator{border-radius:14px;border:1px solid rgba(255,255,255,.05);background:#ffffff04;padding:20px}.cs-section{margin-bottom:16px}.cs-label{display:block;font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-tertiary);margin-bottom:8px}.cs-type-chips{display:flex;flex-wrap:wrap;gap:5px}.cs-type-chip{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid rgba(255,255,255,.06);border-radius:8px;background:#ffffff05;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.74rem;font-weight:500;cursor:pointer;transition:all .18s ease}.cs-type-chip:hover{border-color:#d4a26a33;color:var(--color-text-primary)}.cs-type-chip.active{border-color:#d4a26a73;background:#d4a26a1f;color:var(--color-accent)}.cs-type-icon{font-size:.82rem}.cs-row{display:grid;grid-template-columns:1fr 200px;gap:16px}.cs-tone-section{flex:1}.cs-tone-pills{display:flex;flex-wrap:wrap;gap:5px}.cs-tone-pill{padding:5px 12px;border:1px solid rgba(255,255,255,.06);border-radius:999px;background:#ffffff05;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.7rem;font-weight:500;cursor:pointer;transition:all .18s ease}.cs-tone-pill:hover{border-color:#d4a26a33}.cs-tone-pill.active{border-color:#d4a26a73;background:#d4a26a1f;color:var(--color-accent)}.cs-select{width:100%;padding:9px 12px;border:1px solid rgba(255,255,255,.06);border-radius:8px;background:#ffffff08;color:var(--color-text-primary);font-family:var(--font-body);font-size:.8rem}.cs-select:focus{outline:none;border-color:#d4a26a4d}.cs-instructions{width:100%;padding:10px 12px;border:1px solid rgba(255,255,255,.06);border-radius:8px;background:#ffffff06;color:var(--color-text-primary);font-family:var(--font-body);font-size:.8rem;line-height:1.5;resize:vertical;min-height:48px}.cs-instructions:focus{outline:none;border-color:#d4a26a4d}.cs-context-attached{margin-top:6px;padding:8px 10px;border-radius:6px;border-left:2px solid rgba(212,162,106,.4);background:#d4a26a08;font-size:.7rem;color:var(--color-text-tertiary);line-height:1.5}.cs-context-tag{display:inline-block;font-size:.54rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent);margin-bottom:3px}.cs-context-preview{margin:0}.cs-auto-context-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.cs-auto-tag{background:#d4a26a14;padding:3px 8px;border-radius:4px;border:1px solid rgba(212,162,106,.15)}.cs-context-hint{font-size:.65rem;color:var(--color-text-tertiary);font-style:italic}.cs-generate-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;margin-top:4px;border:none;border-radius:10px;background:#ffffff0f;color:var(--color-text-primary);font-family:var(--font-body);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s ease}.cs-generate-btn:hover:not(:disabled){background:#ffffff1a}.cs-generate-btn:disabled{opacity:.4;cursor:not-allowed}.cs-variants-section{margin-top:28px}.cs-variants-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.cs-variants-header h3{margin:0;font-family:var(--font-display);font-size:1rem;font-weight:600}.cs-regenerate-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:none;border-radius:6px;background:transparent;color:var(--color-accent);font-family:var(--font-body);font-size:.72rem;font-weight:600;cursor:pointer;transition:background .18s ease}.cs-regenerate-btn:hover{background:#d4a26a14}.cs-variants-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.cs-variant-card{border-radius:12px;border:1px solid rgba(255,255,255,.05);background:#ffffff05;padding:16px;cursor:pointer;transition:all .2s ease}.cs-variant-card:hover{border-color:#d4a26a26}.cs-variant-card.selected{border-color:#d4a26a59;background:#d4a26a0a}.cs-variant-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.cs-variant-label{font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-tertiary)}.cs-variant-saved-badge{font-size:.54rem;font-weight:600;color:#86efac}.cs-variant-content{margin:0 0 14px;font-size:.82rem;line-height:1.6;color:var(--color-text-primary)}.cs-variant-actions{display:flex;gap:6px}.cs-variant-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;font-family:var(--font-body);font-size:.68rem;font-weight:600;cursor:pointer;transition:all .18s ease}.cs-variant-btn.save{border:1px solid rgba(212,162,106,.2);background:#d4a26a14;color:var(--color-accent)}.cs-variant-btn.save:hover{background:#d4a26a24}.cs-variant-btn.save:disabled{opacity:.4;cursor:default}.cs-variant-btn.copy{border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--color-text-secondary)}.cs-variant-btn.copy:hover{border-color:#ffffff1f;color:var(--color-text-primary)}.cs-preview-section{margin-top:24px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff03;overflow:hidden}.cs-preview-tabs{display:flex;align-items:center;gap:0;padding:0 16px;border-bottom:1px solid rgba(255,255,255,.04);background:#ffffff04}.cs-preview-label{font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-tertiary);padding:10px 12px 10px 0;margin-right:4px}.cs-preview-tab{padding:10px 14px;border:none;background:transparent;color:var(--color-text-tertiary);font-family:var(--font-body);font-size:.74rem;font-weight:500;cursor:pointer;transition:color .18s ease;border-bottom:2px solid transparent}.cs-preview-tab:hover{color:var(--color-text-secondary)}.cs-preview-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.cs-preview-canvas{padding:24px;display:flex;justify-content:center}.cs-preview-ig{width:340px;border-radius:12px;background:#fafafa;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#262626}.cs-ig-header{display:flex;align-items:center;gap:10px;padding:12px 14px}.cs-ig-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#c13584,#e1306c,#fd1d1d)}.cs-ig-user strong{display:block;font-size:.78rem}.cs-ig-user span{font-size:.64rem;color:#8e8e8e}.cs-ig-image-placeholder{width:100%;aspect-ratio:1;background:#efefef;display:flex;align-items:center;justify-content:center}.cs-ig-caption{padding:12px 14px;font-size:.78rem;line-height:1.5}.cs-preview-tw{width:420px;border-radius:12px;background:#15202b;padding:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e7e9ea}.cs-tw-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.cs-tw-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#1d9bf0,#1a8cd8)}.cs-tw-user strong{display:block;font-size:.82rem;color:#e7e9ea}.cs-tw-user span{font-size:.68rem;color:#71767b}.cs-tw-content{font-size:.88rem;line-height:1.5;margin-bottom:8px}.cs-tw-meta{font-size:.66rem;color:#71767b}.cs-preview-email{width:420px;border-radius:12px;background:#fff;padding:20px;font-family:Georgia,serif;color:#333}.cs-email-subject{font-size:.76rem;color:#666;padding-bottom:12px;border-bottom:1px solid #eee;margin-bottom:16px}.cs-email-subject span{font-weight:600;margin-right:6px}.cs-email-body{font-size:.88rem;line-height:1.7;margin-bottom:20px}.cs-email-cta{display:inline-block;padding:10px 24px;background:#1a1a1a;color:#fff;border-radius:6px;font-family:var(--font-body);font-size:.78rem;font-weight:600}.al-layout{display:grid;grid-template-columns:200px minmax(0,1fr);gap:20px;min-height:460px}.al-sidebar{display:flex;flex-direction:column;gap:0}.al-filter-group{padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}.al-filter-group:first-child{padding-top:0}.al-filter-group:last-child{border-bottom:none}.al-filter-label{display:block;font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-tertiary);margin-bottom:8px}.al-filter-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .18s ease;text-align:left}.al-filter-btn:hover{background:#ffffff08;color:var(--color-text-primary)}.al-filter-btn.active{background:#d4a26a14;color:var(--color-text-primary)}.al-filter-count{font-size:.66rem;color:var(--color-text-tertiary);font-weight:400}.al-view-toggle{display:flex;border:1px solid rgba(255,255,255,.06);border-radius:8px;overflow:hidden}.al-view-btn{flex:1;padding:7px 0;border:none;background:transparent;color:var(--color-text-tertiary);font-family:var(--font-body);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .18s ease}.al-view-btn.active{background:#d4a26a1a;color:var(--color-accent)}.al-content{min-height:400px}.al-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;text-align:center}.al-empty p{margin:12px 0 0;font-size:.82rem;color:var(--color-text-tertiary)}.al-grid{display:grid;gap:10px}.al-grid.grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.al-grid.list{grid-template-columns:1fr}.al-asset-card{border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff04;overflow:hidden;transition:border-color .2s ease,transform .2s ease}.al-asset-card:hover{border-color:#d4a26a26;transform:translateY(-1px)}.al-asset-image-wrap{position:relative;overflow:hidden}.al-asset-image{width:100%;display:block;aspect-ratio:1;object-fit:cover}.al-asset-badge{position:absolute;bottom:8px;left:8px;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 8px;border-radius:4px;background:#00000080;backdrop-filter:blur(6px);color:#ffffffd9}.al-asset-info{padding:10px 12px}.al-asset-type-tag{display:inline-block;font-size:.54rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:2px 7px;border-radius:4px;margin-right:6px}.al-asset-type-tag.visual{background:#9382dc1f;color:#b3a4e0}.al-asset-type-tag.copy{background:#d4a26a1f;color:var(--color-accent)}.al-asset-ratio{font-size:.62rem;color:var(--color-text-tertiary)}.al-asset-prompt{margin:6px 0 4px;font-size:.72rem;color:var(--color-text-secondary);line-height:1.4}.al-asset-time{font-size:.58rem;color:var(--color-text-tertiary)}.al-asset-copy-card{padding:14px}.al-asset-copy-header{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}.al-asset-copy-type{font-size:.66rem;font-weight:600;color:var(--color-text-secondary)}.al-asset-copy-footer{display:flex;justify-content:space-between;align-items:center}.al-asset-tone{font-size:.6rem;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.06);color:var(--color-text-tertiary)}.al-asset-copy-actions{display:flex;gap:4px;margin-left:auto}.al-copy-action-btn{display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-family:var(--font-body);font-size:.6rem;font-weight:600;cursor:pointer;transition:all .15s ease}.al-copy-action-btn.edit{border:1px solid rgba(255,255,255,.06);background:transparent;color:var(--color-text-tertiary)}.al-copy-action-btn.edit:hover{border-color:#d4a26a40;color:var(--color-accent)}.al-copy-action-btn.copy{border:1px solid rgba(255,255,255,.06);background:transparent;color:var(--color-text-tertiary)}.al-copy-action-btn.copy:hover{border-color:#ffffff1f;color:var(--color-text-primary)}.al-copy-action-btn.save{border:1px solid rgba(74,222,128,.3);background:#4ade8014;color:#86efac}.al-copy-action-btn.save:hover{background:#4ade8024}.al-copy-action-btn.cancel{border:1px solid rgba(255,255,255,.06);background:transparent;color:var(--color-text-tertiary)}.al-copy-action-btn.cancel:hover{color:var(--color-text-primary)}.al-asset-copy-card.editing{border-color:#d4a26a33;background:#d4a26a05}.al-asset-copy-editor{width:100%;padding:10px;border:1px solid rgba(212,162,106,.2);border-radius:8px;background:#0003;color:var(--color-text-primary);font-family:var(--font-body);font-size:.78rem;line-height:1.6;resize:vertical;min-height:80px;margin-bottom:8px}.al-asset-copy-editor:focus{outline:none;border-color:#d4a26a59;box-shadow:0 0 0 2px #d4a26a0f}.al-asset-copy-text{margin:0 0 10px;font-size:.78rem;line-height:1.5;color:var(--color-text-primary)}.comp-header{margin-bottom:20px}.comp-title{margin:0 0 4px;font-family:var(--font-display);font-size:1.2rem;font-weight:700}.comp-subtitle{margin:0;font-size:.78rem;color:var(--color-text-tertiary)}.comp-layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:20px;min-height:460px;align-items:start}.comp-browser{display:flex;flex-direction:column;gap:0;max-height:700px;overflow-y:auto}.comp-browser-section{padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}.comp-browser-section:first-child{padding-top:0}.comp-browser-section:last-child{border-bottom:none}.comp-browser-label{display:block;font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-tertiary);margin-bottom:10px}.comp-empty-hint{margin:0;font-size:.74rem;color:var(--color-text-tertiary);font-style:italic}.comp-copy-list{display:flex;flex-direction:column;gap:6px}.comp-copy-card{text-align:left;padding:10px 12px;border:1px solid rgba(255,255,255,.05);border-radius:10px;background:#ffffff04;cursor:pointer;font-family:var(--font-body);transition:all .2s ease}.comp-copy-card:hover{border-color:#d4a26a2e;background:#d4a26a08}.comp-copy-card.selected{border-color:#d4a26a66;background:#d4a26a0f}.comp-copy-type{display:inline-block;font-size:.54rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:2px 7px;border-radius:4px;background:#d4a26a1f;color:var(--color-accent);margin-bottom:4px}.comp-copy-preview{margin:4px 0;font-size:.74rem;line-height:1.5;color:var(--color-text-primary)}.comp-copy-tone{font-size:.58rem;font-weight:600;padding:1px 6px;border-radius:999px;border:1px solid rgba(255,255,255,.06);color:var(--color-text-tertiary)}.comp-visual-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.comp-visual-thumb{position:relative;border:1px solid rgba(255,255,255,.04);border-radius:8px;overflow:hidden;cursor:pointer;background:transparent;padding:0;transition:all .2s ease}.comp-visual-thumb:hover{border-color:#d4a26a33;transform:translateY(-1px)}.comp-visual-thumb.selected{border-color:#d4a26a80;box-shadow:0 0 0 1px #d4a26a33}.comp-visual-img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.comp-visual-style{display:block;padding:4px 6px;font-size:.52rem;font-weight:600;color:var(--color-text-secondary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.comp-preview{border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff03;min-height:480px;overflow:hidden}.comp-preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 28px;text-align:center}.comp-preview-empty-frame{width:72px;height:72px;border:1px dashed rgba(212,162,106,.12);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.comp-preview-empty-title{margin:0 0 6px;font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text-primary)}.comp-preview-empty-desc{margin:0;font-size:.76rem;color:var(--color-text-tertiary);max-width:28ch;line-height:1.5}.comp-ig-image{width:100%;aspect-ratio:1;object-fit:cover;display:block}.comp-tw-image{width:100%;border-radius:12px;margin-top:10px;margin-bottom:8px;max-height:260px;object-fit:cover}.comp-email-image{width:100%;border-radius:8px;margin-bottom:16px;max-height:300px;object-fit:cover}.comp-share-bar{padding:16px 24px;border-top:1px solid rgba(255,255,255,.04);display:flex;justify-content:flex-end}.comp-share-btn{padding:12px 28px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--color-accent),rgba(190,145,90,.9));color:#0c0f0c;font-family:var(--font-body);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:.01em}.comp-share-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #d4a26a33}.comp-share-btn:disabled{opacity:.35;cursor:not-allowed}.mkt-alert{border-radius:12px;padding:10px 14px;margin-bottom:14px;font-size:.82rem;line-height:1.5}.mkt-alert.error{border:1px solid rgba(248,113,113,.35);background:#f8717114;color:#fecaca}.mkt-alert.success{border:1px solid rgba(74,222,128,.35);background:#4ade8014;color:#bbf7d0}.mkt-muted{color:var(--color-text-tertiary);font-size:.82rem}.mkt-empty-center{text-align:center;padding:40px 20px;color:var(--color-text-tertiary);font-size:.86rem}@keyframes mkt-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 960px){.mkt-stats-row{grid-template-columns:repeat(2,1fr)}.mkt-actions-row,.cs-row,.cs-variants-grid,.al-layout,.vs-atelier-layout,.comp-layout{grid-template-columns:1fr}.vs-style-mosaic{grid-template-columns:repeat(2,1fr)}.vs-atelier-header{flex-direction:column;align-items:flex-start;gap:12px}.mkt-secondary-grid{grid-template-columns:1fr}}@media (max-width: 640px){.mkt-studio{padding:18px 14px 40px}.mkt-header{flex-wrap:wrap}.mkt-header-actions{width:100%}.mkt-header-actions .btn{flex:1}.mkt-stats-row{grid-template-columns:1fr}.mkt-visual-prompt-row{flex-direction:column}}@media (prefers-reduced-motion: reduce){.mkt-fade,.mkt-action-card,.mkt-stat-card,.mkt-visual-type{animation:none;transition:none}}.sb-page{height:100dvh;overflow-y:auto;overscroll-behavior:contain;padding:28px 32px 72px;background:var(--color-bg-primary);color:var(--color-text-primary)}.sb-page.sb-loading{display:flex;align-items:center;justify-content:center}.sb-loader{display:flex;flex-direction:column;align-items:center;gap:14px;color:var(--color-text-tertiary);font-size:.82rem}.sb-loader-ring{width:28px;height:28px;border:2px solid rgba(212,162,106,.15);border-top-color:var(--color-accent);border-radius:50%;animation:sb-spin .8s linear infinite}@keyframes sb-spin{to{transform:rotate(360deg)}}.sb-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px}.sb-breadcrumb{margin-bottom:6px}.sb-breadcrumb-link{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:.72rem;font-family:var(--font-body);padding:0;transition:color .15s}.sb-breadcrumb-link:hover{color:var(--color-accent)}.sb-title{margin:0;font-family:var(--font-display);font-size:1.8rem;font-weight:700;letter-spacing:-.01em}.sb-subtitle{margin:4px 0 0;font-size:.78rem;color:var(--color-text-tertiary)}.sb-header-actions{display:flex;gap:8px;flex-shrink:0;padding-top:18px}.sb-generate-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--color-accent),rgba(190,145,90,.85));color:#0c0f0c;font-family:var(--font-body);font-size:.78rem;font-weight:700;cursor:pointer;transition:all .2s ease}.sb-generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #d4a26a40}.sb-generate-btn:disabled{opacity:.6;cursor:default}.sb-gen-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(12,15,12,.2);border-top-color:#0c0f0c;border-radius:50%;animation:sb-spin .7s linear infinite}.sb-add-btn{padding:10px 18px;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:#ffffff0a;color:var(--color-text-primary);font-family:var(--font-body);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s ease}.sb-add-btn:hover{border-color:#d4a26a4d;background:#d4a26a0f}.sb-alert{border-radius:10px;padding:10px 16px;margin-bottom:16px;font-size:.78rem;animation:sb-fade-in .2s ease-out}.sb-alert.error{border:1px solid rgba(248,113,113,.3);background:#f871710f;color:#fecaca}.sb-alert.success{border:1px solid rgba(74,222,128,.3);background:#4ade800f;color:#bbf7d0}@keyframes sb-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sb-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:80px 28px}.sb-empty-visual{margin-bottom:24px}.sb-empty-orb{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#d4a26a26,#d4a26a08 70%);border:1px solid rgba(212,162,106,.1)}.sb-empty h2{margin:0 0 8px;font-family:var(--font-display);font-size:1.3rem;font-weight:600}.sb-empty p{margin:0 0 24px;font-size:.82rem;color:var(--color-text-tertiary);max-width:40ch;line-height:1.6}.sb-empty-actions{display:flex;gap:10px}.sb-empty-card{text-align:center;padding:40px;color:var(--color-text-secondary)}.sb-layout{display:grid;grid-template-columns:180px minmax(0,1fr);gap:20px;min-height:480px}.sb-layout.has-detail{grid-template-columns:180px minmax(0,1fr) 360px}.sb-sidebar{position:sticky;top:16px;align-self:start}.sb-search{display:flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid rgba(255,255,255,.06);border-radius:8px;background:#ffffff05;margin-bottom:14px;transition:border-color .15s}.sb-search:focus-within{border-color:#d4a26a4d}.sb-search svg{flex-shrink:0;color:var(--color-text-muted)}.sb-search input{flex:1;background:none;border:none;color:var(--color-text-primary);font-size:.76rem;outline:none;font-family:var(--font-body);min-width:0}.sb-search-clear{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1rem;padding:0;line-height:1}.sb-categories{display:flex;flex-direction:column;gap:1px}.sb-cat-btn{display:flex;align-items:center;gap:8px;padding:7px 10px;border:none;background:transparent;border-radius:8px;color:var(--color-text-secondary);cursor:pointer;font-size:.76rem;font-family:var(--font-body);text-align:left;transition:all .12s ease}.sb-cat-btn:hover{background:#ffffff08}.sb-cat-btn.active{background:#d4a26a14;color:var(--color-accent)}.sb-cat-icon{width:18px;text-align:center}.sb-cat-label{flex:1}.sb-cat-count{font-size:.6rem;font-weight:600;background:#ffffff0d;padding:1px 5px;border-radius:999px;color:var(--color-text-muted)}.sb-content{min-height:300px}.sb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}.sb-no-results{grid-column:1 / -1;text-align:center;color:var(--color-text-tertiary);font-size:.78rem;padding:48px}.sb-card{text-align:left;padding:14px;border:1px solid rgba(255,255,255,.04);border-radius:10px;background:#ffffff03;cursor:pointer;font-family:var(--font-body);transition:all .18s ease;display:flex;flex-direction:column;gap:4px}.sb-card:hover{border-color:#ffffff1a;background:#ffffff06}.sb-card.selected{border-color:#d4a26a59;background:#d4a26a0a}.sb-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.sb-card-cat{display:inline-flex;align-items:center;gap:3px;font-size:.6rem;font-weight:600;padding:2px 6px;border-radius:4px;background:color-mix(in srgb,var(--cat-color) 12%,transparent);color:var(--cat-color)}.sb-card-x{opacity:0;background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1rem;padding:0 2px;line-height:1;transition:.12s}.sb-card:hover .sb-card-x{opacity:.4}.sb-card-x:hover{opacity:1!important;color:#f87171}.sb-card-name{margin:0;font-family:var(--font-display);font-size:.88rem;font-weight:600}.sb-card-aliases{margin:0;font-size:.64rem;color:var(--color-text-muted)}.sb-card-desc{margin:0;font-size:.72rem;line-height:1.5;color:var(--color-text-secondary)}.sb-card-facts{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.sb-card-fact{font-size:.58rem;padding:1px 6px;border-radius:4px;background:#ffffff0a;color:var(--color-text-muted)}.sb-card-fact strong{color:var(--color-text-secondary);margin-right:2px}.sb-detail{position:sticky;top:16px;align-self:start;max-height:calc(100dvh - 120px);overflow-y:auto;border:1px solid rgba(255,255,255,.06);border-radius:12px;background:#ffffff04;padding:20px;animation:sb-slide-in .2s ease-out}@keyframes sb-slide-in{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.sb-detail-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sb-detail-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:6px;background:color-mix(in srgb,var(--cat-color) 12%,transparent);color:var(--cat-color)}.sb-detail-btns{display:flex;gap:6px;align-items:center}.sb-close-btn{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:6px;transition:.12s}.sb-close-btn:hover{color:var(--color-text-primary);background:#ffffff0d}.sb-btn-sm{padding:5px 12px;border:1px solid rgba(255,255,255,.08);border-radius:6px;background:#ffffff08;color:var(--color-text-secondary);font-size:.68rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:.12s}.sb-btn-sm:hover{border-color:#ffffff26;color:var(--color-text-primary)}.sb-btn-sm.sb-btn-primary{background:var(--color-accent);border-color:var(--color-accent);color:#0c0f0c}.sb-btn-sm.sb-btn-primary:hover{opacity:.9}.sb-btn-sm:disabled{opacity:.4;cursor:default}.sb-view-name{margin:0 0 4px;font-family:var(--font-display);font-size:1.1rem;font-weight:600}.sb-view-aliases{margin:0 0 12px;font-size:.72rem;color:var(--color-text-muted);font-style:italic}.sb-view-desc{margin:0 0 16px;font-size:.78rem;line-height:1.65;color:var(--color-text-secondary);white-space:pre-wrap}.sb-view-facts{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.sb-view-fact{display:flex;gap:8px;font-size:.76rem}.sb-view-fact-key{font-weight:600;color:var(--color-text-primary);min-width:70px;flex-shrink:0}.sb-view-fact-val{color:var(--color-text-secondary)}.sb-view-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px}.sb-view-tag{font-size:.6rem;padding:2px 8px;border-radius:999px;background:#d4a26a14;color:var(--color-accent);border:1px solid rgba(212,162,106,.15)}.sb-edit{display:flex;flex-direction:column;gap:8px}.sb-edit-name{background:none;border:none;border-bottom:1px solid rgba(255,255,255,.1);color:var(--color-text-primary);font-family:var(--font-display);font-size:1.1rem;font-weight:600;padding:4px 0;outline:none}.sb-edit-name:focus{border-bottom-color:var(--color-accent)}.sb-edit-input,.sb-edit-textarea{background:#00000026;border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:8px 10px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.78rem;outline:none;transition:border-color .12s}.sb-edit-input:focus,.sb-edit-textarea:focus{border-color:#d4a26a4d}.sb-edit-textarea{resize:vertical;line-height:1.6}.sb-edit-section-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-top:6px}.sb-edit-fact-row{display:flex;gap:6px;align-items:center}.sb-edit-fact-row input{flex:1;background:#00000026;border:1px solid rgba(255,255,255,.06);border-radius:6px;padding:6px 8px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.74rem;outline:none}.sb-edit-fact-row input:focus{border-color:#d4a26a4d}.sb-edit-fact-x{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1rem;padding:0 2px}.sb-edit-fact-x:hover{color:#f87171}.sb-rels{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.04)}.sb-rels-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sb-rels-title{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted)}.sb-rels-form{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.sb-rels-form select,.sb-rels-form input{background:#00000026;border:1px solid rgba(255,255,255,.06);border-radius:6px;padding:6px 8px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.74rem;outline:none}.sb-rels-list{display:flex;flex-direction:column;gap:4px}.sb-rel-row{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;background:#ffffff05}.sb-rel-name{background:none;border:none;color:var(--color-accent);cursor:pointer;font-size:.74rem;font-weight:600;font-family:var(--font-body);padding:0}.sb-rel-name:hover{text-decoration:underline}.sb-rel-label{flex:1;font-size:.64rem;color:var(--color-text-muted)}.sb-rel-x{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:.85rem;padding:0 2px}.sb-rel-x:hover{color:#f87171}.sb-rels-none{margin:0;font-size:.72rem;color:var(--color-text-tertiary)}.sb-create{border:1px solid rgba(212,162,106,.15);border-radius:12px;background:#d4a26a05;padding:18px;margin-bottom:14px;animation:sb-fade-in .15s ease-out}.sb-create-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.sb-create-top h3{margin:0;font-family:var(--font-display);font-size:.92rem}.sb-mode-toggle{display:flex;border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden}.sb-mode-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border:none;background:transparent;color:var(--color-text-muted);font-family:var(--font-body);font-size:.68rem;font-weight:600;cursor:pointer;transition:all .12s ease}.sb-mode-btn:first-child{border-right:1px solid rgba(255,255,255,.08)}.sb-mode-btn.active{background:#d4a26a1f;color:var(--color-accent)}.sb-mode-btn:hover:not(.active){background:#ffffff08}.sb-create-hint{margin:0 0 12px;font-size:.72rem;color:var(--color-text-tertiary);line-height:1.5}.sb-freeform{width:100%;background:#0003;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.82rem;line-height:1.6;outline:none;resize:vertical;transition:border-color .15s}.sb-freeform:focus{border-color:#d4a26a59}.sb-freeform::placeholder{color:var(--color-text-muted);opacity:.6}.sb-create-fields{display:flex;gap:8px;margin-bottom:8px}.sb-create select,.sb-create input,.sb-create textarea{background:#0003;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:8px 10px;color:var(--color-text-primary);font-family:var(--font-body);font-size:.78rem;outline:none;width:100%}.sb-create select{width:auto;min-width:130px}.sb-create input:focus,.sb-create textarea:focus{border-color:#d4a26a4d}.sb-create textarea{resize:vertical}.sb-create-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.sb-btn-primary{padding:8px 18px;border:none;border-radius:8px;background:var(--color-accent);color:#0c0f0c;font-family:var(--font-body);font-size:.78rem;font-weight:700;cursor:pointer;transition:.15s}.sb-btn-primary:hover:not(:disabled){opacity:.9}.sb-btn-primary:disabled{opacity:.4;cursor:default}.sb-upgrade-banner{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 18px;margin-bottom:16px;border:1px solid rgba(212,162,106,.2);border-radius:12px;background:#d4a26a0a}.sb-upgrade-text{font-size:.78rem;color:var(--color-text-secondary)}.sb-upgrade-text strong{color:var(--color-accent)}.sb-upgrade-actions{display:flex;gap:8px;flex-shrink:0}.sb-legacy{display:flex;flex-direction:column;gap:12px}.sb-legacy-summary{padding:16px 20px;border:1px solid rgba(255,255,255,.06);border-radius:12px;background:#ffffff04}.sb-legacy-summary p{margin:0;font-size:.82rem;color:var(--color-text-secondary);line-height:1.6}.sb-legacy-section{padding:18px 20px;border:1px solid rgba(255,255,255,.05);border-radius:12px;background:#ffffff03}.sb-legacy-section h2{margin:0 0 12px;font-family:var(--font-display);font-size:1.05rem}.sb-legacy-section p{margin:0 0 8px;font-size:.8rem;color:var(--color-text-secondary);line-height:1.55}.sb-legacy-section ul{margin:0 0 8px 18px;color:var(--color-text-secondary);font-size:.8rem;display:flex;flex-direction:column;gap:4px}.sb-legacy-entry{border:1px solid rgba(255,255,255,.04);border-radius:8px;padding:12px 14px;margin-top:8px;background:#ffffff04}.sb-legacy-entry h3{margin:0 0 6px;font-family:var(--font-display);font-size:.88rem}.sb-legacy-entry p{margin:0 0 6px;font-size:.76rem;color:var(--color-text-secondary)}.sb-legacy-entry ul{margin:0 0 6px 16px;font-size:.76rem;color:var(--color-text-secondary)}@media (max-width: 960px){.sb-page{padding:18px 12px 48px}.sb-header{flex-direction:column;align-items:flex-start}.sb-header-actions{padding-top:0}.sb-layout,.sb-layout.has-detail{grid-template-columns:1fr}.sb-sidebar{position:static}.sb-categories{flex-direction:row;flex-wrap:wrap;gap:4px}.sb-detail{position:static;max-height:none}}@media (prefers-reduced-motion: reduce){.sb-detail,.sb-create,.sb-alert{animation:none}.sb-card,.sb-generate-btn{transition:none}}.reader-preview{height:100vh;overflow-y:auto;overscroll-behavior:contain;max-width:1380px;margin:0 auto;padding:34px 34px 64px;background:radial-gradient(ellipse 52% 40% at 50% 0%,rgba(212,162,106,.06),transparent 60%),var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-body)}@supports (height: 100dvh){.reader-preview{height:100dvh}}.reader-preview.loading{display:flex;align-items:center;justify-content:center}.reader-preview-card{border:1px solid var(--color-surface-border);border-radius:14px;padding:24px 28px;background:var(--v5-card-bg);font-family:var(--font-display)}.rp-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.rp-tag{display:inline-block;font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-accent);font-weight:600}.rp-header h1{margin:8px 0 10px;font-family:var(--font-display);font-size:clamp(1.8rem,3.2vw,2.35rem);line-height:1.15}.rp-header p{margin:0;color:var(--color-text-secondary);max-width:760px;line-height:1.6;font-size:.92rem}.rp-header-actions{display:flex;gap:8px;flex-shrink:0}.rp-status-banner,.rp-missing-notice,.rp-empty-warning{margin-top:14px;border-radius:12px;border:1px solid var(--color-surface-border);background:var(--v5-card-bg);padding:12px 14px;font-size:.84rem}.rp-status-banner .error-text,.rp-empty-warning{color:#fecaca}.rp-empty-warning{border-color:#f8717159;background:#f8717114}.rp-missing-notice{border-color:#d4a26a40;background:#d4a26a14;color:var(--color-text-secondary)}.rp-grid{margin-top:16px;display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,420px);gap:16px;align-items:start}.rp-preview-shell{border:1px solid var(--color-surface-border);border-radius:16px;background:var(--v5-card-bg);padding:14px}.rp-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.rp-preview-header h2{margin:0;font-family:var(--font-display);font-size:1rem}.rp-preview-header span{font-size:.76rem;color:var(--color-text-secondary)}.rp-controls{position:sticky;top:14px;max-height:calc(100vh - 28px);overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding-right:2px}@supports (height: 100dvh){.rp-controls{max-height:calc(100dvh - 28px)}}.rp-card{border:1px solid var(--color-surface-border);border-radius:14px;background:var(--v5-card-bg);padding:16px}.rp-card h2{margin:0;font-family:var(--font-display);font-size:.98rem}.rp-controls-card .rp-card-header{margin-bottom:12px}.rp-card-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.rp-card-header span{color:var(--color-accent);font-size:.75rem;border:1px solid rgba(212,162,106,.28);border-radius:100px;padding:2px 10px}.rp-reset-btn{border:1px solid rgba(212,162,106,.26);border-radius:20px;background:transparent;color:var(--color-accent);font-size:.72rem;padding:5px 10px;cursor:pointer}.rp-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-bottom:12px}.rp-tab-btn{border:1px solid var(--color-surface-border);border-radius:8px;background:transparent;color:var(--color-text-secondary);font-size:.72rem;padding:6px 8px;cursor:pointer}.rp-tab-btn.active{color:var(--color-accent);border-color:#d4a26a59;background:#d4a26a14}.rp-tab-panel{display:flex;flex-direction:column;gap:10px}.rp-card label{display:flex;flex-direction:column;gap:6px;font-size:.79rem;color:var(--color-text-secondary)}.rp-card select,.rp-card input{border:1px solid var(--color-surface-border);border-radius:10px;background:#d4a26a0a;color:var(--color-text-primary);padding:8px 10px;font:inherit}.rp-color-row{display:flex;align-items:center;gap:8px}.rp-color-row input[type=color]{width:44px;height:34px;padding:0;border-radius:8px;overflow:hidden;cursor:pointer}.rp-color-row code{font-size:.74rem;color:var(--color-text-secondary);border:1px solid var(--color-surface-border);border-radius:6px;padding:2px 6px}.rp-help-text{margin:0;font-size:.76rem;line-height:1.5;color:var(--color-text-muted)}.rp-selected-list,.rp-available-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:260px;overflow:auto}.rp-selected-item,.rp-available-list li{border:1px solid var(--color-surface-border);border-radius:10px;background:#d4a26a0d}.rp-selected-item{display:flex;align-items:center;gap:8px;padding:10px}.rp-selected-item.dragging{opacity:.6}.rp-selected-item.overlay{width:100%;max-width:340px;flex-direction:column;align-items:flex-start}.rp-drag-handle{border:1px solid rgba(212,162,106,.2);background:transparent;color:var(--color-text-secondary);border-radius:8px;width:28px;height:28px;cursor:grab;flex-shrink:0}.rp-drag-handle:active{cursor:grabbing}.rp-selected-copy,.rp-available-copy{display:flex;flex-direction:column;min-width:0;gap:2px}.rp-selected-name{font-size:.83rem;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-selected-path,.rp-available-copy small{font-size:.7rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-item-action{margin-left:auto;border:1px solid rgba(212,162,106,.26);background:transparent;color:var(--color-accent);border-radius:20px;padding:5px 10px;font-size:.72rem;cursor:pointer;transition:all .2s;flex-shrink:0}.rp-item-action:hover{background:#d4a26a14;border-color:#d4a26a61}.rp-available-list li{display:flex;align-items:center;gap:10px;padding:10px}.rp-available-copy span{font-size:.82rem}.rp-muted{margin:0;color:var(--color-text-muted);font-size:.8rem}.rp-book{display:flex;flex-direction:column;align-items:center;gap:22px;font-size:var(--rp-font-size, 12px);line-height:var(--rp-line-height, 1.65)}.rp-book-page{width:min(100%,var(--rp-page-width, 760px));min-height:880px;border:1px solid rgba(60,48,32,.2);border-radius:8px;padding:var(--rp-page-padding, 56px);box-shadow:0 24px 42px #00000052;background:var(--rp-page-bg, #f8f5ef);color:var(--rp-body-color, #1b1b1b)}.rp-title-page{display:flex;align-items:center;justify-content:center}.rp-title-inner{text-align:center;max-width:72%}.rp-title-label{text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--rp-heading-color, #111111);opacity:.72;margin-bottom:16px}.rp-title-inner h3{margin:0 0 16px;font-family:var(--rp-heading-font, Garamond, serif);font-size:clamp(2rem,4vw,2.6rem);line-height:1.1;color:var(--rp-heading-color, #111111)}.rp-title-inner p{margin:0;line-height:1.7;font-size:1.02em;color:var(--rp-body-color, #1b1b1b)}.rp-title-muted{opacity:.75}.rp-content-page{break-before:page;page-break-before:always}.rp-page-path{font-size:.74em;color:var(--rp-body-color, #1b1b1b);opacity:.72;margin-bottom:20px;letter-spacing:.02em}.rp-markdown-preview{font-size:inherit;line-height:inherit;font-family:var(--rp-body-font, Georgia, serif);color:var(--rp-body-color, #1b1b1b)}.rp-markdown-preview h1,.rp-markdown-preview h2,.rp-markdown-preview h3,.rp-markdown-preview h4{font-family:var(--rp-heading-font, Garamond, serif);margin-top:1.6em;margin-bottom:calc(.6em * var(--rp-paragraph-spacing, 1));line-height:1.25;color:var(--rp-heading-color, #111111)}.rp-markdown-preview h1{margin-top:.4em;font-size:calc(2.15em * var(--rp-heading-scale, 1))}.rp-markdown-preview h2{font-size:calc(1.7em * var(--rp-heading-scale, 1))}.rp-markdown-preview h3{font-size:calc(1.35em * var(--rp-heading-scale, 1))}.rp-markdown-preview h4{font-size:calc(1.1em * var(--rp-heading-scale, 1))}.rp-markdown-preview p,.rp-markdown-preview li,.rp-markdown-preview blockquote{font-size:1em;color:var(--rp-body-color, #1b1b1b);margin-top:calc(.58em * var(--rp-paragraph-spacing, 1));margin-bottom:calc(.58em * var(--rp-paragraph-spacing, 1))}.rp-markdown-preview strong{color:var(--rp-heading-color, #111111)}.rp-markdown-preview ul,.rp-markdown-preview ol{padding-left:1.4em}.rp-markdown-preview blockquote{margin-left:0;padding-left:12px;border-left:2px solid rgba(17,17,17,.28)}.rp-markdown-preview code{border-radius:4px;background:#21170d14;padding:1px 4px}.rp-markdown-preview pre{background:#21170d14;border-radius:8px;padding:12px;overflow-x:auto}@media (max-width: 1180px){.reader-preview{padding:24px 14px 42px}.rp-grid{grid-template-columns:1fr}.rp-controls{position:static;max-height:none;overflow:visible}.rp-header{flex-direction:column;align-items:flex-start}.rp-header-actions{width:100%}.rp-header-actions .btn{flex:1}.rp-book-page{min-height:760px;padding:36px 30px}}@media print{body{background:#fff}.reader-preview{padding:0;margin:0;max-width:none;height:auto;overflow:visible;background:#fff}.rp-shell-controls{display:none!important}.rp-grid{grid-template-columns:1fr;margin:0}.rp-preview-shell{border:none;border-radius:0;padding:0;background:#fff}.rp-book{gap:0}.rp-book-page{width:auto;min-height:0;border:none;border-radius:0;box-shadow:none;padding:0;background:#fff;color:#111}.rp-title-page{break-after:page;page-break-after:always}.rp-content-page{break-before:page;page-break-before:always}}.at-page{height:100vh;min-height:100vh;max-width:1100px;margin:0 auto;padding:40px 32px 80px;color:var(--color-text-primary);font-family:var(--font-body);overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative}.at-page:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 80% 50% at 10% 0%,rgba(212,162,106,.1),transparent 50%),radial-gradient(ellipse 60% 40% at 95% 8%,rgba(92,76,52,.12),transparent 40%),radial-gradient(ellipse 50% 50% at 50% 100%,rgba(212,162,106,.04),transparent 50%),linear-gradient(180deg,#0c0f0c,#0e110e);pointer-events:none}.at-page.at-loading{display:flex;align-items:center;justify-content:center}@supports (height: 100dvh){.at-page{height:100dvh;min-height:100dvh}}.at-header{margin-bottom:32px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.at-header-left{flex:1;min-width:0}.at-header h1{margin:0;font-family:var(--font-display);font-size:clamp(1.45rem,2.8vw,1.85rem);font-weight:600;line-height:1.2;font-style:italic}.at-header h1 span{color:var(--color-text-secondary);font-style:italic;font-weight:400}.at-header-desc{margin:6px 0 0;color:var(--color-text-secondary);font-size:.84rem;line-height:1.6}.at-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.at-alert{border-radius:12px;border:1px solid rgba(248,113,113,.35);background:#f8717114;color:#fecaca;padding:12px 16px;font-size:.82rem;line-height:1.6;margin-bottom:16px}.at-tabs{display:flex;gap:0;margin-bottom:0;border-bottom:1px solid rgba(212,162,106,.1)}.at-tab{position:relative;cursor:pointer;padding:12px 20px;font-family:var(--font-body);font-size:.82rem;font-weight:500;color:var(--color-text-tertiary);background:none;border:none;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease;letter-spacing:.01em}.at-tab:hover{color:var(--color-text-secondary)}.at-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.at-tab strong{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:.58rem;font-weight:700;margin-left:6px;background:#d4a26a1f;color:var(--color-text-tertiary);vertical-align:middle}.at-tab.active strong{background:#d4a26a40;color:var(--color-accent)}.at-surface{padding:28px 0 0;min-height:460px}.at-fade{animation:at-fade-in .26s ease}@keyframes at-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.at-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:24px}.at-stat{border-radius:10px;border:1px solid rgba(255,255,255,.04);background:#d4a26a08;padding:10px 12px;transition:border-color .2s ease}.at-stat:hover{border-color:#d4a26a1f}.at-stat__label{display:block;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary)}.at-stat__value{display:block;margin-top:4px;font-family:var(--font-display);font-size:1.1rem}.at-stat__value--good{color:#6ee7b7}.at-stat__value--mid{color:var(--color-accent)}.at-stat__value--low{color:#f87171}.at-stat__sub{display:block;margin-top:2px;font-size:.72rem;color:var(--color-text-tertiary)}.at-section-label{display:block;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-tertiary);font-weight:600;margin-bottom:10px}.at-personas{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}.at-persona{position:relative;padding:16px;border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;color:var(--color-text-primary);text-align:left;cursor:pointer;transition:border-color .22s ease,background .22s ease,transform .2s ease}.at-persona:hover{border-color:#d4a26a1f;transform:translateY(-1px)}.at-persona.selected{border-color:#d4a26a80;background:#d4a26a0f}.at-persona.selected:after{content:"";position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 6px #d4a26a80}.at-persona:disabled{opacity:.45;pointer-events:none}.at-persona__head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.at-persona__emoji{font-size:1.2rem}.at-persona__name{font-family:var(--font-display);font-size:.92rem}.at-persona__meta{display:block;font-size:.72rem;color:var(--color-text-tertiary);line-height:1.4}.at-persona__taste{margin-top:8px;font-size:.78rem;color:var(--color-text-secondary);line-height:1.5}.at-scope{margin-bottom:24px}.at-scope-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff05}.at-scope-bar__left{display:flex;align-items:center;gap:10px}.at-scope-bar__text{font-size:.82rem;color:var(--color-text-secondary)}.at-pills{display:flex;gap:6px;flex-wrap:wrap}.at-pill{padding:7px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff06;color:var(--color-text-secondary);font-size:.82rem;font-family:var(--font-body);cursor:pointer;transition:all .2s ease}.at-pill:hover{border-color:#d4a26a33;color:var(--color-text-primary)}.at-pill.active{color:#fff6eb;border-color:#d4a26a8c;background:#d4a26a1a}.at-pill:disabled{opacity:.45;pointer-events:none}.at-chapter-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.at-chip{padding:7px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--color-text-secondary);font-size:.78rem;font-family:var(--font-body);cursor:pointer;transition:all .2s ease}.at-chip:hover{border-color:#d4a26a33}.at-chip.active{color:#fff6eb;border-color:#d4a26a8c;background:#d4a26a1a}.at-chip:disabled{opacity:.4;pointer-events:none}.at-results{display:grid;grid-template-columns:260px minmax(0,1fr);gap:16px}.at-rail{align-self:start;position:sticky;top:18px}.at-rail__head{margin-bottom:12px}.at-rail__head h2{margin:0;font-family:var(--font-display);font-size:.92rem}.at-rail-list{display:flex;flex-direction:column;gap:6px}.at-rail-card{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;color:var(--color-text-primary);text-align:left;cursor:pointer;transition:border-color .2s ease,background .2s ease}.at-rail-card:hover{border-color:#d4a26a1f}.at-rail-card.active{border-color:#d4a26a73;background:#d4a26a0f}.at-rail-card__top{display:flex;align-items:center;gap:8px;margin-bottom:6px}.at-rail-card__emoji{font-size:.9rem}.at-rail-card__name{font-family:var(--font-display);font-size:.84rem;flex:1}.at-rail-card__bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.at-rail-card__score{font-family:var(--font-display);font-size:.82rem;color:var(--color-text-tertiary)}.at-status{display:inline-flex;align-items:center;border-radius:999px;font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:3px 8px}.at-status--pending,.at-status--idle{color:var(--color-text-tertiary);border:1px solid rgba(255,255,255,.06)}.at-status--running{color:var(--color-accent);border:1px solid rgba(212,162,106,.3);background:#d4a26a14;animation:at-pulse 2s ease-in-out infinite}@keyframes at-pulse{0%,to{opacity:1}50%{opacity:.6}}.at-status--completed{color:#c6f2da;border:1px solid rgba(110,231,183,.22);background:#6ee7b714}.at-status--failed{color:#ffbbab;border:1px solid rgba(248,113,113,.22);background:#f8717114}.at-main{display:flex;flex-direction:column;gap:12px}.at-scores{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.at-score{border-radius:10px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;padding:12px 14px;text-align:center}.at-score__label{display:block;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary)}.at-score__value{display:block;margin-top:6px;font-family:var(--font-display);font-size:1.5rem;line-height:1}.at-score__value--good{color:#6ee7b7}.at-score__value--mid{color:var(--color-accent)}.at-score__value--low{color:#f87171}.at-score__value--none{color:var(--color-text-muted)}.at-quote{border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;padding:18px 20px}.at-quote__label{display:block;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:10px}.at-quote__text{margin:0;font-family:var(--font-display);font-size:1.15rem;line-height:1.55;color:#f0e6d6;font-style:italic}.at-feedback{border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;padding:18px 20px}.at-feedback__label{margin-bottom:12px;font-size:.64rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600}.at-feedback--strengths .at-feedback__label{color:#6ee7b7}.at-feedback--weaknesses .at-feedback__label{color:#fcd34d}.at-feedback--dropoffs .at-feedback__label{color:#f87171}.at-feedback--priorities .at-feedback__label{color:var(--color-accent)}.at-feedback ul,.at-feedback ol{margin:0;padding-left:18px;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:8px}.at-feedback li{font-size:.84rem;line-height:1.6}.at-feedback li strong{color:var(--color-text-primary)}.at-feedback li span{display:block;margin-top:2px}.at-feedback-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.at-empty{text-align:center;padding:48px 24px}.at-empty h3{font-family:var(--font-display);font-size:1.1rem;margin-bottom:8px}.at-empty p{color:var(--color-text-tertiary);font-size:.86rem;margin:0}.at-history-list{display:flex;flex-direction:column;gap:10px}.at-history-item{border-radius:14px;border:1px solid rgba(255,255,255,.04);background:#ffffff06;padding:16px 20px;transition:border-color .2s ease}.at-history-item.active{border-color:#d4a26a4d;background:#d4a26a0d}.at-history-main{display:flex;justify-content:space-between;align-items:center;gap:12px}.at-history-item h3{margin:0;font-family:var(--font-display);font-size:.92rem;font-weight:600}.at-history-item .at-history-meta{margin:4px 0 0;font-size:.78rem;color:var(--color-text-tertiary)}.at-history-scores{display:flex;gap:12px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.04)}.at-history-score{font-size:.76rem;color:var(--color-text-secondary)}.at-history-score strong{font-family:var(--font-display);margin-left:4px}.at-run-select{min-width:200px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;color:var(--color-text-primary);padding:8px 12px;font-family:var(--font-body);font-size:.82rem;transition:border-color .2s ease}.at-run-select:focus{outline:none;border-color:#d4a26a59}@media (max-width: 900px){.at-page{padding:24px 18px 50px}.at-personas,.at-stats,.at-scores{grid-template-columns:repeat(2,1fr)}.at-results{grid-template-columns:1fr}.at-rail{position:static}.at-feedback-grid{grid-template-columns:1fr}}@media (max-width: 640px){.at-page{padding:18px 14px 40px}.at-header{flex-direction:column}.at-actions{width:100%}.at-actions .btn{flex:1}.at-tabs{overflow-x:auto}.at-personas,.at-stats,.at-scores{grid-template-columns:1fr}.at-scope-bar,.at-history-main{flex-direction:column;align-items:flex-start}.at-run-select{width:100%;min-width:unset}}@media (prefers-reduced-motion: reduce){.at-fade,.at-persona,.at-rail-card,.at-stat{animation:none;transition:none}.at-status--running{animation:none}}.at-ask-ai{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;background:var(--color-accent-subtle);border:1px solid rgba(212,162,106,.2);border-radius:var(--radius-lg)}.at-ask-ai-btn{display:flex;align-items:center;gap:8px;white-space:nowrap}.at-ask-ai-btn svg{flex-shrink:0}.at-ask-ai-hint{font-size:.8rem;color:var(--color-text-muted)}@media (max-width: 640px){.at-ask-ai{flex-direction:column;align-items:flex-start}}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.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__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray: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.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.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:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{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:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.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.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@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;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.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-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.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:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.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-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.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:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.canvas-editor{height:100%;width:100%;display:flex;flex-direction:column;background:var(--color-bg-primary)}.canvas-toolbar{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-surface-border)}.toolbar-label{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--color-accent);text-transform:uppercase;letter-spacing:.08em;margin-right:8px}.react-flow__renderer{background:var(--color-bg-primary)!important}.react-flow__controls{background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:10px;box-shadow:var(--shadow-lg)}.react-flow__controls-button{background:var(--color-bg-elevated)!important;border-bottom:1px solid var(--color-surface-border)!important;fill:var(--color-text-secondary)!important}.react-flow__controls-button:hover{background:#d4a26a0f!important;fill:var(--color-accent)!important}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__edge-path{stroke:var(--color-accent)}.react-flow__handle{width:10px;height:10px;background:var(--color-accent);border:2px solid var(--color-bg-primary)}.react-flow__handle:hover{background:var(--color-accent-hover)}.canvas-node{min-width:180px;max-width:280px;padding:var(--space-3);background:var(--color-bg-elevated);border:2px solid var(--color-surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);cursor:grab}.canvas-node:active{cursor:grabbing}.character-node{border-color:var(--color-node-character)}.character-node .node-icon{background:#f472b633}.location-node{border-color:var(--color-node-location)}.location-node .node-icon{background:#38bdf833}.plotpoint-node{border-color:var(--color-node-plotpoint)}.plotpoint-node .node-icon{background:#a3e63533}.note-node{border-color:var(--color-node-note)}.note-node .node-icon{background:#fbbf2433}.node-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.node-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);font-size:14px}.node-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary);flex:1}.node-input{flex:1;background:var(--color-bg-secondary);border:1px solid var(--color-accent);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary);outline:none}.node-description{font-size:var(--text-xs);color:var(--color-text-tertiary);line-height:var(--leading-relaxed);margin:0}.node-textarea{width:100%;background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-sm);padding:var(--space-2);font-family:var(--font-body);font-size:var(--text-xs);color:var(--color-text-primary);resize:none;outline:none}.node-textarea:focus{border-color:var(--color-accent)}.canvas-studio{height:100vh;display:flex;flex-direction:column;background:var(--color-bg, #111)}.canvas-studio.loading{display:flex;align-items:center;justify-content:center;gap:12px;color:var(--color-text-secondary)}.canvas-studio-header{display:flex;align-items:center;gap:16px;padding:12px 24px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.canvas-studio-header h1{font-size:1rem;font-weight:600;margin:0;color:var(--color-text-primary)}.canvas-studio-project{font-size:.78rem;color:var(--color-text-tertiary);margin-right:auto}.canvas-sync-message{padding:8px 24px;font-size:.82rem}.canvas-sync-success{color:#a3e635;background:#a3e6350f}.canvas-sync-error{color:#f87171;background:#f871710f}.canvas-studio-editor{flex:1;overflow:hidden}.canvas-studio-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-tertiary)}.community-shell{height:100%;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;color:var(--color-text-primary);background:radial-gradient(ellipse at 20% -5%,rgba(212,162,106,.06),transparent 55%),radial-gradient(ellipse at 80% 105%,rgba(110,231,183,.03),transparent 55%),var(--color-bg-primary)}.community-container{max-width:620px;margin:0 auto;padding:0 var(--space-5) var(--space-16)}.community-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-8) 0 var(--space-5)}.community-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;justify-content:flex-end}.community-header h1{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.01em;margin:0;line-height:var(--leading-tight)}.community-subtitle{color:var(--color-text-tertiary);font-family:var(--font-body);font-size:var(--text-sm);margin-top:var(--space-1)}.composer-bar{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);cursor:text;transition:border-color var(--transition-base),box-shadow var(--transition-base);margin-bottom:var(--space-4)}.composer-bar:hover{border-color:#d4a26a26;box-shadow:var(--shadow-sm)}.composer-placeholder{color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-sm);user-select:none}.composer-expanded{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);animation:communityFadeIn .2s ease-out}.composer-type-row{display:flex;gap:var(--space-2)}.composer-type-btn{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);border:1px solid var(--color-surface-border);background:var(--color-bg-secondary);color:var(--color-text-tertiary);font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.composer-type-btn:hover{border-color:#d4a26a33;color:var(--color-text-secondary)}.composer-type-btn.active{background:var(--color-accent);color:var(--color-bg-primary);border-color:transparent}.composer-textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-relaxed);resize:vertical;min-height:72px;transition:border-color var(--transition-fast)}.composer-textarea.small{min-height:56px}.composer-textarea::placeholder{color:var(--color-text-muted)}.composer-textarea:focus{outline:none;border-color:#d4a26a40}.composer-options-row{display:flex;gap:var(--space-3)}.composer-select{flex:1}.composer-input{font-size:var(--text-sm)!important}.composer-excerpt-fields,.composer-poll-fields{display:flex;flex-direction:column;gap:var(--space-3)}.composer-image-preview{position:relative;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-surface-border);max-height:240px}.composer-image-preview img{display:block;width:100%;max-height:240px;object-fit:cover}.composer-image-remove{position:absolute;top:var(--space-2);right:var(--space-2);width:28px;height:28px;border-radius:var(--radius-full);background:#000000b3;border:none;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.composer-image-remove:hover{background:#f87171cc}.composer-prefill-badge{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-md, 8px);background:#d4a26a0f;border:1px solid rgba(212,162,106,.15);font-size:.78rem;color:var(--color-accent, #d4a26a);position:relative}.composer-prefill-badge .composer-image-remove{position:static;width:22px;height:22px;font-size:.8rem}.composer-attach-btn{flex-shrink:0;white-space:nowrap}.composer-footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-2)}.community-tabs{display:flex;margin-bottom:var(--space-4);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-secondary)}.community-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:transparent;color:var(--color-text-muted);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base);text-decoration:none;border:none;position:relative}.community-tab:hover{color:var(--color-text-secondary);background:#d4a26a0a}.community-tab.active{color:var(--color-text-primary);background:var(--color-surface);box-shadow:var(--shadow-sm)}.community-tab+.community-tab{border-left:1px solid var(--color-surface-border)}.community-feed{display:flex;flex-direction:column}.community-posts-list{display:flex;flex-direction:column;gap:var(--space-2)}.community-post-card{padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);transition:border-color var(--transition-base),box-shadow var(--transition-slow);animation:communityFadeIn .3s ease-out both}.community-post-card:hover{border-color:#d4a26a1a;box-shadow:0 2px 12px #00000026}.community-post-top{display:flex;align-items:flex-start;gap:var(--space-3)}.community-post-meta{flex:1;min-width:0}.community-post-meta-primary{display:flex;align-items:baseline;gap:var(--space-2);flex-wrap:wrap}.community-post-meta-secondary{display:flex;align-items:center;gap:var(--space-1);flex-wrap:wrap;margin-top:1px;color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-xs)}.community-genre-dot{color:var(--color-text-muted);font-size:var(--text-xs)}.meta-dot{color:var(--color-text-muted)}.community-avatar{width:40px;height:40px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;background:var(--color-accent-subtle);border:1px solid rgba(212,162,106,.1);font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--color-accent);flex-shrink:0}.community-avatar.small{width:34px;height:34px;font-size:.8rem}.community-avatar.tiny{width:26px;height:26px;font-size:.65rem}.community-avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.community-author-name{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-fast)}.community-author-name:hover{color:var(--color-accent)}.community-author-badge{font-size:.9rem;margin-left:2px;cursor:help}.community-author-handle{color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-xs)}.community-author-bio{color:var(--color-text-secondary);font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-top:var(--space-1)}.community-post-body{margin:var(--space-3) 0}.community-post-body p{font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text-secondary);margin:0}.community-post-image{border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-surface-border);margin-bottom:var(--space-2)}.community-post-image img{display:block;width:100%;max-height:400px;object-fit:cover;transition:opacity var(--transition-base)}.community-post-image img:hover{opacity:.95}.community-post-audio{margin-top:var(--space-3, 8px);padding:12px 14px;border-radius:10px;background:#ffffff05;border:1px solid rgba(255,255,255,.06)}.community-post-audio audio{width:100%;height:36px;border-radius:6px}.community-excerpt{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-left:3px solid rgba(212,162,106,.25);text-align:left;cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--space-1)}.community-excerpt:hover{border-color:#d4a26a26;border-left-color:var(--color-accent);background:var(--color-bg-tertiary)}.community-excerpt blockquote{margin:0;color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-sm);line-height:1.85;font-style:italic}.community-excerpt-caption{color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-xs);margin:0}.community-excerpt.spoiler{border-left-color:#f871714d}.community-spoiler-toggle{color:var(--color-error);font-family:var(--font-display);font-size:var(--text-xs);font-weight:600}.community-poll{border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);padding:var(--space-4);margin-bottom:var(--space-1)}.community-poll-options{display:flex;flex-direction:column;gap:var(--space-2)}.community-poll-option{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-surface-border);background:var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-sm);cursor:pointer;transition:border-color var(--transition-fast);min-height:44px}.community-poll-option:hover:not(:disabled){border-color:#d4a26a33}.community-poll-option.active{border-color:var(--color-accent)}.community-poll-option:disabled{cursor:default}.poll-option-label{position:relative;z-index:1;flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.poll-option-pct{position:relative;z-index:1;flex-shrink:0;font-weight:600;font-size:var(--text-xs);color:var(--color-text-secondary);margin-left:var(--space-3)}.community-poll-bar{position:absolute;top:0;left:0;bottom:0;background:var(--color-accent-subtle);z-index:0;transition:width .5s cubic-bezier(.22,1,.36,1);border-radius:var(--radius-md) 0 0 var(--radius-md)}.community-poll-footer{margin-top:var(--space-3);color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-xs)}.community-post-actions{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--color-surface-border)}.community-action-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-xs);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.community-action-btn:hover{background:var(--color-bg-hover);color:var(--color-text-secondary)}.community-action-btn.liked{color:#e57373}.inline-comments{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-surface-border);display:flex;flex-direction:column;gap:var(--space-3);animation:communityFadeIn .2s ease-out}.inline-comment{display:flex;gap:var(--space-2);align-items:flex-start}.inline-comment-content{flex:1;min-width:0}.inline-comment-header{display:flex;align-items:baseline;gap:var(--space-2);margin-bottom:2px}.inline-comment-author{font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;color:var(--color-text-primary);text-decoration:none}.inline-comment-author:hover{color:var(--color-accent)}.inline-comment-time{font-size:.68rem;color:var(--color-text-muted)}.inline-comment-delete{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-sm);padding:0 2px;line-height:1;transition:color var(--transition-fast)}.inline-comment-delete:hover{color:var(--color-error)}.inline-comment-body{font-family:var(--font-body);font-size:var(--text-xs);line-height:var(--leading-relaxed);color:var(--color-text-secondary);margin:0}.inline-comment-form{display:flex;gap:var(--space-2);align-items:center}.inline-comment-input{flex:1;padding:var(--space-2) var(--space-3);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-full);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-xs);transition:border-color var(--transition-fast)}.inline-comment-input::placeholder{color:var(--color-text-muted)}.inline-comment-input:focus{outline:none;border-color:#d4a26a40}.community-author-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);transition:border-color var(--transition-base);animation:communityFadeIn .3s ease-out both}.community-author-card:hover{border-color:#d4a26a1a}.community-author-top{display:flex;align-items:center;gap:var(--space-3)}.community-author-top .btn{margin-left:auto}.community-meta-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-xs)}.community-banner{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);border:1px solid transparent;cursor:pointer;margin-bottom:var(--space-2)}.community-banner.error{background:#f871710f;border-color:#f871711f;color:var(--color-error)}.community-banner.success{background:#6ee7b70f;border-color:#6ee7b71f;color:var(--color-success)}.community-empty-copy{padding:var(--space-12) var(--space-5);text-align:center;color:var(--color-text-muted);font-family:var(--font-display);font-size:var(--text-sm);font-style:italic}@keyframes communityFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.community-post-card,.community-author-card,.composer-expanded,.inline-comments{animation:none}}.profile-shell{height:100vh;overflow-y:auto;color:var(--color-text-primary);background:radial-gradient(ellipse at 20% -5%,rgba(212,162,106,.06),transparent 55%),radial-gradient(ellipse at 80% 105%,rgba(110,231,183,.03),transparent 55%),var(--color-bg-primary)}.profile-container{max-width:520px;margin:0 auto;padding:0 var(--space-5) var(--space-16)}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-8) 0 var(--space-6)}.profile-header h1{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;margin:0}.profile-header-links{display:flex;gap:var(--space-2)}.profile-card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);overflow:hidden}.profile-card-banner{height:80px;background:linear-gradient(135deg,#d4a26a26,#6ee7b714,#d4a26a1a);position:relative}.profile-card-avatar{width:64px;height:64px;border-radius:var(--radius-full);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--color-accent-subtle);border:3px solid var(--color-surface);font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--color-accent);position:absolute;bottom:-32px;left:var(--space-5)}.profile-card-avatar img{width:100%;height:100%;object-fit:cover;display:block}.profile-card-body{padding:44px var(--space-5) var(--space-5)}.profile-card-identity{margin-bottom:var(--space-5)}.profile-card-name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;margin:0}.profile-card-handle{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:2px}.profile-form{display:flex;flex-direction:column;gap:var(--space-4)}.profile-field{display:flex;flex-direction:column;gap:var(--space-1)}.profile-field-label{color:var(--color-text-tertiary);font-family:var(--font-display);font-size:.7rem;font-weight:600;text-transform:uppercase}.profile-field-error{color:#ef4444;font-size:.75rem}.input-error{border-color:#ef4444!important;letter-spacing:.1em}.profile-field .input,.profile-field .textarea{font-size:var(--text-sm)}.profile-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.profile-genres{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-1)}.profile-field-hint{font-size:.74rem;color:var(--color-text-tertiary);margin:2px 0 8px}.profile-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.profile-badge-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:#ffffff05;color:var(--color-text-secondary);font-size:.78rem;cursor:pointer;transition:all .15s}.profile-badge-chip:hover:not(.locked){background:#d4a26a0f;border-color:#d4a26a33}.profile-badge-chip.selected{background:#d4a26a1a;border-color:#d4a26a66;color:var(--color-accent, #d4a26a)}.profile-badge-chip.locked{opacity:.35;cursor:not-allowed}.profile-badge-icon{font-size:1rem}.profile-badge-name{font-weight:500}.profile-badge-lock{font-size:.65rem;margin-left:2px}.profile-actions{display:flex;justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-surface-border);margin-top:var(--space-2)}.community-public-shell{min-height:100vh;padding:var(--space-12) clamp(20px,4vw,48px);color:var(--color-text-primary);background:radial-gradient(ellipse at 20% -5%,rgba(212,162,106,.06),transparent 55%),radial-gradient(ellipse at 80% 105%,rgba(110,231,183,.03),transparent 55%),var(--color-bg-primary)}.community-back-link{display:inline-flex;align-items:center;gap:var(--space-1);margin-bottom:var(--space-4);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast)}.community-back-link:hover{color:var(--color-accent)}.community-comment-card{padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg)}.community-comment-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-2)}.community-comment-head a{font-family:var(--font-display);font-weight:600;font-size:var(--text-sm)}.community-comment-head span{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:var(--space-2)}.community-comment-card>p{font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.community-comment-form{display:flex;flex-direction:column;gap:var(--space-4)}.community-notification{width:100%;padding:var(--space-4) var(--space-5);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);text-align:left;cursor:pointer;transition:all var(--transition-fast);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg)}.community-notification:hover{background:var(--color-bg-hover);border-color:#d4a26a1a}.community-notification.unread{border-left:3px solid var(--color-accent);background:var(--color-accent-muted)}.community-notification strong{font-family:var(--font-display);font-size:var(--text-sm)}.community-notification p{font-size:var(--text-xs);margin-top:2px;color:var(--color-text-secondary)}.community-panel{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:var(--space-5)}.community-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.community-eyebrow{color:var(--color-accent);font-family:var(--font-display);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--space-2)}.community-identity-block{display:flex;flex-direction:column;gap:var(--space-1)}.community-identity-block strong{font-family:var(--font-display);font-size:var(--text-lg)}.community-identity-block span{color:var(--color-text-muted);font-size:var(--text-sm)}.community-chip-row{display:flex;flex-wrap:wrap;gap:var(--space-2)}.community-chip{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--color-accent-subtle);border:1px solid rgba(212,162,106,.1);color:var(--color-accent);font-size:.7rem;font-weight:600;font-family:var(--font-display)}.community-stack,.community-form-stack{display:flex;flex-direction:column;gap:var(--space-4)}.community-linked-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.community-inline-actions{display:flex;align-items:center;gap:var(--space-3)}.community-link-button{background:none;border:none;color:var(--color-text-muted);padding:0;cursor:pointer;font:inherit;font-size:var(--text-xs);transition:color var(--transition-fast)}.community-link-button:hover{color:var(--color-accent)}.community-modal-backdrop{position:fixed;inset:0;z-index:var(--z-modal);display:grid;place-items:center;padding:var(--space-5);background:#0009;backdrop-filter:blur(8px)}.community-modal{width:min(620px,100%);max-height:calc(100vh - 40px);overflow:auto;padding:var(--space-6);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}.post-follow-btn{margin-left:auto;flex-shrink:0;font-size:var(--text-xs)!important;padding:var(--space-1) var(--space-3)!important}.post-follow-btn.following{color:var(--color-text-muted)}.post-follow-btn.following:hover{color:var(--color-error)}.public-profile-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.public-profile-bio{color:var(--color-text-secondary);font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin:var(--space-3) 0}.public-profile-stats{display:flex;gap:var(--space-4);color:var(--color-text-muted);font-family:var(--font-body);font-size:var(--text-sm);margin-bottom:var(--space-3)}.public-profile-stats strong{color:var(--color-text-primary);font-weight:600}.public-profile-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.public-profile-details{display:flex;flex-wrap:wrap;gap:var(--space-4);color:var(--color-text-muted);font-size:var(--text-xs)}.public-profile-detail{display:inline-flex;align-items:center;gap:var(--space-1)}.public-profile-section{margin-top:var(--space-5)}.public-profile-section-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3)}.public-profile-projects{display:flex;flex-direction:column;gap:var(--space-2)}.public-profile-project{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg)}.public-profile-project strong{font-family:var(--font-display);font-size:var(--text-sm)}.public-profile-project span{color:var(--color-text-muted);font-size:var(--text-xs)}.public-profile-project p{color:var(--color-text-secondary);font-size:var(--text-xs);line-height:var(--leading-relaxed);margin:0}@media (max-width: 720px){.community-container,.profile-container{padding:0 var(--space-4) var(--space-10)}.community-header,.profile-header{padding-top:var(--space-6)}.community-header h1{font-size:var(--text-xl)}.community-post-card,.community-author-card{padding:var(--space-4)}.composer-bar,.composer-expanded{padding:var(--space-3) var(--space-4)}.composer-type-row{flex-wrap:wrap}.profile-row{grid-template-columns:1fr}}.file-tree{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0}.file-tree-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-2) 0}.tree-content{min-height:100%}.tree-empty{padding:var(--space-8) var(--space-4);text-align:center;color:var(--color-text-muted)}.tree-empty .hint{font-size:var(--text-xs);margin-top:var(--space-2)}.tree-item{position:relative;cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast);user-select:none;min-height:28px}.tree-item-content{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);padding-right:var(--space-4)}.tree-item:hover{background:var(--color-bg-hover)}.tree-item.active{background:var(--color-accent-muted)}.tree-item.selected{background:#d4a26a14}.tree-item.active .item-name{color:var(--color-text-primary)}.tree-item.dragging{opacity:.5;background:var(--color-accent-subtle);border-radius:var(--radius-sm)}.tree-item.drag-over{background:var(--color-accent-subtle);border:1px dashed var(--color-accent)}.tree-item.drop-before:before,.tree-item.drop-after:after{content:"";position:absolute;left:12px;right:12px;height:2px;background:var(--color-accent);border-radius:999px}.tree-item.drop-before:before{top:0}.tree-item.drop-after:after{bottom:0}.tree-item.drop-inside{background:#d4a26a1f;box-shadow:inset 0 0 0 1px #d4a26a59;border-radius:var(--radius-sm)}.folder-arrow{display:flex;align-items:center;justify-content:center;width:16px;height:16px;transition:transform var(--transition-fast);color:var(--color-text-muted);border:none;background:transparent;padding:0;cursor:pointer}.folder-arrow.placeholder{opacity:0}.folder-arrow.expanded{transform:rotate(90deg)}.item-icon{width:18px;height:18px;color:var(--color-text-tertiary);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.item-name{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file .item-name{font-family:var(--font-mono);font-size:12px}.folder .tree-item-content{position:relative}.child-count{font-size:10px;color:var(--color-text-muted);background:var(--color-bg-secondary);padding:0 4px;border-radius:var(--radius-sm);margin-left:auto}.sort-button{display:flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:auto;border:none;background:transparent;color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:opacity var(--transition-fast),background var(--transition-fast);padding:0;flex-shrink:0}.tree-item:hover .sort-button{opacity:.6}.sort-button:hover{opacity:1!important;background:var(--color-bg-hover);color:var(--color-accent)}.tree-input{flex:1;background:var(--color-bg-secondary);border:1px solid var(--color-accent);border-radius:var(--radius-sm);padding:2px 6px;font-family:var(--font-mono);font-size:12px;color:var(--color-text-primary);outline:none}.tree-item.creating{background:var(--color-bg-hover)}.drag-overlay{border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding-right:var(--space-3)}.tree-add-content{padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-surface-border)}.tree-add-content .btn{width:100%;justify-content:center;border:1px dashed var(--color-surface-border)}.tree-add-content .btn:hover{border-color:var(--color-text-tertiary)}.context-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;margin-right:var(--space-2);color:var(--color-text-tertiary)}.editor-tabs{display:flex;align-items:center;height:var(--tab-height);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-surface-border);overflow:hidden}.tabs-scroll{display:flex;align-items:center;overflow-x:auto;overflow-y:hidden;flex:1;scrollbar-width:none}.tabs-scroll::-webkit-scrollbar{display:none}.tab{display:flex;align-items:center;gap:6px;height:100%;padding:0 8px 0 14px;font-family:var(--font-body);font-size:.72rem;color:var(--color-text-tertiary);background:transparent;border-right:1px solid var(--color-surface-border);cursor:pointer;white-space:nowrap;transition:all .2s;position:relative}.tab:hover{background:var(--color-bg-hover);color:var(--color-text-secondary)}.tab.active{background:var(--color-bg-primary);color:var(--color-text-primary)}.tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--color-accent)}.tab-icon{font-size:11px}.tab-name{max-width:150px;overflow:hidden;text-overflow:ellipsis}.tab-unsaved{color:var(--color-accent);font-weight:700;margin-left:2px}.tab-close{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;margin-left:4px;background:transparent;border:none;border-radius:4px;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:all .15s}.tab:hover .tab-close,.tab.active .tab-close{opacity:1}.tab-close:hover{background:#d4a26a1a;color:var(--color-text-primary)}.rich-text-editor{display:flex;flex-direction:column;height:100%;position:relative;font-family:var(--font-body)}.editor-toolbar-sleek{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:4px;padding:8px 16px;background:#0e110fd9;backdrop-filter:blur(8px);border-bottom:1px solid var(--color-surface-border);transition:all .2s ease}.toolbar-group{display:flex;align-items:center;gap:2px;padding-right:8px;margin-right:8px;border-right:1px solid var(--color-surface-border)}.toolbar-group:last-child{border-right:none}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:6px;color:var(--color-text-secondary);cursor:pointer;transition:all .15s;font-family:var(--font-display);font-weight:600;font-size:.9rem}.toolbar-btn:hover{background:#d4a26a14;color:var(--color-text-primary)}.toolbar-btn.is-active{background:var(--v5-amber-soft);color:var(--color-accent)}.toolbar-btn svg{width:16px;height:16px;stroke-width:2}.editor-content-wrapper{flex:1;overflow-y:auto;padding:0 4px;outline:none}.ProseMirror{padding:32px 48px 120px;max-width:800px;margin:0 auto;outline:none;min-height:100%;color:var(--color-text-primary);font-size:1.05rem;line-height:1.75}.ProseMirror:focus,.ProseMirror:focus-visible,.prose-editor:focus,.prose-editor:focus-visible,.editor-content-wrapper:focus,.editor-content-wrapper:focus-visible{outline:none!important;box-shadow:none!important}.ProseMirror p{margin-bottom:1.25em}.ProseMirror h1{font-size:2.2rem;margin:1.5em 0 .6em;color:var(--color-accent)}.ProseMirror h2{font-size:1.6rem;margin:1.4em 0 .6em;border-bottom:1px solid var(--color-surface-border);padding-bottom:.3em}.ProseMirror h3{font-size:1.25rem;margin:1.2em 0 .5em;color:var(--color-text-primary)}.ProseMirror ul,.ProseMirror ol{padding-left:1.5em;margin-bottom:1.25em}.ProseMirror li{margin-bottom:.4em;color:var(--color-text-secondary)}.ProseMirror blockquote{border-left:3px solid var(--color-accent);margin:1.5em 0;font-style:italic;color:var(--color-text-secondary);background:var(--v5-card-bg);padding:1em 1.2em;border-radius:0 8px 8px 0}.ProseMirror code{font-family:var(--font-mono);background:var(--color-bg-elevated);padding:.2em .4em;border-radius:4px;font-size:.85em;color:var(--color-text-primary)}.ProseMirror pre{background:var(--color-bg-elevated);padding:1em;border-radius:8px;overflow-x:auto;margin:1.5em 0;border:1px solid var(--color-surface-border)}.ProseMirror pre code{background:none;padding:0;color:inherit;font-size:.85em}.ProseMirror p.is-editor-empty:first-child:before{color:var(--color-text-muted);content:attr(data-placeholder);float:left;height:0;pointer-events:none;font-style:italic}.bubble-toolbar{display:flex;gap:2px;padding:4px 6px;background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:10px;box-shadow:var(--shadow-lg);backdrop-filter:blur(12px);animation:fadeInUp .12s ease-out}.bubble-toolbar .toolbar-btn{width:26px;height:26px}.editor-context-menu{position:fixed;z-index:50;background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:12px;box-shadow:var(--shadow-lg);min-width:220px;padding:6px}.editor-context-menu .context-item{display:flex;align-items:center;gap:8px;padding:7px 10px;width:100%;text-align:left;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:6px;font-size:.85rem;transition:.1s}.editor-context-menu .context-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.editor-context-menu .context-section{padding:8px 10px 4px;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:600;display:flex;align-items:center;gap:6px}.editor-context-menu .ctx-shortcut{margin-left:auto;font-size:.7rem;color:var(--color-text-muted);background:var(--color-bg-primary);padding:2px 6px;border-radius:4px;border:1px solid var(--color-surface-border)}.find-bar{position:sticky;top:0;z-index:11;padding:6px 16px;background:#0e110feb;backdrop-filter:blur(8px);border-bottom:1px solid var(--color-surface-border);animation:findBarSlide .15s ease-out}@keyframes findBarSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.find-bar-inner{display:flex;align-items:center;gap:6px;max-width:480px}.find-bar-icon{flex-shrink:0;color:var(--color-text-muted)}.find-bar-input{flex:1;background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:6px;padding:5px 10px;font-size:.85rem;color:var(--color-text-primary);outline:none;font-family:var(--font-body)}.find-bar-input:focus{border-color:var(--color-accent)}.find-bar-count{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap;min-width:52px;text-align:center}.find-bar-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;border-radius:4px;color:var(--color-text-secondary);cursor:pointer;transition:.12s}.find-bar-btn:hover:not(:disabled){background:#d4a26a1a;color:var(--color-text-primary)}.find-bar-btn:disabled{opacity:.3;cursor:default}.search-match{background:#d4a26a40;border-radius:2px}.search-match--active{background:#d4a26a8c;box-shadow:0 0 0 1px var(--color-accent);border-radius:2px}@media (max-width: 768px){.ProseMirror{padding:24px 20px 100px}.find-bar-inner{max-width:100%}}.diff-view{position:absolute;inset:0;z-index:100;display:flex;flex-direction:column;background:var(--color-bg-primary);animation:slideInUp .2s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.diff-header{padding:var(--space-4);background:linear-gradient(135deg,#4ade801a,#22c55e0d);border-bottom:1px solid rgba(74,222,128,.2)}.diff-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.diff-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:600;color:var(--color-text-primary)}.diff-stats{display:flex;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-sm)}.stat-added{color:#4ade80}.stat-removed{color:#f87171}.diff-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.diff-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.reject-btn{color:var(--color-text-tertiary)}.reject-btn:hover{color:#f87171;background:#f871711a}.accept-btn{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#16a34a}.accept-btn:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.accept-btn svg,.reject-btn svg{margin-right:var(--space-2)}.diff-content{flex:1;overflow-y:auto;padding:var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.6}.diff-line{display:flex;padding:2px var(--space-2);border-radius:var(--radius-sm);margin-bottom:1px}.diff-line.added{background:#4ade8026;border-left:3px solid #4ade80}.diff-line.removed{background:#f8717126;border-left:3px solid #f87171;text-decoration:line-through;opacity:.7}.diff-line.unchanged{color:var(--color-text-tertiary);border-left:3px solid transparent}.line-indicator{width:20px;flex-shrink:0;text-align:center;font-weight:600}.diff-line.added .line-indicator{color:#4ade80}.diff-line.removed .line-indicator{color:#f87171}.line-content{flex:1;white-space:pre-wrap;word-break:break-word}.pending-changes-badge{position:absolute;top:var(--space-2);right:var(--space-2);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:linear-gradient(135deg,#4ade8033,#22c55e1a);border:1px solid rgba(74,222,128,.3);border-radius:var(--radius-md);font-family:var(--font-display);font-size:var(--text-xs);color:#4ade80;z-index:10;cursor:pointer;transition:all var(--transition-fast)}.pending-changes-badge:hover{background:linear-gradient(135deg,#4ade804d,#22c55e33);border-color:#4ade8080}.pending-changes-badge .badge-icon{animation:pulse 2s ease-in-out infinite}.assistant-panel{flex:1;display:flex;flex-direction:column;min-height:0;overflow:visible;position:relative}.ap-header{display:flex;align-items:center;gap:var(--space-2);padding:10px var(--space-4);border-bottom:1px solid var(--color-surface-border);background:var(--color-surface);z-index:4;min-height:48px}.ap-header-chat-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;flex-shrink:0}.ap-header-chat-toggle:hover{border-color:#d4a26a59;color:var(--color-text-primary);background:var(--color-bg-hover)}.ap-chat-count{font-size:.65rem;font-weight:700;min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--color-accent-subtle);color:var(--color-accent);letter-spacing:0}.ap-header-center{flex:1;min-width:0;text-align:center}.ap-header-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.ap-header-btn{width:34px;height:34px;padding:0;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease}.ap-header-btn:hover{border-color:#d4a26a59;color:var(--color-text-primary);background:var(--color-bg-hover)}.ap-chat-drawer{position:absolute;inset:48px 0 0;z-index:10;background:var(--color-surface);display:flex;flex-direction:column;transform:translate(-100%);opacity:0;transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .2s ease;pointer-events:none;border-right:1px solid var(--color-surface-border)}.ap-chat-drawer.open{transform:translate(0);opacity:1;pointer-events:auto}.ap-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-surface-border)}.ap-drawer-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary);letter-spacing:.02em}.ap-drawer-new{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);background:var(--color-accent-subtle);color:var(--color-accent);font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:all .15s ease}.ap-drawer-new:hover{background:var(--color-accent);color:var(--color-bg-primary);border-color:var(--color-accent)}.ap-drawer-search{display:flex;align-items:center;gap:var(--space-2);margin:var(--space-3) var(--space-4);padding:8px 12px;background:var(--color-bg-primary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);color:var(--color-text-muted)}.ap-drawer-search:focus-within{border-color:var(--color-accent)}.ap-drawer-search input{flex:1;border:none;background:transparent;color:var(--color-text-primary);font-size:var(--text-xs);outline:none;font-family:var(--font-body)}.ap-drawer-search input::placeholder{color:var(--color-text-muted)}.ap-drawer-list{flex:1;overflow-y:auto;padding:var(--space-2) var(--space-3)}.ap-drawer-empty{text-align:center;padding:var(--space-6) var(--space-4);color:var(--color-text-muted);font-size:var(--text-xs)}.ap-chat-item{display:flex;align-items:center;gap:var(--space-3);padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;transition:background .12s ease;position:relative}.ap-chat-item:hover{background:var(--color-bg-hover)}.ap-chat-item.active{background:var(--color-accent-subtle)}.ap-chat-item-icon{font-size:18px;flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--color-bg-secondary)}.ap-chat-item.active .ap-chat-item-icon{background:#d4a26a26}.ap-chat-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ap-chat-item-title{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ap-chat-item-meta{font-size:.68rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ap-chat-rename-input{width:100%;padding:2px 6px;border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-sm);outline:none}.ap-chat-item-actions{display:flex;gap:4px;flex-shrink:0}.ap-chat-item-action{width:26px;height:26px;padding:0;border:none;border-radius:var(--radius-sm);background:var(--color-bg-secondary);color:var(--color-text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .12s ease}.ap-chat-item-action:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.ap-chat-item-action.danger:hover{background:#f871711f;color:#f87171}.ap-config-bar{display:flex;align-items:center;gap:var(--space-2);padding:8px var(--space-4);border-bottom:1px solid var(--color-surface-border);background:var(--color-surface);z-index:20;position:relative;overflow:visible}.ap-config-persona-wrap{position:relative;flex:1;min-width:0}.ap-persona-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;width:100%}.ap-persona-btn:hover{border-color:#d4a26a59;color:var(--color-text-primary);background:var(--color-bg-hover)}.ap-persona-emoji{font-size:16px;flex-shrink:0}.ap-persona-name{flex:1;text-align:left;font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ap-persona-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);z-index:50;max-height:320px;overflow-y:auto;padding:4px}.ap-persona-option{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:10px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;text-align:left;transition:background .12s ease}.ap-persona-option:hover,.ap-persona-option.active{background:var(--color-accent-subtle);color:var(--color-text-primary)}.ap-persona-option-emoji{font-size:20px;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--color-bg-secondary)}.ap-persona-option.active .ap-persona-option-emoji{background:#d4a26a26}.ap-persona-option-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.ap-persona-option-name{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.ap-persona-option-desc{font-size:.68rem;color:var(--color-text-tertiary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ap-persona-check{flex-shrink:0;color:var(--color-accent)}.ap-tier-group{display:flex;align-items:center;padding:2px;border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);flex-shrink:0}.ap-tier-btn{border:none;background:transparent;color:var(--color-text-tertiary);font-size:.65rem;font-weight:600;padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;white-space:nowrap}.ap-tier-btn.active{color:var(--color-accent);background:var(--color-accent-subtle);box-shadow:inset 0 0 0 1px #d4a26a4d}.ap-tier-btn:not(.active):hover{color:var(--color-text-secondary)}.ap-clear-btn{width:30px;height:30px;padding:0;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease}.ap-clear-btn:hover{color:#f87171;border-color:#f8717159;background:#f8717114}.ap-messages{flex:1;min-height:0;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.ap-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) var(--space-4) var(--space-6);gap:var(--space-2)}.ap-welcome-icon{font-size:44px;width:72px;height:72px;display:flex;align-items:center;justify-content:center;border-radius:20px;background:var(--color-accent-subtle);margin-bottom:var(--space-2)}.ap-welcome-name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--color-text-primary);margin:0}.ap-welcome-desc{font-size:var(--text-sm);color:var(--color-text-tertiary);line-height:var(--leading-relaxed);max-width:300px;margin:0}.ap-welcome-hints{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4);width:100%;max-width:260px}.ap-hint{display:flex;align-items:center;gap:var(--space-2);padding:8px 12px;border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);color:var(--color-text-tertiary);font-size:var(--text-xs);transition:border-color .15s ease}.ap-hint:hover{border-color:#d4a26a40;color:var(--color-text-secondary)}.ap-msg{display:flex;gap:var(--space-2)}.ap-msg.user{justify-content:flex-end}.ap-msg-avatar{width:26px;height:26px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;border-radius:var(--radius-sm);background:var(--color-bg-secondary);margin-top:2px}.ap-msg-shell{max-width:88%;display:flex;flex-direction:column;gap:var(--space-2)}.ap-msg-content{padding:10px 14px;border-radius:16px;font-size:var(--text-sm);line-height:var(--leading-relaxed)}.ap-msg.user .ap-msg-content{background:var(--color-accent-subtle);color:var(--color-text-primary);border-bottom-right-radius:4px}.ap-msg.assistant .ap-msg-content{background:var(--color-bg-secondary);color:var(--color-text-secondary);border-bottom-left-radius:4px}.ap-msg.tool .ap-msg-content{background:var(--color-bg-elevated);color:var(--color-text-tertiary);border:1px solid var(--color-surface-border);font-size:var(--text-xs);border-radius:var(--radius-md);padding:8px 12px}.ap-msg.error .ap-msg-content{background:#f871711a;color:var(--color-error)}.ap-msg-content p{margin-bottom:var(--space-2)}.ap-msg-content p:last-child{margin-bottom:0}.ap-msg-content ul,.ap-msg-content ol{margin:var(--space-2) 0;padding-left:var(--space-5)}.ap-msg-content code{background:var(--color-bg-elevated);padding:2px 6px;border-radius:var(--radius-sm);font-size:.9em}.ap-msg-content pre{background:var(--color-bg-elevated);padding:var(--space-3);border-radius:var(--radius-md);overflow-x:auto;margin:var(--space-2) 0}.ap-msg-content strong{color:var(--color-text-primary)}.ap-msg-content em{color:var(--color-text-tertiary)}.ap-msg.streaming .ap-msg-content:after{content:"▋";animation:ap-blink 1s step-end infinite;color:var(--color-accent)}.ap-msg-attachments{display:flex;flex-wrap:wrap;gap:var(--space-2)}.ap-msg-attachment{border:1px solid var(--color-surface-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);overflow:hidden}.ap-msg-attachment-img{width:120px;height:80px;object-fit:cover;display:block}.ap-msg-attachment-pdf{display:flex;align-items:center;gap:var(--space-2);padding:8px 12px;font-size:var(--text-xs);color:var(--color-text-primary)}.ap-attachment-badge{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);padding:2px 5px;border-radius:3px;background:var(--color-accent-subtle)}.ap-tool-badge{display:inline-flex;align-items:center;margin-right:var(--space-2);color:var(--color-accent);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.6rem}.ap-typing{display:flex;gap:4px;padding:2px 0}.ap-typing span{width:7px;height:7px;border-radius:50%;background:var(--color-text-muted);animation:ap-bounce 1.4s ease-in-out infinite both}.ap-typing span:nth-child(1){animation-delay:-.32s}.ap-typing span:nth-child(2){animation-delay:-.16s}.ap-composer{border-top:1px solid var(--color-surface-border);background:var(--color-surface);padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.ap-attachments-bar{display:flex;flex-wrap:wrap;gap:6px}.ap-attachment-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border-radius:10px;background:var(--color-bg-secondary);border:1px solid var(--color-surface-border)}.ap-attachment-thumb{width:28px;height:28px;border-radius:6px;object-fit:cover}.ap-attachment-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--text-xs);color:var(--color-text-primary)}.ap-attachment-remove{width:18px;height:18px;padding:0;border:none;border-radius:999px;background:#f871711f;color:#f87171;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .12s ease}.ap-attachment-remove:hover{background:#f8717140}.ap-input-row{position:relative;display:flex;align-items:flex-end;gap:var(--space-2)}.ap-textarea{flex:1;min-height:40px;max-height:140px;padding:10px 14px;resize:none;background:var(--color-bg-primary);border:1px solid var(--color-surface-border);border-radius:14px;color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-sm);line-height:1.45;overflow-y:auto;transition:border-color .15s ease}.ap-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #d4a26a14}.ap-textarea::placeholder{color:var(--color-text-muted)}.ap-composer-btn{width:38px;height:38px;padding:0;border:1px solid var(--color-surface-border);border-radius:12px;background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease}.ap-composer-btn.attach:hover{border-color:#d4a26a59;color:var(--color-text-primary);background:var(--color-bg-hover)}.ap-composer-btn.send{background:var(--color-accent);border-color:transparent;color:var(--color-bg-primary)}.ap-composer-btn.send:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #d4a26a4d}.ap-composer-btn.send.stop{background:#f871711f;border-color:#f871713d;color:#f87171}.ap-composer-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.ap-mention-menu{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:200px;overflow-y:auto;z-index:20;padding:4px}.ap-mention-option{width:100%;display:flex;align-items:center;gap:var(--space-2);text-align:left;padding:8px 10px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:var(--text-xs);transition:background .12s ease}.ap-mention-option.active,.ap-mention-option:hover{background:var(--color-accent-subtle);color:var(--color-text-primary)}.ap-mention-path{font-family:var(--font-mono)}@keyframes ap-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes ap-bounce{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}@media (max-width: 640px){.ap-config-bar{flex-wrap:wrap}.ap-config-persona-wrap{flex-basis:100%}.ap-persona-menu{left:0;right:0}}.shortcuts-overlay{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;background:#0000008c;backdrop-filter:blur(6px);animation:fadeIn .15s ease-out}.shortcuts-modal{width:520px;max-width:92vw;max-height:80vh;background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),var(--shadow-glow);display:flex;flex-direction:column;overflow:hidden;animation:fadeInUp .2s ease-out}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px;border-bottom:1px solid var(--color-surface-border)}.shortcuts-header h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0}.shortcuts-close{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;transition:all .15s}.shortcuts-close:hover{background:#d4a26a14;color:var(--color-text-primary)}.shortcuts-body{padding:16px 24px 24px;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;gap:20px}.shortcut-group-title{font-family:var(--font-display);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent);margin-bottom:10px}.shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0}.shortcut-desc{font-size:.82rem;color:var(--color-text-secondary)}.shortcut-keys{display:flex;gap:3px}.shortcut-keys kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 6px;background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:5px;font-family:var(--font-mono);font-size:.7rem;color:var(--color-text-tertiary);box-shadow:0 1px #0000004d}.app-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr auto var(--ai-panel-width);height:100vh;width:100vw;overflow:hidden;background:var(--color-bg-primary)}.app-layout.focus-mode{grid-template-columns:0 1fr 0 0}.sidebar{display:flex;flex-direction:column;background:var(--color-surface);border-right:1px solid var(--color-surface-border);transition:width .3s,transform .3s;overflow:hidden}.sidebar.collapsed{width:0;border-right:none}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-surface-border);min-height:var(--header-height)}.sidebar-actions{display:flex;align-items:center;gap:6px}.project-info{display:flex;align-items:center;gap:8px;overflow:hidden}.project-icon{font-size:1.15rem;flex-shrink:0}.project-name{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-content{display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg-primary)}.editor-area{flex:1;overflow:hidden;position:relative}.resize-handle{width:5px;cursor:col-resize;background:transparent;position:relative;flex-shrink:0;z-index:10;transition:background .15s}.resize-handle:after{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);width:2px;background:var(--color-surface-border);border-radius:100px;transition:all .2s}.resize-handle:hover:after{width:3px;background:var(--color-accent);box-shadow:0 0 8px #d4a26a4d}.resize-handle:active:after{width:3px;background:var(--color-accent-hover);box-shadow:0 0 12px #d4a26a66}.ai-panel{display:flex;flex-direction:column;background:var(--color-surface);border-left:1px solid var(--color-surface-border);transition:width .3s,transform .3s;overflow:hidden}.ai-panel.collapsed{width:0;border-left:none}.ai-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-surface-border);min-height:var(--header-height)}.panel-title{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--color-accent);text-transform:uppercase;letter-spacing:.1em}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;padding:32px}.empty-content{text-align:center;animation:fadeIn .5s ease-out}.empty-icon{font-size:48px;display:block;margin-bottom:16px;opacity:.4}.empty-content h3{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-bottom:8px}.empty-content p{color:var(--color-text-secondary);font-size:.85rem;max-width:360px;margin:0 auto}.quick-actions{display:flex;gap:12px;justify-content:center;margin-top:24px}.quick-action-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 24px;background:var(--v5-card-bg);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;color:var(--color-text-secondary);min-width:110px}.quick-action-card:hover{background:var(--color-accent-subtle);border-color:#d4a26a40;color:var(--color-text-primary);transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 12px #d4a26a14}.quick-action-card .qa-icon{font-size:24px}.quick-action-card .qa-label{font-family:var(--font-display);font-size:.8rem;font-weight:500}.status-bar{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:var(--statusbar-height);background:var(--color-bg-secondary);border-top:1px solid var(--color-surface-border);font-family:var(--font-mono);font-size:.72rem;color:var(--color-text-tertiary)}.status-left,.status-right{display:flex;align-items:center;gap:8px}.status-separator{color:var(--color-text-muted)}.daily-goal{display:flex;align-items:center;gap:8px}.goal-label{color:var(--color-text-muted)}.goal-bar{width:60px;height:3px;background:#d4a26a1a;border-radius:100px;overflow:hidden}.goal-progress{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover));border-radius:100px;transition:width .3s}.goal-count{min-width:36px;text-align:right;color:var(--color-accent)}.goal-count.clickable{cursor:pointer;border-bottom:1px dotted var(--color-text-muted);transition:all .15s}.goal-count.clickable:hover{color:var(--color-accent-hover);border-bottom-color:var(--color-accent)}.goal-input{width:60px;height:20px;background:var(--color-bg-primary);border:1px solid var(--color-accent);border-radius:4px;padding:0 4px;font-family:var(--font-mono);font-size:.7rem;color:var(--color-text-primary);text-align:right;outline:none}.status-btn{display:flex;align-items:center;justify-content:center;width:24px;height:20px;padding:0;background:transparent;border:none;border-radius:4px;color:var(--color-text-muted);cursor:pointer;transition:all .15s}.status-btn:hover{background:#d4a26a14;color:var(--color-text-primary)}.status-btn.active{color:var(--color-accent);background:var(--v5-amber-soft)}.sidebar-toggle-collapsed,.ai-toggle-collapsed{position:fixed;top:50%;transform:translateY(-50%);z-index:100;width:28px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--color-surface-border);color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.sidebar-toggle-collapsed{left:0;border-radius:0 10px 10px 0;border-left:none}.ai-toggle-collapsed{right:0;border-radius:10px 0 0 10px;border-right:none}.sidebar-toggle-collapsed:hover,.ai-toggle-collapsed:hover{background:var(--color-bg-hover);color:var(--color-accent);border-color:#d4a26a33}.mobile-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100vw;overflow:hidden}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--color-surface);border-bottom:1px solid var(--color-surface-border);min-height:var(--header-height);flex-shrink:0}.mobile-header-actions{display:flex;align-items:center;gap:4px}.mobile-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.mobile-panel-active{flex:1;overflow:hidden;display:flex;flex-direction:column;width:100%}.mobile-layout .sidebar.mobile-panel-active{width:100%;border-right:none}.mobile-layout .ai-panel.mobile-panel-active{width:100%;border-left:none}.mobile-layout .ai-panel.mobile-panel-active .panel-header{display:none}.mobile-tab-bar{display:flex;align-items:stretch;background:var(--color-surface);border-top:1px solid var(--color-surface-border);flex-shrink:0;padding:4px 0;padding-bottom:max(4px,env(safe-area-inset-bottom))}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 4px;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;transition:color .15s;font-family:var(--font-display);font-size:.65rem;font-weight:500}.mobile-tab.active{color:var(--color-accent)}.mobile-tab:active{background:#d4a26a0f}@media (max-width: 768px){.status-bar{display:none}}.app-loading{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary)}.loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);animation:fadeIn .5s ease-out}.loading-logo{font-size:48px;animation:bounce 1s ease-in-out infinite}.loading-text{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text-secondary)}.loading-actions{display:flex;gap:var(--space-3)}:root{--color-bg-primary: #0e110f;--color-bg-secondary: #121510;--color-bg-tertiary: #181c14;--color-bg-elevated: #1c201a;--color-bg-hover: #232820;--color-bg-active: #2a302a;--color-surface: #141812;--color-surface-hover: #1a1e16;--color-surface-border: rgba(212, 162, 106, .08);--color-text-primary: #e8e4dc;--color-text-secondary: #a8a49c;--color-text-tertiary: #858077;--color-text-muted: #66635c;--color-accent: #d4a26a;--color-accent-hover: #e9c46a;--color-accent-subtle: rgba(212, 162, 106, .15);--color-accent-muted: rgba(212, 162, 106, .08);--color-success: #6ee7b7;--color-warning: #fcd34d;--color-error: #f87171;--color-info: #93c5fd;--color-fiction: #818cf8;--color-nonfiction: #34d399;--color-scifi: #22d3ee;--color-mystery: #a78bfa;--color-romance: #fb7185;--color-fantasy: #c084fc;--color-biography: #facc15;--color-selfhelp: #4ade80;--color-node-character: #f472b6;--color-node-location: #38bdf8;--color-node-plotpoint: #a3e635;--color-node-note: #fbbf24;--font-display: "Lora", "Georgia", serif;--font-body: "Nunito Sans", "Helvetica Neue", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--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, .5), 0 8px 10px -6px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(212, 162, 106, .18);--v5-card-bg: rgba(255, 255, 255, .025);--v5-amber-soft: rgba(212, 162, 106, .1);--transition-fast: .1s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--sidebar-width: 260px;--ai-panel-width: 340px;--header-height: 44px;--tab-height: 38px;--statusbar-height: 28px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);overflow:auto}#root{height:100vh;width:100vw;overflow:auto}::selection{background-color:var(--color-accent-subtle);color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-surface-border);border-radius:var(--radius-full);border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary);border:2px solid transparent;background-clip:padding-box}*{scrollbar-width:thin;scrollbar-color:var(--color-surface-border) transparent}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:var(--leading-tight);color:var(--color-text-primary)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{color:var(--color-text-secondary);line-height:var(--leading-relaxed)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}code,pre{font-family:var(--font-mono);font-size:.9em}code{background:var(--color-bg-elevated);padding:.2em .4em;border-radius:var(--radius-sm)}.text-muted{color:var(--color-text-muted)}.text-tertiary{color:var(--color-text-tertiary)}.text-secondary{color:var(--color-text-secondary)}.text-primary{color:var(--color-text-primary)}.text-accent{color:var(--color-accent)}.font-display{font-family:var(--font-display)}.font-body{font-family:var(--font-body)}.font-mono{font-family:var(--font-mono)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease-out}.animate-fade-in-down{animation:fadeInDown var(--transition-slow) ease-out}.animate-slide-in-left{animation:slideInLeft var(--transition-slow) ease-out}.animate-slide-in-right{animation:slideInRight var(--transition-slow) ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.stagger-1{animation-delay:50ms}.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}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:11px 26px;font-family:var(--font-display);font-size:.88rem;font-weight:600;line-height:1;border-radius:24px;border:1px solid transparent;cursor:pointer;transition:all .3s;white-space:nowrap;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:var(--color-bg-primary);border-color:transparent;box-shadow:none}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #d4a26a40}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:transparent;color:var(--color-text-primary);border-color:var(--color-surface-border)}.btn-secondary:hover:not(:disabled){border-color:#d4a26a66;color:var(--color-accent)}.btn-ghost{background:transparent;color:var(--color-text-secondary);border:none}.btn-ghost:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-icon{width:32px;height:32px;padding:0;border-radius:var(--radius-md)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);transition:all var(--transition-base)}.input::placeholder{color:var(--color-text-muted)}.input:hover{border-color:var(--color-text-tertiary)}.input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.input-lg{padding:var(--space-4) var(--space-5);font-size:var(--text-lg)}.textarea{min-height:100px;resize:vertical;line-height:var(--leading-relaxed)}.select-wrapper{position:relative;width:100%}.select{width:100%;padding:var(--space-3) var(--space-4);padding-right:var(--space-10);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);cursor:pointer;appearance:none;transition:all var(--transition-base)}.select:hover{border-color:var(--color-text-tertiary)}.select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.select-wrapper:after{content:"";position:absolute;right:16px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--color-text-tertiary);pointer-events:none}.chip-group{display:flex;flex-wrap:wrap;gap:var(--space-2)}.chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);user-select:none}.chip:hover{background:var(--color-bg-hover);border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.chip.selected{background:var(--color-accent-subtle);border-color:var(--color-accent);color:var(--color-accent)}.chip[data-genre=Fiction].selected{border-color:var(--color-fiction);color:var(--color-fiction);background:#818cf826}.chip[data-genre=Non-Fiction].selected{border-color:var(--color-nonfiction);color:var(--color-nonfiction);background:#34d39926}.chip[data-genre=Sci-Fi].selected{border-color:var(--color-scifi);color:var(--color-scifi);background:#22d3ee26}.chip[data-genre=Mystery].selected{border-color:var(--color-mystery);color:var(--color-mystery);background:#a78bfa26}.chip[data-genre=Romance].selected{border-color:var(--color-romance);color:var(--color-romance);background:#fb718526}.chip[data-genre=Fantasy].selected{border-color:var(--color-fantasy);color:var(--color-fantasy);background:#c084fc26}.chip[data-genre=Biography].selected{border-color:var(--color-biography);color:var(--color-biography);background:#facc1526}.chip[data-genre=Self-Help].selected{border-color:var(--color-selfhelp);color:var(--color-selfhelp);background:#4ade8026}.card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:var(--space-6)}.card-elevated{background:var(--color-bg-elevated);box-shadow:var(--shadow-lg)}.panel{background:var(--color-surface);border-right:1px solid var(--color-surface-border);height:100%;overflow:hidden;display:flex;flex-direction:column}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-surface-border);min-height:var(--header-height)}.panel-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.panel-content{flex:1;overflow-y:auto;padding:var(--space-2)}.divider{height:1px;background:var(--color-surface-border);margin:var(--space-4) 0}.divider-vertical{width:1px;height:100%;background:var(--color-surface-border)}.progress-bar{display:flex;gap:var(--space-2);align-items:center}.progress-segment{height:4px;flex:1;background:var(--color-surface-border);border-radius:var(--radius-full);overflow:hidden;transition:background var(--transition-base)}.progress-segment.completed{background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover))}.progress-segment.current{background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover));animation:pulse 2s ease-in-out infinite}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-family:var(--font-display);color:var(--color-text-primary);background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:var(--radius-sm);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);pointer-events:none;z-index:var(--z-tooltip)}.tooltip:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.skeleton{background:linear-gradient(90deg,var(--color-bg-secondary) 25%,var(--color-bg-elevated) 50%,var(--color-bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.spinner{width:20px;height:20px;border:2px solid var(--color-surface-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-sm);background:var(--color-accent-subtle);color:var(--color-accent)}.badge-success{background:#6ee7b726;color:var(--color-success)}.badge-warning{background:#fcd34d26;color:var(--color-warning)}.badge-error{background:#f8717126;color:var(--color-error)}.context-menu{position:fixed;min-width:180px;background:var(--color-bg-elevated);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:var(--space-1);box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);animation:fadeInUp .15s ease-out}.context-menu-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.context-menu-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.context-menu-item.disabled{opacity:.45;cursor:not-allowed}.context-menu-item.disabled:hover{background:transparent;color:var(--color-text-secondary)}.context-menu-item.danger:hover{background:#f8717126;color:var(--color-error)}.context-menu-separator{height:1px;background:var(--color-surface-border);margin:var(--space-1) 0}[dir=rtl] .app-layout{direction:rtl}[dir=rtl] .sidebar{border-right:none;border-left:1px solid var(--color-surface-border)}[dir=rtl] .sidebar.collapsed{border-left:none}[dir=rtl] .ai-panel{border-left:none;border-right:1px solid var(--color-surface-border)}[dir=rtl] .ai-panel.collapsed{border-right:none}[dir=rtl] .sidebar-toggle-collapsed{left:auto;right:0;border-radius:10px 0 0 10px;border-right:none;border-left:1px solid var(--color-surface-border)}[dir=rtl] .ai-toggle-collapsed{right:auto;left:0;border-radius:0 10px 10px 0;border-left:none;border-right:1px solid var(--color-surface-border)}[dir=rtl] .tree-item-content{padding-left:var(--space-4);padding-right:var(--space-3)}[dir=rtl] .folder-arrow{transform:scaleX(-1)}[dir=rtl] .folder-arrow.expanded{transform:scaleX(-1) rotate(90deg)}[dir=rtl] .child-count{margin-left:0;margin-right:auto}[dir=rtl] .tree-item.nested:before{left:auto;right:24px}[dir=rtl] .tree-item.drop-before:before,[dir=rtl] .tree-item.drop-after:after{left:12px;right:12px}[dir=rtl] .context-icon{margin-right:0;margin-left:var(--space-2)}[dir=rtl] .tab{border-right:none;border-left:1px solid var(--color-surface-border);padding-left:8px;padding-right:14px}[dir=rtl] .tab-unsaved{margin-left:0;margin-right:2px}[dir=rtl] .tab-close{margin-left:0;margin-right:4px}[dir=rtl] .goal-count,[dir=rtl] .goal-input{text-align:left}[dir=rtl] .ap-chat-drawer{transform:translate(100%);border-right:none;border-left:1px solid var(--color-surface-border)}[dir=rtl] .ap-chat-drawer.open{transform:translate(0)}[dir=rtl] .ap-msg-bubble{text-align:right}[dir=rtl] .ap-tool-label{padding-left:0;padding-right:var(--space-5)}[dir=rtl] .ap-mention-icon{margin-right:0;margin-left:var(--space-2)}[dir=rtl] .editor-toolbar-group{padding-right:0;padding-left:8px;margin-right:0;margin-left:8px;border-right:none;border-left:1px solid var(--color-surface-border)}[dir=rtl] .editor-toolbar-group:last-child{border-left:none}[dir=rtl] .ProseMirror blockquote{border-left:none;border-right:3px solid var(--color-accent);padding-left:0;padding-right:1.2em}[dir=rtl] .ProseMirror ol,[dir=rtl] .ProseMirror ul{padding-left:0;padding-right:1.5em}[dir=rtl] .selection-actions{float:right}[dir=rtl] .ai-action-chip{margin-left:0;margin-right:auto}[dir=rtl] .markdown-editor .CodeMirror{padding-left:40px!important;padding-right:40px!important;direction:rtl}[dir=rtl] .canvas-toolbar-item{margin-right:0;margin-left:8px}[dir=rtl] .hub-topbar{direction:rtl}[dir=rtl] .hub-card-menu{right:auto;left:0}[dir=rtl] .hub-card-arrow{transform:scaleX(-1)}[dir=rtl] .streak-heatmap-legend{direction:rtl}[dir=rtl] .hub-next-ach__credits{margin-left:0;margin-right:auto}[dir=rtl] .ph-back{direction:rtl}[dir=rtl] .ph-tool-arrow{transform:scaleX(-1)}[dir=rtl] .ph-stage-chevron{margin-left:0;margin-right:4px}[dir=rtl] .ph-sb-left{direction:rtl}[dir=rtl] .pam-dropdown{right:auto;left:0}[dir=rtl] .pam-item{text-align:right}[dir=rtl] .pam-icon{margin-right:0;margin-left:var(--space-2)}[dir=rtl] .dr7-header,[dir=rtl] .dr7-step-card{direction:rtl}[dir=rtl] .dr7-chevron{transform:scaleX(-1)}[dir=rtl] .dr7-chevron.open{transform:scaleX(-1) rotate(90deg)}[dir=rtl] .dr7-issue-warn-icon{margin-right:0;margin-left:var(--space-2)}[dir=rtl] .dr7-fix-toolbar,[dir=rtl] .ms-header,[dir=rtl] .ms-copy-type-btn,[dir=rtl] .ms-tone-pill{direction:rtl}[dir=rtl] .ms-asset-card{text-align:right}[dir=rtl] .ab-header,[dir=rtl] .ab-scope-bar,[dir=rtl] .ab-cast-row{direction:rtl}[dir=rtl] .ab-voice{text-align:right}[dir=rtl] .ab-track__top,[dir=rtl] .at-header{direction:rtl}[dir=rtl] .at-persona{text-align:right}[dir=rtl] .at-scope-bar{direction:rtl}[dir=rtl] .at-rail{border-right:none;border-left:1px solid var(--color-surface-border)}[dir=rtl] .at-score,[dir=rtl] .at-feedback{text-align:right}[dir=rtl] .at-history-scores{direction:rtl}[dir=rtl] .at-history-score strong{margin-left:0;margin-right:4px}[dir=rtl] .rp-header{direction:rtl}[dir=rtl] .rp-drag-handle{margin-right:0;margin-left:var(--space-2)}[dir=rtl] .rp-controls,[dir=rtl] .rp-color-row,[dir=rtl] .story-bible-header{direction:rtl}[dir=rtl] .story-bible-sidebar{border-right:none;border-left:1px solid var(--color-surface-border)}[dir=rtl] .story-bible-section{text-align:right}[dir=rtl] .community-shell{direction:rtl}[dir=rtl] .community-post-card{text-align:right}[dir=rtl] .community-post-header{direction:rtl}[dir=rtl] .community-excerpt{border-left:none;border-right:3px solid rgba(212,162,106,.25);text-align:right}[dir=rtl] .community-excerpt.active{border-right-color:var(--color-accent)}[dir=rtl] .community-excerpt.spoiler{border-right-color:#f871714d}[dir=rtl] .community-comment-input{margin-left:0;margin-right:var(--space-3)}[dir=rtl] .community-action-row{direction:rtl}[dir=rtl] .community-save-btn,[dir=rtl] .community-follow-btn{margin-left:0;margin-right:auto}[dir=rtl] .composer-type-row,[dir=rtl] .composer-options-row{direction:rtl}[dir=rtl] .composer-image-remove,[dir=rtl] .community-report-menu{right:auto;left:var(--space-2)}[dir=rtl] .auth-form{text-align:right}[dir=rtl] .auth-gate-card{text-align:center}[dir=rtl] .onboarding{direction:rtl}[dir=rtl] .step-content,[dir=rtl] .onboarding-field{text-align:right}[dir=rtl] .step-navigation{direction:rtl}[dir=rtl] .mentor-suggested{margin-left:0;margin-right:auto}[dir=rtl] .hub-card-menu-wrapper .hub-card-menu{right:auto;left:0}[dir=rtl] .select-wrapper:after{right:auto;left:16px}[dir=rtl] .select{padding-right:var(--space-4);padding-left:var(--space-10)}[dir=rtl] .v5-nav{direction:rtl}[dir=rtl] .v5-pipeline-num{margin-right:0;margin-left:var(--space-4)}[dir=rtl] .v5-pipeline-body{text-align:right}[dir=rtl] .v5-pipeline-feats{text-align:right;padding-left:0;padding-right:18px}[dir=rtl] .v5-pipeline-feats li:before{left:auto;right:0}[dir=rtl] .v5-authorbot-card,[dir=rtl] .v5-pricing-card{text-align:right}[dir=rtl] .v5-price-features{text-align:right;padding-left:0;padding-right:18px}[dir=rtl] .v5-faq-wrap{text-align:right}[dir=rtl] .v5-footer{direction:rtl}[dir=rtl] .v5-hero-leaf-1{right:auto;left:12%}[dir=rtl] .v5-hero-leaf-2{left:auto;right:10%}[dir=rtl] .shortcuts-overlay,[dir=rtl] .shortcut-row,[dir=rtl] .diff-view,[dir=rtl] .diff-header{direction:rtl}[dir=rtl] .rewards-achievement-card{border-left:none;border-right:3px solid var(--color-accent)}[dir=rtl] body,[dir=rtl] input,[dir=rtl] textarea,[dir=rtl] select{text-align:right}[dir=rtl] input[type=number],[dir=rtl] input[type=email],[dir=rtl] input[type=url]{direction:ltr;text-align:right}[dir=rtl] .panel{border-right:none;border-left:1px solid var(--color-surface-border)}[dir=rtl] .tooltip:after{left:auto;right:50%;transform:translate(50%)}[dir=rtl] .tooltip:hover:after{transform:translate(50%) translateY(-4px)}[dir=rtl] .profile-page,[dir=rtl] .profile-header{direction:rtl}@keyframes slideInRight-rtl{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft-rtl{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}[dir=rtl] .animate-slide-in-left{animation-name:slideInLeft-rtl}[dir=rtl] .animate-slide-in-right{animation-name:slideInRight-rtl}
