@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,500;0,600;1,400&family=Playfair+Display:ital,wght@0,400;0,600;1,400&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--linen: #f5efe6;--parchment: #e8dfd0;--clay: #c1694f;--clay-deep: #a85a42;--ink: #2c2c2c;--ink-soft: #3a3a3a;--stone: #888888;--stone-light: #b5ab98;--cream: #fdfaf7;--ivory: #ffffff;--blush: #e8d5c4;--sage: #8a9a7e;--error: #c0503b;--font-serif: "Cormorant Garamond", "Georgia", serif;--font-sans: "DM Sans", -apple-system, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 40px;--space-2xl: 64px;--radius-sm: 0px;--radius-md: 0px;--radius-lg: 0px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1)}[data-theme=white]{--linen: #ffffff;--parchment: #d8d5cf;--clay: #000000;--clay-deep: #2a2a2a;--ink: #1a1a1a;--ink-soft: #2a2a2a;--stone: #757575;--stone-light: #b0ada8;--cream: #f4f2ed;--ivory: #ffffff;--blush: #ededed}html{background:var(--linen);color:var(--ink);font-family:var(--font-sans);font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.5}body{min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px}::selection{background:var(--clay);color:var(--cream)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--stone-light);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--stone)}h1,h2,h3{font-family:var(--font-serif);font-weight:400;letter-spacing:-.01em;color:var(--ink)}a{color:var(--clay);text-decoration:none;transition:color .2s var(--ease-out)}a:hover{color:var(--clay-deep)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 22px;font-family:var(--font-sans);font-size:13px;font-weight:500;letter-spacing:.02em;border:none;border-radius:9999px;cursor:pointer;transition:all .2s var(--ease-out);position:relative;overflow:hidden}.btn-primary{background:var(--clay);color:var(--cream)}.btn-primary:hover{background:var(--clay-deep);transform:translateY(-1px);box-shadow:0 4px 12px #c1694f38}.btn-primary:active{transform:translateY(0)}.btn-warm{background:var(--clay);color:#fff}.btn-warm:hover{background:var(--clay-deep);transform:translateY(-1px);box-shadow:0 4px 16px #c4956a4d}.btn-ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--parchment)}.btn-ghost:hover{border-color:var(--stone-light);background:var(--cream)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}.input{width:100%;padding:14px 16px;font-family:var(--font-sans);font-size:15px;color:var(--ink);background:var(--ivory);border:1.5px solid var(--parchment);border-radius:var(--radius-md);outline:none;transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out)}.input:focus{border-color:var(--clay);box-shadow:0 0 0 3px #c4956a1f}.input::placeholder{color:var(--stone-light)}.card{background:var(--ivory);border:1px solid var(--parchment);border-radius:var(--radius-md);transition:all .25s var(--ease-out)}.card:hover{border-color:var(--stone-light);box-shadow:0 2px 12px #1e1b180f}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px);box-shadow:0 8px 24px #1e1b1814}.badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:11px;font-weight:500;letter-spacing:.03em;border-radius:20px}.badge-draft{background:var(--parchment);color:var(--stone)}.badge-ready{background:#fef3e2;color:#c07a1a}.badge-ordered{background:#e8f0e4;color:var(--sage)}.page-shell{max-width:720px;margin:0 auto;padding:var(--space-xl) var(--space-lg);animation:fadeUp .5s var(--ease-out)}.page-shell-fit{height:100svh;max-height:100svh;padding-top:var(--space-lg);padding-bottom:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}@supports not (height: 100svh){.page-shell-fit{height:100vh;max-height:100vh}}.page-shell-with-nav{height:100svh;max-height:100svh;display:flex;flex-direction:column}@supports not (height: 100svh){.page-shell-with-nav{height:100vh;max-height:100vh}}.page-shell-nested{height:auto;max-height:none;flex:1 1 auto;min-height:0;width:100%;padding-top:var(--space-md)}.page-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;scrollbar-gutter:stable}.page-shell-fit .upload-header{margin-bottom:0}.page-shell-fit .upload-generate-bar{margin-top:0;padding-top:var(--space-md)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg)}.login-card{width:100%;max-width:380px;text-align:center;animation:fadeUp .6s var(--ease-out)}.login-brand{font-family:var(--font-serif);font-size:32px;font-weight:300;letter-spacing:-.02em;margin-bottom:6px;color:var(--ink)}.login-subtitle{font-size:14px;color:var(--stone);margin-bottom:var(--space-xl)}.login-divider{width:32px;height:1px;background:var(--parchment);margin:0 auto var(--space-lg)}.login-form{display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--parchment)}.dashboard-title{font-size:28px;font-weight:300}.dashboard-email{font-size:13px;color:var(--stone);margin-top:4px}.dashboard-actions{display:flex;gap:var(--space-sm)}.project-list{display:flex;flex-direction:column;gap:var(--space-sm)}.project-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg)}.project-title{font-family:var(--font-serif);font-size:17px;font-weight:500}.project-meta{font-size:12px;color:var(--stone);margin-top:3px}.page-shell-library{max-width:1040px}.bookshelf{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:44px var(--space-lg);padding-top:var(--space-md)}.bookshelf-slot{display:flex;flex-direction:column;align-items:stretch;min-width:0}.bookshelf-book{position:relative;width:100%;border:none;padding:0;cursor:pointer;overflow:hidden;font-family:var(--font-serif);transition:transform .28s var(--ease-out),box-shadow .28s var(--ease-out);box-shadow:1px 0 #00000014,2px 3px 6px #0000002e,4px 10px 22px #00000029,0 22px 18px -14px #00000059;z-index:1}.bookshelf-book:hover{transform:translateY(-4px);box-shadow:1px 0 #0000001a,3px 5px 10px #0003,6px 14px 28px #0003,0 28px 22px -16px #0006}.bookshelf-book:focus-visible{outline:2px solid var(--clay);outline-offset:4px}.bookshelf-spine{position:absolute;top:0;bottom:0;left:0;width:14px;background:linear-gradient(90deg,#00000047,#0000002e 30%,#ffffff14,#0000001f 80%,#00000005);pointer-events:none}.bookshelf-cover-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.bookshelf-book.has-cover .bookshelf-sheen{background:linear-gradient(180deg,#0000 40%,#00000080),linear-gradient(90deg,rgba(0,0,0,.15) 0%,transparent 30%)}.bookshelf-book.has-cover .bookshelf-title{color:#fff;top:68%;right:10%;bottom:10%;left:14%;text-align:center;justify-content:center;align-items:flex-start;text-shadow:0 2px 6px rgba(0,0,0,.55),0 1px 2px rgba(0,0,0,.4)}.bookshelf-book.has-cover.title-top .bookshelf-title{top:12%;right:10%;bottom:68%;left:14%}.bookshelf-book.has-cover.title-top .bookshelf-sheen{background:linear-gradient(0deg,#0000 40%,#00000080),linear-gradient(90deg,rgba(0,0,0,.15) 0%,transparent 30%)}.bookshelf-sheen{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 14%),linear-gradient(0deg,rgba(0,0,0,.08) 0%,transparent 10%);pointer-events:none}.bookshelf-title{position:absolute;top:18%;right:14%;bottom:18%;left:22%;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--font-serif);font-weight:500;font-size:clamp(15px,1.6vw,20px);line-height:1.18;letter-spacing:-.005em;word-break:break-word;text-wrap:balance;z-index:2}.bookshelf-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 2px 0;margin-top:8px;border-top:1px solid var(--parchment);min-height:34px}.bookshelf-eyebrow{font-family:var(--font-sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:520px){.bookshelf{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:36px 14px}.bookshelf-title{font-size:14px;top:16%;right:12%;bottom:16%;left:20%}}.project-actions{display:flex;align-items:center;gap:var(--space-sm)}.project-menu-wrap{position:relative}.project-menu-trigger{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--stone);cursor:pointer;border-radius:8px;transition:background .12s ease,color .12s ease}.project-menu-trigger:hover{background:color-mix(in srgb,var(--ink) 6%,transparent);color:var(--ink)}.project-menu-trigger[aria-expanded=true]{background:color-mix(in srgb,var(--ink) 8%,transparent);color:var(--ink)}.project-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;background:var(--ivory);border:1px solid var(--parchment);border-radius:var(--radius-md);box-shadow:0 12px 28px #00000024;padding:6px;display:flex;flex-direction:column;gap:2px;z-index:20;animation:fadeUp .12s var(--ease-out)}.project-menu button{text-align:left;background:transparent;border:none;font-family:var(--font-sans);font-size:14px;color:var(--ink);padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .12s ease}.project-menu button:hover{background:color-mix(in srgb,var(--clay) 8%,var(--cream))}.project-menu button.project-menu-danger{color:var(--error)}.project-menu button.project-menu-danger:hover{background:#c0503b14}.btn-danger{background:var(--error);color:var(--cream)}.btn-danger:hover{background:#a74636;transform:translateY(-1px);box-shadow:0 4px 12px #c0503b40}.btn-danger:active{transform:translateY(0)}.empty-state{text-align:center;padding:var(--space-2xl) 0}.empty-state-title{font-family:var(--font-serif);font-size:28px;font-weight:400;color:var(--ink);margin-bottom:var(--space-sm)}.empty-state-text{font-size:15px;color:var(--stone);margin-bottom:var(--space-md)}.dashboard-search{display:flex;align-items:center;gap:8px;background:var(--ivory);border:1px solid var(--parchment);border-radius:var(--radius-md);padding:8px 12px;margin-bottom:var(--space-md);color:var(--stone);transition:border-color .15s ease}.dashboard-search:focus-within{border-color:var(--stone-light)}.dashboard-search-input{flex:1;border:none;background:transparent;outline:none;font-family:var(--font-sans);font-size:14px;color:var(--ink)}.dashboard-search-input::placeholder{color:var(--stone-light)}.upload-header{margin-bottom:var(--space-lg)}.upload-title{font-size:28px;font-weight:300;margin-bottom:4px}.upload-count{font-size:14px;color:var(--stone)}.upload-dropzone{border:2px dashed var(--parchment);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);text-align:center;cursor:pointer;transition:all .25s var(--ease-out);background:var(--cream);position:relative;overflow:hidden}.upload-dropzone.upload-dropzone-compact{padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:center;gap:10px}.upload-dropzone-compact .upload-dropzone-icon{width:20px;height:20px;margin:0}.upload-dropzone-compact .upload-dropzone-text{font-size:13px;font-weight:500;color:var(--stone)}.upload-dropzone:hover{border-color:var(--stone-light);background:var(--ivory)}.upload-dropzone.drag-over{border-color:var(--clay);background:#c4956a0a;transform:scale(1.005)}.upload-dropzone-icon{width:48px;height:48px;margin:0 auto var(--space-md);color:var(--stone-light)}.upload-dropzone-text{font-size:15px;color:var(--stone)}.upload-dropzone-hint{font-size:12px;color:var(--stone-light);margin-top:var(--space-xs)}.upload-progress{font-family:var(--font-sans);font-size:14px;color:var(--clay);font-weight:500}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px;margin-top:var(--space-lg)}.photo-grid-item{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--parchment);position:relative}.photo-grid-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s var(--ease-out)}.photo-grid-item:hover img{transform:scale(1.05)}.upload-generate-bar{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--parchment)}.variant-picker{animation:fadeUp .5s var(--ease-out)}.variant-picker-title{font-size:32px;font-weight:300;margin-bottom:var(--space-sm)}.variant-picker-subtitle{color:var(--stone);font-size:15px;margin-bottom:var(--space-xl)}.variant-card{padding:var(--space-lg)}.variant-card:hover{border-color:var(--clay)}.variant-card-title{font-family:var(--font-serif);font-size:20px;font-weight:400;margin-bottom:4px}.variant-card-desc{font-size:14px;color:var(--stone);margin-bottom:4px}.variant-card-meta{font-size:12px;color:var(--stone-light)}.editor-root{font-family:var(--font-sans)!important;color:var(--ink)!important}.editor-navbar{background:var(--cream)!important;border-bottom-color:var(--parchment)!important}.editor-navbar-left a{color:var(--stone)!important}.editor-navbar-left a:hover{color:var(--ink)!important}.editor-navbar-title{font-family:var(--font-serif)!important}.editor-canvas{background:var(--linen)!important}.editor-sidebar{background:var(--cream)!important;border-right-color:var(--parchment)!important}.editor-bottom-bar{background:var(--cream)!important;border-top-color:var(--parchment)!important}.editor-btn-primary{background:var(--clay)!important}.editor-btn-primary:hover{background:var(--clay-deep)!important}.spread-thumbnail.active{border-color:var(--clay)!important;background:#c4956a1a!important}.bottom-bar-btn:hover,.bottom-bar-btn.active{color:var(--clay)!important;background:#c4956a14!important}.layout-popup-item.active{border-color:var(--clay)!important}.editor-loading{background:var(--linen)!important}.editor-spinner{border-color:var(--parchment)!important;border-top-color:var(--clay)!important}.editor-loading-text{font-family:var(--font-serif)!important;font-size:16px!important;font-weight:300!important;color:var(--stone)!important}.generating-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--linen);padding:24px;text-align:center}.generating-phrase{font-family:var(--font-display, Georgia, serif);font-size:24px;color:var(--ink);max-width:520px;line-height:1.4;margin:0;transition:opacity .45s ease-in-out;will-change:opacity}@media(min-width:768px){.generating-phrase{font-size:32px}}.generating-dots{display:flex;gap:10px;margin-top:32px}.generating-dot{width:7px;height:7px;border-radius:50%;background:var(--stone-light);opacity:.35;transition:opacity .3s ease,background .3s ease,transform .3s ease}.generating-dot.is-on{background:var(--clay);opacity:1;transform:scale(1.1)}.generating-cancel{margin-top:28px;background:transparent;border:none;color:var(--stone);font-family:var(--font-sans);font-size:13px;cursor:pointer;padding:6px 10px;text-decoration:underline;text-underline-offset:3px;opacity:.7;transition:opacity .15s ease}.generating-cancel:hover{opacity:1}.preview-shell{height:100svh;max-height:100svh;overflow:hidden;background:var(--linen);color:var(--ink);padding:0 0 16px;display:flex;flex-direction:column;align-items:stretch;gap:12px}@supports not (height: 100svh){.preview-shell{height:100vh;max-height:100vh}}.preview-loading-text{margin:auto;font-family:var(--font-display, Georgia, serif);font-size:18px;color:var(--ink-soft)}.preview-loading-spinner{margin:auto;width:28px;height:28px;border:2px solid var(--parchment);border-top-color:var(--clay);border-radius:50%;animation:editor-spin .9s ease-in-out infinite}.preview-book-wrap{flex:1 1 auto;min-height:0;display:flex;align-items:flex-start;justify-content:center;padding:24px 56px 0}.preview-footer{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;padding:0 24px}.preview-tagline{font-family:var(--font-display, Georgia, serif);font-size:19px;font-style:italic;color:var(--ink-soft);margin:0;text-align:center}.preview-meta{font-size:13px;color:var(--stone, #888);letter-spacing:.02em;margin:0;text-align:center}.preview-cta-row{display:flex;flex-direction:column;align-items:center;gap:6px}.preview-price-caption{font-size:11px;color:var(--stone);letter-spacing:.02em;margin:2px 0 0;text-align:center}.preview-gift-note{color:var(--stone-light);font-size:12px}.btn-order-primary{background:var(--clay, #c1694f);color:#fff;font-family:var(--font-sans, sans-serif);font-size:15px;font-weight:600;padding:13px 28px;border:none;border-radius:999px;cursor:pointer;box-shadow:0 8px 24px #c1694f52;transition:transform .15s ease,box-shadow .15s ease;min-width:260px}.btn-order-primary:hover{transform:translateY(-1px);box-shadow:0 14px 36px #c1694f6b}.btn-preview-adjust{background:transparent;border:none;color:var(--stone, #888);font-family:var(--font-sans, sans-serif);font-size:13px;cursor:pointer;padding:4px 8px;text-decoration:underline;text-underline-offset:3px;opacity:.75}.btn-preview-adjust:hover{opacity:1}.btn-preview-flip-hint{background:transparent;border:1px solid var(--parchment, #ddd);color:var(--ink-soft);font-family:var(--font-sans, sans-serif);font-size:12px;padding:8px 16px;border-radius:999px;cursor:pointer;margin-top:4px}.preview-flipping{width:100%;display:flex;flex-direction:column;align-items:center;gap:24px}.btn-preview-back{align-self:flex-start;background:transparent;border:none;color:var(--ink-soft);font-family:var(--font-sans, sans-serif);font-size:14px;cursor:pointer;padding:6px 10px}.book-flipper{display:flex;flex-direction:column;align-items:center;gap:20px}.book-flipper-frame{filter:drop-shadow(0 20px 32px rgba(0,0,0,.15));background:#fff}.book-flipper-edge{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:none;background:#ffffffe6;box-shadow:0 4px 16px #00000026;font-size:28px;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.book-flipper-edge-left{left:-24px}.book-flipper-edge-right{right:-24px}.chapter-indicator{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:8px}.chapter-indicator-text{font-family:var(--font-sans, sans-serif);font-size:13px;color:var(--ink-soft);margin:0;text-align:center}.chapter-indicator-pos{letter-spacing:.04em;text-transform:uppercase;font-size:11px;color:var(--stone, #888)}.chapter-indicator-sep{color:var(--stone, #888)}.chapter-indicator-title{font-family:var(--font-display, Georgia, serif);font-style:italic}.chapter-indicator-dots{display:flex;gap:8px}.chapter-indicator-dot{width:7px;height:7px;border-radius:50%;background:var(--stone, #bbb);opacity:.35;transition:opacity .2s ease,transform .2s ease}.chapter-indicator-dot.is-active{opacity:1;background:var(--clay, #c1694f);transform:scale(1.2)}@media(max-width:640px){.preview-shell{padding:0 0 12px;gap:10px}.preview-book-wrap{padding:16px 22px 0}.preview-footer{padding:0 12px}.preview-tagline{font-size:16px}.preview-meta{font-size:12px}.btn-order-primary{min-width:0;width:100%;font-size:14px;padding:12px 18px}.book-flipper-edge-left{left:-10px}.book-flipper-edge-right{right:-10px}.book-flipper-edge{width:40px;height:40px;font-size:22px}}.confirmation-page{height:100svh;max-height:100svh;overflow:hidden;background:var(--linen);display:flex;flex-direction:column}@supports not (height: 100svh){.confirmation-page{height:100vh;max-height:100vh}}.confirmation-shell{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center;padding:24px}.confirmation-card{max-width:480px;text-align:center;display:flex;flex-direction:column;gap:24px}.confirmation-headline{font-family:var(--font-display, Georgia, serif);font-size:36px;font-weight:500;color:var(--ink);margin:0;line-height:1.2}.confirmation-body{font-family:var(--font-sans, sans-serif);font-size:16px;color:var(--ink-soft);margin:0;line-height:1.5}.confirmation-gift-note{font-family:var(--font-display, Georgia, serif);font-style:italic;font-size:14px;color:var(--stone, #888);margin:0}.confirmation-back-link{margin-top:12px;background:transparent;border:none;color:var(--ink-soft);font-family:var(--font-sans, sans-serif);font-size:13px;cursor:pointer;padding:8px 12px;align-self:center;text-decoration:underline;text-underline-offset:3px;opacity:.75}.confirmation-back-link:hover{opacity:1}.preview-gift-check{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-sans, sans-serif);font-size:13px;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none;margin-top:-4px}.preview-gift-check input{width:16px;height:16px;accent-color:var(--clay, #c1694f);cursor:pointer}.preview-order-error{color:var(--ink-soft);font-family:var(--font-display, Georgia, serif);font-style:italic;font-size:13px;margin:4px 0 0}.theme-toggle{position:fixed;bottom:14px;left:16px;z-index:40;display:inline-flex;align-items:center;gap:2px;padding:4px;background:color-mix(in srgb,var(--cream) 94%,transparent);border:1px solid var(--parchment);border-radius:999px;cursor:pointer;-webkit-backdrop-filter:saturate(1.2) blur(8px);backdrop-filter:saturate(1.2) blur(8px);transition:border-color .2s var(--ease-out),background .2s var(--ease-out);box-shadow:0 4px 12px #00000014}.theme-toggle:hover{border-color:var(--stone-light)}.theme-toggle-btn{width:20px;height:20px;border-radius:50%;border:1px solid var(--parchment);cursor:pointer;padding:0;background:transparent;box-shadow:inset 0 0 0 0 var(--ink);transition:box-shadow .2s var(--ease-out),transform .2s var(--ease-out)}.theme-toggle-btn:hover{transform:scale(1.08)}.theme-toggle-btn.is-active{box-shadow:inset 0 0 0 2px var(--ink)}.theme-toggle-btn-linen{background:#f5efe6}.theme-toggle-btn-white{background:#fff}.error-boundary{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px 24px;text-align:center;background:var(--linen)}.error-boundary-title{font-family:var(--font-serif);font-size:32px;font-weight:500;color:var(--ink);margin:0}.error-boundary-body{max-width:400px;color:var(--stone);font-size:14px;line-height:1.5;margin:0}.error-boundary-actions{display:flex;gap:10px;margin-top:8px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,8px);z-index:140;background:var(--ink);color:var(--cream);font-family:var(--font-sans);font-size:13px;padding:10px 18px;border-radius:999px;box-shadow:0 10px 24px #0003;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .2s ease}.toast.is-visible{opacity:1;transform:translate(-50%)}.appnav{height:56px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 20px;background:color-mix(in srgb,var(--linen) 92%,transparent);backdrop-filter:saturate(1.2) blur(12px);-webkit-backdrop-filter:saturate(1.2) blur(12px);border-bottom:1px solid var(--parchment);flex-shrink:0;position:relative;z-index:30}.appnav-borderless{border-bottom:0}.appnav-left{display:flex;align-items:center;gap:12px;font-size:14px;min-width:0}.appnav-brand{display:inline-flex;align-items:center;flex-shrink:0;transition:opacity .15s ease}.appnav-brand:hover{opacity:.75}.appnav-logo{height:18px;width:auto;display:block}@media(min-width:768px){.appnav-logo{height:20px}}.appnav-center{display:flex;align-items:center;justify-content:center;flex-shrink:0}.appnav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.appnav-crumb{color:var(--stone);font-family:var(--font-sans);font-size:14px;text-decoration:none;transition:color .15s ease;cursor:pointer;flex-shrink:0}.appnav-crumb:hover{color:var(--ink)}.appnav-separator{color:var(--parchment);margin:0 4px}.appnav-title{font-family:var(--font-serif);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:-.005em;max-width:40vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.appnav-meta{color:var(--stone);font-size:13px;font-weight:400;margin-left:4px}.appnav-menu-wrap{position:relative}.appnav-menu-trigger{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--ink);cursor:pointer;transition:background .15s ease,border-color .15s ease}.appnav-menu-trigger:hover{background:color-mix(in srgb,var(--ink) 5%,transparent)}.appnav-menu-trigger[aria-expanded=true]{background:color-mix(in srgb,var(--ink) 8%,transparent)}.appnav-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:var(--ivory);border:1px solid var(--parchment);border-radius:var(--radius-md);box-shadow:0 12px 30px #0000001f;padding:6px;display:flex;flex-direction:column;gap:2px;animation:fadeUp .12s var(--ease-out)}.appnav-menu button{text-align:left;background:transparent;border:none;font-family:var(--font-sans);font-size:14px;color:var(--ink);padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .12s ease}.appnav-menu button:hover{background:color-mix(in srgb,var(--clay) 8%,var(--cream))}@media(max-width:520px){.appnav{padding:0 8px}.appnav-title{font-size:14px;max-width:44vw}.appnav-back span:not([aria-hidden]){display:none}}.newbook-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;background:color-mix(in srgb,var(--ink) 25%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .18s var(--ease-out)}.newbook-card{background:var(--linen);border:1px solid var(--parchment);border-radius:var(--radius-lg);box-shadow:0 24px 60px #0000002e;width:min(480px,100%);padding:28px 28px 22px;display:flex;flex-direction:column;gap:16px;animation:fadeUp .25s var(--ease-out)}.newbook-heading{font-family:var(--font-serif);font-size:26px;font-weight:500;color:var(--ink);margin:0;letter-spacing:-.01em}.newbook-sub{font-size:13px;color:var(--stone);margin:0 0 4px}.newbook-field{display:flex;flex-direction:column;gap:6px}.newbook-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--stone);font-weight:500}.newbook-sizes{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.newbook-size{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 8px 12px;background:var(--ivory);border:1.5px solid var(--parchment);border-radius:var(--radius-md);cursor:pointer;transition:all .15s var(--ease-out);font-family:var(--font-sans)}.newbook-size:hover{border-color:var(--stone-light)}.newbook-size.is-selected{border-color:var(--ink);background:var(--ivory)}.newbook-sizes.has-selection .newbook-size:not(.is-selected){opacity:.55}.newbook-sizes.has-selection .newbook-size:not(.is-selected):hover{opacity:.85}.newbook-size-swatch{background:var(--stone-light);border-radius:3px;display:block;transition:background .15s ease}.newbook-size.is-selected .newbook-size-swatch{background:var(--ink)}.newbook-label-hint{font-size:11px;color:var(--stone-light);text-transform:none;letter-spacing:0;font-weight:400;margin-left:6px}.newbook-size-label{font-size:13px;font-weight:500;color:var(--ink)}.newbook-size-meta{font-size:11px;color:var(--stone);letter-spacing:.02em}.newbook-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}:root{--editor-bg: #f0ede8;--editor-surface: #faf9f7;--editor-nav-bg: #faf9f7;--editor-border: #e4dfd6;--editor-text: #2c2825;--editor-text-muted: #8a837a;--editor-accent: #c8956c;--editor-accent-hover: #b8824f;--editor-selection: #c8956c33;--editor-selection-border: #c8956c;--editor-page-shadow: 0 1px 3px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.08);--editor-radius: 10px;--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", -apple-system, sans-serif}.editor-root{font-family:var(--font-body);color:var(--editor-text);-webkit-font-smoothing:antialiased}.editor-navbar{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 20px;background:var(--cream);border-bottom:1px solid var(--parchment);flex-shrink:0;z-index:10;position:relative}.editor-navbar-left{display:flex;align-items:center;gap:6px;font-size:14px}.editor-navbar-left a{color:var(--editor-text-muted);text-decoration:none;transition:color .15s}.editor-navbar-left a:hover{color:var(--editor-text)}.editor-navbar-left .separator{color:var(--editor-border);margin:0 4px}.editor-navbar-title{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--editor-text)}@media(max-width:768px){.editor-navbar{padding:0 10px!important;gap:6px}.editor-navbar-left .separator,.editor-navbar-page-count{display:none}.editor-navbar-center .font-selector{padding:2px}.editor-navbar-center .font-selector svg{display:none}.font-selector-btn{padding:3px 8px;font-size:12px}}.editor-navbar-title-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer;padding:2px 6px;border-radius:6px;transition:background .12s ease}.editor-navbar-title-btn:hover{background:color-mix(in srgb,var(--editor-text) 6%,transparent)}.editor-navbar-title-btn svg{opacity:.5;transition:opacity .12s ease}.editor-navbar-title-btn:hover svg{opacity:1}.editor-navbar-page-count{color:var(--editor-text-muted);font-size:13px;font-weight:400;margin-left:4px}.editor-navbar-center{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center}.font-selector{display:flex;align-items:center;gap:4px;background:var(--editor-bg);border-radius:8px;padding:3px 4px;color:var(--editor-text-muted)}.font-selector-btn{padding:4px 12px;font-size:13px;font-weight:500;border:none;background:transparent;color:var(--editor-text-muted);border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap}.font-selector-btn:hover{color:var(--editor-text)}.font-selector-btn.active{background:var(--editor-surface);color:var(--editor-text);box-shadow:0 1px 3px #00000014}.editor-navbar-right{display:flex;align-items:center;gap:8px}.editor-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;font-family:var(--font-body);border-radius:8px;cursor:pointer;transition:all .15s;border:none}.editor-btn-ghost{background:transparent;color:var(--editor-text);border:1px solid var(--editor-border)}.editor-btn-ghost:hover{background:var(--editor-bg);border-color:var(--editor-text-muted)}.editor-btn-primary{background:var(--editor-accent);color:#fff;font-weight:600;padding:8px 20px}.editor-btn-primary:hover{background:var(--editor-accent-hover)}.editor-btn-primary:disabled{opacity:.5;cursor:not-allowed}.editor-sidebar{width:220px;background:var(--editor-surface);border-right:1px solid var(--editor-border);overflow-y:auto;padding:16px 12px;flex-shrink:0}@media(max-width:768px){.editor-root>div[style*="display: flex"][style*="flex: 1"]{flex-direction:column!important}.editor-sidebar{width:100%;height:auto;max-height:110px;border-right:none;border-top:1px solid var(--editor-border);order:2;overflow-x:auto;overflow-y:hidden;display:flex;gap:10px;padding:10px 12px}.editor-sidebar>div{display:flex!important;flex-direction:row!important;gap:10px;width:max-content!important}.spread-thumbnail{min-width:96px;margin-bottom:0;flex-shrink:0}}.editor-sidebar::-webkit-scrollbar{width:4px}.editor-sidebar::-webkit-scrollbar-thumb{background:var(--editor-border);border-radius:4px}.spread-thumbnail{display:flex;gap:1px;padding:6px;border-radius:8px;cursor:pointer;margin-bottom:8px;transition:all .15s;border:2px solid transparent;background:transparent}.spread-thumbnail:hover{background:var(--editor-selection)}.spread-thumbnail.active{border-color:var(--editor-selection-border);background:var(--editor-selection)}.spread-thumb-page{position:relative;background:#fff;border-radius:2px;overflow:hidden;box-shadow:0 1px 3px #00000014}.spread-thumb-label{font-size:10px;color:var(--editor-text-muted);text-align:center;margin-top:4px;font-weight:500}.sidebar-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;border:1px dashed var(--editor-border);border-radius:8px;background:transparent;color:var(--editor-text-muted);font-size:12px;font-family:var(--font-body);cursor:pointer;transition:all .15s;margin-top:4px}.sidebar-add-btn:hover{border-color:var(--editor-accent);color:var(--editor-accent);background:var(--editor-selection)}.editor-canvas{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--editor-bg);overflow:hidden;position:relative}.spread-container{display:flex;position:relative;filter:drop-shadow(0 4px 20px rgba(0,0,0,.12))}@keyframes cornerPeelRight{0%{transform:rotateY(0) rotateX(0) rotate(0);filter:drop-shadow(0 4px 16px rgba(0,0,0,.1))}15%{transform:rotateY(-15deg) rotateX(2deg) rotate(-.5deg);filter:drop-shadow(-4px 8px 20px rgba(0,0,0,.15))}40%{transform:rotateY(-70deg) rotateX(4deg) rotate(-1deg);filter:drop-shadow(-10px 12px 30px rgba(0,0,0,.18))}70%{transform:rotateY(-140deg) rotateX(2deg) rotate(-.5deg);filter:drop-shadow(-6px 6px 20px rgba(0,0,0,.1))}to{transform:rotateY(-180deg) rotateX(0) rotate(0);filter:drop-shadow(0 0 0 rgba(0,0,0,0));opacity:0}}@keyframes cornerPeelLeft{0%{transform:rotateY(0) rotateX(0) rotate(0);filter:drop-shadow(0 4px 16px rgba(0,0,0,.1))}15%{transform:rotateY(15deg) rotateX(2deg) rotate(.5deg);filter:drop-shadow(4px 8px 20px rgba(0,0,0,.15))}40%{transform:rotateY(70deg) rotateX(4deg) rotate(1deg);filter:drop-shadow(10px 12px 30px rgba(0,0,0,.18))}70%{transform:rotateY(140deg) rotateX(2deg) rotate(.5deg);filter:drop-shadow(6px 6px 20px rgba(0,0,0,.1))}to{transform:rotateY(180deg) rotateX(0) rotate(0);filter:drop-shadow(0 0 0 rgba(0,0,0,0));opacity:0}}@keyframes cornerPeelRightNoShadow{0%{transform:rotateY(0) rotateX(0) rotate(0)}15%{transform:rotateY(-15deg) rotateX(2deg) rotate(-.5deg)}40%{transform:rotateY(-70deg) rotateX(4deg) rotate(-1deg)}70%{transform:rotateY(-140deg) rotateX(2deg) rotate(-.5deg)}to{transform:rotateY(-180deg) rotateX(0) rotate(0);opacity:0}}@keyframes cornerPeelLeftNoShadow{0%{transform:rotateY(0) rotateX(0) rotate(0)}15%{transform:rotateY(15deg) rotateX(2deg) rotate(.5deg)}40%{transform:rotateY(70deg) rotateX(4deg) rotate(1deg)}70%{transform:rotateY(140deg) rotateX(2deg) rotate(.5deg)}to{transform:rotateY(180deg) rotateX(0) rotate(0);opacity:0}}@keyframes castShadow{0%{opacity:0}20%{opacity:.8}60%{opacity:1}to{opacity:0}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spread-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#1e1b180f;border:1px solid rgba(30,27,24,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:5;color:var(--ink-soft, #3d3731)}.spread-nav-btn:hover{background:#1e1b1880;border-color:transparent;color:#fff}.spread-nav-prev{left:-64px}.spread-nav-next{right:-64px}.spread-spine{position:absolute;top:0;left:50%;transform:translate(-50%);width:16px;height:100%;z-index:5;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.04) 25%,rgba(0,0,0,.08) 45%,rgba(0,0,0,.12) 50%,rgba(0,0,0,.08) 55%,rgba(0,0,0,.04) 75%,transparent 100%)}.spread-page-left{position:relative}.spread-page-left:after{content:"";position:absolute;top:0;right:0;width:20px;height:100%;background:linear-gradient(90deg,transparent,rgba(0,0,0,.03));pointer-events:none}.spread-page-right{position:relative}.spread-page-right:after{content:"";position:absolute;top:0;left:0;width:20px;height:100%;background:linear-gradient(270deg,transparent,rgba(0,0,0,.03));pointer-events:none}.spread-page-indicator{margin-top:16px;font-size:12px;color:var(--editor-text-muted);font-weight:500;letter-spacing:.5px}.editor-bottom-bar{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 24px;background:var(--editor-surface);border-top:1px solid var(--editor-border);flex-shrink:0}.bottom-bar-tools{display:flex;align-items:center;gap:4px}.bottom-bar-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 14px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:var(--editor-text-muted);font-size:10px;font-family:var(--font-body);font-weight:500;transition:all .15s}.bottom-bar-btn:hover,.bottom-bar-btn.active{background:var(--editor-selection);color:var(--editor-accent)}.bottom-bar-btn svg{width:20px;height:20px}.bottom-bar-actions{display:flex;align-items:center;gap:4px}.bottom-bar-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:var(--editor-text-muted);transition:all .15s}.bottom-bar-icon-btn:hover{background:var(--editor-selection);color:var(--editor-text)}.layout-popup{position:absolute;bottom:64px;left:24px;background:#fff;border:1px solid var(--editor-border);border-radius:var(--editor-radius);box-shadow:0 8px 32px #0000001f;padding:12px;z-index:20}.layout-popup-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.layout-popup-item{position:relative;background:var(--editor-bg);border-radius:4px;cursor:pointer;border:2px solid transparent;transition:all .15s;overflow:hidden}.layout-popup-item:hover{border-color:var(--editor-text-muted)}.layout-popup-item.active{border-color:var(--editor-accent)}.editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--editor-bg);font-family:var(--font-body);color:var(--editor-text);gap:16px}.editor-spinner{width:32px;height:32px;border:2.5px solid var(--editor-border);border-top-color:var(--editor-accent);border-radius:50%;animation:editor-spin .8s ease-in-out infinite}@keyframes editor-spin{to{transform:rotate(360deg)}}.editor-loading-text{font-size:14px;color:var(--editor-text-muted);font-weight:500}.cover-softcover-shell{border-radius:3px;overflow:visible!important;box-shadow:1px 2px 3px #0000001f,2px 6px 16px #00000014,4px 12px 32px #0000000f}.cover-softcover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:3px;z-index:5;pointer-events:none}.cover-softcover-overlay:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:3px;background:linear-gradient(180deg,rgba(255,255,255,.06) 0%,transparent 8%),linear-gradient(0deg,rgba(0,0,0,.04) 0%,transparent 8%),linear-gradient(90deg,rgba(0,0,0,.02) 0%,transparent 4%),linear-gradient(270deg,rgba(0,0,0,.02) 0%,transparent 4%);pointer-events:none}.cover-softcover-edge{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:4px;z-index:-1;pointer-events:none}.cover-spine-softcover{position:absolute;top:0;bottom:0;width:8px;z-index:6;pointer-events:none}.cover-spine-softcover.spine-left{left:0;background:linear-gradient(90deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.08) 35%,rgba(255,255,255,.04) 50%,transparent 100%);border-radius:3px 0 0 3px}.cover-spine-softcover.spine-right{right:0;background:linear-gradient(270deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.08) 35%,rgba(255,255,255,.04) 50%,transparent 100%);border-radius:0 3px 3px 0}.cover-hardcover-shell{border-radius:4px;overflow:visible!important;box-shadow:2px 3px 4px #00000026,3px 8px 20px #0000001a,5px 16px 40px #00000014}.cover-hardcover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;z-index:5;pointer-events:none}.cover-hardcover-overlay:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 6%),linear-gradient(0deg,rgba(0,0,0,.06) 0%,transparent 6%),linear-gradient(90deg,rgba(0,0,0,.03) 0%,transparent 3%),linear-gradient(270deg,rgba(0,0,0,.03) 0%,transparent 3%);pointer-events:none}.cover-hardcover-edge{position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border-radius:6px;z-index:-1;pointer-events:none}.cover-spine-hardcover{position:absolute;top:-5px;bottom:-5px;width:24px;z-index:6;pointer-events:none}.cover-spine-hardcover.spine-left{left:-5px;border-radius:6px 0 0 6px;background:linear-gradient(90deg,rgba(0,0,0,.04) 0%,rgba(0,0,0,.08) 8%,rgba(255,255,255,.12) 18%,rgba(255,255,255,.08) 25%,rgba(0,0,0,.16) 35%,rgba(0,0,0,.2) 42%,rgba(0,0,0,.16) 50%,rgba(255,255,255,.04) 60%,rgba(0,0,0,.03) 75%,transparent 100%)}.cover-spine-hardcover.spine-right{right:-5px;border-radius:0 6px 6px 0;background:linear-gradient(270deg,rgba(0,0,0,.04) 0%,rgba(0,0,0,.08) 8%,rgba(255,255,255,.12) 18%,rgba(255,255,255,.08) 25%,rgba(0,0,0,.16) 35%,rgba(0,0,0,.2) 42%,rgba(0,0,0,.16) 50%,rgba(255,255,255,.04) 60%,rgba(0,0,0,.03) 75%,transparent 100%)}.spread-toolbar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;pointer-events:auto;align-items:center;gap:8px;padding:6px 14px;background:#2c2825d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;z-index:10;white-space:nowrap;animation:toolbarFadeIn .15s ease}@keyframes toolbarFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.cover-hover-divider{width:1px;height:20px;background:#fff3;flex-shrink:0}.cover-type-toggle{display:flex;gap:2px;background:#ffffff1a;border-radius:8px;padding:2px}.cover-type-btn{padding:5px 12px;border:none;border-radius:6px;font-size:12px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:all .15s;color:#fff9;background:transparent}.cover-type-btn:hover{color:#ffffffe6}.cover-type-btn.active{background:#fff3;color:#fff}.cover-color-swatches{display:flex;gap:6px;align-items:center}.cover-color-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s;padding:0;outline:none}.cover-color-swatch:hover{transform:scale(1.15)}.cover-color-swatch.active{border-color:#fff}
