.compositor-canva{--comp-bg: #1a1a2e;--comp-sidebar-bg: #16213e;--comp-surface: #1f2937;--comp-surface-hover: #374151;--comp-border: #374151;--comp-text: #f3f4f6;--comp-text-muted: #9ca3af;--comp-primary: #8b5cf6;--comp-primary-hover: #7c3aed;--comp-canvas-bg: #0f172a;--comp-taskbar-bg: #1e293b;--comp-radius: 6px;--comp-radius-lg: 10px}.compositor-canva{display:grid;grid-template-rows:48px 1fr;height:100%;width:100%;background:var(--comp-bg);color:var(--comp-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;position:relative}.compositor-canva *,.compositor-canva *:before,.compositor-canva *:after{box-sizing:border-box}.compositor-topbar{display:flex;align-items:center;justify-content:space-between;height:48px;padding:0 12px;background:var(--comp-surface);border-bottom:1px solid var(--comp-border)}.topbar-left,.topbar-center,.topbar-right{display:flex;align-items:center;gap:8px}.topbar-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:5px 8px;background:transparent;border:none;border-radius:var(--comp-radius);color:var(--comp-text);font-size:12px;cursor:pointer;transition:background .15s}.topbar-btn:hover{background:var(--comp-surface-hover)}.topbar-btn-primary{background:var(--comp-primary);font-weight:500}.topbar-btn-primary:hover{background:var(--comp-primary-hover)}.topbar-divider{width:1px;height:18px;background:var(--comp-border)}.topbar-title{font-weight:500;font-size:13px;color:var(--comp-text);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-select{padding:4px 6px;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:var(--comp-radius);color:var(--comp-text);font-size:11px;cursor:pointer}.topbar-checkbox{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--comp-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.topbar-checkbox input[type=checkbox]{width:14px;height:14px;accent-color:var(--comp-primary);cursor:pointer}.topbar-checkbox:hover{color:var(--comp-text)}.page-indicator{font-size:12px;color:var(--comp-text-muted);min-width:80px;text-align:center}.zoom-controls{display:flex;align-items:center;gap:4px;background:var(--comp-surface-hover);border-radius:var(--comp-radius);padding:2px}.zoom-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--comp-text);font-size:14px;cursor:pointer;transition:background .1s}.zoom-btn:hover{background:var(--comp-surface)}.zoom-btn:active{background:var(--comp-primary)}.zoom-level{font-size:11px;font-weight:500;color:var(--comp-text);min-width:40px;text-align:center;cursor:pointer;padding:2px 4px;border-radius:3px}.zoom-level:hover{background:var(--comp-surface)}.zoom-slider{width:80px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--comp-border);border-radius:2px;cursor:pointer}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--comp-primary);border-radius:50%;cursor:pointer}.zoom-slider::-moz-range-thumb{width:12px;height:12px;background:var(--comp-primary);border-radius:50%;cursor:pointer;border:none}.compositor-main{display:flex;flex:1;min-height:0;overflow:hidden;position:relative}.compositor-sidebar{width:220px;min-width:220px;background:var(--comp-sidebar-bg);border-right:1px solid var(--comp-border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:10px 14px;border-bottom:1px solid var(--comp-border);flex-shrink:0}.sidebar-header h3{margin:0;font-size:13px;font-weight:600}.sidebar-content{flex:1;overflow-y:auto}.sidebar-section{border-bottom:1px solid var(--comp-border)}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--comp-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-section-header:hover{color:var(--comp-text)}.section-chevron{transition:transform .2s}.section-chevron.rotated{transform:rotate(-90deg)}.color-themes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:8px 10px 12px;max-height:140px;overflow-y:auto;transition:max-height .2s}.color-themes-grid.collapsed{max-height:0;padding-top:0;padding-bottom:0;overflow:hidden}.color-theme-btn{display:flex;align-items:center;justify-content:center;padding:0;background:transparent;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s}.color-theme-btn:hover{border-color:var(--comp-surface-hover);transform:scale(1.08)}.color-theme-btn.active{border-color:var(--comp-primary);box-shadow:0 0 0 1px var(--comp-primary)}.color-theme-swatch{width:36px;height:36px;border-radius:4px;border:1px solid;position:relative;overflow:hidden}.color-theme-accent{position:absolute;bottom:0;left:0;right:0;height:8px}.template-gallery{overflow-y:auto;padding:10px}.template-category-section{margin-bottom:12px}.template-category-header{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--comp-text-muted);padding:2px 4px 6px;position:sticky;top:0;background:var(--comp-sidebar-bg);z-index:1}.template-category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.template-card{background:var(--comp-surface);border-radius:var(--comp-radius);overflow:hidden;cursor:pointer;transition:all .15s;border:2px solid transparent}.template-card:hover{border-color:var(--comp-surface-hover)}.template-card.selected{border-color:var(--comp-primary);box-shadow:0 0 0 1px var(--comp-primary)}.template-preview-visual{aspect-ratio:1;padding:4px;display:flex;align-items:center;justify-content:center}.template-preview-visual svg{width:100%;height:100%}.template-name{font-size:9px;font-weight:500;color:var(--comp-text);padding:4px;text-align:center;background:var(--comp-surface);border-top:1px solid var(--comp-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compositor-canvas-area{flex:1;display:flex;flex-direction:column;background:var(--comp-canvas-bg);min-width:0;min-height:0;overflow:hidden;position:relative}.canvas-container{position:absolute;top:0;left:0;right:0;bottom:76px;display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden}.preview-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;transform-origin:center center;transition:transform .1s ease-out}.page-preview{background:#fff;border-radius:var(--comp-radius);box-shadow:0 8px 24px #0006;overflow:visible;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center}.page-preview svg{display:block;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;pointer-events:all}.page-preview svg image,.page-preview svg g,.page-preview svg text{pointer-events:all;cursor:pointer}.preview-loading,.preview-error{display:flex;align-items:center;justify-content:center;width:280px;height:280px;color:var(--comp-text-muted)}.spinner{width:24px;height:24px;border:2px solid var(--comp-border);border-top-color:var(--comp-primary);border-radius:50%;animation:spin .6s linear infinite}.selection-overlay{position:absolute;border:2px solid var(--comp-primary);border-radius:3px;pointer-events:none;background:#8b5cf60d}.selection-overlay:not(.hidden){pointer-events:auto;cursor:move}.selection-overlay.hidden{display:none}.resize-handle{position:absolute;width:10px;height:10px;background:#fff;border:2px solid var(--comp-primary);border-radius:2px}.resize-handle.nw{top:-5px;left:-5px;cursor:nwse-resize}.resize-handle.ne{top:-5px;right:-5px;cursor:nesw-resize}.resize-handle.sw{bottom:-5px;left:-5px;cursor:nesw-resize}.resize-handle.se{bottom:-5px;right:-5px;cursor:nwse-resize}.thumbnails-strip{position:absolute;bottom:0;left:0;right:0;background:var(--comp-surface);border-top:1px solid var(--comp-border);padding:8px 16px;height:60px;z-index:50;display:flex;align-items:center}.preview-thumbnails{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;height:100%;align-items:center;scrollbar-width:thin}.preview-thumbnails::-webkit-scrollbar{height:4px}.preview-thumbnails::-webkit-scrollbar-track{background:transparent}.preview-thumbnails::-webkit-scrollbar-thumb{background:var(--comp-border);border-radius:2px}.thumbnail{flex-shrink:0;cursor:pointer;transition:transform .1s;display:flex;flex-direction:column;align-items:center;gap:2px}.thumbnail:hover{transform:scale(1.05)}.thumbnail.active .thumbnail-inner{box-shadow:0 0 0 2px var(--comp-primary)}.thumbnail-inner{width:32px;height:32px;border-radius:3px;overflow:hidden;background:var(--comp-surface-hover)}.thumbnail-inner img{width:100%;height:100%;object-fit:cover}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:8px;color:var(--comp-text-muted);background:#fff}.thumbnail-number{display:block;text-align:center;font-size:8px;color:var(--comp-text-muted);line-height:1}.floating-taskbar{position:absolute;bottom:72px;left:50%;transform:translate(-50%);background:var(--comp-taskbar-bg);border:1px solid var(--comp-border);border-radius:var(--comp-radius-lg);padding:8px 14px;box-shadow:0 8px 24px #0006;z-index:100;transition:opacity .15s,transform .15s}.floating-taskbar.hidden{opacity:0;transform:translate(-50%) translateY(10px);pointer-events:none}.taskbar-content{display:flex;align-items:center;gap:10px}.taskbar-section{display:flex;align-items:center;gap:6px}.taskbar-label{font-size:10px;font-weight:500;color:var(--comp-text-muted);text-transform:uppercase;letter-spacing:.3px}.taskbar-value{font-size:11px;font-weight:500;color:var(--comp-text);min-width:36px;text-align:center}.taskbar-divider{width:1px;height:24px;background:var(--comp-border)}.taskbar-frames{display:flex;gap:2px}.taskbar-frame-btn{width:28px;height:28px;padding:2px;background:transparent;border:2px solid transparent;border-radius:4px;color:var(--comp-text-muted);cursor:pointer;transition:all .1s}.taskbar-frame-btn:hover{background:var(--comp-surface-hover);color:var(--comp-text)}.taskbar-frame-btn.active{border-color:var(--comp-primary);color:var(--comp-primary);background:#8b5cf626}.taskbar-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:4px;color:var(--comp-text);font-size:13px;cursor:pointer;transition:all .1s}.taskbar-btn:hover{background:var(--comp-primary);border-color:var(--comp-primary)}.taskbar-btn.active{background:var(--comp-primary);border-color:var(--comp-primary);color:#fff}.taskbar-btn:disabled{opacity:.4;cursor:not-allowed}.taskbar-align-btns,.taskbar-snap-btns{display:flex;gap:2px}.taskbar-align-btns .taskbar-btn,.taskbar-snap-btns .taskbar-btn{width:24px;height:24px}.taskbar-btn-icon{width:26px;height:26px;padding:0;background:transparent;border:none;color:var(--comp-text-muted);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.taskbar-btn-icon:hover{color:var(--comp-text)}.taskbar-btn-apply{display:flex;align-items:center;gap:5px;padding:6px 10px;background:transparent;border:1px solid var(--comp-border);border-radius:4px;color:var(--comp-text-muted);font-size:10px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.taskbar-btn-apply:hover{background:var(--comp-primary);border-color:var(--comp-primary);color:#fff}.taskbar-btn-apply.applied{background:#10b981;border-color:#10b981;color:#fff}.taskbar-select{padding:4px 6px;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:4px;color:var(--comp-text);font-size:11px;cursor:pointer;min-width:110px}.taskbar-fontsize,.taskbar-crop,.taskbar-pan{display:flex;align-items:center;gap:3px}.taskbar-colors{display:flex;gap:4px}.taskbar-color-btn{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s}.taskbar-color-btn:hover{transform:scale(1.15)}.taskbar-color-btn.active{box-shadow:0 0 0 2px var(--comp-taskbar-bg),0 0 0 4px var(--comp-primary)}.taskbar-btn-mode{display:flex;align-items:center;gap:5px;padding:6px 10px;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:4px;color:var(--comp-text);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.taskbar-btn-mode:hover{background:var(--comp-primary);border-color:var(--comp-primary)}.taskbar-btn-mode.active{background:var(--comp-primary);border-color:var(--comp-primary);color:#fff}.page-preview.crop-mode{box-shadow:0 0 0 3px var(--comp-primary),0 8px 24px #0006}.crop-overlay-image,.crop-frame-border{pointer-events:none}.compositor-wrap .modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:200}.compositor-wrap .modal.hidden{display:none}.compositor-wrap .modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.compositor-wrap .modal-dialog{position:relative;background:var(--comp-surface);border-radius:var(--comp-radius-lg);width:90%;max-width:520px;box-shadow:0 16px 48px #00000080}.compositor-wrap .modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--comp-border)}.compositor-wrap .modal-header h3{margin:0;font-size:15px;font-weight:600}.compositor-wrap .modal-close{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--comp-text-muted);font-size:18px;cursor:pointer}.compositor-wrap .modal-close:hover{background:var(--comp-surface-hover);color:var(--comp-text)}.compositor-wrap .modal-body{padding:16px}.export-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}.export-option{padding:14px;background:var(--comp-surface-hover);border:2px solid transparent;border-radius:var(--comp-radius);text-align:center;cursor:pointer;transition:all .15s}.export-option:hover{border-color:var(--comp-primary)}.export-option-icon{font-size:24px;margin-bottom:4px}.export-option-label{font-weight:600;font-size:12px;margin-bottom:2px}.export-option-desc{font-size:10px;color:var(--comp-text-muted)}.export-quality{margin-bottom:10px}.export-quality label{display:block;font-size:11px;font-weight:500;color:var(--comp-text-muted);margin-bottom:4px}.export-quality select{width:100%;padding:6px 8px;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:var(--comp-radius);color:var(--comp-text);font-size:12px}.export-progress.hidden{display:none}.progress-bar{height:5px;background:var(--comp-surface-hover);border-radius:3px;overflow:hidden;margin-bottom:4px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--comp-primary),#06b6d4);border-radius:3px;transition:width .2s}.progress-text{font-size:11px;color:var(--comp-text-muted);text-align:center}.template-gallery::-webkit-scrollbar,.preview-thumbnails::-webkit-scrollbar{width:5px;height:5px}.template-gallery::-webkit-scrollbar-track,.preview-thumbnails::-webkit-scrollbar-track{background:transparent}.template-gallery::-webkit-scrollbar-thumb,.preview-thumbnails::-webkit-scrollbar-thumb{background:var(--comp-border);border-radius:3px}.topbar-dropdown-wrap{position:relative}.topbar-dropdown-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:var(--comp-radius);color:var(--comp-text);font-size:11px;cursor:pointer;transition:all .15s}.topbar-dropdown-btn:hover{background:var(--comp-surface);border-color:var(--comp-primary)}.topbar-dropdown-btn svg{flex-shrink:0}.dropdown-label{white-space:nowrap}.dropdown-caret{opacity:.6;margin-left:2px}.topbar-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--comp-surface);border:1px solid var(--comp-border);border-radius:var(--comp-radius);box-shadow:0 8px 24px #0006;z-index:150;min-width:140px;overflow:hidden}.topbar-dropdown.hidden{display:none}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:none;color:var(--comp-text);font-size:12px;cursor:pointer;transition:background .1s;text-align:left}.dropdown-item:hover{background:var(--comp-surface-hover)}.dropdown-item.active{background:#8b5cf626;color:var(--comp-primary)}.dropdown-item svg{flex-shrink:0;opacity:.8}#ab-pattern-btn.active{background:var(--comp-primary);border-color:var(--comp-primary);color:#fff}.side-by-side-container{display:flex;gap:4px;align-items:center;justify-content:center}.spread-page{position:relative;background:#fff;border-radius:var(--comp-radius);box-shadow:0 4px 16px #0000004d;transition:box-shadow .2s;overflow:hidden}.spread-page.spread-page-empty{background:#f5f5f5;display:flex;align-items:center;justify-content:center;min-width:200px;min-height:200px}.spread-page.spread-page-empty .empty-page-placeholder{width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,0,0,.03) 10px,rgba(0,0,0,.03) 20px)}.spread-page.selected{box-shadow:0 0 0 3px var(--comp-primary),0 4px 16px #0000004d}.spread-page svg{display:block;max-height:100%;width:auto;pointer-events:all}.spread-selection-overlay{position:absolute;border:2px solid var(--comp-primary);border-radius:3px;background:#8b5cf60d;pointer-events:auto;cursor:move;z-index:10}.spread-selection-overlay.hidden{display:none}.spread-selection-overlay .resize-handle{position:absolute;width:10px;height:10px;background:#fff;border:2px solid var(--comp-primary);border-radius:2px}.spread-selection-overlay .resize-handle.nw{top:-5px;left:-5px;cursor:nwse-resize}.spread-selection-overlay .resize-handle.ne{top:-5px;right:-5px;cursor:nesw-resize}.spread-selection-overlay .resize-handle.sw{bottom:-5px;left:-5px;cursor:nesw-resize}.spread-selection-overlay .resize-handle.se{bottom:-5px;right:-5px;cursor:nwse-resize}.compositor-canva[data-view-mode=grid] .compositor-main,.compositor-canva[data-view-mode=list] .compositor-main{display:flex}.compositor-canva[data-view-mode=grid] .compositor-canvas-area,.compositor-canva[data-view-mode=list] .compositor-canvas-area{flex:1}.compositor-canva[data-view-mode=grid] .canvas-container,.compositor-canva[data-view-mode=list] .canvas-container{padding:0}.compositor-canva[data-view-mode=grid] .preview-wrapper,.compositor-canva[data-view-mode=list] .preview-wrapper{width:100%;height:100%}.compositor-canva[data-view-mode=grid] .page-preview,.compositor-canva[data-view-mode=list] .page-preview{width:100%;height:100%;background:transparent;box-shadow:none;border-radius:0}.view-grid .canvas-container{padding:0}.grid-view-container{width:100%;height:100%;overflow:hidden;position:relative;cursor:grab;background:var(--comp-canvas-bg)}.grid-view-inner{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding:24px;transform-origin:top left;transition:transform .1s ease-out}.grid-page{background:#fff;border-radius:var(--comp-radius-lg);box-shadow:0 4px 16px #00000040;cursor:pointer;transition:transform .15s,box-shadow .15s;overflow:hidden}.grid-page:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000059}.grid-page svg{display:block;width:100%;height:auto}.grid-page-label{display:block;text-align:center;padding:10px;font-size:12px;font-weight:600;color:var(--comp-text);background:var(--comp-surface);border-top:1px solid var(--comp-border)}.grid-zoom-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--comp-taskbar-bg);border:1px solid var(--comp-border);border-radius:var(--comp-radius-lg);padding:8px 16px;box-shadow:0 4px 16px #0000004d}.grid-zoom-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:6px;color:var(--comp-text);font-size:16px;cursor:pointer;transition:all .1s}.grid-zoom-btn:hover{background:var(--comp-primary);border-color:var(--comp-primary)}#grid-zoom-level{font-size:12px;font-weight:600;color:var(--comp-text);min-width:50px;text-align:center}.list-view-container{display:flex;flex-direction:column;gap:16px;padding:24px;max-height:100%;overflow-y:auto;background:var(--comp-canvas-bg)}.list-page{display:flex;gap:20px;background:var(--comp-surface);border:1px solid var(--comp-border);border-radius:var(--comp-radius-lg);padding:16px;cursor:pointer;transition:all .15s}.list-page:hover{background:var(--comp-surface-hover);border-color:var(--comp-primary);transform:translate(4px)}.list-page-preview{flex-shrink:0;width:140px;background:#fff;border-radius:var(--comp-radius);overflow:hidden;box-shadow:0 2px 8px #0003}.list-page-preview svg{display:block;width:100%;height:auto}.list-page-info{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0;padding:8px 0}.list-page-number{font-size:14px;font-weight:700;color:var(--comp-text)}.list-page-text{font-size:13px;color:var(--comp-text-muted);line-height:1.5;overflow:hidden;text-overflow:ellipsis}.thumbnail-spread{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:transform .1s}.thumbnail-spread:hover{transform:scale(1.05)}.thumbnail-spread.active .thumbnail-spread-inner{box-shadow:0 0 0 2px var(--comp-primary)}.thumbnail-spread-inner{display:flex;gap:1px;background:var(--comp-surface);border-radius:3px;padding:2px;box-shadow:0 2px 6px #0003}.thumbnail-spread-page{width:24px;height:30px;background:#fff;border-radius:2px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:7px;color:var(--comp-text-muted)}.thumbnail-spread-page.thumbnail-spread-empty{background:#e5e5e5}.thumbnail-spread-page svg{width:100%;height:100%}.thumbnail-spread-label{font-size:8px;color:var(--comp-text-muted);font-weight:500;line-height:1}.thumbnail-inner svg{width:100%;height:100%}.compositor-wrap .modal-dialog-sm{max-width:480px}.compositor-wrap .modal-text{font-size:13px;color:var(--comp-text);margin:0 0 12px;line-height:1.5}.compositor-wrap .modal-text-muted{color:var(--comp-text-muted);font-size:11px}.compositor-wrap .modal-list{margin:0 0 16px;padding-left:20px;font-size:12px;color:var(--comp-text);line-height:1.6}.compositor-wrap .modal-list li{margin-bottom:4px}.compositor-wrap .modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.compositor-wrap .modal-btn{padding:8px 16px;border-radius:var(--comp-radius);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.compositor-wrap .modal-btn-secondary{background:var(--comp-surface-hover);border:1px solid var(--comp-border);color:var(--comp-text)}.compositor-wrap .modal-btn-secondary:hover{background:var(--comp-surface)}.compositor-wrap .modal-btn-primary{background:var(--comp-primary);border:1px solid var(--comp-primary);color:#fff}.compositor-wrap .modal-btn-primary:hover{background:var(--comp-primary-hover)}.cart-modal-subtitle{color:var(--comp-text-muted);font-size:13px;margin:0 0 16px}.cart-product-row{display:grid;grid-template-columns:40px 1fr auto auto;gap:12px;align-items:center;padding:14px;background:var(--comp-surface-hover);border-radius:var(--comp-radius);margin-bottom:10px}.cart-product-icon{font-size:28px}.cart-product-info{min-width:0}.cart-product-name{font-size:14px;font-weight:600;margin-bottom:2px}.cart-product-desc{font-size:11px;color:var(--comp-text-muted)}.cart-product-size{margin-top:8px;display:flex;align-items:center;gap:8px}.cart-product-size label{font-size:11px;color:var(--comp-text-muted)}.cart-product-size select{flex:1;padding:4px 8px;background:var(--comp-surface);border:1px solid var(--comp-border);border-radius:var(--comp-radius);color:var(--comp-text);font-size:11px}.cart-product-price{font-size:16px;font-weight:700;color:var(--comp-primary);min-width:60px;text-align:right}.cart-product-qty{display:flex;align-items:center;gap:6px}.cart-product-qty .qty-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--comp-surface);border:1px solid var(--comp-border);border-radius:var(--comp-radius);color:var(--comp-text);font-size:16px;cursor:pointer;transition:all .15s}.cart-product-qty .qty-btn:hover{background:var(--comp-primary);border-color:var(--comp-primary)}.cart-product-qty .qty-value{min-width:28px;text-align:center;font-size:14px;font-weight:600}.cart-modal-footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--comp-border)}.cart-modal-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px}#cart-modal-subtotal{font-size:20px;font-weight:700;color:var(--comp-primary)}.add-to-cart-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:linear-gradient(135deg,var(--comp-primary),#7c3aed);border:none;border-radius:var(--comp-radius);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.add-to-cart-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #8b5cf666}.add-to-cart-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.compositor-wrap .modal-dialog-lg{max-width:600px}.checkout-subtitle{color:var(--comp-text-muted);font-size:13px;margin:0 0 16px;text-align:center}.product-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.product-option{position:relative;padding:20px 16px;background:var(--comp-surface-hover);border:2px solid transparent;border-radius:var(--comp-radius-lg);text-align:center;cursor:pointer;transition:all .2s}.product-option:hover{border-color:var(--comp-primary);transform:translateY(-2px)}.product-option.unlocked{border-color:#10b981;background:#10b9811a}.product-option.unlocked:hover{border-color:#10b981}.product-option-badge{position:absolute;top:8px;right:8px;padding:2px 8px;background:var(--comp-primary);color:#fff;font-size:10px;font-weight:600;border-radius:10px;text-transform:uppercase}.product-option.unlocked .product-option-badge{background:#10b981}.product-option-icon{font-size:36px;margin-bottom:8px}.product-option-name{font-size:16px;font-weight:600;margin-bottom:4px}.product-option-desc{font-size:12px;color:var(--comp-text-muted);margin-bottom:12px}.product-option-price{font-size:20px;font-weight:700;color:var(--comp-primary)}.product-option.unlocked .product-option-price{color:#10b981;text-decoration:line-through;opacity:.5}.product-option-status{margin-top:8px;font-size:12px;font-weight:600}.product-option-status.purchased{color:#10b981}.checkout-step.hidden{display:none}.checkout-back-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:transparent;border:1px solid var(--comp-border);border-radius:var(--comp-radius);color:var(--comp-text-muted);font-size:12px;cursor:pointer;margin-bottom:16px;transition:all .15s}.checkout-back-btn:hover{background:var(--comp-surface-hover);color:var(--comp-text)}.checkout-payment-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--comp-surface-hover);border-radius:var(--comp-radius);margin-bottom:16px}#checkout-product-name{font-weight:600}#checkout-product-price{font-size:18px;font-weight:700;color:var(--comp-primary)}.checkout-embed-container{min-height:400px;background:#fff;border-radius:var(--comp-radius);overflow:hidden}.checkout-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:12px;color:var(--comp-text-muted)}.checkout-error{padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--comp-radius);color:#ef4444;font-size:13px;text-align:center}.checkout-error.hidden{display:none}.checkout-error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:8px;color:var(--comp-text-muted)}.checkout-error-state .error-detail{font-size:12px;color:#ef4444}.checkout-error-state button{margin-top:12px;padding:8px 16px;background:var(--comp-surface-hover);border:1px solid var(--comp-border);border-radius:var(--comp-radius);color:var(--comp-text);cursor:pointer}.checkout-success{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}.checkout-success-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;color:#fff;font-size:32px;margin-bottom:16px}.checkout-success h4{margin:0 0 8px;font-size:20px}.checkout-success p{margin:0 0 24px;color:var(--comp-text-muted)}.checkout-download-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--comp-primary),var(--comp-primary-hover));border:none;border-radius:var(--comp-radius);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.checkout-download-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}@media (max-width: 800px){.compositor-sidebar{width:170px;min-width:170px}.template-category-grid{grid-template-columns:1fr}.page-preview svg{max-width:100%;max-height:100%}.floating-taskbar{padding:6px 10px}.taskbar-content{gap:6px}.dropdown-label{display:none}.grid-view-inner{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.product-options-grid{grid-template-columns:1fr}}@media (max-width: 600px){.compositor-sidebar,.topbar-title{display:none}.page-preview svg{max-width:100%;max-height:100%}.taskbar-content{flex-wrap:wrap;justify-content:center}.taskbar-btn-apply span,.topbar-dropdown-btn span{display:none}.grid-view-inner{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;padding:12px}}:root{--bg: #080c18;--bg2: #0e1220;--bg3: #141828;--text: rgba(255,255,255,.93);--muted: rgba(255,255,255,.58);--faint: rgba(255,255,255,.3);--stroke: rgba(255,255,255,.08);--stroke2: rgba(255,255,255,.15);--brand: #7c5cff;--brand-l: #a488ff;--brand-glow: rgba(124,92,255,.28);--teal: #34d399;--amber: #fbbf24;--danger: #fb7185;--r-xl: 22px;--r-lg: 16px;--r-md: 12px;--r-sm: 7px;--topbar-h: 68px;--pad: clamp(1rem, 4vw, 3rem);--sans: "Nunito", ui-sans-serif, system-ui, sans-serif;--speed: .16s;--panel: rgba(255,255,255,.05);--panel2: rgba(255,255,255,.08);--warn: #fbbf24;--shadow: 0 8px 24px rgba(0,0,0,.3);--shadow2: 0 18px 60px rgba(0,0,0,.45);--ease: cubic-bezier(.16,1,.3,1);--radius-md: var(--r-md);--radius-lg: var(--r-lg);--radius-xl: var(--r-xl);--mono: ui-monospace, SFMono-Regular, monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(900px 700px at 10% 5%,rgba(124,92,255,.11),transparent 60%),radial-gradient(700px 500px at 90% 15%,rgba(52,211,153,.07),transparent 55%)}.hidden{display:none!important}#app{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}.topbar{position:sticky;top:0;z-index:50;height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 var(--pad);gap:1rem;border-bottom:1px solid var(--stroke);background:#080c18d1;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--text);flex-shrink:0}.brand-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--teal));display:grid;place-items:center;font-size:15px}.brand-name{font-size:17px;font-weight:800;white-space:nowrap}.step-bar{display:flex;align-items:center;flex:1;justify-content:center;max-width:540px;gap:2px;opacity:1;transition:opacity .3s}body[data-phase=dashboard] .step-bar,body[data-phase=orders] .step-bar{opacity:0;pointer-events:none}.sb-step{display:flex;align-items:center;gap:6px}.sb-dot{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;background:var(--bg3);color:var(--faint);border:1px solid var(--stroke2);transition:all .2s}.sb-step.active .sb-dot{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 0 0 3px #7c5cff33}.sb-step.done .sb-dot{background:var(--teal);color:#fff;border-color:var(--teal)}.sb-label{font-size:12px;font-weight:700;color:var(--faint);white-space:nowrap;transition:color .2s}.sb-step.active .sb-label{color:var(--text)}.sb-step.done .sb-label{color:var(--muted)}.sb-line{flex:1;height:1px;background:var(--stroke2);min-width:14px;max-width:40px;margin:0 2px}.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.icon-btn{width:34px;height:34px;border-radius:var(--r-md);background:none;border:1px solid var(--stroke);color:var(--muted);cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:all var(--speed)}.icon-btn:hover{border-color:var(--stroke2);color:var(--text);background:#ffffff0a}.badge-dot{position:absolute;top:-4px;right:-4px;background:var(--brand);color:#fff;font-size:9px;font-weight:800;min-width:15px;height:15px;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 3px}.queue-wrap,.account-wrap{position:relative}.dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg2);border:1px solid var(--stroke2);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 16px 40px #00000073;z-index:100;min-width:240px}.dropdown-header{padding:10px 14px;border-bottom:1px solid var(--stroke);font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.dropdown-footer{padding:8px 14px;border-top:1px solid var(--stroke)}.queue-list{max-height:280px;overflow-y:auto}.empty-msg{padding:1.25rem;text-align:center;font-size:13px;color:var(--faint)}.link-btn{background:none;border:none;color:var(--muted);font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;padding:0;transition:color var(--speed)}.link-btn:hover{color:var(--text)}.account-btn{display:flex;align-items:center;gap:7px;background:none;border:1px solid var(--stroke);border-radius:var(--r-lg);color:var(--text);cursor:pointer;padding:6px 10px;font-family:var(--sans);transition:all var(--speed)}.account-btn:hover{border-color:var(--stroke2);background:#ffffff0a}.avatar{width:24px;height:24px;border-radius:50%;background:#7c5cff33;color:var(--brand-l);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}.account-name{font-size:14px;font-weight:700}.chev{font-size:10px;color:var(--faint)}.menu-item{display:block;width:100%;padding:11px 16px;background:none;border:none;color:var(--muted);font-family:var(--sans);font-size:14px;font-weight:600;text-align:left;cursor:pointer;transition:all var(--speed)}.menu-item:hover{background:#ffffff0f;color:var(--text)}.menu-sep{height:1px;background:var(--stroke);margin:3px 0}#main{flex:1;display:flex;flex-direction:column;position:relative;min-width:0;overflow-x:hidden}.view{flex:1;display:flex;flex-direction:column}.view.hidden{display:none!important}.view.view-entering{animation:view-enter .35s cubic-bezier(.16,1,.3,1) both}.view.view-exiting{display:flex!important;position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;animation:view-exit .22s ease forwards;z-index:2}@keyframes view-enter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes view-exit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.page-wrap{max-width:900px;margin:0 auto;width:100%;padding:2.5rem var(--pad)}.page-wrap.page-narrow{max-width:560px}.page-wrap.page-wide{max-width:1100px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.page-title{font-family:Fraunces,serif;font-size:clamp(1.8rem,3vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:3px}.page-sub{font-size:15px;color:var(--muted)}.step-head{margin-bottom:2rem}.step-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.step-title{font-family:Fraunces,serif;font-size:clamp(1.5rem,2.5vw,2.1rem);font-weight:700;letter-spacing:-.02em;margin-bottom:5px;line-height:1.2}.step-sub{font-size:15px;color:var(--muted);line-height:1.65}.book-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.25rem}.story-card,.book-card{background:var(--bg2);border:1px solid var(--stroke);border-radius:var(--r-xl);overflow:hidden;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s}.story-card:hover,.book-card:hover{transform:translateY(-4px);border-color:var(--stroke2);box-shadow:0 12px 32px #0000004d}.story-card .thumb,.book-card .thumb{aspect-ratio:3/4;background:var(--bg3);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.story-card .thumb img,.book-card .thumb img{width:100%;height:100%;object-fit:cover}.story-card .card-body,.book-card .card-body{padding:10px 12px}.story-card .card-title,.book-card .card-title{font-size:13px;font-weight:800;line-height:1.35;margin-bottom:2px}.story-card .card-sub,.book-card .card-sub{font-size:12px;color:var(--faint)}.story-card .card-meta,.book-card .card-meta{display:flex;justify-content:space-between;font-size:10px;color:var(--faint);margin-top:5px}.story-card.draft,.book-card.draft{opacity:.7}.new-story-card{background:var(--bg2);border:1.5px dashed var(--stroke2);border-radius:var(--r-xl);aspect-ratio:3/4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s}.new-story-card:hover{border-color:var(--brand);background:#7c5cff0d;transform:translateY(-3px)}.new-story-card-icon{width:40px;height:40px;border-radius:50%;background:#7c5cff26;color:var(--brand-l);display:flex;align-items:center;justify-content:center;font-size:20px}.new-story-card-text{font-size:12px;font-weight:700;color:var(--muted)}.badge{position:absolute;top:6px;left:6px;font-size:9px;font-weight:800;color:#ffffffe6;background:#0009;border-radius:4px;padding:2px 6px;z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.thumb-empty{font-size:13px;color:var(--faint);text-align:center;padding:1rem}.generating-overlay,.queued-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#080c18b8;font-size:12px;color:var(--muted);text-align:center}.spinner{display:block;width:28px;height:28px;min-width:28px;min-height:28px;flex-shrink:0;border:2.5px solid rgba(124,92,255,.25);border-top-color:var(--brand);border-radius:50%;animation:spin .75s linear infinite;box-sizing:border-box}@keyframes spin{to{transform:rotate(360deg)}}.queue-icon{font-size:18px}.list .story-card{display:flex;flex-direction:row}.list .story-card .thumb{width:60px;height:60px;aspect-ratio:unset;flex-shrink:0;border-radius:var(--r-md) 0 0 var(--r-md)}.list .story-card .card-body{display:flex;flex-direction:column;justify-content:center;flex:1}.wiz-form{display:flex;flex-direction:column;gap:1.125rem}.field{display:flex;flex-direction:column;gap:5px}.field-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:end}.field-row.three-col{grid-template-columns:1fr auto auto}.field-sm{min-width:90px;max-width:110px}.field-label{font-size:13px;font-weight:700;color:var(--muted)}.field-opt{font-size:11px;font-weight:600;color:var(--faint);margin-left:4px;text-transform:none}.req{color:var(--brand-l)}.field-hint{font-size:11px;color:var(--faint)}.field-input{width:100%;background:var(--bg2);border:1px solid var(--stroke2);border-radius:var(--r-md);color:var(--text);font-family:var(--sans);font-size:15px;font-weight:600;padding:10px 12px;outline:none;transition:all var(--speed)}.field-input::placeholder{color:var(--faint);font-weight:400}.field-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #7c5cff1f}textarea.field-input{resize:vertical;min-height:70px}select.field-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.input{width:100%;background:var(--bg2);border:1px solid var(--stroke2);border-radius:var(--r-md);color:var(--text);font-family:var(--sans);font-size:14px;padding:10px 12px;outline:none;transition:all var(--speed)}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #7c5cff1f}.label{font-size:12px;font-weight:700;color:var(--muted)}.select,.select-sm{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.select-sm{font-size:13px;padding:7px 10px}.textarea-sm{font-size:13px}.ideas-list{display:flex;flex-direction:column;gap:10px}.idea-card{background:var(--bg2);border:1px solid var(--stroke);border-radius:var(--r-xl);padding:1.25rem 1.5rem;display:flex;align-items:flex-start;gap:1rem;cursor:pointer;transition:all .2s}.idea-card:hover{border-color:var(--brand);background:#7c5cff0a;transform:translate(3px)}.idea-num{width:32px;height:32px;border-radius:var(--r-md);flex-shrink:0;background:#7c5cff1f;color:var(--brand-l);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:900}.idea-title{font-size:16px;font-weight:800;margin-bottom:4px}.idea-desc{font-size:14px;color:var(--muted);line-height:1.6}.idea-arrow{font-size:16px;color:var(--brand-l);opacity:0;transition:opacity .2s;align-self:center;flex-shrink:0}.idea-card:hover .idea-arrow{opacity:1}.idea-genre-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:999px;margin:5px 0 7px}.idea-genre-adventure{background:#fbbf2426;color:#fbbf24}.idea-genre-mystery{background:#7c5cff26;color:#a488ff}.idea-genre-fantasy{background:#f472b626;color:#f472b6}.idea-genre-spooky{background:#34d39926;color:#34d399}.idea-genre-funny{background:#fb923c26;color:#fb923c}.idea-genre-heartwarming{background:#f8717126;color:#f87171}.photo-upload-area{border:2px dashed var(--stroke2);border-radius:var(--r-xl);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;min-height:220px;display:flex;align-items:center;justify-content:center}.photo-upload-area:hover,.photo-upload-area.drag-over{border-color:var(--brand);background:#7c5cff0a}.photo-upload-area.has-photo{border-style:solid;border-color:var(--teal);padding:0}.photo-upload-inner{display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}.photo-upload-icon{font-size:2.5rem}.photo-upload-title{font-size:16px;font-weight:800}.photo-upload-sub{font-size:13px;color:var(--muted)}.photo-preview-img{width:100%;height:100%;object-fit:cover;display:block;border-radius:calc(var(--r-xl) - 2px);max-height:360px}.photo-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.25rem}.photo-tip{font-size:12px;color:var(--faint);text-align:center;margin-top:1rem;line-height:1.5}.editor-pages{display:flex;flex-direction:column;gap:14px}.editor-card{background:var(--bg2);border:1px solid var(--stroke);border-radius:var(--r-lg);padding:1.25rem 1.5rem;display:flex;align-items:flex-start;gap:1.25rem;transition:border-color var(--speed)}.editor-card:focus-within{border-color:var(--stroke2)}.editor-card-main{flex:1;min-width:0}.editor-page-label{font-size:10px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:8px}.editor-textarea{width:100%;background:none;border:none;color:var(--text);font-family:var(--sans);font-size:15px;font-weight:600;line-height:1.7;resize:none;outline:none;padding:0;min-height:60px;overflow:hidden;field-sizing:content}.editor-textarea::placeholder{color:var(--faint);font-weight:400}.editor-card-actions{display:flex;flex-direction:column;gap:5px;flex-shrink:0;padding-top:2px}.editor-action-btn{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--stroke);border-radius:var(--r-sm);color:var(--faint);font-family:var(--sans);font-size:11px;font-weight:700;padding:5px 9px;cursor:pointer;white-space:nowrap;transition:all var(--speed)}.editor-action-btn:hover:not(:disabled){border-color:var(--stroke2);color:var(--muted);background:#ffffff0a}.editor-action-btn:disabled{opacity:.25;cursor:not-allowed}.editor-action-btn.danger:hover:not(:disabled){border-color:#fb718559;color:var(--danger);background:#fb71850f}.editor-action-btn .btn-icon-sm{font-size:12px}.extras-grid{display:flex;flex-direction:column;gap:2rem;margin-top:1.5rem}.extras-section-title{font-size:11px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.85rem}.extras-section-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));gap:1rem}.extra-card{background:var(--bg2);border:1px solid var(--stroke);border-radius:var(--r-xl);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;transition:border-color var(--speed)}.extra-card:hover{border-color:var(--stroke2)}.extra-card-name{font-size:14px;font-weight:800;line-height:1.3}.extra-card-desc{font-size:12px;color:var(--muted);line-height:1.5}.extra-upload-zone{border:1.5px dashed var(--stroke2);border-radius:var(--r-md);padding:1rem;text-align:center;cursor:pointer;transition:all var(--speed);position:relative;overflow:hidden}.extra-upload-zone:hover{border-color:var(--brand);background:#7c5cff0a}.extra-upload-zone.uploaded{border-style:solid;border-color:var(--teal);padding:0}.extra-upload-zone-label{font-size:12px;color:var(--muted)}.extra-upload-preview{width:100%;height:100px;object-fit:contain;display:block;border-radius:calc(var(--r-md) - 1px)}.extra-ai-badge{font-size:11px;color:var(--teal);background:#34d3991a;border:1px solid rgba(52,211,153,.2);border-radius:99px;padding:3px 10px;text-align:center}.extra-ai-badge--confirmed{color:var(--teal);background:#34d39926;border-color:#34d39966;font-weight:700}.extras-note{font-size:13px;color:var(--faint)}.view-splash{background:var(--bg);position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;align-items:center;justify-content:center;animation:none}.view-splash.hidden{display:none!important}.view-splash:not(.hidden){display:flex!important}.splash-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;padding:2rem;max-width:480px;position:relative;z-index:1}.splash-stars{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none}.splash-star{position:absolute;border-radius:50%;animation:splash-twinkle var(--d, 3s) ease-in-out infinite;animation-delay:var(--delay, 0s)}@keyframes splash-twinkle{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.9;transform:scale(1.4)}}.splash-book{font-size:4rem;animation:splash-float 3s ease-in-out infinite}@keyframes splash-float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.splash-title{font-family:Fraunces,serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;letter-spacing:-.02em}.splash-sub{font-size:15px;color:var(--muted);line-height:1.6}.splash-progress{width:240px;height:4px;background:var(--stroke2);border-radius:99px;overflow:hidden}.splash-progress-bar{height:100%;background:linear-gradient(90deg,var(--brand),var(--teal));border-radius:99px;width:0%;transition:width .4s ease}.splash-hint{font-size:13px;color:var(--faint);min-height:18px}@keyframes splash-fade-out{to{opacity:0;transform:scale(1.04)}}.splash-exiting{animation:splash-fade-out .5s ease forwards}.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(185px,45vw),1fr));gap:14px}.pages-grid.list-view{display:flex;flex-direction:column;gap:8px}.page-card{background:var(--bg2);border:1px solid var(--stroke);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s}.page-card:hover{transform:translateY(-3px);border-color:var(--stroke2);box-shadow:0 8px 24px #00000040}.page-card .thumb{aspect-ratio:4/3;min-height:100px;background:var(--bg3);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.page-card .thumb img{width:100%;height:100%;object-fit:cover}.page-card .card-body{padding:8px 12px}.page-card .card-title{font-size:13px;font-weight:800;line-height:1.35;margin-bottom:2px}.page-card .card-sub{font-size:12px;color:var(--faint);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.page-card .card-meta{display:flex;justify-content:space-between;font-size:10px;color:var(--faint);margin-top:5px}.pages-grid.list-view .page-card{display:flex;flex-direction:row}.pages-grid.list-view .page-card .thumb{width:70px;height:70px;aspect-ratio:unset;flex-shrink:0;border-radius:var(--r-md) 0 0 var(--r-md)}.pages-grid.list-view .page-card .card-body{display:flex;flex-direction:column;justify-content:center;flex:1}.filter-pills{display:flex;gap:3px;background:var(--bg2);border:1px solid var(--stroke);border-radius:99px;padding:3px}.pill{font-family:var(--sans);font-size:12px;font-weight:700;color:var(--faint);background:none;border:none;border-radius:99px;padding:4px 12px;cursor:pointer;transition:all var(--speed)}.pill.active{background:var(--bg3);color:var(--text)}.pill:hover:not(.active){color:var(--muted)}.view-btns{display:flex;gap:3px}.view-btn{width:30px;height:30px;font-family:var(--sans);font-size:13px;background:var(--bg2);border:1px solid var(--stroke);border-radius:var(--r-sm);color:var(--faint);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--speed)}.view-btn.active{background:var(--bg3);color:var(--text);border-color:var(--stroke2)}.view-btn:hover:not(.active){color:var(--muted)}.notice-warn{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:10px 14px;border-radius:var(--r-md);background:#fbbf2414;border:1px solid rgba(251,191,36,.2);color:var(--amber);font-size:13px;font-weight:600}.status-msg{font-size:13px;color:var(--muted);min-height:18px;padding:2px 0}.book-ready-banner{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#7c5cff1f,#34d39914);border:1px solid rgba(124,92,255,.25);border-radius:var(--r-lg);padding:14px 18px;margin-bottom:1rem;animation:banner-in .4s cubic-bezier(.16,1,.3,1) both}.book-ready-banner.hidden{display:none}.book-ready-icon{font-size:24px;flex-shrink:0}.book-ready-banner strong{font-size:15px;font-weight:800;color:var(--text);display:block;margin-bottom:2px}.book-ready-banner span{font-size:13px;color:var(--muted)}@keyframes banner-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.new-book-hero-btn{position:relative;width:100%;display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#7c5cff2e,#34d3991a);border:1.5px solid rgba(124,92,255,.35);border-radius:var(--r-xl);padding:1.25rem 1.75rem;cursor:pointer;margin-bottom:1.75rem;overflow:hidden;transition:border-color .2s,transform .2s var(--ease),box-shadow .2s;text-align:left;font-family:var(--sans)}.new-book-hero-btn:hover{border-color:#7c5cffb3;transform:translateY(-2px);box-shadow:0 8px 32px #7c5cff33}.new-book-hero-btn:active{transform:translateY(0)}.new-book-hero-shine{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.07) 50%,transparent 70%);transform:translate(-100%);animation:hero-shine 3s ease-in-out infinite}@keyframes hero-shine{0%{transform:translate(-100%)}40%,to{transform:translate(200%)}}.new-book-hero-icon{width:48px;height:48px;flex-shrink:0;background:linear-gradient(135deg,var(--brand),var(--teal));border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;box-shadow:0 4px 16px #7c5cff66}.new-book-hero-label{font-size:17px;font-weight:800;color:var(--text);display:block;line-height:1.2}.new-book-hero-sub{font-size:13px;font-weight:600;color:var(--muted);display:block;margin-top:2px}#view-dashboard.auth-wall-active .page-head,#view-dashboard.auth-wall-active .new-book-hero-btn,#view-dashboard.auth-wall-active #results{display:none}.dashboard-auth-wall{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:2rem}.daw-inner{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:420px;gap:0}.daw-icon{font-size:3rem;margin-bottom:1.25rem;filter:drop-shadow(0 4px 16px rgba(124,92,255,.3))}.daw-title{font-size:22px;font-weight:800;margin-bottom:.6rem;letter-spacing:-.02em}.daw-sub{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:2rem}.daw-actions{display:flex;flex-direction:column;gap:.75rem;width:100%}.daw-btn{width:100%;justify-content:center;padding:13px 20px;font-size:15px;font-weight:700;border-radius:var(--r-lg)}.daw-btn.btn-ghost{background:var(--bg3);border:1px solid var(--stroke2);color:var(--muted)}.daw-btn.btn-ghost:hover{border-color:var(--stroke2);color:var(--text);background:var(--bg2)}.loader{display:flex;align-items:center;justify-content:center;padding:4rem 2rem;font-size:14px;color:var(--muted);gap:10px;grid-column:1 / -1;width:100%}.btn-primary{font-family:var(--sans);display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--brand);color:#fff;border:none;border-radius:var(--r-lg);font-size:15px;font-weight:800;padding:11px 22px;cursor:pointer;white-space:nowrap;transition:transform var(--speed) var(--ease),box-shadow var(--speed),background var(--speed)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);background:var(--brand-l);box-shadow:0 6px 20px var(--brand-glow)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-primary.btn-lg{font-size:15px;padding:13px 26px;border-radius:var(--r-xl)}.btn-primary.btn-full{width:100%}.btn-secondary{font-family:var(--sans);display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#ffffff12;color:var(--text);border:1px solid var(--stroke2);border-radius:var(--r-lg);font-size:15px;font-weight:700;padding:11px 22px;cursor:pointer;white-space:nowrap;transition:all var(--speed)}.btn-secondary:hover:not(:disabled){background:#ffffff1f}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary.btn-full{width:100%}.btn-ghost{font-family:var(--sans);display:inline-flex;align-items:center;justify-content:center;gap:6px;background:none;color:var(--muted);border:1px solid var(--stroke2);border-radius:var(--r-lg);font-size:15px;font-weight:700;padding:10px 20px;cursor:pointer;white-space:nowrap;transition:all var(--speed)}.btn-ghost:hover:not(:disabled){border-color:var(--brand);color:var(--text);background:#7c5cff0f}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}.btn{font-family:var(--sans);display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;padding:8px 16px;border-radius:var(--r-md);cursor:pointer;border:1px solid transparent;transition:all var(--speed);white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn.btn-primary:hover:not(:disabled){background:var(--brand-l)}.btn.btn-secondary{background:#ffffff12;color:var(--text);border-color:var(--stroke2)}.btn.btn-secondary:hover:not(:disabled){background:#ffffff1f}.btn.btn-ghost{background:none;color:var(--muted);border-color:transparent}.btn.btn-ghost:hover:not(:disabled){color:var(--text);background:#ffffff0d}.btn-full{width:100%}.btn-sm{font-size:11px;padding:5px 10px}.btn-xs{font-size:10px;padding:3px 8px;border-radius:var(--r-sm)}.btn-icon{width:16px;height:16px;flex-shrink:0}.btn-danger-subtle{background:#fb71851a;color:var(--danger);border-color:#fb718540}.btn-danger-subtle:hover{background:#fb718533}.icon-btn-sm{width:26px;height:26px;font-size:11px}.icon-btn-danger{border-color:#fb718540;color:var(--danger)}.icon-btn-danger:hover{background:#fb71851a;border-color:var(--danger)}.badge-inline,.pill-inline,.pill-badge{font-size:10px;font-weight:800;background:#ffffff1f;border-radius:99px;padding:2px 8px}.row-gap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.row-center{display:flex;align-items:center;justify-content:center}.row-between{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{position:relative;z-index:1;background:var(--bg2);border:1px solid var(--stroke2);border-radius:var(--r-xl);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 70px #00000080}.modal-box-sm{max-width:400px}.modal-box-md{max-width:580px}.modal-box-wide{max-width:820px}.modal-dialog,.modal-dialog-sm,.auth-modal-dialog{position:relative;z-index:1;background:var(--bg2);border:1px solid var(--stroke2);border-radius:var(--r-xl);width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 70px #00000080}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--stroke)}.modal-header-left{flex:1}.modal-title{font-size:15px;font-weight:800}.modal-subtitle{font-size:12px;color:var(--muted);margin-top:2px}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--stroke)}.modal-sub{font-size:12px;color:var(--muted);margin-top:2px}.modal-close{background:none;border:none;color:var(--faint);font-size:15px;cursor:pointer;padding:2px;transition:color var(--speed);flex-shrink:0}.modal-close:hover,.modal-close:is(#close-auth-modal):hover{color:var(--text)}#close-auth-modal{background:none;border:none;color:var(--faint);font-size:15px;cursor:pointer;padding:2px;transition:color var(--speed)}.modal-body{padding:1.25rem 1.5rem}.modal-body-col{display:flex;flex-direction:column;gap:1rem}.preview-layout{display:grid;grid-template-columns:1fr 280px;gap:1.25rem;align-items:start}.preview-ctrl-col{display:flex;flex-direction:column;gap:1rem}.ctrl-section{display:flex;flex-direction:column;gap:6px}.ctrl-label{font-size:10px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.08em}.regen-presets{display:flex;flex-wrap:wrap;gap:6px}.regen-preset{font-family:var(--sans);font-size:12px;font-weight:700;color:var(--muted);background:var(--bg3);border:1px solid var(--stroke);border-radius:var(--r-md);padding:7px 11px;cursor:pointer;transition:all var(--speed);text-align:left}.regen-preset:hover:not(:disabled){color:var(--text);border-color:var(--brand);background:#7c5cff14}.regen-preset:disabled{opacity:.4;cursor:not-allowed}.revision-thumbs-container{display:flex;gap:6px;flex-wrap:wrap}.revision-thumb{width:54px;height:54px;border-radius:var(--r-sm);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color var(--speed)}.revision-thumb.active{border-color:var(--brand)}.revision-thumb img{width:100%;height:100%;object-fit:cover}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:700;color:var(--muted)}.auth-error{font-size:13px;color:var(--danger);padding:8px 10px;background:#fb718514;border:1px solid rgba(251,113,133,.2);border-radius:var(--r-sm)}.auth-success{font-size:13px;color:var(--teal);padding:8px 10px;background:#34d39914;border:1px solid rgba(52,211,153,.2);border-radius:var(--r-sm)}.auth-footer{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--muted)}.btn-link{background:none;border:none;color:var(--brand-l);font-family:var(--sans);font-size:13px;font-weight:700;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.auth-divider{color:var(--faint)}.password-strength{font-size:12px}.strength-good{color:var(--teal)}.strength-weak{color:var(--amber)}.order-detail-box{background:var(--bg3);border:1px solid var(--stroke);border-radius:var(--r-lg);padding:1rem;width:100%}.order-detail-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;font-size:13px}.order-detail-row+.order-detail-row{border-top:1px solid var(--stroke)}.status-pill{background:#34d3991a;color:var(--teal);border:1px solid rgba(52,211,153,.2);border-radius:99px;padding:2px 10px;font-size:11px;font-weight:700}.queue-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--stroke);font-size:12px;cursor:pointer;transition:background var(--speed)}.queue-item:hover{background:#ffffff0a}.queue-item-thumb{width:36px;height:36px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0;background:var(--bg3)}.queue-item-thumb img{width:100%;height:100%;object-fit:cover}.queue-item-info{flex:1;min-width:0}.queue-item-title{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-item-sub{color:var(--faint);font-size:11px}.history-list{max-height:440px;overflow-y:auto}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:400;display:flex;flex-direction:column;gap:7px;pointer-events:none}.toast{background:var(--bg2);border:1px solid var(--stroke2);border-radius:var(--r-lg);padding:11px 15px;min-width:220px;max-width:320px;box-shadow:0 12px 32px #0006;pointer-events:auto;animation:toast-in .25s ease}@keyframes toast-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}.toast-title{font-size:14px;font-weight:800}.toast-msg{font-size:13px;color:var(--muted);margin-top:1px}.toast.success .toast-title{color:var(--teal)}.toast.error .toast-title{color:var(--danger)}.toast.warn .toast-title{color:var(--amber)}@media (max-width: 860px){.step-bar{display:none}.preview-layout{grid-template-columns:1fr}.book-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 580px){.account-name,.chev{display:none}.field-row,.field-row.three-col{grid-template-columns:1fr}.field-sm{max-width:100%;min-width:0}.step-head-row{flex-direction:column}.step-head-row .row-gap{width:100%}.book-grid,.grid{grid-template-columns:repeat(2,1fr)}.pages-grid{grid-template-columns:repeat(2,1fr);gap:10px}.extras-section-grid{grid-template-columns:1fr}.page-wrap{padding:1.5rem 1rem}.preview-layout{grid-template-columns:1fr}.editor-card{flex-direction:column}.editor-card-actions{display:flex;flex-wrap:wrap;gap:6px}.modal{padding:.75rem;align-items:flex-end}.auth-modal-dialog{max-height:92vh;border-bottom-left-radius:var(--r-lg);border-bottom-right-radius:var(--r-lg)}.modal-header{padding:1rem 1.25rem}.modal-title{font-size:16px}.modal-subtitle{font-size:13px}.modal-body{padding:1rem 1.25rem 1.5rem}.auth-form{gap:.85rem}.form-group label{font-size:13px}.input{font-size:16px;padding:12px}.field-input,.editor-textarea,select.field-input,textarea.field-input{font-size:16px}.auth-switch{font-size:13px;text-align:center;margin-top:.25rem}.btn.btn-primary.btn-full{padding:14px;font-size:15px}}.finalize-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#080c18eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center}.finalize-inner{display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center;padding:2rem;max-width:400px;width:100%}.finalize-icon{font-size:2.5rem;animation:finalize-pulse 2s ease-in-out infinite}@keyframes finalize-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:.8}}.finalize-title{font-family:Fraunces,serif;font-size:1.6rem;font-weight:700;letter-spacing:-.02em}.finalize-sub{font-size:14px;color:var(--muted)}.finalize-stages{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:.5rem}.finalize-stage{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg2);border:1px solid var(--stroke);border-radius:var(--r-md);font-size:14px;color:var(--faint);transition:border-color .3s,color .3s,background .3s}.finalize-stage.active{border-color:#7c5cff59;color:var(--text);background:#7c5cff0f}.finalize-stage.done{border-color:#34d3994d;color:var(--teal);background:#34d3990d}.fstage-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--stroke2);transition:background .3s}.finalize-stage.active .fstage-dot{background:var(--brand);animation:fstage-spin .8s linear infinite;border-radius:0;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}.finalize-stage.done .fstage-dot{background:var(--teal);clip-path:polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0%,43% 62%);border-radius:0;animation:none}@keyframes fstage-spin{to{transform:rotate(360deg)}}.preview-wrap{display:flex;flex-direction:column;gap:3rem;padding-bottom:4rem}.preview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.book-stage{display:flex;justify-content:center;align-items:center;padding:3rem 0 2rem;width:100%;perspective:1800px;perspective-origin:center 40%}.flipbook-bob{--page-w: clamp(140px, 42vw, 340px);--page-h: var(--page-w);position:relative;width:calc(var(--page-w) * 2);height:var(--page-h);transform-style:preserve-3d;transform:rotateX(6deg) rotateY(-12deg);transition:transform .6s cubic-bezier(.4,0,.2,1);animation:book-float-slow 12s ease-in-out infinite}.flipbook-bob:before{content:"";position:absolute;left:5%;right:5%;bottom:-30px;height:50px;background:radial-gradient(ellipse at center,#00000073,#00000040,#0000 70%);filter:blur(6px);pointer-events:none;z-index:-1}.book-thickness{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;transform-style:preserve-3d}.thickness-side{position:absolute;top:0;bottom:0;transform-style:preserve-3d}.thickness-right{left:50%;right:0}.thickness-left{left:0;right:50%}.depth-layer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#f4efe5,#ece7dc,#e4dfd4);border-radius:2px;opacity:0;transform:translateZ(0);transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1)}.thickness-right .depth-layer.visible:nth-child(1){opacity:1;transform:translate3d(2px,2px,-3px)}.thickness-right .depth-layer.visible:nth-child(2){opacity:1;transform:translate3d(4px,4px,-6px);background:linear-gradient(to bottom,#efeade,#e6e0d2,#ddd6c6)}.thickness-right .depth-layer.visible:nth-child(3){opacity:1;transform:translate3d(6px,6px,-9px);background:linear-gradient(to bottom,#e9e3d6,#ddd6c8,#d0c7b4)}.thickness-right .depth-layer.visible:nth-child(4){opacity:1;transform:translate3d(8px,8px,-12px);background:linear-gradient(to bottom,#e3dcce,#d2cab8,#c1b8a0)}.thickness-left .depth-layer.visible:nth-child(1){opacity:1;transform:translate3d(2px,2px,-3px)}.thickness-left .depth-layer.visible:nth-child(2){opacity:1;transform:translate3d(4px,4px,-6px);background:linear-gradient(to bottom,#efeade,#e6e0d2,#ddd6c6)}.thickness-left .depth-layer.visible:nth-child(3){opacity:1;transform:translate3d(6px,6px,-9px);background:linear-gradient(to bottom,#e9e3d6,#ddd6c8,#d0c7b4)}.thickness-left .depth-layer.visible:nth-child(4){opacity:1;transform:translate3d(8px,8px,-12px);background:linear-gradient(to bottom,#e3dcce,#d2cab8,#c1b8a0)}.book-spine{position:absolute;top:0;bottom:0;left:50%;width:14px;transform:translate(-50%) translateZ(-7px);background:linear-gradient(90deg,#140f0abf,#32261a8c,#140f0abf);box-shadow:inset 1px 0 #ffffff0d,inset -1px 0 #ffffff0d;border-radius:1px;opacity:0;transition:opacity .45s ease;pointer-events:none}.flipbook-bob[data-book-state=closed-front] .book-spine,.flipbook-bob[data-book-state=closed-back] .book-spine{opacity:1}.back-cover-overlay{display:none}.flipbook-bob[data-book-state=closed-front]{transform:translate(calc(var(--page-w) * -.5)) rotateX(6deg) rotateY(-12deg)}.flipbook-bob[data-book-state=closed-back]{transform:translate(calc(var(--page-w) * .5)) rotateX(6deg) rotateY(-12deg)}.flipbook{position:absolute;top:0;right:0;bottom:0;left:0}@keyframes book-float-slow{0%,to{translate:0 0}50%{translate:0 -10px}}.pf-page.is-cover{background-color:#1a1510}.pf-page.is-blank{background:#faf7f2}.pf-page.is-image{background-color:var(--bg3)}.pf-full-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.pf-page.is-title-page{background:#faf7f2;display:flex;align-items:center;justify-content:center;padding:8%;text-align:center}.pf-page.is-title-page>h3{font-family:Fraunces,serif;font-size:clamp(16px,2.8vw,28px);font-weight:700;color:#1a1510;margin:0;line-height:1.2}.pf-page.is-text{background:#faf7f2;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:7.14%}.pf-page.is-text>p{font-family:"Nunito",var(--sans);font-weight:700;line-height:1.5;color:#1a1510;margin:0}.face-page-num{position:absolute;bottom:6%;left:50%;transform:translate(-50%);font-size:clamp(9px,1.6vw,11px);font-weight:800;color:#00000040;text-transform:uppercase;letter-spacing:.1em}.face-cover-overlay{position:absolute;left:0;right:0;bottom:0;padding:22px 14px 14px;background:linear-gradient(to top,rgba(0,0,0,.72),transparent);display:flex;align-items:flex-end;justify-content:center}.face-cover-title{font-family:"Nunito",var(--sans);font-size:clamp(13px,1.8vw,17px);font-weight:800;color:#fff;text-align:center;line-height:1.3;text-shadow:0 1px 4px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.4);word-break:break-word}.pf-page.is-back-cover{background:#fdfbf6}.pf-page{position:relative;width:100%;height:100%;overflow:hidden;box-sizing:border-box}.face-back-synopsis-block{position:absolute;top:18%;left:8%;right:8%;bottom:28%;display:flex;align-items:center;justify-content:center}.face-synopsis{font-family:"Nunito",var(--sans);font-size:clamp(10px,1.55vw,14px);font-weight:700;line-height:1.55;color:#211c19;text-align:center;margin:0}.face-back-footer{position:absolute;left:0;right:0;bottom:4%;display:flex;flex-direction:column;align-items:center;gap:2px}.face-back-rule{width:18%;height:1px;background:#7c5cff66;margin-bottom:7px}.face-brand{font-family:"Nunito",var(--sans);font-size:clamp(11px,1.6vw,15px);font-weight:800;color:#7c5cffcc;margin:0;letter-spacing:.01em}.face-tagline{font-family:"Nunito",var(--sans);font-size:clamp(8px,1.05vw,11px);font-weight:500;color:#8c857a;margin:0;text-align:center}.flipbook-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:0 0 1rem}.flipper-label{font-size:13px;font-weight:700;color:var(--muted);min-width:120px;text-align:center}.flipper-btn{min-width:48px;height:40px;padding:0 14px;background:var(--bg2);border:1px solid var(--stroke2);border-radius:var(--r-md);color:var(--text);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--speed)}.flipper-btn:hover:not(:disabled){background:var(--bg3);border-color:var(--brand);color:var(--brand)}.flipper-btn:disabled{opacity:.3;cursor:not-allowed}.preview-disclaimer{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--muted);background:#ffffff08;border:1px solid var(--stroke);border-radius:var(--r-md);padding:10px 14px;margin-bottom:1rem;line-height:1.5}.preview-disclaimer-icon{flex-shrink:0;opacity:.6;font-style:normal}.regen-count{font-size:10px;font-weight:600;color:var(--faint);margin-left:4px}.preview-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--stroke)}.cart-wrap{position:relative}.cart-drawer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;justify-content:flex-end}.cart-drawer.hidden{display:none}.cart-drawer-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073}.cart-drawer-panel{position:relative;z-index:1;width:360px;max-width:100vw;background:var(--bg);display:flex;flex-direction:column;box-shadow:-4px 0 32px #0000004d}.cart-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--stroke)}.cart-drawer-header h3{font-size:1.1rem;font-weight:700;margin:0}.cart-drawer-body{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.cart-empty-msg{color:var(--muted);font-size:14px;text-align:center;margin-top:2rem}.cart-drawer-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;border-radius:var(--r-md);background:var(--bg2);border:1px solid var(--stroke)}.cart-drawer-item-info{flex:1;min-width:0}.cart-drawer-item-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-drawer-item-sub{font-size:12px;color:var(--muted);margin-top:2px}.cart-drawer-item-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.cart-drawer-item-price{font-size:14px;font-weight:700}.cart-drawer-remove{background:none;border:none;cursor:pointer;color:var(--muted);font-size:12px;padding:2px 4px;border-radius:4px;line-height:1;transition:color var(--speed)}.cart-drawer-remove:hover{color:var(--danger, #ef4444)}.cart-drawer-footer{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--stroke);display:flex;flex-direction:column;gap:.75rem}.cart-drawer-total{display:flex;justify-content:space-between;font-weight:700;font-size:15px}.btn-full{width:100%;justify-content:center}.pcm-option{display:block;cursor:pointer;border-radius:var(--r-md);border:2px solid var(--stroke);overflow:hidden;transition:border-color var(--speed)}.pcm-option:has(.pcm-checkbox:checked){border-color:var(--brand)}.pcm-checkbox{position:absolute;opacity:0;width:0;height:0}.pcm-option-inner{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem}.pcm-option-icon{color:var(--muted);flex-shrink:0}.pcm-option:has(.pcm-checkbox:checked) .pcm-option-icon{color:var(--brand)}.pcm-option-info{flex:1}.pcm-option-title{font-size:15px;font-weight:600}.pcm-option-desc{font-size:12px;color:var(--muted);margin-top:2px}.pcm-option-price{font-size:15px;font-weight:700;flex-shrink:0}.pcm-note-section{display:flex;flex-direction:column;gap:6px}.pcm-note-label{font-size:13px;font-weight:600;color:var(--text)}.pcm-note-hint{font-size:11px;font-weight:400;color:var(--muted);margin-left:4px}.pcm-note-input{width:100%;resize:vertical;padding:.65rem .8rem;font-family:inherit;font-size:13px;line-height:1.4;background:var(--bg2);border:2px solid var(--stroke);border-radius:var(--r-md);color:var(--text);transition:border-color var(--speed);box-sizing:border-box}.pcm-note-input:focus{outline:none;border-color:var(--brand)}.pcm-note-counter{font-size:11px;color:var(--muted);text-align:right}.ebook-download-btn{display:inline-flex;align-items:center;gap:4px;margin-top:6px;padding:4px 10px;background:var(--brand, #7c5cff);color:#fff;border:none;border-radius:var(--r-sm, 6px);font-size:11px;font-weight:700;cursor:pointer;transition:opacity var(--speed)}.ebook-download-btn:hover{opacity:.85}.ebook-download-btn:disabled{opacity:.5;cursor:not-allowed}
