@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&display=swap";:root{--text:#1f2421;--text-h:#1f2421;--bg:#f0f3f1;--border:#d8dfdb;--code-bg:#f7f9f8;--accent:#c09f80;--accent-bg:#c09f801a;--accent-border:#c09f8080;--social-bg:#d8dfdb80;--shadow:#1f24211a 0 10px 15px -3px, #1f24210d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0}:root{--parchment:#f0f3f1;--parchment-light:#f7f9f8;--parchment-dark:#d8dfdb;--ink:#1f2421;--ink-light:#434d47;--ink-muted:#78827c;--accent:#c09f80;--accent-glow:#a88565;--accent-soft:#c09f801a;--forest:#355c4d;--forest-soft:#355c4d14;--night:#1f2421;--night-soft:#1f242114;--shadow:#1f24210a;--shadow-deep:#1f24211f;--radius:12px;--radius-sm:8px}body{background:var(--parchment);color:var(--ink);font-family:Plus Jakarta Sans,sans-serif}.app{background:radial-gradient(ellipse at 20% 0%, #355c4d0a 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, #c09f800a 0%, transparent 50%), var(--parchment);flex-direction:column;height:100vh;display:flex;overflow:hidden}.header{border-bottom:1px solid var(--parchment-dark);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#fcfaf7e6;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:relative}.logo{cursor:pointer;align-items:center;gap:14px;height:100%;display:flex}.logo-icon{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;line-height:1;display:flex}.logo h1{color:var(--ink);letter-spacing:-.6px;font-family:Playfair Display,serif;font-size:30px;font-weight:700;line-height:1}.logo h1 span{color:var(--accent)}.header-title{z-index:5;pointer-events:none;justify-content:center;align-items:center;margin:auto;display:flex;position:absolute;top:0;bottom:0}.header-title>*{pointer-events:auto}.header.in-project-mode.view-editor .header-title{left:300px;right:260px}.header.in-project-mode.view-reader .header-title{left:0;right:0}.project-title-display{color:var(--ink);cursor:pointer;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;padding:4px 16px;font-family:Playfair Display,serif;font-size:18px;font-weight:600;transition:background-color .2s,color .2s;display:inline-flex;position:relative}.project-title-display:hover{background-color:var(--parchment-dark);color:var(--accent);border-color:#355c4d26}.project-title-display .edit-icon{opacity:0;font-size:12px;transition:opacity .2s;position:absolute;top:50%;left:calc(100% + 6px);transform:translateY(-50%)}.project-title-display:hover .edit-icon{opacity:.6}.project-title-input{color:var(--ink);border:1px solid var(--accent);text-align:center;box-shadow:0 0 0 3px var(--accent-soft);background:#fff;border-radius:6px;outline:none;padding:4px 10px;font-family:Playfair Display,serif;font-size:18px;font-weight:600}.header-actions{align-items:center;gap:12px;height:100%;display:flex}.header-actions .tab-group,.header-actions .tab,.header-actions .btn{border-radius:999px}.tab-group{background:var(--parchment-dark);border-radius:8px;padding:3px;display:flex}.tab{cursor:pointer;color:var(--ink-light);background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s}.tab.active{color:var(--ink);box-shadow:0 1px 3px var(--shadow);background:#fff}.tab-icon{justify-content:center;align-items:center;padding:6px 12px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-glow);transform:translateY(-1px)}.btn-secondary{color:var(--ink);border:1px solid var(--parchment-dark);background:#fff}.btn-secondary:hover{border-color:var(--ink-muted)}.btn-secondary.btn-active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.btn-ghost{color:var(--ink-light);background:0 0}.btn-ghost:hover{color:var(--ink);background:var(--shadow)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-danger{color:#c0392b;background:0 0;font-size:12px}.btn-danger:hover{background:#c0392b14}.main{flex:1;display:flex;overflow:hidden}.landing-screen{flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.landing-options{gap:24px;width:100%;max-width:700px;display:flex}.landing-card{border:2px solid var(--parchment-dark);text-align:center;cursor:pointer;background:#fff;border-radius:20px;flex:1;padding:48px 32px;transition:all .3s}.landing-card:hover{border-color:var(--accent);background:var(--accent-soft)}.landing-card .card-icon{background:var(--accent-soft);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;font-size:28px;display:flex}.landing-card h2{margin-bottom:8px;font-family:Playfair Display,serif;font-size:22px;font-weight:600}.landing-card p{color:var(--ink-muted);font-size:14px;line-height:1.5}.reader{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:24px;display:flex;position:relative;overflow:hidden}.reader-spread-wrap{flex:1;width:100%;min-height:0;position:relative}.book-spread{max-width:100%;max-height:100%;box-shadow:0 8px 40px var(--shadow-deep), 0 2px 8px var(--shadow);border-radius:4px;grid-template-columns:1fr 1px 1fr;margin:auto;display:grid;position:absolute;inset:0;overflow:hidden}.page-tap-zone{cursor:pointer;min-width:0;min-height:0;position:relative;overflow:hidden}.book-page{--px:.2cqi;min-width:0;height:100%;min-height:0;position:relative;overflow:hidden;container-type:inline-size}.book-page.image-page{background:#1a1a2e;position:relative}.book-page.image-page img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.book-page.text-page{background:#faf8f4;flex-direction:column;font-family:Playfair Display,serif;display:flex;position:relative}.book-page.text-page .author-name{top:calc(24 * var(--px));right:calc(32 * var(--px));font-size:calc(11 * var(--px));letter-spacing:calc(2 * var(--px));text-transform:uppercase;color:var(--ink-muted);font-family:Plus Jakarta Sans,sans-serif;font-weight:500;position:absolute}.book-page.text-page .page-text{padding-top:calc(32 * var(--px));flex-direction:column;flex:1;display:flex;overflow:hidden}.book-page.text-page.text-inset .page-text{justify-content:center}.book-page.text-page .page-text-content{font-size:calc(18 * var(--px))}.book-page.text-page .page-number{bottom:calc(24 * var(--px));right:calc(32 * var(--px));font-size:calc(13 * var(--px));color:var(--ink-muted);position:absolute}.book-page.empty-page{background:radial-gradient(circle at 50% 50%, var(--parchment) 0%, var(--parchment-dark) 100%);color:var(--ink-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.book-page.empty-page.empty-right{background:radial-gradient(circle at 50% 50%, var(--parchment) 0%, #ece7dd 100%)}.book-spine{background:var(--parchment-dark);flex-shrink:0;width:1px}.page-nav{align-items:center;gap:16px;margin-top:16px;display:flex}.page-info{color:var(--ink-light);text-align:center;min-width:80px;font-family:Playfair Display,serif;font-size:15px}.nav-btn{border:1px solid var(--parchment-dark);cursor:pointer;width:36px;height:36px;color:var(--ink-light);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.nav-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.tool-row{background:var(--parchment);border-radius:var(--radius);align-items:center;gap:8px;margin-bottom:6px;padding:8px 12px;display:flex}.tool-row-icon{flex-shrink:0;font-size:14px;line-height:1}.tool-row-label{color:var(--ink-light);white-space:nowrap;font-size:12px;font-weight:500}.tool-row-options{background:var(--parchment-dark);border-radius:calc(var(--radius-sm) - 2px);gap:2px;margin-left:auto;padding:2px;display:flex}.tool-row-opt{cursor:pointer;border-radius:calc(var(--radius-sm) - 4px);color:var(--ink-muted);background:0 0;border:none;padding:4px 8px;font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:500;transition:all .15s}.tool-row-opt.active{color:var(--ink);box-shadow:0 1px 3px var(--shadow);background:#fff}.tool-row-delete{cursor:pointer;color:var(--ink-muted);background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:flex}.tool-row-delete:hover{color:#d93025}.editor-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.editor-top-bar{border-bottom:1px solid var(--parchment-dark);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb3;align-items:center;gap:12px;padding:12px 24px;display:flex}.editor-top-bar input{border:none;border-bottom:1.5px solid var(--parchment-dark);color:var(--ink);background:0 0;border-radius:0;outline:none;padding:6px 2px;font-family:Playfair Display,serif;font-size:16px;transition:border-color .3s}.editor-top-bar input:focus{border-bottom-color:var(--accent)}.editor-top-bar input::placeholder{color:var(--ink-muted);font-style:italic}.format-buttons{background:var(--parchment-dark);border-radius:var(--radius-sm);gap:2px;padding:2px;display:flex}.format-btn{cursor:pointer;color:var(--ink-muted);background:0 0;border:none;border-radius:6px;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:4px 8px;transition:all .15s;display:flex}.format-btn:hover{color:var(--ink);background:var(--shadow)}.format-btn.active{color:var(--accent);box-shadow:0 1px 3px var(--shadow);background:#fff}.format-btn-spread{color:#2c241826;justify-content:center;align-items:center;height:16px;display:flex}.format-btn-spread svg{shape-rendering:crispedges;display:block}.format-btn.active .format-btn-spread{color:#355c4d99}.format-btn:hover .format-btn-spread{color:#2c241866}.format-btn-label{letter-spacing:.02em;opacity:1;font-size:8px;font-weight:500}.editor-main{flex:1;display:flex;overflow:hidden}.editor-canvas-area{background:var(--parchment-light);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.canvas-container{box-sizing:border-box;flex-direction:column;flex:1;align-items:center;gap:20px;padding:80px 40px 40px;display:flex;overflow:auto}.format-toolbar-wrapper{z-index:100;pointer-events:none;animation:.2s ease-out toolbarFadeIn;position:absolute;top:20px;left:50%;transform:translate(-50%)}.format-toolbar-wrapper>*{pointer-events:auto}.format-toolbar-pill button:hover{background:#355c4d0d!important}.format-toolbar-pill .btn-delete:hover{background:#d9302514!important}@keyframes toolbarFadeIn{0%{opacity:0}to{opacity:1}}.zoom-bar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#ffffffd9;border:1px solid #355c4d26;border-radius:30px;align-items:center;gap:6px;padding:4px 8px;display:flex;position:absolute;bottom:24px;right:24px;box-shadow:0 4px 16px #0003}.zoom-btn-round{cursor:pointer;width:24px;height:24px;color:var(--ink);background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;font-weight:700;transition:background .2s,transform .15s;display:flex;box-shadow:0 1px 3px #0000001a}.zoom-btn-round:hover{background:var(--parchment-light)}.zoom-btn-round:active{transform:scale(.95)}.zoom-text{text-align:center;min-width:40px;color:var(--ink);font-size:11px;font-weight:600}@property --zoom{syntax:"<number>";inherits:true;initial-value:1}.canvas-zoom-wrapper{width:calc(var(--base-w) * var(--zoom));height:calc(var(--base-h) * var(--zoom));flex-shrink:0;position:relative}.canvas-zoom-inner{width:var(--base-w);height:var(--base-h);transform:scale(var(--zoom));transform-origin:0 0;position:absolute;top:0;left:0}.editor-canvas{flex:1;justify-content:center;align-items:center;padding:24px 24px 44px;display:flex;overflow:auto}.editor-spread-wrap{flex:1;height:100%;min-height:0;position:relative}.editor-spread{border-radius:6px;max-width:100%;max-height:100%;margin:auto;display:flex;position:absolute;inset:0;overflow:hidden;box-shadow:inset 0 1px #fff9,0 12px 48px #2d232526,0 4px 12px #2d232514,0 0 0 1px #2d23250f}.editor-page{--px:.2cqi;flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden;container-type:inline-size}.editor-page [data-placeholder]:empty:before{content:attr(data-placeholder);color:var(--ink-muted,#b0a89c);opacity:.65;pointer-events:none}.editor-page-content{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.editor-page.type-empty .editor-page-content{background:radial-gradient(circle at 50% 50%, var(--parchment) 0%, var(--parchment-dark) 100%)}.editor-page.type-empty.empty-right .editor-page-content{background:radial-gradient(circle at 50% 50%, var(--parchment) 0%, #ece7dd 100%)}.empty-page-prompt{color:var(--ink-muted);text-align:center;opacity:.7;flex-direction:column;align-items:center;gap:12px;transition:opacity .3s;display:flex}.editor-page.type-empty:hover .empty-page-prompt{opacity:1}.empty-label{color:var(--ink-muted);font-family:Playfair Display,serif;font-size:15px;font-style:italic}.empty-actions{gap:12px;margin-top:4px;display:flex}.empty-action-btn{border-radius:var(--radius);border:1.5px dashed var(--parchment-dark);cursor:pointer;min-width:100px;color:var(--ink-light);background:#ffffff80;flex-direction:column;align-items:center;gap:6px;padding:16px 24px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:500;transition:all .2s;display:flex}.empty-action-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 4px 12px var(--shadow);background:#ffffffe6;transform:translateY(-2px)}.empty-action-icon{font-size:20px}.page-clear-btn{color:#fff;cursor:pointer;opacity:0;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;transition:all .2s;display:flex;position:absolute;top:8px;right:8px}.editor-page:hover .page-clear-btn{opacity:.6}.page-clear-btn:hover{background:#c0392bcc;opacity:1!important}.editor-page.type-image .editor-page-content{cursor:pointer;background:#1c1b22;position:relative}.editor-page.type-image .editor-page-content img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.image-placeholder{color:#fff6;text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.image-placeholder .upload-ring{border:2px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:24px;transition:all .3s;display:flex}.editor-page.type-image:hover .upload-ring{background:#ffffff0d;border-color:#fff6}.image-placeholder .upload-label{font-size:13px;font-weight:500}.image-replace-btn{cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;background:#0009;border:none;border-radius:20px;padding:5px 12px;font-size:11px;font-weight:500;transition:all .2s;position:absolute;bottom:12px;right:12px}.editor-page.type-image:hover .image-replace-btn{opacity:1}.image-replace-btn:hover{background:#000c}.editor-page.type-text .editor-page-content{background:#faf8f4;flex-direction:column;align-items:stretch;padding:16px 20px 0}.text-toolbar{flex-wrap:wrap;flex-shrink:0;align-self:flex-start;gap:6px;margin-bottom:10px;display:flex}.toolbar-group{box-shadow:0 1px 4px var(--shadow);background:#fff;border-radius:20px;align-items:center;gap:1px;padding:4px 6px;display:flex}.text-toolbar button{cursor:pointer;width:28px;height:28px;color:var(--ink-light);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.text-toolbar button:hover,.text-toolbar button.layout-active{background:var(--accent-soft);color:var(--accent)}.text-toolbar .toolbar-divider{background:var(--parchment-dark);width:1px;margin:4px}.size-stepper{align-items:center;gap:0;display:flex}.size-stepper button{width:24px;height:24px;font-size:14px;font-weight:600}.size-stepper .size-value{color:var(--ink-light);text-align:center;-webkit-user-select:none;user-select:none;min-width:24px;font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:600}.text-toolbar select{color:var(--ink-light);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:0 4px;font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:500}.text-toolbar select:hover{color:var(--ink)}.color-input-wrapper{justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:relative}.color-input-wrapper input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.color-swatch{border:2px solid var(--parchment-dark);pointer-events:none;border-radius:50%;width:18px;height:18px}.layout-toggle-wrap{align-items:center;gap:0;display:flex;position:relative}.layout-toggle-wrap .dropdown-arrow{cursor:pointer;width:28px;height:28px;color:var(--ink-light);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:11px;font-weight:500;transition:all .15s;display:flex}.layout-toggle-wrap .dropdown-arrow svg{width:13px;height:13px}.layout-toggle-wrap .dropdown-arrow:hover{background:var(--accent-soft);color:var(--accent)}.margin-popover{z-index:10;background:#fff;border-radius:12px;grid-template-rows:auto auto auto;grid-template-columns:1fr auto 1fr;place-items:center;gap:4px;min-width:160px;margin-top:8px;padding:16px;display:grid;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000026}.add-popover-item{width:100%!important;height:auto!important;color:var(--ink)!important;background:0 0!important;border-radius:6px!important;justify-content:flex-start!important;padding:8px 12px!important;font-family:Plus Jakarta Sans,sans-serif!important;font-size:13px!important;font-weight:500!important;transition:all .15s!important}.add-popover-item:hover:not(:disabled){background:var(--shadow)!important;color:var(--ink)!important}.margin-popover .margin-top{grid-area:1/2}.margin-popover .margin-left{grid-area:2/1}.margin-popover .margin-center{border:1.5px solid var(--parchment-dark);background:var(--parchment);cursor:pointer;width:32px;height:32px;color:var(--ink-light);border-radius:4px;grid-area:2/2;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.margin-popover .margin-center:disabled{opacity:.3;cursor:default;pointer-events:none}.margin-popover .margin-center:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.margin-popover .margin-right{grid-area:2/3}.margin-popover .margin-bottom{grid-area:3/2}.margin-input{border:1px solid var(--parchment-dark);text-align:center;width:44px;color:var(--ink);background:var(--parchment);border-radius:6px;outline:none;padding:4px;font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:600}.margin-input:focus{border-color:var(--accent);background:#fff}.text-editable{padding:calc(8 * var(--px)) 0;outline:none;flex:none;font-family:Playfair Display,serif;overflow:visible}.drop-cap:first-letter{float:left;margin-right:calc(6 * var(--px));margin-top:calc(2 * var(--px));font-size:5em;font-weight:400;line-height:.55}.text-editable:empty:before{content:"Start typing here...";color:var(--ink-muted);opacity:.6;font-style:italic}.page-title{margin-bottom:calc(16 * var(--px));text-align:left;font-family:Playfair Display,serif;font-weight:700;line-height:1.2}.page-title-wrap{width:max-content;margin-bottom:calc(16 * var(--px));justify-content:flex-start;align-self:flex-start;align-items:center;max-width:100%;display:inline-flex;position:relative}.page-title-input{text-align:left;word-wrap:break-word;background:0 0;border:none;outline:none;max-width:100%;padding-right:34px;font-family:Playfair Display,serif;font-weight:700;display:inline-block}.page-title-input:empty:before{content:"Add headline...";color:var(--ink-muted);opacity:.4;pointer-events:none;font-style:italic;font-weight:500;display:inline-block}.remove-title-btn{border:1px solid var(--parchment-dark);color:#c0392b;cursor:pointer;opacity:0;width:16px;height:16px;box-shadow:0 1px 4px var(--shadow);z-index:10;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:8px;font-weight:700;transition:all .2s;display:flex;position:absolute;top:-4px;right:0}.remove-title-btn:hover{color:#fff;background:#c0392b;border-color:#c0392b}.page-title-wrap:hover .remove-title-btn{opacity:1}.inline-image-wrap{margin-bottom:calc(46 * var(--px));flex:1;justify-content:center;width:100%;min-height:0;display:flex;position:relative}.inline-image{object-fit:contain;border-radius:8px;max-width:100%;max-height:100%;display:block;box-shadow:0 4px 16px #0000000d}.inline-image-placeholder{width:100%;min-height:140px;color:var(--ink-muted);cursor:pointer;background:#00000005;border:2px dashed #0000001a;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;transition:all .2s;display:flex}.inline-image-placeholder:hover{background:#0000000a;border-color:#00000026}.inline-image-placeholder .upload-ring{width:48px;height:48px;color:var(--ink-muted);border:2px solid #00000026;border-radius:50%;justify-content:center;align-items:center;margin-bottom:8px;transition:all .2s;display:flex}.inline-image-placeholder:hover .upload-ring{color:var(--ink);border-color:#0000004d}.inline-replace-btn{white-space:nowrap!important;color:#2d2325!important;pointer-events:none!important;opacity:0!important;cursor:pointer!important;z-index:100!important;background:#fff!important;border:1px solid #0000001a!important;border-radius:20px!important;width:auto!important;min-width:0!important;height:auto!important;min-height:0!important;margin:0!important;padding:6px 14px!important;font-size:11px!important;line-height:1!important;transition:all .2s!important;display:block!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;box-shadow:0 4px 12px #00000026!important}.inline-image-inner{max-width:100%;max-height:100%;display:block;position:relative}.inline-image:hover+.inline-replace-btn,.inline-replace-btn:hover{opacity:1!important;pointer-events:auto!important}.remove-inline-btn{border:1px solid var(--parchment-dark);color:#c0392b;cursor:pointer;opacity:0;width:24px;height:24px;box-shadow:0 2px 8px var(--shadow);z-index:10;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;transition:all .2s;display:flex;position:absolute;top:-10px;right:-10px}.remove-inline-btn:hover{color:#fff;background:#c0392b}.inline-image-wrap:hover .remove-inline-btn{opacity:1}.editor-page.text-overflow .text-editable{outline-offset:4px;border-radius:4px;outline:2px solid #d93025;position:relative}.text-editable-wrap{flex-direction:column;flex:1;height:100%;min-height:0;display:flex;position:relative}.text-editable-wrap.text-inset{justify-content:center}.text-editable-wrap.text-inset .text-editable{flex:none}.editor-page.text-overflow .text-editable-wrap:after{content:"+";color:#fff;text-align:center;pointer-events:none;z-index:2;background:#d93025;border-radius:2px;width:16px;height:16px;font-size:13px;font-weight:700;line-height:16px;position:absolute;bottom:-13px;right:12px}.sidebar{border-left:1px solid var(--parchment-dark);background:#fff;flex-direction:column;flex-shrink:0;width:320px;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--parchment-dark);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.sidebar-header h3{font-family:Playfair Display,serif;font-size:17px;font-weight:600}.sidebar-body{flex:1;padding:16px 20px;overflow-y:auto}.spread-list{flex-direction:column;gap:8px;display:flex}.spread-item{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;align-items:center;gap:10px;padding:8px 10px;transition:all .15s;display:flex}.spread-item:hover{background:var(--parchment)}.spread-item.active{background:var(--accent-soft);border-color:#355c4d33}.spread-thumb-pair{flex-shrink:0;gap:2px;display:flex}.spread-thumb{background:var(--parchment-dark);object-fit:cover;width:28px;height:36px;color:var(--ink-muted);border-radius:2px;justify-content:center;align-items:center;font-size:8px;display:flex;overflow:hidden}.spread-thumb img{object-fit:cover;width:100%;height:100%}.spread-item-info{flex:1;min-width:0}.spread-item-title{margin-bottom:2px;font-size:13px;font-weight:500}.spread-item-status{color:var(--ink-muted);font-size:11px}.status-dot{border-radius:50%;width:6px;height:6px;margin-right:4px;display:inline-block}.status-dot.ready{background:var(--forest)}.status-dot.empty{background:var(--ink-muted)}.section-label{text-transform:uppercase;letter-spacing:1px;color:var(--ink-muted);margin-bottom:8px;font-size:10px;font-weight:600}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}.spinner-dark{border-color:#2d232526;border-top-color:var(--accent)}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--parchment-dark);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}input[type=text],textarea,select{color:var(--ink);background:#fdfdfb;outline:none;padding:10px 12px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;transition:all .2s ease-in-out;border:1px solid #355c4d26!important;border-radius:8px!important}input[type=text]:focus,textarea:focus,select:focus{box-shadow:0 0 0 3px var(--accent-soft);background:#fff;border-color:var(--accent)!important}.landing-card{box-shadow:0 4px 12px var(--shadow);cursor:pointer;background:#fff;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;border:1px solid var(--parchment-dark)!important;border-radius:16px!important}.landing-card:before{content:"";background:var(--accent);transform-origin:0;height:4px;transition:transform .25s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.landing-card:hover{box-shadow:0 16px 36px var(--shadow-deep);transform:translateY(-4px);border-color:#355c4d40!important}.landing-card:hover:before{transform:scaleX(1)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#2d232566;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--parchment);border:1px solid #355c4d26;border-radius:20px;width:100%;max-width:400px;padding:32px;animation:.25s cubic-bezier(.34,1.56,.64,1) slideUp;box-shadow:0 20px 50px #2d232540}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sidebar-title-accent{color:var(--accent);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--parchment-dark);margin-bottom:16px;padding-bottom:6px;font-size:11px;font-weight:700}.sidebar-header-wrapper{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.sidebar-header-wrapper.collapsed{margin-bottom:0}.sidebar-header-wrapper h3{border-bottom:none;margin:0;padding-bottom:0}.section-collapsible{border-bottom:1px solid var(--parchment-dark);margin-bottom:16px;padding-bottom:16px}.section-collapsible.collapsed{margin-bottom:12px;padding-bottom:0}.sidebar-title-muted{color:var(--ink-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:11px;font-weight:600}.sidebar-label{color:var(--ink-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;font-size:10px;font-weight:700;display:block}.data-panel-label{color:var(--ink-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;padding-left:6px;font-size:11px;font-weight:600;display:block}.data-panel{border-right:1px solid var(--parchment-dark);background:radial-gradient(circle at 50% 0,#fffffffa 0%,#fcfcfcf2 50%,#f4f4f4e8 100%);flex-direction:column;width:300px;height:100%;display:flex;overflow-y:auto}.data-panel .section{border-bottom:1px solid var(--parchment-dark);padding:16px 20px}.inspector{border-left:1px solid var(--parchment-dark);scrollbar-gutter:stable;background:radial-gradient(circle at 50% 0,#fffffffa 0%,#fcfcfcf2 50%,#f4f4f4e8 100%);flex-direction:column;width:260px;height:100%;padding:16px 20px;display:flex;overflow-y:auto}.sidebar-field-row{margin-bottom:12px}.sidebar-input,.sidebar-select{border:1px solid var(--parchment-dark);width:100%;color:var(--ink);background:#fff;border-radius:4px;outline:none;padding:8px;font-size:14px}.sidebar-input::placeholder{color:var(--ink-muted,#9e8e91);opacity:.5;font-style:italic}.toggle-switch{background:var(--parchment-dark);cursor:pointer;border:none;border-radius:999px;flex-shrink:0;width:38px;height:22px;padding:0;transition:background .2s;position:relative}.toggle-switch.on{background:var(--accent,#355c4d)}.toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000040}.toggle-switch.on .toggle-knob{transform:translate(16px)}.sidebar-textarea{border:1px solid var(--parchment-dark);resize:vertical;width:100%;height:100px;color:var(--ink);background:#fff;border-radius:4px;outline:none;padding:8px;font-family:inherit;font-size:14px}.stepper-container{border:1px solid var(--parchment-dark);background:#f5f3f0;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:2px;display:flex}.stepper-btn{cursor:pointer;width:26px;height:26px;color:var(--ink-light);background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.stepper-value{color:var(--ink);font-size:13px;font-weight:700}.items-list-container{flex-direction:column;gap:4px;max-height:200px;margin-bottom:20px;display:flex;overflow-y:auto}.items-list-row{border:1px solid var(--parchment-dark);cursor:pointer;border-radius:16px;justify-content:space-between;align-items:center;padding:8px 12px;transition:all .2s;display:flex}.items-list-row.active{background:var(--parchment-dark)}.items-list-row.inactive{background:#fff}.items-list-row-text{white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.items-list-row-text.active{font-weight:600}.items-list-row-text.inactive{font-weight:400}.logo-upload-wrapper{align-items:center;gap:8px;display:flex}.logo-image-container{position:relative}.logo-img{border:1px solid var(--parchment-dark);border-radius:4px;height:60px}.logo-delete-btn{border:1px solid var(--parchment-dark);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 1px 3px #0000001a}.orientation-btn{cursor:pointer;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:8px 4px;font-size:11px;transition:all .2s;display:flex}.orientation-btn.active{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent);font-weight:600}.orientation-btn.inactive{color:var(--ink-light);border:1px solid var(--parchment-dark);background:#fff;font-weight:400}.sidebar-icon-btn{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.item-editor{border-top:1px solid var(--parchment-dark);padding-top:16px}.printable-sheet{-webkit-user-select:none;user-select:none}.panning-grab{cursor:grab}.panning-grabbing{cursor:grabbing;-webkit-user-select:none;user-select:none}@keyframes panelFadeIn{0%{opacity:0;transform:scale(.97)translateY(4px)}to{opacity:1;transform:scale(1)translateY(0)}}.resize-handle-bar:hover .resize-handle-pill{opacity:.65!important;background-color:#555!important}.items-list-row-edit-btn{opacity:0;color:var(--ink,#2d2325);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-left:4px;padding:0;transition:all .2s;display:flex}.items-list-row:hover .items-list-row-edit-btn{opacity:.65}.items-list-row-edit-btn:hover{opacity:1!important;color:var(--accent,#355c4d)!important;background:#355c4d14!important}.items-list-row.active .items-list-row-edit-btn{opacity:.3}.items-list-row.active:hover .items-list-row-edit-btn{opacity:.65}.image-drop-target{border:1.5px dashed var(--parchment-dark);cursor:pointer;width:100%;color:var(--ink-muted);background:#ffffff4d;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:16px;transition:all .2s;display:flex}.image-drop-target:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.image-drop-target.dragging{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);transform:scale(1.02);box-shadow:0 4px 12px #355c4d1a}
