*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#faf9f7;--color-text:#1a1a1a;--color-text-muted:#6b6b6b;--color-accent:#8b4513;--color-border:#e5e2dd;--color-success:#2e7d32;--color-error:#c62828;--color-warning:#f57c00;--color-warning-dark:#b8860b;--color-info:#1976d2;--color-neutral:#757575;--color-card:white;--color-card-alt:#f8f7f4;--color-star:#f5a623;--color-stale-bg:#fff3cd;--color-stale-border:#ffc107;--color-stale-text:#e65100;--color-tier-pro:#9333ea;--color-tier-writer:#2563eb;--color-tier-starter:#059669;--color-state-running:#2e7d32;--color-state-starting:#f57c00;--color-state-stopped:#757575;--color-state-info:#1976d2;--color-state-error:#c62828;--font-serif:"Cormorant Garamond",Georgia,serif;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--z-panel-overlay:500;--z-panel:501;--z-modal:600;--z-dialog:700;--z-onboarding:800;--z-admin-confirm:1000}[data-theme=dark]{--color-bg:#242017;--color-text:#d8d4cf;--color-text-muted:#a49d91;--color-accent:#eca471;--color-border:#383d40;--color-success:#82d186;--color-error:#da4a4a;--color-warning:#ffb74d;--color-warning-dark:#d4a853;--color-info:#64b5f6;--color-neutral:#999;--color-card:#181a1b;--color-card-alt:#1c1a12;--color-star:#ffc85a;--color-stale-bg:#3d2e0f;--color-stale-border:#5c4a1f;--color-stale-text:#ffb74d;--color-tier-pro:#a855f7;--color-tier-writer:#60a5fa;--color-tier-starter:#34d399;--color-state-running:#82d186;--color-state-starting:#ffb74d;--color-state-stopped:#999;--color-state-info:#64b5f6;--color-state-error:#da4a4a}html{scroll-behavior:smooth;font-size:18px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);flex-direction:column;min-height:100vh;line-height:1.6;display:flex}main{flex:1}.book-header{border-bottom:1px solid var(--color-border);background:var(--color-card);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.logo{font-family:var(--font-serif);letter-spacing:.05em;color:var(--color-text);font-size:1.75rem;font-weight:600;text-decoration:none}.logo span{color:var(--color-accent)}.logo-tagline{color:var(--color-text-muted);letter-spacing:.02em;margin-left:.75rem;font-size:.9rem;font-weight:400}.header-nav{align-items:center;gap:1.5rem;display:flex}.header-nav a{color:var(--color-text-muted);font-size:.9rem;text-decoration:none;transition:color .2s}.header-nav a:hover{color:var(--color-accent)}.page-container,.book-layout{width:100%;max-width:1200px;margin:0 auto;padding:2rem}.breadcrumb{color:var(--color-text-muted);margin-bottom:2rem;font-size:.85rem}.breadcrumb a{color:var(--color-text-muted);text-decoration:none}.breadcrumb a:hover{color:var(--color-accent)}.book-hero{grid-template-columns:300px 1fr;gap:3rem;margin-bottom:3rem;display:grid}@media (max-width:768px){.book-hero{grid-template-columns:1fr;gap:2rem}}.book-cover-container{align-self:start;position:sticky;top:2rem}@media (max-width:768px){.book-cover-container{max-width:250px;margin:0 auto;position:static}}.book-cover{aspect-ratio:2/3;background:linear-gradient(135deg,var(--color-border)0%,#d5d0c8 100%);border-radius:8px;overflow:hidden;box-shadow:0 8px 24px #00000026}.book-cover img{object-fit:cover;width:100%;height:100%}.book-cover-placeholder{width:100%;height:100%;color:var(--color-text-muted);justify-content:center;align-items:center;font-size:.9rem;display:flex}.book-title{font-family:var(--font-serif);color:var(--color-text);margin-bottom:.5rem;font-size:2.5rem;font-weight:600;line-height:1.2}.book-author{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:1.1rem}.book-meta{color:var(--color-text-muted);flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;font-size:.9rem;display:flex}.book-genres{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.genre-tag{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:20px;padding:.35rem .75rem;font-size:.8rem}.book-purchase{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.book-price{font-family:var(--font-serif);color:var(--color-accent);margin-bottom:.5rem;font-size:2rem;font-weight:600}.book-price-note{color:var(--color-text-muted);margin-bottom:1rem;font-size:.85rem}.btn-buy{width:100%;font-size:1rem;font-family:var(--font-sans);background:var(--color-accent);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:4px;padding:1rem;font-weight:500;text-decoration:none;transition:background .2s;display:block}.btn-buy:hover{background:var(--color-text)}.btn-buy:disabled{opacity:.6;cursor:not-allowed}.purchase-note{color:var(--color-text-muted);text-align:center;margin-top:1rem;font-size:.8rem}.owned-badge{color:var(--color-success);background:#2e7d321a;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:1rem;font-weight:500;display:flex}.book-section{margin-bottom:2.5rem}.section-title{font-family:var(--font-serif);border-bottom:1px solid var(--color-border);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.5rem;font-weight:400}.book-blurb{color:var(--color-text);margin-bottom:1.5rem;font-size:1.1rem;line-height:1.7}.book-description{color:var(--color-text);font-size:1rem;line-height:1.8}.book-description p{margin-bottom:1rem}.ai-disclosure{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;margin-top:1.5rem;padding:1.25rem}.ai-disclosure-header{color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.95rem;font-weight:500;display:flex}.ai-disclosure p{color:var(--color-text-muted);margin:0;font-size:.9rem;line-height:1.6}.book-footer{border-top:1px solid var(--color-border);text-align:center;margin-top:2rem;padding:2rem}.book-footer a{color:var(--color-text-muted);font-size:.9rem;text-decoration:none}.book-footer a:hover{color:var(--color-accent)}.btn{font-size:.9rem;font-family:var(--font-sans);cursor:pointer;text-align:center;border:none;border-radius:4px;padding:.875rem 1.5rem;font-weight:500;text-decoration:none;transition:background-color .2s;display:inline-block}.btn-primary{background-color:var(--color-accent);color:#fff}.btn-primary:hover{background-color:var(--color-text)}[data-theme=dark] .btn-primary{color:#1a1a1a}.btn-outline{border:1px solid var(--color-border);color:var(--color-text);background:0 0}.btn-outline:hover{border-color:var(--color-accent);color:var(--color-accent)}.btn-danger{background:var(--color-error);color:#fff;border:none}.btn-danger:hover{background:#a21f1f}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-action{font-size:.75rem;font-family:var(--font-sans);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;gap:.35rem;min-width:4.5rem;height:1.75rem;padding:0 .75rem;text-decoration:none;transition:all .2s;display:inline-flex}.btn-action:hover{border-color:var(--color-accent);color:var(--color-accent)}.btn-action.danger:hover{border-color:var(--color-error);color:var(--color-error)}.loading{text-align:center;color:var(--color-text-muted);padding:4rem 2rem}.hero{text-align:center;margin-bottom:3rem}.hero h1{font-family:var(--font-serif);margin-bottom:.5rem;font-size:2.5rem;font-weight:400}.hero p{color:var(--color-text-muted);max-width:600px;margin:0 auto}.hero-paths{justify-content:center;gap:1rem;margin-top:1.5rem;display:flex}.hero-path-btn{border-radius:4px;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.hero-path-primary{background:var(--color-accent);color:#fff}.hero-path-primary:hover{background:var(--color-text)}[data-theme=dark] .hero-path-primary{color:#1a1a1a}.hero-path-secondary{border:1px solid var(--color-border);color:var(--color-text);background:0 0}.hero-path-secondary:hover{border-color:var(--color-accent);color:var(--color-accent)}@media (max-width:480px){.hero-paths{flex-direction:column;align-items:center}.hero-path-btn{text-align:center;width:100%;max-width:200px}}.accent{color:var(--color-accent)}.book-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem;width:100%;display:grid}.book-card{color:inherit;text-decoration:none;transition:transform .2s;display:block}.book-card:hover{transform:translateY(-4px)}.book-card-cover{aspect-ratio:2/3;background-color:var(--color-border);border-radius:8px;margin-bottom:.75rem;overflow:hidden;box-shadow:0 4px 12px #0000001a}.book-card-cover img{object-fit:cover;width:100%;height:100%}.book-card-cover-placeholder{width:100%;height:100%;color:var(--color-text-muted);justify-content:center;align-items:center;font-size:.8rem;display:flex}.book-card-title{font-family:var(--font-serif);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.25rem;font-size:1rem;font-weight:600;display:-webkit-box;overflow:hidden}.book-card-price{color:var(--color-accent);font-size:.85rem;font-weight:500}.book-card-genre{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem}.book-card-cover{position:relative}.book-card-badge{z-index:1;position:absolute;top:8px;right:8px}.book-card-author{color:var(--color-text-muted);margin-bottom:.25rem;font-size:.8rem}.author-verified-badge{color:#166534;white-space:nowrap;background-color:#dcfce7;border-radius:12px;align-items:center;gap:4px;padding:3px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.author-verified-badge svg{color:#16a34a}[data-theme=dark] .author-verified-badge{color:#86efac;background-color:#22c55e33}[data-theme=dark] .author-verified-badge svg{color:#86efac}.author-badge-inline{vertical-align:middle;margin-left:.5rem}.author-certification{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;margin-top:1rem;padding:1.5rem}.certification-header{align-items:center;gap:8px;margin-bottom:1rem;display:flex}.certification-icon{color:#16a34a;width:24px;height:24px}.certification-label{color:#166534;font-size:1.1rem;font-weight:600}[data-theme=dark] .certification-label{color:#86efac}.certification-content{align-items:flex-start;gap:1.5rem;display:flex}.certification-photo{flex-shrink:0}.certification-photo-img{object-fit:cover;border-radius:50%}.certification-details{flex:1}.certification-author{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.2rem;font-weight:600}.certification-note{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.9rem;line-height:1.5}.certification-date{color:var(--color-text-muted);font-size:.8rem;font-style:italic}.ai-disclosure-owned{background-color:#22c55e0d;border-color:#16a34a}.ai-disclosure-owned .ai-disclosure-header{color:#166534}[data-theme=dark] .ai-disclosure-owned{background-color:#22c55e1a;border-color:#22c55e}[data-theme=dark] .ai-disclosure-owned .ai-disclosure-header{color:#86efac}.ai-disclosure-mixed{background-color:#d977060d;border-color:#d97706}.ai-disclosure-mixed .ai-disclosure-header{color:#92400e}[data-theme=dark] .ai-disclosure-mixed{background-color:#f59e0b1a;border-color:#f59e0b}[data-theme=dark] .ai-disclosure-mixed .ai-disclosure-header{color:#fcd34d}@media (max-width:640px){.certification-content{text-align:center;flex-direction:column;align-items:center}.certification-photo{margin-bottom:1rem}}.empty-state{text-align:center;color:var(--color-text-muted);padding:3rem}@media (max-width:1024px){.page-container,.book-layout{padding:1.5rem}.book-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.25rem}}@media (max-width:768px){.page-container,.book-layout{padding:1rem}.book-header{flex-direction:column;gap:1rem;padding:1rem}.header-nav{justify-content:center;width:100%}.hero h1{font-size:1.75rem}.hero p{font-size:.9rem}.section-title{font-size:1.25rem}.book-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.book-card-title{font-size:.9rem}.book-card-price{font-size:.8rem}.book-title{font-size:1.75rem}.btn{padding:.75rem 1.25rem;font-size:.85rem}.logo{font-size:1.5rem}.logo-tagline{display:none}.header-nav{gap:1rem}.header-nav a{font-size:.8rem}}@media (max-width:480px){.book-header{padding:.75rem 1rem}.logo{font-size:1.25rem}.header-nav{gap:.75rem}.header-nav a{font-size:.75rem}.page-container,.book-layout{padding:.75rem}.hero h1{font-size:1.5rem}.book-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.book-card-cover{border-radius:6px}.section-title{font-size:1.1rem}}.rating-stars{color:var(--color-star)}.star-rating{vertical-align:middle;gap:1px;display:inline-flex}.star-rating .star-filled{color:var(--color-star);fill:var(--color-star)}.star-rating .star-empty{color:var(--color-text-muted);fill:none}.review-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1rem;padding:1.25rem}.no-reviews{text-align:center;color:var(--color-text-muted);background:var(--color-card);border:1px dashed var(--color-border);border-radius:8px;padding:2rem}.site-footer{border-top:1px solid var(--color-border);text-align:center;margin-top:auto;padding:2rem}.site-footer .footer-content{color:var(--color-text-muted);font-size:.85rem}.site-footer .footer-links{justify-content:center;gap:1.5rem;margin-bottom:1rem;display:flex}.site-footer .footer-links a{color:var(--color-text-muted);font-size:.85rem;text-decoration:none}.site-footer .footer-links a:hover{color:var(--color-accent)}.site-footer .footer-content a{color:var(--color-text-muted);text-decoration:none}.site-footer .footer-content a:hover{color:var(--color-accent)}.form-container{width:100%;max-width:360px;margin:0 auto;padding:4rem 2rem}.form-container h1{font-family:var(--font-serif);text-align:center;margin-bottom:.5rem;font-size:2rem;font-weight:400}.form-container .subtitle{color:var(--color-text-muted);text-align:center;margin-bottom:2rem;font-size:.95rem}.form-container .subtitle a{color:var(--color-accent);text-decoration:none}.form-container .subtitle a:hover{text-decoration:underline}.form-group{text-align:left;margin-bottom:1rem}.form-group label{color:var(--color-text);margin-bottom:.5rem;font-size:.85rem;font-weight:500;display:block}.form-group input{width:100%;font-size:1rem;font-family:var(--font-sans);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);border-radius:4px;padding:.875rem 1rem;transition:border-color .2s}.form-group input:focus{border-color:var(--color-accent);outline:none}.form-group input::placeholder{color:var(--color-text-muted)}.form-group textarea,.form-group select{width:100%;font-size:1rem;font-family:var(--font-sans);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);border-radius:4px;padding:.875rem 1rem;transition:border-color .2s}.form-group textarea:focus,.form-group select:focus{border-color:var(--color-accent);outline:none}.form-message{text-align:center;min-height:1.4em;margin-top:1rem;font-size:.9rem}.form-message.success{color:var(--color-success)}.form-message.error{color:var(--color-error)}.form-links{text-align:center;margin-top:1.5rem;font-size:.9rem}.form-links a{color:var(--color-accent);text-decoration:none}.form-links a:hover{text-decoration:underline}.form-links p{color:var(--color-text-muted);margin:.5rem 0}.role-select{gap:1rem;margin-bottom:1.5rem;display:flex}.role-option{border:1px solid var(--color-border);cursor:pointer;text-align:center;border-radius:4px;flex:1;padding:1rem;transition:border-color .2s,background-color .2s}.role-option:hover{border-color:var(--color-accent)}.role-option.selected{border-color:var(--color-accent);background-color:#8b45130d}.role-option input{display:none}.role-option .role-title{margin-bottom:.25rem;font-weight:500}.role-option .role-desc{color:var(--color-text-muted);font-size:.8rem}.checkbox-label{color:var(--color-text-muted);cursor:pointer;align-items:flex-start;gap:.5rem;font-size:.85rem;display:flex}.checkbox-label input[type=checkbox]{width:auto;accent-color:var(--color-accent);margin-top:.2rem}.checkbox-label a{color:var(--color-accent);text-decoration:none}.checkbox-label a:hover{text-decoration:underline}.cli-info{background:var(--color-card-alt);border:1px solid var(--color-border);text-align:center;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.cli-info h2{font-family:var(--font-serif);color:var(--color-text);margin-bottom:.5rem;font-size:1.25rem}.cli-info p{color:var(--color-text-muted);font-size:.9rem}.cli-info code{background:var(--color-border);border-radius:4px;padding:.2rem .5rem;font-family:monospace;font-size:.85rem}.permissions{background:var(--color-card);border:1px solid var(--color-border);text-align:left;border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.5rem}.permissions h3{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:.75rem;font-size:.85rem}.permissions ul{margin:0;padding:0;list-style:none}.permissions li{color:var(--color-text);align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.permissions li svg{color:var(--color-accent);flex-shrink:0}.btn-group .btn{flex:1}.btn-secondary{border:1px solid var(--color-border);color:var(--color-text);background:0 0}.btn-secondary:hover{background:var(--color-card-alt)}.status-authenticating{text-align:center;padding:3rem 0}.status-authenticating h2{font-family:var(--font-serif);margin-bottom:1rem;font-weight:400}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:40px;height:40px;margin:1rem auto;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.checkmark{color:var(--color-success);margin-bottom:1rem;font-size:3rem}.legal-layout{text-align:left;max-width:800px;margin:0 auto;padding:2rem}.legal-nav{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;margin-bottom:2rem;padding:1rem 1.5rem}.legal-nav-title{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.9rem;font-weight:500}.legal-nav ul{flex-wrap:wrap;gap:1.5rem;margin:0;padding:0;list-style:none;display:flex}.legal-nav li{margin:0}.legal-nav a{color:var(--color-text);font-size:.9rem;text-decoration:none}.legal-nav a:hover{color:var(--color-accent)}.legal-nav a.active{color:var(--color-accent);font-weight:500}.legal-header{border-bottom:1px solid var(--color-border);margin-bottom:2rem;padding-bottom:1.5rem}.legal-header h1{font-family:var(--font-serif);margin-bottom:.5rem;font-size:2.5rem;font-weight:400}.legal-header .last-updated{color:var(--color-text-muted);font-size:.9rem}.legal-content h2{font-family:var(--font-serif);margin-top:2rem;margin-bottom:1rem;font-size:1.5rem;font-weight:600}.legal-content h3{margin-top:1.5rem;margin-bottom:.75rem;font-size:1.1rem;font-weight:500}.legal-content p{margin-bottom:1rem;line-height:1.7}.legal-content ul,.legal-content ol{margin-bottom:1rem;padding-left:1.5rem}.legal-content li{margin-bottom:.5rem;line-height:1.6}.legal-content a{color:var(--color-accent);text-decoration:none}.legal-content a:hover{text-decoration:underline}.legal-content table,.legal-table{border-collapse:collapse;width:100%;margin:1rem 0}.legal-content th,.legal-content td,.legal-table th,.legal-table td{text-align:left;border:1px solid var(--color-border);padding:.75rem}.legal-content th,.legal-table th{background:#8b45130d;font-weight:500}.notice-box{border:1px solid var(--color-border);border-left:4px solid var(--color-accent);background:#8b45130d;border-radius:4px;margin:1.5rem 0;padding:1.25rem}.notice-box h4{margin:0 0 .5rem;font-weight:500}.notice-box p{margin:0}.contact-block{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;margin:1.5rem 0;padding:1.5rem}.contact-block p{margin:.25rem 0}.contact-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.contact-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem}.contact-card h3{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.contact-card p{color:var(--color-text-muted);margin-bottom:.75rem;font-size:.9rem}.contact-card a{color:var(--color-accent);font-weight:500}.faq-item{border-bottom:1px solid var(--color-border);margin-bottom:1.5rem;padding-bottom:1.5rem}.faq-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.faq-item h3{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.faq-item p{color:var(--color-text-muted);line-height:1.7}.faq-item a{color:var(--color-accent)}@media (max-width:600px){.legal-layout{padding:1rem}.legal-header h1{font-size:2rem}.legal-nav ul{flex-direction:column;gap:.75rem}.legal-content table,.legal-table{font-size:.85rem}.legal-content th,.legal-content td,.legal-table th,.legal-table td{padding:.5rem}}.success-container{text-align:center;max-width:500px;margin:0 auto;padding:4rem 2rem}.success-icon{color:var(--color-success);margin-bottom:1.5rem;font-size:4rem}.success-container h1{font-family:var(--font-serif);margin-bottom:.5rem;font-size:2rem;font-weight:400}.success-container .subtitle{color:var(--color-text-muted);margin-bottom:2rem}.success-details{background:var(--color-card);border:1px solid var(--color-border);text-align:left;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.success-details p{margin:.5rem 0}.success-actions{flex-direction:column;gap:1rem;display:flex}.theme-toggle{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.5rem;transition:color .2s,background-color .2s;display:flex}.theme-toggle:hover{color:var(--color-accent);background:var(--color-card-alt)}.theme-toggle svg{width:20px;height:20px}.page-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:1rem;display:flex}.page-title{font-family:var(--font-serif);margin-bottom:0;font-size:2rem;font-weight:400}.page-subtitle{color:var(--color-text-muted)}.header-actions{gap:1rem;display:flex}@media (max-width:768px){.page-header{flex-direction:column;gap:1rem}.header-actions{width:100%}.header-actions .btn{flex:1;justify-content:center}}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;width:100%;margin-bottom:2rem;display:grid}.stats-grid-3{grid-template-columns:repeat(3,1fr)}.stat-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem}.stat-label{color:var(--color-text-muted);margin-bottom:.25rem;font-size:.85rem}.stat-value{font-family:var(--font-serif);font-size:1.75rem;font-weight:600}.stat-value.running{color:var(--color-info)}.stat-value.completed{color:var(--color-success)}.stat-value.failed{color:var(--color-error)}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stats-grid-3{grid-template-columns:1fr}}.novels-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.novel-card{background:var(--color-card);border:1px solid var(--color-border);cursor:pointer;text-align:left;border-radius:12px;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.novel-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.novel-card.running{border-color:var(--color-info)}.novel-card.failed{border-color:var(--color-error)}.novel-card-cover{aspect-ratio:2/3;background:var(--color-bg-alt);position:relative;overflow:hidden}.novel-card-cover img{object-fit:cover;width:100%;height:100%}.novel-card-placeholder{width:100%;height:100%;color:var(--color-text-muted);background:linear-gradient(135deg,var(--color-bg-alt)0%,var(--color-border)100%);justify-content:center;align-items:center;display:flex}.novel-card-running-overlay{color:#fff;background:#00000080;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.novel-card-running-overlay .icon{width:32px;height:32px}.novel-card-content{flex-direction:column;flex:1;gap:.5rem;padding:1rem;display:flex}.novel-card-title{font-family:var(--font-serif);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1rem;font-weight:500;line-height:1.3;display:-webkit-box;overflow:hidden}.novel-card-prompt{color:var(--color-text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;margin:0;font-size:.8rem;line-height:1.4;display:-webkit-box;overflow:hidden}.novel-card-footer{justify-content:space-between;align-items:center;gap:.5rem;margin-top:auto;display:flex}.novel-card-progress{color:var(--color-info);font-size:.75rem;font-weight:600}.novel-card-retry{background:var(--color-error);color:#fff;cursor:pointer;z-index:1;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .2s,background .2s;display:flex;position:absolute;top:.5rem;right:.5rem}.novel-card-retry:hover{background:var(--color-error-hover);transform:scale(1.1)}.novel-card-retry:disabled{opacity:.7;cursor:not-allowed}.badge-sm{padding:.2rem .4rem;font-size:.65rem}.pagination{justify-content:center;align-items:center;gap:1rem;padding:1rem 0;display:flex}.pagination-btn{border:1px solid var(--color-border);background:var(--color-card);width:36px;height:36px;color:var(--color-text);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:background .2s,border-color .2s;display:flex}.pagination-btn:hover:not(:disabled){background:var(--color-hover);border-color:var(--color-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}@media (max-width:640px){.novels-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.novel-card-content{padding:.75rem}.novel-card-title{font-size:.9rem}}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:4px;padding:.25rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.badge-pending{background:color-mix(in srgb,var(--color-warning)15%,white);color:var(--color-warning)}.badge-running{background:color-mix(in srgb,var(--color-info)15%,white);color:var(--color-info)}.badge-success{background:color-mix(in srgb,var(--color-success)15%,white);color:var(--color-success)}.badge-failed{background:color-mix(in srgb,var(--color-error)15%,white);color:var(--color-error)}.badge-cancelled{background:color-mix(in srgb,var(--color-neutral)15%,white);color:var(--color-neutral)}.badge-draft{color:var(--color-neutral);background:#f5f5f5}.badge-published{background:color-mix(in srgb,var(--color-success)15%,white);color:var(--color-success)}[data-theme=dark] .badge-pending{background:color-mix(in srgb,var(--color-warning)20%,black)}[data-theme=dark] .badge-running{background:color-mix(in srgb,var(--color-info)20%,black)}[data-theme=dark] .badge-success{background:color-mix(in srgb,var(--color-success)20%,black)}[data-theme=dark] .badge-failed{background:color-mix(in srgb,var(--color-error)20%,black)}[data-theme=dark] .badge-cancelled{background:color-mix(in srgb,var(--color-neutral)20%,black)}[data-theme=dark] .badge-draft{background:#2d2d2d}[data-theme=dark] .badge-published{background:color-mix(in srgb,var(--color-success)20%,black)}.data-table-container{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;width:100%;overflow:hidden}.table-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.table-title{font-family:var(--font-serif);font-size:1.25rem;font-weight:400}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:.875rem 1rem}.data-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);background:var(--color-card-alt);font-size:.75rem;font-weight:600}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-card-alt)}@media (max-width:768px){.data-table{font-size:.85rem}.data-table th,.data-table td{padding:.75rem .5rem}}.card{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;width:100%;padding:1.5rem}.card-lg{padding:2rem}.card-title{font-family:var(--font-serif);margin-bottom:1rem;font-size:1.25rem;font-weight:400}.info-box{background:var(--color-card-alt);border-radius:6px;margin-top:1.5rem;padding:1rem}.info-box-title{margin-bottom:.5rem;font-size:.9rem;font-weight:500}.info-box-text{color:var(--color-text-muted);font-size:.85rem;line-height:1.6}.info-box-text a{color:var(--color-accent)}.info-box-list{color:var(--color-text-muted);margin-top:.5rem;padding-left:0;font-size:.85rem;list-style:none}.info-box-list li{align-items:flex-start;gap:.5rem;margin-bottom:.25rem;display:flex}.info-box-list li svg{color:var(--color-accent);flex-shrink:0;margin-top:.2rem}.form-input,.form-textarea{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);border-radius:6px;padding:.875rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:var(--color-accent);outline:none}.form-input-mono{font-family:monospace}.form-textarea{resize:vertical;min-height:150px}.form-label{margin-bottom:.5rem;font-weight:500;display:block}.form-hint{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.85rem}.form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1rem;display:flex}@media (max-width:600px){.form-actions{flex-direction:column}.form-actions .btn{justify-content:center;width:100%}}.alert{border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.alert-success{color:#2e7d32;background:#e8f5e9;border:1px solid #a5d6a7}.alert-error{color:#c62828;background:#ffebee;border:1px solid #ef9a9a}.alert-warning{color:#e65100;background:#fff3e0;border:1px solid #ffcc80}[data-theme=dark] .alert-success{color:#81c784;background:#1b3d1f;border-color:#2e5a33}[data-theme=dark] .alert-error{color:#e57373;background:#3d1f1f;border-color:#5c2f2f}[data-theme=dark] .alert-warning{color:#ffb74d;background:#3d2e0f;border-color:#5c4a1f}.warning-banner{background:#fff3e0;border:1px solid #ffcc80;border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;padding:1rem 1.5rem;display:flex}[data-theme=dark] .warning-banner{background:color-mix(in srgb,var(--color-warning)15%,black);border-color:color-mix(in srgb,var(--color-warning)30%,black)}.warning-banner-content{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.warning-banner-icon{flex-shrink:0;font-size:1.25rem}.warning-banner .btn{flex-shrink:0}@media (max-width:640px){.warning-banner{text-align:center;flex-direction:column;align-items:stretch}.warning-banner-content{justify-content:center}.warning-banner .btn{width:100%}}.progress-bar{align-items:center;gap:3px;display:flex}.progress-dot{background:var(--color-border);border-radius:50%;width:10px;height:10px}.progress-dot.complete{background:var(--color-success)}.progress-dot.current{background:var(--color-info);animation:1.5s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.author-hero{border-bottom:1px solid var(--color-border);align-items:flex-start;gap:2rem;width:100%;margin-bottom:3rem;padding-bottom:2rem;display:flex}.author-avatar{background:linear-gradient(135deg,var(--color-border)0%,#d5d0c8 100%);width:150px;height:150px;color:var(--color-text-muted);font-size:3rem;font-family:var(--font-serif);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.author-avatar img{object-fit:cover;width:100%;height:100%}.author-info{flex:1}.author-name{font-family:var(--font-serif);margin-bottom:.5rem;font-size:2.5rem;font-weight:600}.author-stats{color:var(--color-text-muted);gap:1.5rem;margin-bottom:1rem;font-size:.9rem;display:flex}.author-bio{color:var(--color-text-muted);max-width:600px;line-height:1.7}@media (max-width:768px){.author-avatar{width:120px;height:120px;font-size:2.5rem}.author-name{font-size:2rem}}@media (max-width:600px){.author-hero{text-align:center;flex-direction:column;align-items:center}.author-stats{justify-content:center}.author-bio{max-width:none}}.library-book-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;text-decoration:none;transition:box-shadow .2s;display:block;overflow:hidden}.library-book-card:hover{box-shadow:0 4px 12px #00000014}.library-book-cover{aspect-ratio:2/3;background:linear-gradient(135deg,var(--color-border)0%,#d5d0c8 100%);color:var(--color-text-muted);justify-content:center;align-items:center;font-size:.85rem;display:flex}.library-book-cover img{object-fit:cover;width:100%;height:100%}.library-book-info{padding:1rem}.library-book-title{font-family:var(--font-serif);color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.25rem;font-size:1rem;font-weight:600;display:-webkit-box;overflow:hidden}.library-book-author{color:var(--color-text-muted);font-size:.85rem}.library-book-date{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem}.library-book-price{color:var(--color-accent);font-size:.9rem;font-weight:500}.pagination-controls{border-top:1px solid var(--color-border);flex-direction:column;align-items:center;gap:.75rem;margin-top:2rem;padding-top:1.5rem;display:flex}.pagination-info{color:var(--color-text-muted);font-size:.875rem}.book-thumb{background:linear-gradient(135deg,var(--color-border)0%,#d5d0c8 100%);border-radius:4px;flex-shrink:0;width:40px;height:60px;overflow:hidden}.book-thumb img{object-fit:cover;width:100%;height:100%}.book-cell{align-items:center;gap:.75rem;display:flex}.phase-item{background:var(--color-bg);border-radius:6px;align-items:center;gap:1rem;padding:.75rem 1rem;transition:background .2s;display:flex}.phase-item.completed{background:#2e7d321a}.phase-item.current{background:#1976d21a;border:1px solid #1976d24d;animation:2s ease-in-out infinite phase-pulse}@keyframes phase-pulse{0%,to{background:#1976d21a;border-color:#1976d24d;box-shadow:0 0 #1976d200}50%{background:#1976d226;border-color:#1976d280;box-shadow:0 0 8px #1976d233}}.phase-item.pending{opacity:.5}.phase-item.cancelled{background:#7575751a;border:1px solid #7575754d}.phase-item.failed{background:#c628281a;border:1px solid #c628284d}.phase-status{font-size:.8rem;font-weight:500}.phase-icon{text-align:center;width:32px;font-size:1.25rem;transition:transform .2s}.phase-item.current .phase-icon{animation:2s ease-in-out infinite icon-bounce}@keyframes icon-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.phase-info{flex:1}.phase-label{font-weight:500}.phase-desc{color:var(--color-text-muted);font-size:.8rem}.phase-chapter{color:var(--color-info);font-size:.8rem;font-weight:500;animation:2s ease-in-out infinite chapter-pulse}@keyframes chapter-pulse{0%,to{opacity:1}50%{opacity:.6}}.phase-check{color:var(--color-success);font-weight:700}.error-box{background:#ffebee;border:1px solid #ef9a9a;border-radius:8px;margin-top:1rem;padding:1rem}[data-theme=dark] .error-box{background:#3d1f1f;border-color:#5c2f2f}.error-box-title{color:#c62828;margin-bottom:.5rem;font-weight:500}[data-theme=dark] .error-box-title{color:#e57373}.error-box-message{color:#c62828;font-size:.9rem}[data-theme=dark] .error-box-message{color:#ef9a9a}.error-box-actions{align-items:center;gap:1rem;margin-top:1rem;display:flex}.modal-overlay{z-index:var(--z-modal);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-card);border-radius:12px;width:90%;max-width:450px;box-shadow:0 20px 40px #0003}.modal-header h3{font-family:var(--font-serif);margin:0;font-size:1.25rem;font-weight:400}.modal-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--color-text)}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.change-plan-modal .modal-body{padding:1.5rem}.change-plan-toggles{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.change-plan-toggles .toggle-group{justify-content:center;gap:.5rem;display:flex}.change-plan-toggles .toggle-btn{border:1px solid var(--color-border);background:var(--color-card-alt);cursor:pointer;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;transition:all .2s;display:flex}.change-plan-toggles .toggle-btn:hover{border-color:var(--color-text-muted)}.change-plan-toggles .toggle-btn.active{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.change-plan-toggles .toggle-btn .save-badge{background:var(--color-success);color:#fff;border-radius:4px;padding:.15rem .4rem;font-size:.7rem;font-weight:600}.change-plan-toggles .mode-toggle{gap:.75rem}.change-plan-toggles .mode-btn{flex-direction:column;min-width:140px;padding:.75rem 1.25rem}.change-plan-toggles .toggle-label{font-weight:600}.change-plan-toggles .toggle-subtitle{opacity:.7;font-size:.75rem}.change-plan-warning{color:#856404;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;margin-bottom:1rem;padding:1rem}.change-plan-warning strong{margin-bottom:.25rem;display:block}.change-plan-warning p{margin:0;font-size:.9rem}.change-plan-tiers{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.change-plan-tiers .tier-card{background:var(--color-card-alt);border:2px solid var(--color-border);text-align:center;cursor:pointer;border-radius:8px;padding:1.25rem;transition:all .2s;position:relative}.change-plan-tiers .tier-card:hover:not(.current){border-color:var(--color-text-muted)}.change-plan-tiers .tier-card.selected{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.change-plan-tiers .tier-card.current{opacity:.6;cursor:default}.change-plan-tiers .current-badge{background:var(--color-text-muted);color:#fff;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:.2rem .6rem;font-size:.65rem;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.change-plan-tiers .tier-name{margin-bottom:.25rem;font-size:1rem;font-weight:600}.change-plan-tiers .tier-price{margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.change-plan-tiers .tier-period{color:var(--color-text-muted);font-size:.8rem;font-weight:400}.change-plan-tiers .tier-details{color:var(--color-text-muted);flex-direction:column;gap:.25rem;margin-bottom:.75rem;font-size:.8rem;display:flex}.change-plan-tiers .btn-sm{padding:.4rem .75rem;font-size:.8rem}.proration-preview{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1rem;padding:1rem}.proration-loading,.proration-error{text-align:center;color:var(--color-text-muted);font-size:.9rem}.proration-error{color:var(--color-error)}.proration-summary{margin-bottom:.75rem}.proration-change{justify-content:center;align-items:center;gap:.75rem;font-size:.95rem;display:flex}.proration-change .old-plan{color:var(--color-text-muted);text-decoration:line-through}.proration-change .arrow{color:var(--color-text-muted)}.proration-change .new-plan{color:var(--color-text);font-weight:600}.proration-amount{text-align:center;border-radius:6px;margin-bottom:.75rem;padding:.75rem;font-size:.9rem}.proration-amount.charge{color:#e65100;background:#fff3e0}.proration-amount.credit{color:#2e7d32;background:#e8f5e9}.proration-next{text-align:center;color:var(--color-text-muted);font-size:.85rem}.change-plan-modal .pricing-note{text-align:center;color:var(--color-text-muted);margin:0;font-size:.85rem}@media (max-width:640px){.change-plan-tiers{grid-template-columns:1fr}.change-plan-toggles .mode-toggle{flex-direction:column}.change-plan-toggles .mode-btn{min-width:100%}}.tier-grid{grid-template-columns:repeat(3,1fr);gap:1rem;width:100%;display:grid}.tier-card{background:var(--color-card-alt);border:1px solid var(--color-border);text-align:center;border-radius:8px;padding:1.5rem;position:relative}.tier-card.popular{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.tier-card .popular-badge{background:var(--color-accent);color:#fff;text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:.25rem .75rem;font-size:.7rem;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.tier-name{margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.tier-price{margin-bottom:1rem;font-size:2rem;font-weight:700}.tier-period{color:var(--color-text-muted);font-size:.9rem;font-weight:400}.tier-features{text-align:left;margin:0 0 1.5rem;padding:0;list-style:none}.tier-features li{color:var(--color-text-muted);align-items:center;gap:.5rem;padding:.4rem 0;font-size:.9rem;display:flex}.tier-features li svg{color:var(--color-success);flex-shrink:0}.tier-features li.highlight{color:var(--color-text);font-weight:500}.tier-features li.more-features{color:var(--color-text-muted);padding-left:1.25rem;font-style:italic}.tier-features-compact{margin-bottom:1rem;font-size:.85rem}.tier-features-compact li{padding:.3rem 0}.new-badge{background:var(--color-accent);color:#fff;text-transform:uppercase;vertical-align:middle;border-radius:999px;margin-left:.5rem;padding:.1rem .4rem;font-size:.65rem;font-weight:600}[data-theme=dark] .new-badge{color:#1a1a1a}@media (max-width:768px){.tier-grid{grid-template-columns:1fr}}.ink-balance-display{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;padding:1rem 1.25rem}.ink-balance-row{align-items:center;gap:.75rem;display:flex}.ink-label{color:var(--color-text-muted);font-size:.9rem}.ink-value{color:var(--color-accent);font-size:1.25rem;font-weight:600}.btn-icon{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-muted);background:0 0;border-radius:4px;padding:.25rem .5rem;font-size:1rem;transition:all .15s}.btn-icon:hover{background:var(--color-card-alt);color:var(--color-text)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.ink-packages{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.ink-package{background:var(--color-card-alt);border:1px solid var(--color-border);text-align:center;border-radius:8px;padding:1.25rem;position:relative}.ink-package.popular{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.ink-package .popular-badge{background:var(--color-accent);color:#fff;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-radius:999px;padding:.2rem .6rem;font-size:.65rem;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.ink-package-credits{margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.ink-package-price{color:var(--color-text-muted);margin-bottom:.5rem;font-size:1rem}@media (max-width:500px){.ink-packages{grid-template-columns:1fr}}.author-photo-section{align-items:flex-start;gap:1.5rem;display:flex}.author-photo-preview{flex-shrink:0}.author-photo-img{object-fit:cover;border:2px solid var(--color-border);border-radius:50%;width:100px;height:100px}.author-photo-placeholder{background:var(--color-card-alt);border:2px dashed var(--color-border);width:100px;height:100px;color:var(--color-text-muted);border-radius:50%;justify-content:center;align-items:center;display:flex}.author-photo-actions{flex-direction:column;align-items:flex-start;gap:.5rem;display:flex}.author-photo-actions .text-danger{color:var(--color-error)}.author-photo-actions .text-danger:hover{background:#ef44441a}@media (max-width:500px){.author-photo-section{text-align:center;flex-direction:column;align-items:center}.author-photo-actions{flex-direction:row;justify-content:center}}.style-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;width:100%;display:grid}.style-option{border:2px solid var(--color-border);cursor:pointer;background:var(--color-bg);border-radius:6px;padding:.75rem;transition:border-color .2s}.style-option:hover{border-color:var(--color-text-muted)}.style-option.selected{border-color:var(--color-accent);background:var(--color-card-alt)}.style-option .style-name{margin-bottom:.25rem;font-weight:500}.style-option .style-desc{color:var(--color-text-muted);font-size:.75rem}@media (max-width:600px){.style-grid{grid-template-columns:1fr}}.key-status{border-radius:999px;align-items:center;gap:.5rem;padding:.25rem .75rem;font-size:.8rem;font-weight:500;display:inline-flex}.key-status.valid{color:var(--color-success);background:#2e7d321a}.key-status.invalid{color:var(--color-error);background:#c628281a}.sub-status{border-radius:999px;align-items:center;padding:.25rem .75rem;font-size:.8rem;font-weight:500;display:inline-flex}.sub-status.active{color:var(--color-success);background:#2e7d321a}.sub-status.trialing{color:#1976d2;background:#1976d21a}.content-grid{grid-template-columns:1fr 350px;gap:2rem;width:100%;display:grid}@media (max-width:900px){.content-grid{grid-template-columns:1fr}.content-grid .sidebar{order:-1}}.sidebar{flex-direction:column;gap:1.5rem;display:flex}.info-row{border-bottom:1px solid var(--color-border);justify-content:space-between;padding:.5rem 0;display:flex}.info-row:last-child{border-bottom:none}.info-row-label{color:var(--color-text-muted);font-size:.9rem}.info-row-value{font-weight:500}.progress-list{flex-direction:column;gap:.5rem;display:flex}.progress-item{background:var(--color-bg);border-radius:4px;gap:.75rem;padding:.5rem;font-size:.85rem;animation:.3s ease-out slide-in;display:flex}@keyframes slide-in{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.progress-time{color:var(--color-text-muted);flex-shrink:0;font-family:monospace;font-size:.75rem}.progress-message{flex:1}.progress-status-started,.progress-status-progress{color:var(--color-info)}.progress-status-completed{color:var(--color-success)}.progress-status-failed{color:var(--color-error)}.progress-status-retrying{color:#f57c00}.status-badge{border-radius:999px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;display:inline-flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.running{animation:1.5s infinite pulse-status}.animated-ellipsis:after{content:"";animation:1.5s steps(4,end) infinite ellipsis}@keyframes ellipsis{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.stale-warning{background:var(--color-stale-bg);border:1px solid var(--color-stale-border);border-radius:4px;margin-bottom:.5rem;padding:.75rem;animation:2s ease-in-out infinite stale-pulse}@keyframes stale-pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes pulse-status{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.loading-state,.error-state{text-align:center;color:var(--color-text-muted);padding:4rem}.error-page{justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.error-content{text-align:center;max-width:500px}.error-content h1{color:var(--color-text);margin-bottom:1rem;font-size:1.75rem}.error-content .error-message{color:var(--color-text-muted);margin-bottom:1.5rem;line-height:1.6}.error-actions{justify-content:center;gap:1rem;margin-bottom:1.5rem;display:flex}.error-content .error-help{color:var(--color-text-muted);font-size:.875rem}.error-content .error-help a{color:var(--color-accent)}.loading-page{justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.loading-content{text-align:center}.loading-content p{color:var(--color-text-muted);margin-top:1rem;font-size:.9rem}.novel-title-cell{font-weight:500}.novel-prompt-cell{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-size:.85rem;overflow:hidden}.actions-cell{gap:.5rem;display:flex}.btn-retry{font-size:.75rem;font-family:var(--font-sans);border:1px solid var(--color-error);background:var(--color-card);color:var(--color-error);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;min-width:4.5rem;height:1.75rem;padding:0 .75rem;transition:all .2s;display:inline-flex}.btn-retry:hover:not(:disabled){background:var(--color-error);color:#fff}.btn-retry:disabled{opacity:.6;cursor:not-allowed}.generate-page{flex-direction:column;min-height:100vh;display:flex}.current-key{background:var(--color-card-alt);border-radius:6px;margin-bottom:1rem;padding:1rem}.key-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.key-hint{font-family:monospace;font-size:1.1rem}.key-meta{color:var(--color-text-muted);font-size:.85rem}.key-actions{gap:.75rem;margin-top:1rem;display:flex}.current-subscription{background:var(--color-card-alt);border-radius:8px;padding:1.25rem}.sub-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.sub-tier{margin-right:.75rem;font-size:1.25rem;font-weight:600}.sub-price{font-size:1.5rem;font-weight:600}.sub-period{color:var(--color-text-muted);font-size:.9rem;font-weight:400}.sub-details{border-top:1px solid var(--color-border);padding-top:1rem}.sub-usage{justify-content:space-between;margin-bottom:.5rem;display:flex}.usage-label{color:var(--color-text-muted)}.usage-value{font-weight:500}.sub-period-info{color:var(--color-text-muted);font-size:.85rem}.sub-warning{color:var(--color-error);background:#c628281a;border:1px solid #c628284d;border-radius:8px;padding:1.25rem}.sub-intro{color:var(--color-text-muted);margin-bottom:1.5rem;line-height:1.6}.sub-mode-badge{text-transform:uppercase;letter-spacing:.05em;vertical-align:middle;border-radius:4px;margin-right:.5rem;padding:.2rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.sub-mode-badge.byok{color:#3b82f6;background:#3b82f626}.sub-mode-badge.all-inclusive{color:#a855f7;background:linear-gradient(135deg,#a855f726,#ec489926)}.sub-model-info{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.sub-model-info .model-badge{color:#a855f7;background:linear-gradient(135deg,#a855f733,#ec489933);border-radius:4px;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.sub-model-info .model-note{color:var(--color-text-muted);font-size:.8rem}.trial-banner{background:linear-gradient(135deg,#a855f71a,#ec48991a);border:1px solid #a855f74d;border-radius:12px;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.trial-banner-content{flex:1}.trial-banner-info{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.trial-badge{color:#fff;text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,#a855f7,#ec4899);border-radius:4px;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.trial-days{color:var(--color-text);font-size:.9rem;font-weight:500}.trial-banner-text{color:var(--color-text-muted);margin:0;font-size:.85rem}.all-inclusive-badge{background:linear-gradient(135deg,#a855f71a,#ec48991a);border:1px solid #a855f74d;border-radius:12px;align-items:center;gap:1rem;padding:1.25rem;display:flex}.all-inclusive-badge-icon{font-size:2rem}.all-inclusive-badge-content{flex-direction:column;display:flex}.all-inclusive-badge-title{background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:600}.all-inclusive-badge-subtitle{color:var(--color-text-muted);font-size:.85rem}.model-fixed-badge{background:linear-gradient(135deg,#a855f71a,#ec48991a);border:1px solid #a855f74d;border-radius:8px;align-items:center;gap:.75rem;padding:.875rem 1rem;display:flex}.model-fixed-icon{font-size:1.25rem}.model-fixed-content{flex-direction:column;display:flex}.model-fixed-name{background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:600}.model-fixed-note{color:var(--color-text-muted);font-size:.8rem}.illustration-style-picker{flex-direction:column;gap:.75rem;display:flex}.illustration-chips{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;display:grid}.illustration-chip{background:var(--color-card-alt);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;font-size:.85rem;transition:border-color .2s,background .2s,transform .1s;display:flex}.illustration-chip:hover:not(:disabled){border-color:var(--color-text-muted);transform:translateY(-1px)}.illustration-chip.selected{border-color:var(--color-accent);background:#8b451314}.illustration-chip:disabled{opacity:.5;cursor:not-allowed}.illustration-chip-icon{font-size:1.25rem;line-height:1}.illustration-chip-label{color:var(--color-text);text-align:center;font-weight:500}.illustration-chip.selected .illustration-chip-label{color:var(--color-accent)}.illustration-hint{color:var(--color-text-muted);margin:0;padding-left:.25rem;font-size:.8rem}.model-selector{flex-direction:column;gap:.5rem;display:flex}.model-option{background:var(--color-card-alt);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;align-items:center;gap:.75rem;padding:.875rem 1rem;transition:border-color .2s,background .2s;display:flex}.model-option:hover{border-color:var(--color-text-muted)}.model-option.selected{border-color:var(--color-primary);background:var(--color-card)}.model-option input[type=radio]{accent-color:var(--color-primary);flex-shrink:0;width:16px;height:16px}.model-info{flex:1;min-width:0}.model-name{flex-wrap:wrap;align-items:center;gap:.5rem;font-weight:500;display:flex}.model-badge{background:var(--color-primary);color:#fff;text-transform:uppercase;letter-spacing:.025em;border-radius:3px;padding:.125rem .375rem;font-size:.65rem;font-weight:600}.model-desc{color:var(--color-text-muted);margin-top:.125rem;font-size:.8rem}.dialog-overlay{z-index:var(--z-dialog);background:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.15s ease-out dialog-fade-in;display:flex;position:fixed;inset:0}@keyframes dialog-fade-in{0%{opacity:0}to{opacity:1}}.dialog{background:var(--color-card);border-radius:12px;width:100%;max-width:400px;animation:.15s ease-out dialog-slide-in;box-shadow:0 20px 40px #0003}@keyframes dialog-slide-in{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.dialog-content{gap:1rem;padding:1.5rem;display:flex}.dialog-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.dialog-icon svg{width:22px;height:22px}.dialog-icon-info{color:#1976d2;background:#1976d21a}.dialog-icon-warning{color:#f57c00;background:#f57c001a}.dialog-icon-error,.dialog-icon-danger{color:#c62828;background:#c628281a}.dialog-icon-success{color:#2e7d32;background:#2e7d321a}[data-theme=dark] .dialog-icon-info{color:#64b5f6;background:#64b5f626}[data-theme=dark] .dialog-icon-warning{color:#ffb74d;background:#ffb74d26}[data-theme=dark] .dialog-icon-error,[data-theme=dark] .dialog-icon-danger{color:#e57373;background:#e5737326}[data-theme=dark] .dialog-icon-success{color:#81c784;background:#81c78426}.dialog-text{flex:1;min-width:0}.dialog-title{font-family:var(--font-serif);color:var(--color-text);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.dialog-description{color:var(--color-text-muted);margin:0;font-size:.95rem;line-height:1.5}.dialog-list{margin:.75rem 0;padding:0;list-style:none}.dialog-list li{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.dialog-list li svg{color:var(--color-text-muted);flex-shrink:0}.dialog-actions{border-top:1px solid var(--color-border);background:var(--color-card-alt);border-radius:0 0 12px 12px;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.dialog-actions .btn{min-width:80px}.dialog-danger .dialog-title{color:var(--color-error)}@media (max-width:480px){.dialog-content{text-align:center;flex-direction:column}.dialog-icon{margin:0 auto}.dialog-actions{flex-direction:column-reverse}.dialog-actions .btn{width:100%}}.session-timeout-overlay{z-index:var(--z-dialog);background:#0009;justify-content:center;align-items:center;padding:1rem;animation:.15s ease-out dialog-fade-in;display:flex;position:fixed;inset:0}.session-timeout-dialog{background:var(--color-card);text-align:center;border-radius:12px;width:100%;max-width:360px;padding:2rem;animation:.15s ease-out dialog-slide-in;box-shadow:0 20px 40px #0000004d}.session-timeout-icon{width:64px;height:64px;color:var(--color-warning);background:#ffc1071a;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}[data-theme=dark] .session-timeout-icon{background:#ffc10726}.session-timeout-title{font-family:var(--font-serif);color:var(--color-text);margin:0 0 .75rem;font-size:1.5rem;font-weight:600}.session-timeout-description{color:var(--color-text-muted);margin:0 0 1.5rem;font-size:.95rem;line-height:1.5}.session-timeout-description strong{color:var(--color-warning);font-weight:600}.pricing-hero{text-align:center;padding:3rem 0 4rem}.pricing-hero h1{font-family:var(--font-serif);margin-bottom:1rem;font-size:3rem;font-weight:400;line-height:1.2}.pricing-hero-subtitle{color:var(--color-text-muted);max-width:600px;margin:0 auto 2rem;font-size:1.1rem;line-height:1.6}.pricing-hero-cta{flex-direction:column;align-items:center;gap:.75rem;display:flex}.pricing-hero-note{color:var(--color-text-muted);font-size:.85rem}.btn-large{padding:1rem 2rem;font-size:1rem}.pricing-section{border-top:1px solid var(--color-border);padding:3rem 0}.section-subtitle{color:var(--color-text-muted);text-align:center;max-width:500px;margin:.5rem auto 2rem}.tier-grid-pricing{max-width:900px;margin:0 auto}.pricing-note{text-align:center;color:var(--color-text-muted);margin-top:1.5rem;font-size:.9rem}.billing-toggles{flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.billing-toggle-group{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;padding:4px;display:inline-flex}.billing-toggle-btn{font-family:var(--font-sans);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.billing-toggle-btn:hover{color:var(--color-text)}.billing-toggle-btn.active{background:var(--color-card);color:var(--color-text);box-shadow:0 1px 3px #0000001a}[data-theme=dark] .billing-toggle-btn.active{box-shadow:0 1px 3px #0000004d}.save-badge{background:var(--color-success);color:#fff;white-space:nowrap;border-radius:999px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.billing-mode-group{margin-top:.5rem}.billing-mode-btn{flex-direction:column;align-items:flex-start;min-width:160px;padding:.75rem 1.5rem}.toggle-label{font-size:.95rem;font-weight:600}.toggle-subtitle{color:var(--color-text-muted);margin-top:.125rem;font-size:.75rem;font-weight:400}.billing-toggle-btn.active .toggle-subtitle{color:var(--color-text-muted)}@media (max-width:480px){.billing-toggle-group{flex-direction:column;width:100%;max-width:320px}.billing-toggle-btn{justify-content:center;width:100%}.billing-mode-btn{text-align:center;align-items:center}}.trial-signup{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;max-width:400px;margin:0 auto;padding:2rem}.trial-signup-header{text-align:center;margin-bottom:1.5rem}.trial-signup-header h3{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.trial-signup-header p{color:var(--color-text-muted);font-size:.95rem}.trial-signup-info{margin-bottom:1.5rem}.trial-signup-info ul{margin:0;padding:0;list-style:none}.trial-signup-info li{align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem;display:flex}.trial-signup-info li svg{color:var(--color-success);flex-shrink:0}.trial-error{border:1px solid var(--color-error);color:var(--color-error);background:#c628281a;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.trial-signup-actions{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.trial-signup-note{text-align:center;color:var(--color-text-muted);margin:0;font-size:.8rem}.trial-card-form{margin-bottom:1.5rem}.trial-card-form label{margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.trial-card-element{border:1px solid var(--color-border);background:var(--color-bg);border-radius:6px;padding:.875rem 1rem;transition:border-color .2s}.trial-card-element:focus-within{border-color:var(--color-accent)}[data-theme=dark] .trial-card-element{background:#1a1a1a}.trial-success{text-align:center;padding:2rem 0}.trial-success-icon{background:var(--color-success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 1rem;font-size:2rem;display:flex}.trial-success p{color:var(--color-text-muted)}.pipeline-grid{grid-template-columns:repeat(2,1fr);gap:1rem;max-width:800px;margin:0 auto;display:grid}.pipeline-phase{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;align-items:flex-start;gap:1rem;padding:1rem;display:flex}.phase-number{background:var(--color-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.85rem;font-weight:600;display:flex}[data-theme=dark] .phase-number{color:#1a1a1a}.phase-content{flex:1;min-width:0}.phase-name{margin-bottom:.25rem;font-weight:600}.phase-desc{color:var(--color-text-muted);font-size:.85rem;line-height:1.4}.steps-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:900px;margin:0 auto;display:grid}.step-card{text-align:center;background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;flex-direction:column;align-items:center;padding:1.5rem 1rem;display:flex}.step-number{background:var(--color-accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;margin-bottom:1rem;font-size:1rem;font-weight:600;display:flex}[data-theme=dark] .step-number{color:#1a1a1a}.step-title{margin-bottom:.5rem;font-size:1rem;font-weight:600}.step-desc{color:var(--color-text-muted);font-size:.85rem;line-height:1.5}@media (max-width:768px){.steps-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.steps-grid{grid-template-columns:1fr}}.faq-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:900px;margin:0 auto;display:grid}.faq-item{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem}.faq-question{font-family:var(--font-serif);margin-bottom:.75rem;font-size:1.1rem;font-weight:600}.faq-answer{color:var(--color-text-muted);font-size:.9rem;line-height:1.6}.pricing-cta{text-align:center;border-top:1px solid var(--color-border);padding:4rem 0}.pricing-cta h2{font-family:var(--font-serif);margin-bottom:.5rem;font-size:2rem;font-weight:400}.pricing-cta p{color:var(--color-text-muted);margin-bottom:1.5rem}@media (max-width:768px){.pricing-hero h1{font-size:2rem}.pricing-hero-subtitle{font-size:1rem}.pipeline-grid,.faq-grid{grid-template-columns:1fr}.pricing-cta h2{font-size:1.5rem}}.generate-tabs{width:100%}.tabs-nav{border-bottom:1px solid var(--color-border);gap:0;margin-bottom:1.5rem;display:flex}.tab-btn{font-family:var(--font-sans);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;margin-bottom:-1px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.tab-btn:disabled{opacity:.5;cursor:not-allowed}.tab-icon{font-size:1rem}.tab-badge{background:var(--color-accent);color:#fff;border-radius:999px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}[data-theme=dark] .tab-badge{color:#1a1a1a}.tabs-content{min-height:200px}.tab-panel{animation:.2s tab-fade-in}@keyframes tab-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tabs-container{flex:1;gap:0;min-width:0;display:flex}.tab-label{white-space:nowrap}.tab-btn.closable{gap:.375rem;padding-right:.5rem}.tab-close{width:18px;height:18px;color:var(--color-text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin-left:.25rem;padding:0;transition:all .15s;display:flex}.tab-btn.closable:hover .tab-close,.tab-btn.closable:focus-within .tab-close{opacity:1}.tab-close:hover{background:var(--color-border);color:var(--color-text)}.tab-status-icon{flex-shrink:0;align-items:center;display:flex}.status-icon-completed{color:var(--color-success,#22c55e)}.status-icon-failed{color:var(--color-error,#ef4444)}.status-icon-queued{color:var(--color-text-muted)}@keyframes tab-flash{0%,to{background:0 0}50%{background:color-mix(in srgb,var(--color-accent)20%,transparent)}}.tab-btn.flashing{animation:.5s ease-in-out 3 tab-flash}.tabs-nav.compact .tab-btn.closable .tab-label{display:none}.tabs-nav.compact .tab-btn.closable{padding:.75rem}.tabs-overflow-btn{border:none;border-bottom:1px solid var(--color-border);width:32px;color:var(--color-text-muted);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.tabs-overflow-btn:hover{color:var(--color-text);background:var(--color-bg-hover)}.tabs-overflow-left{border-right:1px solid var(--color-border)}.tabs-overflow-right{border-left:1px solid var(--color-border)}@media (max-width:768px){.tabs-nav{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab-btn{white-space:nowrap;padding:.5rem 1rem}.tab-btn.closable .tab-label{display:none}.tab-btn.closable{padding:.5rem .625rem}}.settings-icon-btn{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;transition:color .2s;display:flex}.settings-icon-btn:hover{color:var(--color-text)}.settings-icon-btn.active{color:var(--color-accent)}.settings-expansion{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1.5rem;animation:.25s settings-slide-down;overflow:hidden}@keyframes settings-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.settings-expansion-header{border-bottom:1px solid var(--color-border);background:var(--color-card-alt);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.settings-expansion-tabs{gap:.25rem;display:flex}.settings-expansion-tab{font-family:var(--font-sans);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.85rem;font-weight:500;transition:all .15s;display:flex}.settings-expansion-tab:hover{background:var(--color-bg);color:var(--color-text)}.settings-expansion-tab.active{background:var(--color-accent);color:#fff}[data-theme=dark] .settings-expansion-tab.active{color:#1a1a1a}.settings-expansion-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.375rem;transition:color .2s;display:flex}.settings-expansion-close:hover{color:var(--color-text);background:var(--color-bg)}.settings-expansion-body{max-height:400px;padding:1.25rem;overflow-y:auto}.settings-tab-content .card{margin-bottom:0}.settings-tab-content .card-lg{padding:1rem}.all-inclusive-badge-card{background:var(--color-bg);border-radius:8px;padding:1rem}@media (max-width:768px){.settings-expansion-tabs{gap:.125rem}.settings-expansion-tab{padding:.375rem .625rem;font-size:.8rem}.settings-expansion-tab span{display:none}.settings-expansion-body{padding:1rem}}.inline-novel-form{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.inline-form-row{align-items:stretch;gap:.75rem;display:flex}.inline-form-row-prompt{margin-bottom:.75rem}.inline-form-row-prompt .inline-prompt,.inline-form-row-title .inline-title{flex:1}.inline-prompt{border:1px solid var(--color-border);width:100%;font-family:var(--font-sans);background:var(--color-background);color:var(--color-text);resize:none;border-radius:8px;padding:.75rem 1rem;font-size:.95rem;line-height:1.5}.inline-prompt:focus{border-color:var(--color-accent);outline:none}.inline-title{border:1px solid var(--color-border);width:100%;font-family:var(--font-sans);background:var(--color-background);color:var(--color-text);border-radius:8px;padding:.6rem 1rem;font-size:.9rem}.inline-title:focus{border-color:var(--color-accent);outline:none}.btn-write{white-space:nowrap;flex-shrink:0;min-width:100px;padding:0 1.5rem;font-size:.95rem}.btn-settings{border:1px solid var(--color-border);background:var(--color-background);min-width:100px;color:var(--color-text-muted);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:0 1rem;transition:all .2s;display:flex}.btn-settings:hover{background:var(--color-card-alt);color:var(--color-text)}.btn-settings.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}[data-theme=dark] .btn-settings.active{color:#1a1a1a}.btn-settings:disabled{opacity:.5;cursor:not-allowed}.inline-advanced-settings{border-top:1px solid var(--color-border);margin-top:1.25rem;padding-top:1.25rem;animation:.2s settings-slide-down}.advanced-section{margin-bottom:1.25rem}.advanced-section:last-child{margin-bottom:0}.advanced-label{color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:.6rem;font-size:.85rem;font-weight:600;display:flex}.label-badge{text-transform:uppercase;letter-spacing:.05em;color:#a855f7;background:linear-gradient(135deg,#a855f726,#ec489926);border-radius:4px;padding:.2rem .4rem;font-size:.65rem;font-weight:500}.label-badge-ink{color:#3b82f6;background:linear-gradient(135deg,#3b82f626,#6366f126)}.byok-illustrations-section{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;padding:1rem}.byok-illustrations-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.byok-illustrations-toggle{flex:1;min-width:200px}.byok-ink-balance{color:var(--color-text-muted);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.byok-ink-balance .ink-icon{color:#3b82f6}.byok-ink-balance .ink-loading{color:var(--color-text-muted)}.btn-buy-ink{color:var(--color-accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:.85rem;text-decoration:underline}.btn-buy-ink:hover{color:var(--color-accent-hover)}.byok-illustrations-picker{border-top:1px solid var(--color-border);margin-top:1rem;padding-top:1rem}@media (max-width:500px){.byok-illustrations-header{flex-direction:column;align-items:flex-start}.byok-ink-balance{justify-content:flex-start;width:100%}}.advanced-hint{color:var(--color-text-muted);margin:0 0 .75rem;font-size:.8rem}.inline-novel-form .toggle-group{flex-direction:column;gap:.75rem;display:flex}.inline-novel-form .toggle-option{cursor:pointer;align-items:flex-start;gap:.75rem;display:flex}.inline-novel-form .toggle-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent);cursor:pointer;margin-top:.15rem}.inline-novel-form .toggle-option .toggle-label{color:var(--color-text);font-size:.9rem;font-weight:500;display:block}.inline-novel-form .toggle-option .toggle-desc{color:var(--color-text-muted);margin-top:.15rem;font-size:.8rem;display:block}.style-chips{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.style-chip{border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text-muted);font-family:var(--font-sans);cursor:pointer;border-radius:999px;padding:.4rem .8rem;font-size:.8rem;transition:all .15s}[data-theme=dark] .style-chip.selected{color:#1a1a1a}.custom-style-input{padding:.5rem .75rem;font-size:.85rem}.model-chips{flex-wrap:wrap;gap:.5rem;display:flex}.model-chip{border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text-muted);font-family:var(--font-sans);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:.15rem;min-width:100px;padding:.6rem 1rem;transition:all .15s;display:flex}.model-chip:hover{border-color:var(--color-accent);color:var(--color-text)}.model-chip.selected{background:var(--color-accent);border-color:var(--color-accent);color:#fff}[data-theme=dark] .model-chip.selected{color:#1a1a1a}.model-chip:disabled{opacity:.5;cursor:not-allowed}.model-chip-name{align-items:center;gap:.3rem;font-size:.85rem;font-weight:500;display:flex}.model-chip-cost{opacity:.8;font-size:.75rem}.chip-badge{background:#ffffff40;border-radius:4px;padding:.1rem .35rem;font-size:.6rem;font-weight:600}.model-chip.selected .chip-badge{background:#00000026}.inline-info-box{background:var(--color-card-alt);color:var(--color-text-muted);border-radius:8px;padding:.75rem 1rem;font-size:.8rem}.inline-info-box strong{color:var(--color-text)}.text-separator{vertical-align:middle;opacity:.5;margin:0 .25rem;display:inline}@media (max-width:640px){.inline-form-row{flex-direction:column}.inline-form-row-prompt .btn-settings{width:100%;min-width:unset}.inline-form-row-title .btn-write{width:100%}.model-chips{flex-direction:column}.model-chip{flex-direction:row;justify-content:space-between;width:100%}}.admin-tab-content{width:100%}.admin-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.admin-updated{color:var(--color-text-muted);align-items:center;gap:.5rem;margin:0;font-size:.85rem;display:flex}.live-indicator{color:var(--color-success);font-size:.8rem;font-weight:500;animation:2s ease-in-out infinite live-pulse}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.5}}.admin-stats{grid-template-columns:repeat(6,1fr)}.admin-subtabs{border-bottom:1px solid var(--color-border);gap:.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex}.admin-subtab{cursor:pointer;color:var(--color-text-muted);font-size:.9rem;font-family:var(--font-sans);background:0 0;border:none;border-radius:4px;padding:.5rem 1rem}.admin-subtab:hover{background:var(--color-card-alt)}.admin-subtab.active{background:var(--color-card);color:var(--color-text);font-weight:500}.queue-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;padding:1.5rem;display:grid}.queue-item{background:var(--color-bg);border-radius:6px;padding:1rem}.queue-name{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.85rem}.queue-count{font-size:1.5rem;font-weight:600}.queue-count.high{color:var(--color-warning)}.error-message{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-size:.8rem;overflow:hidden}.btn-sm{padding:.35rem .75rem;font-size:.85rem}@media (max-width:1024px){.admin-stats{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}}.panel-overlay{z-index:var(--z-panel-overlay);background:#0006;animation:.2s panel-overlay-in;position:fixed;inset:0}@keyframes panel-overlay-in{0%{opacity:0}to{opacity:1}}.job-panel{background:var(--color-card);border-left:1px solid var(--color-border);width:45%;min-width:360px;max-width:600px;z-index:var(--z-panel);scrollbar-width:none;-ms-overflow-style:none;flex-direction:column;animation:.25s panel-slide-in;display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto}.job-panel::-webkit-scrollbar{display:none}@keyframes panel-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-header{border-bottom:1px solid var(--color-border);background:var(--color-card-alt);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.panel-title{font-family:var(--font-serif);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.25rem;font-weight:600;overflow:hidden}.panel-close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1;transition:color .2s}.panel-close:hover{color:var(--color-text)}.panel-body{flex:1;padding:1.5rem}.panel-loading,.panel-error{text-align:center;color:var(--color-text-muted);padding:2rem}.job-tab-content{padding:0}.job-tab-loading,.job-tab-error{text-align:center;color:var(--color-text-muted);justify-content:center;align-items:center;gap:.75rem;padding:3rem 2rem;display:flex}.panel-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1rem;padding:1rem 1.25rem}.panel-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.75rem;font-size:.8rem;font-weight:600}.panel-section.expandable-section{padding:0}.expandable-section-header{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.25rem;display:flex}.expandable-section-header:hover{background:var(--color-hover)}.expandable-section-header .panel-section-title{margin-bottom:0}.expandable-section-icon{color:var(--color-text-muted);flex-shrink:0}.expandable-section-content{padding:0 1.25rem 1rem}.panel-status-row{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.panel-date{color:var(--color-text-muted);font-size:.85rem}.panel-prompt{color:var(--color-text);margin:0;font-size:.9rem;line-height:1.6}.panel-console{background:#1a1a1a;border-radius:4px;max-height:200px;padding:.75rem 1rem;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.75rem;line-height:1.5;overflow-y:auto}.console-line{color:#a0a0a0;white-space:pre-wrap;word-break:break-all}.panel-actions{border-top:1px solid var(--color-border);background:var(--color-card-alt);gap:.75rem;padding:1rem 1.5rem;display:flex}.panel-meta{color:var(--color-text-muted);font-size:.85rem}.panel-duration{color:var(--color-text-muted);margin-top:.75rem;font-size:.85rem}.panel-phases{flex-direction:column;gap:.25rem;display:flex}.panel-phase-item{background:var(--color-card-alt);opacity:.5;border-radius:6px;align-items:center;gap:.75rem;padding:.5rem .75rem;transition:all .2s;display:flex}.panel-phase-item.completed{opacity:1}.panel-phase-item.current{opacity:1;background:color-mix(in srgb,var(--color-info)10%,transparent);border:1px solid color-mix(in srgb,var(--color-info)30%,transparent);animation:1.5s ease-in-out infinite phase-pulse}.panel-phase-item.failed{opacity:1;background:color-mix(in srgb,var(--color-error)10%,transparent);border:1px solid color-mix(in srgb,var(--color-error)30%,transparent)}.panel-phase-item.cancelled{opacity:1;background:color-mix(in srgb,var(--color-neutral)10%,transparent);border:1px solid color-mix(in srgb,var(--color-neutral)30%,transparent)}.panel-phase-item.pending{opacity:.35}.panel-phase-icon{font-size:1rem}.panel-phase-info{flex:1}.panel-phase-label{font-size:.85rem}.panel-phase-item.completed .panel-phase-label{color:var(--color-text)}.panel-phase-chapter{color:var(--color-info);background:color-mix(in srgb,var(--color-info)10%,transparent);border-radius:4px;padding:.125rem .5rem;font-size:.75rem;font-weight:600}.panel-phase-check{color:var(--color-success);font-weight:700}.panel-error-box{background:color-mix(in srgb,var(--color-error)10%,transparent);border:1px solid var(--color-error);border-radius:6px;padding:1rem}.panel-error-title{color:var(--color-error);margin-bottom:.5rem;font-weight:600}.panel-error-message{color:var(--color-error);word-break:break-word;font-family:monospace;font-size:.85rem}.panel-error-attempts{color:var(--color-text-muted);margin-top:.5rem;font-size:.8rem}.panel-stale-warning{background:var(--color-stale-bg);border:1px solid var(--color-stale-border);border-radius:6px;margin-bottom:.75rem;padding:.75rem 1rem}.panel-stale-warning strong{color:var(--color-stale-text);margin-bottom:.25rem;display:block}.panel-stale-warning span{color:var(--color-warning);font-size:.85rem}.panel-running-text{color:var(--color-text-muted);margin:0 0 .5rem;font-size:.9rem}.panel-action-error{color:var(--color-error);margin-top:.5rem;font-size:.85rem}.panel-admin-controls{border-top:1px solid var(--color-border);margin-top:1rem;padding-top:1rem}.panel-admin-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.5rem;font-size:.7rem;font-weight:600}.panel-admin-buttons,.panel-actions-grid{flex-wrap:wrap;gap:.5rem;display:flex}.panel-actions-grid .btn{text-align:center;flex:1;min-width:120px}.panel-actions-content{border-top:1px solid var(--color-border);margin-top:1rem;padding-top:1rem}.panel-heartbeat{border-radius:6px;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.85rem;display:flex}.panel-heartbeat.alive{background:color-mix(in srgb,var(--color-success)15%,transparent)}.panel-heartbeat.warning{background:color-mix(in srgb,var(--color-warning)15%,transparent)}.panel-heartbeat.stuck{background:color-mix(in srgb,var(--color-error)15%,transparent)}.heartbeat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.heartbeat-dot.alive{background:var(--color-success);animation:2s infinite heartbeat-pulse}.heartbeat-dot.warning{background:var(--color-warning)}.heartbeat-dot.stuck{background:var(--color-error)}@keyframes heartbeat-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.heartbeat-status{font-weight:500}.heartbeat-status.alive{color:var(--color-success)}.heartbeat-status.warning{color:var(--color-warning)}.heartbeat-status.stuck{color:var(--color-error)}.panel-detail-row{border-bottom:1px solid var(--color-border);justify-content:space-between;padding:.5rem 0;font-size:.85rem;display:flex}.panel-detail-row:last-child{border-bottom:none}.panel-detail-row span:first-child{color:var(--color-text-muted)}.panel-detail-row span:last-child{font-weight:500}.panel-concept-premise{margin:0 0 .75rem;font-size:.9rem;line-height:1.6}.panel-concept-tags{flex-wrap:wrap;gap:.5rem;display:flex}.panel-concept-themes{color:var(--color-text-muted);margin:.75rem 0 0;font-size:.85rem}.panel-activity-log{max-height:200px;overflow-y:auto}.panel-activity-item{border-bottom:1px solid var(--color-border);gap:.75rem;padding:.375rem .5rem;font-size:.8rem;display:flex}.panel-activity-item:last-child{border-bottom:none}.panel-activity-time{color:var(--color-text-muted);white-space:nowrap;font-family:monospace}.panel-activity-message{word-break:break-word;flex:1}.panel-activity-started{color:#1976d2}.panel-activity-completed{color:#2e7d32}.panel-activity-failed{color:var(--color-error)}@media (max-width:768px){.job-panel{width:100%;min-width:auto;max-width:none}.panel-progress-phases{grid-template-columns:repeat(5,1fr)}.panel-phases{font-size:.85rem}.panel-phase-item{padding:.375rem .5rem}}.progress-bar-container{margin-bottom:.75rem;position:relative}.progress-bar-track{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;height:40px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#1976d2,#42a5f5);border-radius:8px;height:100%;transition:width .5s ease-out}.progress-bar-fill.running{animation:2s ease-in-out infinite progress-pulse}.progress-bar-fill.completed{background:linear-gradient(90deg,#2e7d32,#66bb6a)}.progress-bar-fill.failed{background:linear-gradient(90deg,#c62828,#ef5350)}.progress-bar-fill.cancelled{background:linear-gradient(90deg,#757575,#9e9e9e)}@keyframes progress-pulse{0%,to{opacity:1}50%{opacity:.85}}.progress-bar-overlay{pointer-events:none;justify-content:space-between;align-items:center;padding:0 1rem;display:flex;position:absolute;inset:0}.progress-bar-text{color:var(--color-text);text-shadow:0 1px 2px #ffffff80;font-size:.9rem;font-weight:500}.progress-bar-container.running .progress-bar-text,.progress-bar-container.completed .progress-bar-text,.progress-bar-container.failed .progress-bar-text{color:#fff;text-shadow:0 1px 2px #0000004d}.progress-bar-percent{color:var(--color-text);font-size:.95rem;font-weight:700}.progress-bar-container.running .progress-bar-percent,.progress-bar-container.completed .progress-bar-percent,.progress-bar-container.failed .progress-bar-percent{color:#fff;text-shadow:0 1px 2px #0000004d}.content-preview{flex-direction:column;gap:1.5rem;display:flex}.content-preview-cover{opacity:0;justify-content:center;transition:opacity .5s,transform .5s;display:flex;transform:scale(.95)}.content-preview-cover.loaded{opacity:1;transform:scale(1)}.content-preview-cover-image{border-radius:8px;max-width:200px;height:auto;box-shadow:0 4px 16px #0003}.content-preview-hero{align-items:flex-start;gap:1.25rem;display:flex}.content-preview-hero .content-preview-cover{flex-shrink:0}.content-preview-concept{flex-direction:column;flex:1;gap:.75rem;min-width:0;display:flex}.content-preview-concept-premise{color:var(--color-text);margin:0;font-size:.9rem;line-height:1.5}.content-preview-concept-tags{flex-wrap:wrap;gap:.375rem;display:flex}.content-preview-concept-themes{color:var(--color-text-muted);margin:0;font-size:.8rem;font-style:italic}@media (max-width:500px){.content-preview-hero{text-align:center;flex-direction:column;align-items:center}.content-preview-concept-tags{justify-content:center}}.content-preview-chapters{flex-direction:column;gap:.75rem;display:flex}.content-preview-chapters-title{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:600}.content-preview-empty{text-align:center;color:var(--color-text-muted);padding:2rem 1rem;font-style:italic}.content-preview-bookend{margin:.5rem 0}.bookend-card{background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:8px;padding:1rem}.bookend-card.prologue{border-left-color:var(--color-primary)}.bookend-card.epilogue{border-left-color:var(--color-success)}.bookend-card-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.bookend-card-header svg{color:var(--color-text-muted)}.bookend-card-title{font-size:.95rem;font-weight:600}.bookend-card-preview{color:var(--color-text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:.85rem;line-height:1.5;display:-webkit-box;overflow:hidden}[data-theme=dark] .bookend-card{background:var(--color-surface-dark)}.chapter-cards-grid{flex-direction:column;gap:.5rem;display:flex}.chapter-card{background:var(--color-card-alt);border:1px solid var(--color-border);opacity:0;border-radius:8px;gap:.75rem;padding:.75rem;animation:.4s ease-out forwards fadeInCard;display:flex}.chapter-card.has-content{border-color:#1976d24d}.chapter-card.polished:not(.active){border-color:#4caf5080}[data-theme=dark] .chapter-card.polished:not(.active){border-color:#81c78480}.chapter-card.active{opacity:1;border-color:#ff980099;animation:2s ease-in-out infinite chapter-glow;box-shadow:0 0 12px #ff980066,0 0 4px #ff980033}@keyframes chapter-glow{0%,to{box-shadow:0 0 12px #ff980066,0 0 4px #ff980033}50%{box-shadow:0 0 20px #ff980099,0 0 8px #ff98004d}}[data-theme=dark] .chapter-card.active{opacity:1;border-color:#ffb74d99;animation:2s ease-in-out infinite chapter-glow-dark;box-shadow:0 0 12px #ffb74d4d,0 0 4px #ffb74d26}@keyframes chapter-glow-dark{0%,to{box-shadow:0 0 12px #ffb74d4d,0 0 4px #ffb74d26}50%{box-shadow:0 0 20px #ffb74d80,0 0 8px #ffb74d40}}@keyframes fadeInCard{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chapter-card-illustration{opacity:1;border-radius:6px;flex-shrink:0;width:60px;height:90px;position:relative;overflow:hidden}.chapter-card-illustration.clickable{cursor:pointer}.chapter-card-illustration.clickable:hover .chapter-card-image{transition:transform .2s;transform:scale(1.05)}.chapter-card-image{object-fit:cover;opacity:0;width:100%;height:100%;animation:.5s ease-out forwards fadeIn}.chapter-card-illustration-placeholder{background:var(--color-card-alt);border:1px dashed var(--color-border);border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;width:100%;height:100%;display:flex}.chapter-card-illustration-placeholder.pending{color:var(--color-text-muted)}.chapter-card-illustration-placeholder.generating{color:var(--color-primary);border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.05)}.chapter-card-illustration-placeholder.failed{color:#d32f2f;background:#d32f2f0d;border-color:#d32f2f}[data-theme=dark] .chapter-card-illustration-placeholder.failed{color:#ef5350;background:#ef53501a;border-color:#ef5350}.chapter-card-regen-btn{background:var(--color-bg);border:1px solid var(--color-border);cursor:pointer;width:20px;height:20px;color:var(--color-text-muted);border-radius:4px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex;position:absolute;bottom:4px;right:4px}.chapter-card-regen-btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.chapter-card-regen-btn:disabled{opacity:.7;cursor:not-allowed}.chapter-card-regen-btn.free{border-color:var(--color-success);color:var(--color-success)}.chapter-card-regen-btn.free:hover{background:var(--color-success);border-color:var(--color-success);color:#fff}.chapter-card-regen-btn.buy-ink{color:#f57c00;border-color:#f57c00}.chapter-card-regen-btn.buy-ink:hover{color:#fff;background:#f57c00;border-color:#f57c00}.chapter-card-illustration-complete{width:100%;height:100%;position:relative}.chapter-card-illustration-complete .chapter-card-regen-btn{opacity:0;transition:opacity .2s}.chapter-card-illustration-complete:hover .chapter-card-regen-btn,.chapter-card-illustration-complete .chapter-card-regen-btn:disabled{opacity:1}.cover-regen-btn{color:#fff;cursor:pointer;opacity:0;background:#000000b3;border:1px solid #fff3;border-radius:4px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.75rem;transition:opacity .2s,background .15s;display:flex;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.content-preview-cover:hover .cover-regen-btn,.cover-regen-btn:disabled{opacity:1}.cover-regen-btn:hover{background:#000000d9}.cover-regen-btn:disabled{cursor:not-allowed;background:#000000d9}.cover-regen-btn.free{border-color:var(--color-success)}.cover-regen-btn.buy-ink{border-color:#f57c00}.ink-balance-indicator{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.ink-balance-row{color:var(--color-text);align-items:center;gap:.35rem;display:flex}.ink-balance-value{font-weight:500}.ink-balance-refresh{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem;transition:background .15s}.ink-balance-refresh:hover{background:var(--color-bg)}.ink-balance-buy{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:.35rem .75rem;font-size:.8rem;font-weight:500;transition:background .15s}.ink-balance-buy:hover{background:var(--color-primary-dark)}.ink-balance-compact{background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;border-radius:4px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.8rem;transition:background .15s;display:inline-flex}.ink-balance-compact:hover{background:var(--color-bg)}.ink-modal-balance{color:var(--color-text);margin-bottom:.75rem}.ink-modal-description{color:var(--color-text-muted);margin-bottom:1rem;font-size:.9rem}.ink-modal-error{color:#ef5350;background:#ef53501a;border:1px solid #ef5350;border-radius:6px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem;font-size:.9rem;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.chapter-card-content{flex:1;min-width:0}.chapter-card-header{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.chapter-card-number{color:var(--color-text-muted);font-size:.85rem;font-weight:600}.chapter-card-title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.9rem;font-weight:500;overflow:hidden}.chapter-card-status{color:#f57c00;white-space:nowrap;font-size:.75rem;font-style:italic}[data-theme=dark] .chapter-card-status{color:#ffb74d}.chapter-card-stage{border-radius:10px;padding:.125rem .5rem;font-size:.75rem;font-weight:500}.chapter-card-stage.stage-draft{color:#f57c00;background:#ff980026}.chapter-card-stage.stage-revised{color:#1976d2;background:#2196f326}.chapter-card-stage.stage-polished{color:#388e3c;background:#4caf5026}.chapter-card-check{color:#388e3c}.chapter-card-summary{color:var(--color-text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.8rem;line-height:1.4;display:-webkit-box;overflow:hidden}.chapter-card-words{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem;display:block}[data-theme=dark] .chapter-card-stage.stage-draft{color:#ffb74d;background:#ff980033}[data-theme=dark] .chapter-card-stage.stage-revised{color:#64b5f6;background:#2196f333}[data-theme=dark] .chapter-card-stage.stage-polished{color:#81c784;background:#4caf5033}[data-theme=dark] .chapter-card-check{color:#81c784}.lightbox-overlay{z-index:9999;background:#000000e6;justify-content:center;align-items:center;padding:2rem;animation:.2s ease-out lightboxFadeIn;display:flex;position:fixed;inset:0}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox-container{flex-direction:column;align-items:center;max-width:100%;max-height:100%;display:flex;position:relative}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;padding:0;transition:background .15s;display:flex;position:fixed;top:1rem;right:1rem}.lightbox-close:hover{background:#fff3}.lightbox-nav{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;padding:0;transition:background .15s;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#fff3}.lightbox-nav-prev{left:1rem}.lightbox-nav-next{right:1rem}.lightbox-image-wrapper{justify-content:center;align-items:center;max-width:calc(100vw - 6rem);max-height:calc(100vh - 8rem);display:flex}.lightbox-image{object-fit:contain;border-radius:8px;max-width:100%;max-height:calc(100vh - 8rem);box-shadow:0 20px 60px #00000080;width:auto!important;height:auto!important}.lightbox-caption{text-align:center;color:#fff;flex-direction:column;align-items:center;gap:.25rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.lightbox-chapter{text-transform:uppercase;letter-spacing:.05em;opacity:.8;font-size:.85rem;font-weight:600}.lightbox-title{font-size:1.1rem;font-weight:500}@media (max-width:640px){.lightbox-overlay{padding:1rem}.lightbox-close{width:40px;height:40px;top:.5rem;right:.5rem}.lightbox-nav{width:40px;height:40px}.lightbox-nav-prev{left:.5rem}.lightbox-nav-next{right:.5rem}.lightbox-image-wrapper{max-width:calc(100vw - 2rem);max-height:calc(100vh - 6rem)}.lightbox-image{max-height:calc(100vh - 6rem)}.lightbox-caption{bottom:.75rem}}[data-theme=dark] .progress-status-message.running{color:#64b5f6}[data-theme=dark] .progress-status-message.completed{color:#81c784}.job-subtabs{background:var(--color-card-alt);border-radius:8px;gap:.25rem;margin-bottom:1.5rem;padding:.5rem;display:flex}.job-subtab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.job-subtab:hover{color:var(--color-text);background:var(--color-bg)}.job-subtab.active{color:var(--color-primary);background:var(--color-bg);box-shadow:0 1px 3px #00000014}.job-subtab svg{opacity:.7}.job-subtab.active svg{opacity:1}.editor-tab{flex-direction:column;gap:1.5rem;display:flex}.editor-tab-loading,.editor-tab-error{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.editor-tab-loading svg{color:var(--color-primary)}.editor-tab-error svg{color:var(--color-error)}.editor-draft-banner{background:linear-gradient(135deg,var(--color-primary-light)0%,var(--color-card-alt)100%);border:1px solid var(--color-primary);border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.editor-draft-info{align-items:center;gap:.75rem;display:flex}.editor-draft-info svg{color:var(--color-primary)}.editor-draft-title{color:var(--color-text);font-weight:600}.editor-draft-subtitle{color:var(--color-text-muted);font-size:.85rem}.editor-draft-actions{gap:.75rem;display:flex}.copyright-indicator{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;margin-top:1rem;padding:1.25rem}.copyright-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.copyright-badge{border-radius:6px;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.8rem;font-weight:600;display:inline-flex}.copyright-badge-public{background:color-mix(in srgb,var(--color-neutral)15%,white);color:var(--color-neutral)}.copyright-badge-mixed{background:color-mix(in srgb,var(--color-warning)15%,white);color:var(--color-warning-dark)}.copyright-badge-owned{background:color-mix(in srgb,var(--color-success)15%,white);color:var(--color-success)}[data-theme=dark] .copyright-badge-public{background:color-mix(in srgb,var(--color-neutral)20%,black)}[data-theme=dark] .copyright-badge-mixed{background:color-mix(in srgb,var(--color-warning)20%,black)}[data-theme=dark] .copyright-badge-owned{background:color-mix(in srgb,var(--color-success)20%,black)}.copyright-certified{color:var(--color-success);align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;display:inline-flex}.copyright-description{color:var(--color-text-muted);margin-bottom:1rem;font-size:.85rem;line-height:1.5}.copyright-progress{margin-bottom:1.25rem}.copyright-progress-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.copyright-progress-title{color:var(--color-text);font-size:.85rem;font-weight:500}.copyright-progress-value{color:var(--color-text-muted);font-size:.8rem;font-family:var(--font-mono,monospace)}.copyright-progress-track{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:4px;height:8px;overflow:hidden}.copyright-progress-fill{background:linear-gradient(90deg,#8b4513,#d2691e);border-radius:4px;height:100%;transition:width .4s ease-out}.copyright-triggers{border-top:1px solid var(--color-border);padding-top:1rem}.copyright-triggers-title{color:var(--color-text);margin-bottom:.75rem;font-size:.85rem;font-weight:600}.copyright-triggers-list{flex-direction:column;gap:.5rem;margin-bottom:.75rem;list-style:none;display:flex}.copyright-triggers-list li{color:var(--color-text-muted);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.copyright-triggers-list li svg{color:var(--color-border);flex-shrink:0}.copyright-triggers-list li.achieved{color:var(--color-text)}.copyright-triggers-list li.achieved svg{color:var(--color-success)}.copyright-triggers-hint{color:var(--color-text-muted);font-size:.8rem;font-style:italic}@media (max-width:640px){.copyright-indicator{padding:1rem}.copyright-header{flex-direction:column;align-items:flex-start;gap:.5rem}.copyright-progress-header{flex-direction:column;align-items:flex-start;gap:.25rem}}.editor-content{flex-direction:column;gap:1.5rem;display:flex}.editor-placeholder{background:var(--color-card-alt);border:2px dashed var(--color-border);text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.editor-placeholder svg{color:var(--color-text-muted);opacity:.5}.editor-placeholder h3{color:var(--color-text);margin:0;font-size:1.125rem;font-weight:600}.editor-placeholder p{color:var(--color-text-muted);max-width:400px;margin:0;font-size:.9rem}.versions-tab-placeholder{background:var(--color-card-alt);border:2px dashed var(--color-border);text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.versions-tab-placeholder svg{color:var(--color-text-muted);opacity:.5}.versions-tab-placeholder h3{color:var(--color-text);margin:0;font-size:1.125rem;font-weight:600}.versions-tab-placeholder p{color:var(--color-text-muted);max-width:400px;margin:0;font-size:.9rem}.start-revision{text-align:center;flex-direction:column;align-items:center;padding:3rem 2rem;display:flex}.start-revision-header{flex-direction:column;align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.start-revision-icon{color:var(--color-primary);opacity:.8}.start-revision-title{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:600}.start-revision-subtitle{color:var(--color-text-muted);max-width:450px;margin:0;font-size:.95rem;line-height:1.5}.start-revision-form{flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:320px;display:flex}.start-revision-label{color:var(--color-text);font-size:.9rem;font-weight:500}.start-revision-select-wrapper{width:100%;position:relative}.start-revision-select{width:100%;color:var(--color-text);background:var(--color-input-bg);border:1px solid var(--color-input-border);cursor:pointer;appearance:none;border-radius:8px;padding:.75rem 2.5rem .75rem 1rem;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.start-revision-select:hover{border-color:var(--color-primary)}.start-revision-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.start-revision-select:disabled{opacity:.5;cursor:not-allowed}.start-revision-select-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.start-revision-info{background:var(--color-card-alt);text-align:left;border-radius:8px;width:100%;padding:.75rem 1rem}.start-revision-info-row{justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.start-revision-info-label{color:var(--color-text-muted)}.start-revision-info-value{color:var(--color-text);font-weight:500}.start-revision-info-note{border-top:1px solid var(--color-border);color:var(--color-text-muted);align-items:center;gap:.5rem;margin-top:.5rem;padding-top:.5rem;font-size:.8rem;display:flex}.start-revision-info-note svg{color:var(--color-primary);flex-shrink:0}.start-revision-btn{width:100%;margin-top:.5rem}.start-revision-empty{background:var(--color-card-alt);text-align:center;border-radius:8px;flex-direction:column;align-items:center;gap:.75rem;margin-top:1.5rem;padding:2rem;display:flex}.start-revision-empty svg{color:var(--color-warning)}.start-revision-empty p{color:var(--color-text-muted);max-width:350px;margin:0;font-size:.9rem}[data-theme=dark] .editor-draft-banner{background:linear-gradient(135deg,#8b5cf626 0%,var(--color-card-alt)100%)}[data-theme=dark] .job-subtab.active{box-shadow:0 1px 3px #0003}@media (max-width:640px){.job-subtabs{padding:.375rem}.job-subtab{flex:1;justify-content:center;padding:.5rem .625rem;font-size:.8rem}.job-subtab span{display:none}.job-subtab svg{margin:0}.editor-draft-banner{flex-direction:column;align-items:stretch;gap:.75rem;padding:.875rem 1rem}.editor-draft-actions{justify-content:stretch}.editor-draft-actions .btn{flex:1;justify-content:center}}.settings-page{flex-direction:column;min-height:100vh;display:flex}.settings-page .page-container{flex:1}.settings-content{width:100%}.info-grid{flex-direction:column;display:flex}.info-grid .info-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.info-grid .info-row:last-child{border-bottom:none}.info-grid .info-label{color:var(--color-text-muted);font-size:.9rem}.info-grid .info-value{font-weight:500}.card-danger{border-color:#c628284d}.card-danger .card-title{color:#c62828}[data-theme=dark] .card-danger{border-color:#ef53504d}[data-theme=dark] .card-danger .card-title{color:#ef5350}.btn-group{gap:.75rem;margin-top:1rem;display:flex}.placeholder-box{background:var(--color-card-alt);border:2px dashed var(--color-border);text-align:center;border-radius:8px;padding:3rem 2rem}.placeholder-icon{color:var(--color-text-muted);font-size:.9rem;font-weight:500}.canto9-settings .card{margin-bottom:1.5rem}@media (max-width:768px){.btn-group{flex-direction:column}.btn-group .btn{width:100%}}.onboarding-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-onboarding);background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.onboarding-wizard{background:var(--color-card);border-radius:16px;width:100%;max-width:520px;overflow:hidden;box-shadow:0 25px 50px #00000040}.onboarding-progress{background:var(--color-card-alt);border-bottom:1px solid var(--color-border);justify-content:center;align-items:center;gap:0;padding:1.5rem;display:flex}.progress-step{background:var(--color-border);width:32px;height:32px;color:var(--color-text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.progress-step.active{background:var(--color-accent);color:#fff}.progress-line{background:var(--color-border);width:40px;height:2px}.onboarding-step{padding:2rem}.onboarding-header{text-align:center;margin-bottom:2rem}.onboarding-header h2{font-family:var(--font-serif);margin-bottom:.5rem;font-size:1.75rem;font-weight:500}.onboarding-subtitle{color:var(--color-text-muted);font-size:.95rem}.onboarding-content{margin-bottom:2rem}.onboarding-actions{justify-content:space-between;gap:1rem;display:flex}.onboarding-actions .btn{flex:1}.welcome-feature{background:var(--color-card-alt);border-radius:8px;gap:1rem;margin-bottom:1rem;padding:1rem;display:flex}.welcome-feature:last-child{margin-bottom:0}.welcome-icon{text-align:center;flex-shrink:0;width:40px;font-size:1.5rem}.welcome-feature strong{margin-bottom:.25rem;display:block}.welcome-feature p{color:var(--color-text-muted);margin:0;font-size:.9rem}.style-chips{flex-wrap:wrap;gap:.5rem;display:flex}.style-chip{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:20px;padding:.5rem 1rem;font-size:.85rem;transition:all .2s}.style-chip:hover{border-color:var(--color-accent);color:var(--color-accent)}.style-chip.selected{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.style-chip:disabled{opacity:.5;cursor:not-allowed}.trial-summary{background:var(--color-card-alt);border-radius:8px;margin-top:1.5rem;padding:1rem}.trial-summary-row{justify-content:space-between;padding:.35rem 0;font-size:.9rem;display:flex}.trial-summary-row span:first-child{color:var(--color-text-muted)}@media (max-width:480px){.onboarding-wizard{border-radius:12px;max-width:none}.onboarding-step{padding:1.5rem}.onboarding-header h2{font-size:1.5rem}.onboarding-actions{flex-direction:column}.welcome-feature{text-align:center;flex-direction:column}.welcome-icon{width:auto}}.text-capitalize{text-transform:capitalize}.btn-full-width{width:100%}.ai-disclosure-link{color:inherit;text-decoration:underline}.book-section-blurb{margin-top:1.5rem}.settings-content .card,.settings-alert{margin-bottom:1.5rem}.admin-message{border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.admin-message.error{background:color-mix(in srgb,var(--color-error)10%,transparent);color:var(--color-error);border:1px solid color-mix(in srgb,var(--color-error)20%,transparent)}.admin-message.success{background:color-mix(in srgb,var(--color-success)10%,transparent);color:var(--color-success);border:1px solid color-mix(in srgb,var(--color-success)20%,transparent)}.admin-message.warning{background:color-mix(in srgb,var(--color-warning)10%,transparent);color:var(--color-warning-dark);border:1px solid color-mix(in srgb,var(--color-warning)20%,transparent)}.admin-spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:1s linear infinite admin-spin}@keyframes admin-spin{to{transform:rotate(360deg)}}.admin-loading-state,.admin-error-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem;display:flex}.admin-btn-refresh{background:var(--color-bg);border:1px solid var(--color-border);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.admin-btn-refresh:hover{background:var(--color-card);border-color:var(--color-accent)}.admin-btn-retry{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.admin-btn-retry:hover{opacity:.9}.admin-btn-success{background:color-mix(in srgb,var(--color-success)10%,transparent);border:1px solid color-mix(in srgb,var(--color-success)30%,transparent);color:var(--color-success)}.admin-btn-success:hover:not(:disabled){background:color-mix(in srgb,var(--color-success)20%,transparent);border-color:var(--color-success)}.admin-btn-danger{background:color-mix(in srgb,var(--color-error)10%,transparent);border:1px solid color-mix(in srgb,var(--color-error)30%,transparent);color:var(--color-error)}.admin-btn-danger:hover:not(:disabled){background:color-mix(in srgb,var(--color-error)20%,transparent);border-color:var(--color-error)}.admin-btn-warning{background:color-mix(in srgb,var(--color-warning)10%,transparent);border:1px solid color-mix(in srgb,var(--color-warning)30%,transparent);color:var(--color-warning-dark)}.admin-btn-warning:hover:not(:disabled){background:color-mix(in srgb,var(--color-warning)20%,transparent);border-color:var(--color-warning)}.admin-confirm-overlay{z-index:var(--z-admin-confirm);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.admin-confirm-dialog{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;width:90%;max-width:400px;padding:1.5rem}.admin-confirm-dialog h4{font-family:var(--font-serif);margin:0 0 1rem;font-size:1.25rem}.admin-confirm-dialog p{color:var(--color-text-muted);margin:0 0 1.5rem;line-height:1.5}.admin-confirm-actions{justify-content:flex-end;gap:.75rem;display:flex}.admin-confirm-actions button{cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.admin-btn-cancel{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.admin-btn-cancel:hover{background:var(--color-bg)}.admin-btn-confirm-danger{background:var(--color-error);color:#fff;border:none}.admin-btn-confirm-danger:hover{opacity:.9}.admin-btn-confirm-warning{background:var(--color-warning);color:#212529;border:none}.admin-btn-confirm-warning:hover{opacity:.9}.tier-badge{text-transform:uppercase;background:var(--color-bg);border-radius:4px;padding:.25rem .5rem;font-size:.6875rem;font-weight:600}.tier-badge.pro{color:var(--color-tier-pro)}.tier-badge.writer{color:var(--color-tier-writer)}.tier-badge.starter{color:var(--color-tier-starter)}.tier-badge.all{color:var(--color-text-muted)}.state-badge{align-items:center;gap:.25rem;display:inline-flex}.state-badge.running{color:var(--color-state-running)}.state-badge.starting,.state-badge.stopping,.state-badge.replacing{color:var(--color-state-starting)}.state-badge.stopped{color:var(--color-state-stopped)}.state-badge.created{color:var(--color-state-info)}.state-badge.destroying,.state-badge.destroyed{color:var(--color-state-error)}.admin-loading-fallback{justify-content:center;align-items:center;max-width:1200px;min-height:300px;margin:0 auto;padding:2rem;display:flex}@media (max-width:768px){.admin-confirm-actions{flex-direction:column}.admin-confirm-actions button{width:100%}}.icon{vertical-align:middle;flex-shrink:0;display:inline-flex}.icon-xs{width:14px;height:14px}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:24px;height:24px}.icon-xl{width:32px;height:32px}.icon-spin,.animate-spin{animation:1s linear infinite spin}:root{--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem}.btn-with-icon{align-items:center;gap:.5rem;display:inline-flex}.btn-icon-only{padding:.5rem;line-height:1}.btn-icon-only.btn-sm{padding:.35rem}.loading-state{color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2rem;display:flex}.loading-state-inline{color:var(--color-text-muted);align-items:center;gap:.5rem;display:inline-flex}.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;padding:3rem 2rem;display:flex}.empty-state-icon{opacity:.5;margin-bottom:1rem}.empty-state-title{font-family:var(--font-serif);color:var(--color-text);margin:0 0 .5rem;font-size:1.25rem;font-weight:500}.empty-state-description{max-width:300px;margin:0 0 1.5rem;font-size:.9rem;line-height:1.5}.empty-state-action{margin-top:.5rem}.form-field{flex-direction:column;gap:.25rem;margin-bottom:1rem;display:flex}.form-field:last-child{margin-bottom:0}.form-select{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;border-radius:6px;padding:.875rem 2.5rem .875rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}[data-theme=dark] .form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a49d91' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.form-select:focus{border-color:var(--color-accent);outline:none}.form-input-error,.form-textarea.form-input-error,.form-select.form-input-error,.form-input-error:focus,.form-textarea.form-input-error:focus,.form-select.form-input-error:focus{border-color:var(--color-error)}.form-error{color:var(--color-error);margin-top:.25rem;font-size:.75rem}.form-input-wrapper{position:relative}.form-input-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.form-input-has-icon{padding-left:2.75rem}.modal-overlay{z-index:var(--z-modal);background:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.15s ease-out modalFadeIn;display:flex;position:fixed;inset:0}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-card);border-radius:8px;flex-direction:column;max-height:calc(100vh - 2rem);animation:.15s ease-out modalSlideIn;display:flex;box-shadow:0 4px 24px #00000026}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-sm{width:100%;max-width:400px}.modal-md{width:100%;max-width:500px}.modal-lg{width:100%;max-width:680px}.modal-xl{width:100%;max-width:900px}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-title{font-family:var(--font-serif);color:var(--color-text);align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:500;display:flex}.modal-title-icon{color:var(--color-accent)}.modal-close{width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--color-border);gap:.75rem;padding:1rem 1.5rem;display:flex}.modal-footer-left{justify-content:flex-start}.modal-footer-center{justify-content:center}.modal-footer-right{justify-content:flex-end}.modal-footer-between{justify-content:space-between}@media (max-width:640px){.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:12px 12px 0 0;width:100%;max-width:100%;max-height:90vh}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}}.progress-bar-compact{align-items:center;gap:.75rem;display:flex}.progress-bar-compact .progress-bar-track{background:var(--color-border);border-radius:3px;flex:1;height:6px;overflow:hidden}.progress-bar-compact .progress-bar-fill{background:var(--color-success);border-radius:3px;height:100%;transition:width .3s}.progress-bar-label{color:var(--color-text-muted);white-space:nowrap;font-size:.75rem}.status-badge-sm{padding:.2rem .5rem;font-size:.7rem}.status-badge-md{padding:.25rem .75rem;font-size:.8rem}.status-badge-lg{padding:.35rem 1rem;font-size:.9rem}.editor-cover-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.editor-section-header{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.editor-section-header svg{color:var(--color-primary)}.editor-section-header h3{color:var(--color-text);margin:0;font-size:1rem;font-weight:600}.editor-section-count{color:var(--color-text-muted);margin-left:auto;font-size:.8rem}.editor-cover-content{align-items:flex-start;gap:1.5rem;display:flex}.editor-cover-image-wrapper{background:var(--color-card-alt);border-radius:8px;flex-shrink:0;width:200px;overflow:hidden}.editor-cover-image{width:100%;height:auto;display:block}.editor-cover-placeholder{color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:3rem 1rem;display:flex}.editor-cover-placeholder span{font-size:.85rem}.editor-cover-actions{flex-direction:column;gap:.75rem;display:flex}.editor-cost-badge{background:var(--color-card-alt);color:var(--color-text-muted);border-radius:4px;margin-left:.5rem;padding:.125rem .375rem;font-size:.7rem}.editor-error-message{color:var(--color-error);background:#c628281a;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.editor-error-dismiss{cursor:pointer;color:var(--color-error);opacity:.7;background:0 0;border:none;margin-left:auto;padding:.25rem}.editor-error-dismiss:hover{opacity:1}.editor-ink-balance{color:var(--color-text-muted);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.editor-ink-balance svg{color:var(--color-info)}.editor-chapters-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.editor-chapters-list{flex-direction:column;gap:.5rem;display:flex}.editor-chapter-row{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem;display:flex}.editor-chapter-illustration{background:var(--color-card);border-radius:4px;flex-shrink:0;width:80px;height:45px;overflow:hidden}.editor-illustration-image{object-fit:cover;width:100%;height:100%}.editor-illustration-placeholder{width:100%;height:100%;color:var(--color-text-muted);opacity:.5;justify-content:center;align-items:center;display:flex}.editor-chapter-info{flex:1;min-width:0}.editor-chapter-header{align-items:center;gap:.5rem;margin-bottom:.125rem;display:flex}.editor-chapter-number{color:var(--color-text-muted);font-size:.8rem;font-weight:600}.editor-chapter-title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.editor-chapter-words{color:var(--color-text-muted);font-size:.75rem}.editor-chapter-actions{flex-shrink:0;gap:.5rem;display:flex}.editor-chapter-actions .btn{white-space:nowrap}.editor-matter-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.editor-section-hint{color:var(--color-text-muted);margin-left:auto;font-size:.8rem;font-weight:400}.editor-matter-list{flex-direction:column;gap:.75rem;display:flex}.collapsible-editor{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:8px;transition:border-color .15s;overflow:hidden}.collapsible-editor:hover{border-color:var(--color-border-hover)}.collapsible-editor.expanded{border-color:var(--color-primary)}.collapsible-editor.has-content:not(.expanded){border-color:var(--color-success)}.collapsible-editor-header{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1rem;display:flex}.collapsible-editor-header:hover{background:#00000005}[data-theme=dark] .collapsible-editor-header:hover{background:#ffffff05}.collapsible-editor-title{color:var(--color-text);align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.collapsible-editor-title svg{color:var(--color-text-muted)}.collapsible-editor.expanded .collapsible-editor-title svg:first-child{color:var(--color-primary)}.collapsible-editor.has-content .collapsible-editor-title svg:first-child{color:var(--color-success)}.collapsible-editor-badge{background:var(--color-success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.collapsible-editor-badge svg{color:#fff}.collapsible-editor-actions{align-items:center;gap:.5rem;display:flex}.collapsible-editor-saving{color:var(--color-primary)}.collapsible-editor-chevron{color:var(--color-text-muted);transition:transform .15s}.collapsible-editor.expanded .collapsible-editor-chevron{color:var(--color-primary)}.collapsible-editor-body{border-top:1px solid var(--color-border);padding:0 1rem 1rem;animation:.15s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.collapsible-editor-description{color:var(--color-text-muted);margin:.75rem 0;font-size:.85rem;line-height:1.5}.collapsible-editor-footer{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;display:flex}.collapsible-editor-char-count{flex:1;align-items:center;gap:.75rem;display:flex}.char-count-bar{background:var(--color-border);border-radius:2px;width:100px;height:4px;overflow:hidden}.char-count-fill{background:var(--color-primary);height:100%;transition:width .15s,background-color .15s}.collapsible-editor-char-count.over-limit .char-count-fill{background:var(--color-error)}.char-count-text{color:var(--color-text-muted);font-size:.75rem}.collapsible-editor-char-count.over-limit .char-count-text{color:var(--color-error);font-weight:500}.collapsible-editor-warning{color:var(--color-error);background:#c628281a;border-radius:6px;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.markdown-editor-wrapper{border-radius:6px;overflow:hidden}.markdown-editor-wrapper .w-md-editor{border:1px solid var(--color-border);border-radius:6px}[data-theme=dark] .markdown-editor-wrapper .w-md-editor{background-color:var(--color-card-alt)}[data-theme=dark] .markdown-editor-wrapper .w-md-editor-toolbar{background-color:var(--color-card)}[data-theme=dark] .markdown-editor-wrapper .w-md-editor-text-input,[data-theme=dark] .markdown-editor-wrapper .w-md-editor-text-pre>code,[data-theme=dark] .markdown-editor-wrapper .w-md-editor-text{color:var(--color-text)}[data-theme=dark] .collapsible-editor-warning{background:#da4a4a26}.editor-publish-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;display:flex}.editor-publish-section .btn{min-width:200px}.editor-publish-hint{color:var(--color-text-muted);font-size:.8rem}[data-theme=dark] .editor-cost-badge{background:#ffffff1a}[data-theme=dark] .editor-error-message{background:#da4a4a26}@media (max-width:640px){.editor-cover-content{flex-direction:column}.editor-cover-image-wrapper{width:100%;max-width:200px}.editor-chapter-row{flex-wrap:wrap}.editor-chapter-actions{width:100%;margin-top:.5rem}}.chapter-edit-modal-overlay{z-index:var(--z-modal);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.chapter-edit-modal{background:var(--color-card);border-radius:12px;flex-direction:column;width:100%;max-width:1000px;max-height:calc(100vh - 2rem);animation:.2s ease-out modalSlideIn;display:flex;box-shadow:0 20px 50px #0000004d}.chapter-edit-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;display:flex}.chapter-edit-title-section{flex-direction:column;gap:.25rem;display:flex}.chapter-edit-title{color:var(--color-text);margin:0;font-size:1.25rem;font-weight:600}.chapter-edit-stats{align-items:center;gap:.75rem;display:flex}.chapter-edit-word-count{color:var(--color-text-muted);font-size:.85rem}.chapter-edit-modified{color:var(--color-warning-dark);background:var(--color-stale-bg);border-radius:9999px;align-items:center;gap:.25rem;padding:.125rem .5rem;font-size:.75rem;display:flex}.chapter-edit-actions{flex-shrink:0;gap:.5rem;display:flex}.chapter-edit-error{color:var(--color-error);background:#c628281a;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.85rem;display:flex}.chapter-edit-error-dismiss{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;margin-left:auto;padding:.25rem;display:flex}.chapter-edit-error-dismiss:hover{opacity:1}.chapter-edit-content{flex:1;padding:1.5rem;overflow:auto}.markdown-editor-wrapper{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.markdown-editor-wrapper .w-md-editor{box-shadow:none!important;border:none!important}.markdown-editor-wrapper .w-md-editor-toolbar{background:var(--color-card-alt)!important;border-bottom:1px solid var(--color-border)!important}.markdown-editor-wrapper .w-md-editor-text-pre,.markdown-editor-wrapper .w-md-editor-text-input,.markdown-editor-wrapper .w-md-editor-text{font-family:JetBrains Mono,SF Mono,Monaco,Inconsolata,Roboto Mono,monospace!important;font-size:.9rem!important;line-height:1.6!important}[data-theme=dark] .chapter-edit-error{background:#da4a4a26}[data-theme=dark] .markdown-editor-wrapper .w-md-editor-toolbar{background:var(--color-card)!important}@media (max-width:768px){.chapter-edit-modal-overlay{padding:0}.chapter-edit-modal{border-radius:0;max-height:100vh}.chapter-edit-header{flex-direction:column;gap:.75rem}.chapter-edit-actions{justify-content:flex-end;width:100%}.chapter-edit-actions .btn{flex:1}.chapter-edit-actions .btn:first-child{display:none}}.versions-tab{flex-direction:column;gap:1.5rem;padding:1rem 0;display:flex}.versions-tab-loading,.versions-tab-error,.versions-tab-empty{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 1rem;display:flex}.versions-tab-loading svg{color:var(--color-primary)}.versions-tab-error svg{color:var(--color-error)}.versions-tab-empty svg{color:var(--color-text-muted);opacity:.5}.versions-tab-empty h3{color:var(--color-text);margin:0;font-size:1.1rem;font-weight:600}.versions-tab-empty p{margin:0;font-size:.9rem}.versions-section{flex-direction:column;gap:.75rem;display:flex}.versions-section-header{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);align-items:center;gap:.5rem;padding-bottom:.5rem;font-size:.85rem;font-weight:600;display:flex}.versions-section-header svg{width:14px;height:14px}.versions-section-original{border-top:2px solid var(--color-border);margin-top:1rem;padding-top:1rem}.versions-original-note{color:var(--color-text-muted);background:var(--color-card-alt);border-radius:8px;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.versions-original-note svg{color:var(--color-success);flex-shrink:0}.revision-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem 1.25rem;transition:border-color .15s,box-shadow .15s;display:flex}.revision-card:hover{border-color:var(--color-border-hover)}.revision-card-draft{border-color:var(--color-primary);background:linear-gradient(135deg,var(--color-card)0%,rgba(var(--color-primary-rgb),.05)100%)}.revision-card-original{background:linear-gradient(135deg,var(--color-card)0%,#ffc1070d 100%)}.revision-card-header{flex-direction:column;gap:.25rem;display:flex}.revision-card-title{color:var(--color-text);align-items:center;gap:.5rem;font-size:1rem;font-weight:600;display:flex}.revision-original-icon{color:var(--color-warning)}.revision-draft-icon{color:var(--color-primary)}.revision-card-meta{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:.375rem;font-size:.85rem;display:flex}.revision-card-separator{color:var(--color-border)}.revision-card-subtitle,.revision-card-words,.revision-card-date{color:var(--color-text-muted)}.revision-card-actions{border-top:1px solid var(--color-border);flex-wrap:wrap;gap:.5rem;padding-top:.5rem;display:flex}.revision-card-actions .btn{font-size:.85rem}.versions-loading-overlay{z-index:var(--z-modal);color:#fff;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;font-size:1rem;display:flex;position:fixed;inset:0}.versions-loading-overlay svg{width:32px;height:32px}[data-theme=dark] .revision-card-draft{background:linear-gradient(135deg,var(--color-card)0%,rgba(var(--color-primary-rgb),.08)100%)}[data-theme=dark] .revision-card-original{background:linear-gradient(135deg,var(--color-card)0%,#ffc10714 100%)}[data-theme=dark] .versions-original-note{background:#ffffff0d}@media (max-width:640px){.revision-card{padding:.875rem 1rem}.revision-card-meta{font-size:.8rem}.revision-card-actions{flex-direction:column}.revision-card-actions .btn{justify-content:center;width:100%}}
