@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700&family=Gaegu:wght@400;700&family=Crafty+Girls&family=Sue+Ellen+Francisco&family=Homemade+Apple&display=swap";:root{--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--spacing-3xl:64px;--font-body:"Nunito", "Helvetica Neue", Arial, sans-serif;--font-handwriting:"Gaegu", cursive;--font-size-xs:12px;--font-size-sm:14px;--font-size-base:16px;--font-size-md:18px;--font-size-lg:22px;--font-size-xl:28px;--font-size-2xl:36px;--font-weight-normal:400;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-base:1.5;--line-height-loose:1.75;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #0000001a, 0 2px 4px #0000000f;--shadow-lg:0 10px 30px #0000001f, 0 4px 8px #0000000f;--shadow-page:2px 2px 16px #00000024, -1px 0 6px #0000000a;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--color-bg:#f8f5f0;--color-surface:#fff;--color-surface-subtle:#faf8f5;--color-border:#e8e2d9;--color-border-strong:#cfc8bc;--color-text:#2d2a26;--color-text-muted:#7a7368;--color-text-faint:#b0a898;--page-width:clamp(300px, 90vw, 420px);--page-height:calc(var(--page-width) * 1.414);--page-padding:var(--spacing-lg);--spine-width:20px;--book-color-primary:#e8a87c;--book-color-secondary:#f7e0c8;--book-color-accent:#c46b3c;--book-color-page-bg:#fffdf8;--book-color-text:#3a2e24}[data-theme=fruehling]{--book-color-primary:#f9a8c9;--book-color-secondary:#fde8f2;--book-color-accent:#d4548a;--book-color-page-bg:#fff9fc;--book-color-text:#3a1f2e}[data-theme=weltraum]{--book-color-primary:#7c6ee8;--book-color-secondary:#e0ddff;--book-color-accent:#f0c040;--book-color-page-bg:#f5f4ff;--book-color-text:#1e1a3a}[data-theme=ozean]{--book-color-primary:#5bb8d4;--book-color-secondary:#d4f0f8;--book-color-accent:#e87c5a;--book-color-page-bg:#f5fbfd;--book-color-text:#1a3040}[data-theme=wald]{--book-color-primary:#6abf8a;--book-color-secondary:#d8f2e3;--book-color-accent:#c87942;--book-color-page-bg:#f6fcf8;--book-color-text:#1a3022}[data-theme=stadt]{--book-color-primary:#f07070;--book-color-secondary:#fde0e0;--book-color-accent:#3a7abf;--book-color-page-bg:#fff8f8;--book-color-text:#2e1a1a}[data-theme=pastell]{--book-color-primary:#c8b4e8;--book-color-secondary:#ede6f8;--book-color-accent:#f0a87c;--book-color-page-bg:#fdfaff;--book-color-text:#2e2040}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}body{min-height:100vh;line-height:var(--line-height-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul,ol{list-style:none}button{cursor:pointer;background:0 0;border:none}body{font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-bg);line-height:var(--line-height-base)}h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}h4{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}a{color:var(--book-color-accent);text-decoration:underline}a:hover{opacity:.8}input[type=text],input[type=email],input[type=password],input[type=date],input[type=number],input[type=url],textarea,select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);font-family:var(--font-body);color:var(--color-text);background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;outline:none;display:block}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=date]::placeholder,input[type=number]::placeholder,input[type=url]::placeholder,textarea::placeholder,select::placeholder{color:var(--color-text-faint)}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=date]:focus,input[type=number]:focus,input[type=url]:focus,textarea:focus,select:focus{border-color:var(--book-color-primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--book-color-primary) 20%, transparent)}input[type=text]:disabled,input[type=email]:disabled,input[type=password]:disabled,input[type=date]:disabled,input[type=number]:disabled,input[type=url]:disabled,textarea:disabled,select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-surface-subtle)}textarea{resize:vertical;min-height:80px}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237a7368' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center;padding-right:calc(var(--spacing-md) + 24px);cursor:pointer;background-size:16px}input[type=checkbox]{appearance:none;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);cursor:pointer;width:18px;height:18px;transition:border-color var(--transition-fast), background-color var(--transition-fast);flex-shrink:0;position:relative}input[type=checkbox]:checked{background-color:var(--book-color-primary);border-color:var(--book-color-primary)}input[type=checkbox]:checked:after{content:"";border:2px solid var(--book-color-page-bg,#fff);border-top:none;border-left:none;width:8px;height:12px;position:absolute;top:0;left:3px;transform:rotate(45deg)scaleY(.85)}input[type=checkbox]:focus-visible{border-color:var(--book-color-primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--book-color-primary) 20%, transparent);outline:none}.btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);font-family:var(--font-body);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:2px solid #0000;line-height:1;text-decoration:none;display:inline-flex}.btn--primary{background-color:var(--book-color-primary);color:var(--book-color-page-bg);border-color:var(--book-color-primary)}.btn--primary:hover{filter:brightness(.92);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--primary:active{transform:translateY(0)}.btn--secondary{color:var(--book-color-accent);border-color:var(--book-color-accent);background-color:#0000}.btn--secondary:hover{background-color:var(--book-color-secondary)}.btn--ghost{color:var(--color-text-muted);border-color:var(--color-border);background-color:#0000}.btn--ghost:hover{background-color:var(--color-surface-subtle);border-color:var(--color-border-strong)}.btn--danger{color:#fff;background-color:#e85a5a;border-color:#e85a5a}.btn--danger:hover{filter:brightness(.88);background-color:#e85a5a;border-color:#e85a5a}.btn--sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.btn--lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-md)}.btn--icon{padding:var(--spacing-sm);aspect-ratio:1;border-radius:var(--radius-full)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.flash{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-weight:var(--font-weight-semibold)}.flash--success{color:#1a6637;background-color:#d4f2e0;border:1.5px solid #6abd8c}.flash--error{color:#8b1a1a;background-color:#fde0e0;border:1.5px solid #e88080}.flash--info{color:#1a3a6b;background-color:#e0edf8;border:1.5px solid #80aae0}.flash--warning{color:#6b4a1a;background-color:#fdf3d4;border:1.5px solid #e8c470}.field-error{font-size:var(--font-size-sm);color:#c0392b;margin-top:var(--spacing-xs);display:block}.label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);margin-bottom:var(--spacing-xs);letter-spacing:.02em;text-transform:uppercase;display:block}.page{flex-direction:column;min-height:100vh;display:flex}.container{width:100%;max-width:1100px;padding-left:var(--spacing-md);padding-right:var(--spacing-md);margin-left:auto;margin-right:auto}.container--narrow{max-width:680px}.container--wide{max-width:1400px}.main{padding-top:calc(40px + var(--spacing-xl));padding-bottom:var(--spacing-2xl);flex:1}.main--entry{padding-top:40px}.card{background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-sm)}.card--raised{box-shadow:var(--shadow-md)}.card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-md)}.section{margin-bottom:var(--spacing-3xl)}.section__header{margin-bottom:var(--spacing-xl)}.section__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-xs)}.section__subtitle{color:var(--color-text-muted);font-size:var(--font-size-md)}.hero{text-align:center;padding:var(--spacing-3xl) var(--spacing-md)}.hero__title{font-size:clamp(var(--font-size-2xl), 5vw, 52px);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-md);font-family:var(--font-handwriting)}.hero__subtitle{font-size:var(--font-size-lg);color:var(--color-text-muted);max-width:560px;margin:0 auto var(--spacing-xl)}.hero__actions{gap:var(--spacing-md);flex-wrap:wrap;justify-content:center;display:flex}.empty-state{text-align:center;padding:var(--spacing-3xl) var(--spacing-xl);color:var(--color-text-muted)}.empty-state__icon{margin-bottom:var(--spacing-md);font-size:48px}.empty-state__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-sm)}.empty-state__text{font-size:var(--font-size-base);margin-bottom:var(--spacing-lg)}.grid{gap:var(--spacing-lg);display:grid}.grid--2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid--3{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.stack{flex-direction:column;display:flex}.stack--sm{gap:var(--spacing-sm)}.stack--md{gap:var(--spacing-md)}.stack--lg{gap:var(--spacing-lg)}.row{align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.row--between{justify-content:space-between}.row--center{justify-content:center}.divider{border:none;border-top:1.5px solid var(--color-border);margin:var(--spacing-xl) 0}.badge{padding:2px var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.04em;text-transform:uppercase;background-color:var(--book-color-secondary);color:var(--book-color-accent);align-items:center;display:inline-flex}.page--book{flex-direction:column;min-height:100vh;display:flex;position:relative}.main--book{flex-direction:column;flex:1;min-height:100vh;padding-top:0;display:flex}.main--book .book-viewer{flex:1;align-items:center}.site-header{background-color:var(--color-surface);border-bottom:1.5px solid var(--color-border);z-index:100;position:sticky;top:0;box-shadow:0 2px 8px #0000000a}.site-header__inner{height:60px;padding:0 var(--spacing-lg);justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;display:flex}.site-header__logo{align-items:center;gap:var(--spacing-sm);font-family:var(--font-handwriting);font-size:var(--font-size-lg);color:var(--book-color-accent);font-weight:700;text-decoration:none;display:flex}.site-header__logo:hover{opacity:.85}.site-header__logo-icon{font-size:24px}.site-header__nav{align-items:center;gap:var(--spacing-sm);display:flex}.site-header__user{align-items:center;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted);display:flex}.site-header--ghost{box-shadow:none;z-index:50;background:0 0;border-bottom:none;width:100%;position:absolute}.site-header--ghost .site-header__inner{height:40px}.site-header--bar{background:color-mix(in srgb, var(--color-surface) 85%, transparent);border-bottom:1px solid color-mix(in srgb, var(--color-border) 50%, transparent);-webkit-backdrop-filter:blur(12px);z-index:50;box-shadow:none;position:sticky;top:0}.site-header--bar .site-header__inner{height:auto;min-height:48px;padding:4px var(--spacing-lg)}.mode-tabs{align-items:stretch;gap:0;display:flex}.mode-tabs__tab{font-size:12px;font-weight:var(--font-weight-semibold);color:var(--color-text-muted);cursor:pointer;letter-spacing:.04em;text-transform:uppercase;transition:color var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 14px;font-family:inherit;line-height:1}.mode-tabs__tab--active{color:var(--color-text);border-bottom-color:var(--color-text)}.mode-tabs__tab:hover:not(.mode-tabs__tab--active){color:var(--color-text)}.edit-actions{align-items:center;gap:var(--spacing-md);display:flex}.edit-actions__status{color:var(--color-text-muted);opacity:.45;white-space:nowrap;font-size:11px}.edit-actions__cancel{font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;opacity:.55;transition:opacity var(--transition-fast);white-space:nowrap;background:0 0;border:none;padding:0;font-family:inherit}.edit-actions__cancel:hover{opacity:1}.edit-actions__submit{background:var(--book-color-accent);color:#fff;border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-semibold);cursor:pointer;transition:opacity var(--transition-fast);white-space:nowrap;border:none;padding:7px 18px;font-family:inherit}.edit-actions__submit:hover{opacity:.88}.edit-actions__submit:disabled{opacity:.5;cursor:default}.entry-mode-bar{z-index:45;justify-content:center;padding:4px 0;display:flex;position:relative}.entry-mode-bar .mode-tabs{pointer-events:auto}.entry-mode-bar .mode-tabs__tab{opacity:.3;border-bottom-color:#0000}.entry-mode-bar .mode-tabs__tab.mode-tabs__tab--active{opacity:.65;border-bottom-color:var(--color-text)}.entry-mode-bar .mode-tabs__tab:hover:not(.mode-tabs__tab--active){opacity:.55}@media (width<=768px){.entry-mode-bar{z-index:200;background:var(--color-surface);border-top:1px solid var(--color-border);padding:4px 0;padding-bottom:max(4px, env(safe-area-inset-bottom));position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0000000f}.main--entry{padding-bottom:80px}}.faf-logo{font-family:var(--font-handwriting);color:var(--color-text-muted);opacity:.35;letter-spacing:.04em;transition:opacity var(--transition-fast);font-size:17px;font-weight:700;line-height:1;text-decoration:none}.faf-logo:hover{opacity:.65}.auth-brand{font-family:var(--font-handwriting);font-size:var(--font-size-base);color:var(--color-text-muted);opacity:.45;font-weight:700}@media (width<=480px){.auth-brand{display:none}.site-header--ghost .site-header__inner{justify-content:center}}.ghost-actions{align-items:center;gap:var(--spacing-md);opacity:.4;transition:opacity var(--transition-fast);display:flex}.ghost-actions:hover{opacity:.75}.ghost-actions a,.ghost-actions button{font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-family:inherit;text-decoration:none}.ghost-actions a:hover,.ghost-actions button:hover{color:var(--color-text)}.ghost-actions .edit-actions__submit{background:var(--color-text-muted);color:var(--color-surface);border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-semibold);padding:5px 14px}.ghost-actions .edit-actions__submit:hover{background:var(--color-text);color:var(--color-surface)}.ghost-actions .edit-actions__submit:disabled{opacity:.5;cursor:default}.ghost-actions .edit-actions__status{opacity:.7;font-size:11px}.dashboard__welcome{margin-bottom:var(--spacing-2xl)}.dashboard__welcome h1{font-family:var(--font-handwriting);font-size:var(--font-size-2xl);color:var(--book-color-accent);margin-bottom:var(--spacing-xs)}.dashboard__welcome p{color:var(--color-text-muted)}.dashboard__books-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.dashboard__books-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.book-card{background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);transition:transform var(--transition-fast), box-shadow var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.book-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.book-card__cover{aspect-ratio:3/4;background-color:var(--book-color-secondary);padding:var(--spacing-lg);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.book-card__cover:before{content:"";background:linear-gradient(135deg, color-mix(in srgb, var(--book-color-primary) 15%, transparent), transparent 60%);position:absolute;inset:0}.book-card__cover-title{font-family:var(--font-handwriting);font-size:var(--font-size-lg);color:var(--book-color-accent);text-align:center;z-index:1;font-weight:700;line-height:1.3;position:relative}.book-card__cover-decoration{opacity:.25;font-size:36px;position:absolute}.book-card__cover-decoration--tl{top:var(--spacing-sm);left:var(--spacing-sm)}.book-card__cover-decoration--br{bottom:var(--spacing-sm);right:var(--spacing-sm)}.book-card__body{padding:var(--spacing-md) var(--spacing-lg);gap:var(--spacing-sm);flex-direction:column;flex:1;display:flex}.book-card__title{font-weight:var(--font-weight-bold);font-size:var(--font-size-md);color:var(--color-text)}.book-card__meta{font-size:var(--font-size-sm);color:var(--color-text-muted);align-items:center;gap:var(--spacing-xs);display:flex}.book-card__progress{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-muted);display:flex}.book-card__progress-bar{background-color:var(--color-border);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.book-card__progress-bar-fill{background-color:var(--book-color-primary);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.book-card__footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);gap:var(--spacing-sm);display:flex}.book-card--create{border:2px dashed var(--color-border-strong);cursor:pointer;min-height:280px;color:var(--color-text-muted);transition:all var(--transition-fast);background-color:#0000;justify-content:center;align-items:center;text-decoration:none}.book-card--create:hover{border-color:var(--book-color-primary);background-color:var(--book-color-secondary);color:var(--book-color-accent);box-shadow:var(--shadow-md);transform:translateY(-3px)}.book-card--create .book-card__create-icon{margin-bottom:var(--spacing-sm);font-size:36px}.book-card--create .book-card__create-label{font-weight:var(--font-weight-semibold);font-size:var(--font-size-md)}.form__group{margin-bottom:var(--spacing-lg)}.form__row{gap:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=480px){.form__row{grid-template-columns:1fr}}.form__hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs);display:block}.form__actions{gap:var(--spacing-md);margin-top:var(--spacing-xl);align-items:center;display:flex}@media (width<=480px){.form__actions{flex-direction:column}.form__actions .btn{width:100%}}.question-item{align-items:center;row-gap:4px;gap:var(--spacing-sm);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);cursor:default;flex-wrap:wrap;display:flex}.question-item--dragging{opacity:.5;border-style:dashed}.question-item--drag-over{border-color:var(--book-color-primary);background:color-mix(in srgb, var(--book-color-secondary) 60%, transparent)}.question-item__handle{cursor:grab;color:var(--color-text-faint);flex-shrink:0;font-size:18px;line-height:1}.question-item__label-input{font-size:var(--font-size-sm);border-radius:var(--radius-sm);color:var(--color-text);min-width:0;transition:border-color var(--transition-fast), background var(--transition-fast);background:0 0;border:1px solid #0000;flex:1;padding:3px 6px}.question-item__label-input:hover{border-color:var(--color-border)}.question-item__label-input:focus{border-color:var(--color-border-strong);background:var(--color-surface);outline:none}.question-item__type-badge{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-surface-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;padding:2px 8px}.question-item__remove{flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;display:flex}.question-item__placeholder-row{align-items:center;gap:var(--spacing-xs);padding-left:calc(26px + var(--spacing-sm));flex-basis:100%;display:flex}.question-item__placeholder-label{font-size:var(--font-size-xs);color:var(--color-text-faint);white-space:nowrap;flex-shrink:0}.question-item__placeholder-input{font-size:var(--font-size-xs);color:var(--color-text-muted);border-radius:var(--radius-sm);min-width:0;transition:border-color var(--transition-fast), background var(--transition-fast);background:0 0;border:1px solid #0000;flex:1;padding:2px 6px;font-style:italic}.question-item__placeholder-input:hover{border-color:var(--color-border)}.question-item__placeholder-input:focus{border-color:var(--color-border-strong);background:var(--color-surface);outline:none}.auth-form{max-width:440px;margin:var(--spacing-3xl) auto;padding:var(--spacing-md)}.auth-form__card{background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-md)}@media (width<=480px){.auth-form__card{padding:var(--spacing-lg)}}.auth-form__logo{text-align:center;margin-bottom:var(--spacing-xl)}.auth-form__logo span{font-family:var(--font-handwriting);font-size:var(--font-size-2xl);color:var(--book-color-accent);font-weight:700}.auth-form__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);text-align:center;margin-bottom:var(--spacing-xs)}.auth-form__subtitle{text-align:center;color:var(--color-text-muted);margin-bottom:var(--spacing-xl);font-size:var(--font-size-sm)}.auth-form__footer{text-align:center;margin-top:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-muted)}.auth-form__footer a{color:var(--book-color-accent);font-weight:var(--font-weight-semibold)}.auth-form__separator{text-align:center;margin:var(--spacing-lg) 0;color:var(--color-text-faint);font-size:var(--font-size-sm);position:relative}.auth-form__separator:before,.auth-form__separator:after{content:"";background:var(--color-border);width:calc(50% - 30px);height:1px;position:absolute;top:50%}.auth-form__separator:before{left:0}.auth-form__separator:after{right:0}.admin-header{justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);display:flex}.admin-header h1{margin:0}.admin-breadcrumb{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-xs);display:inline-block}.admin-breadcrumb:hover{color:var(--color-text)}.admin-nav{gap:var(--spacing-md);flex-direction:column;display:flex}.admin-nav__count{min-width:22px;height:22px;padding:0 var(--spacing-xs);border-radius:var(--radius-full);background:var(--color-border);font-size:var(--font-size-xs);margin-left:var(--spacing-sm);justify-content:center;align-items:center;display:inline-flex}.admin-table-wrap{border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.admin-table th,.admin-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border);vertical-align:middle}.admin-table thead th{color:var(--color-text-muted);background:var(--color-surface);font-weight:600}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table__name{font-weight:500}.admin-table__actions{align-items:center;gap:var(--spacing-xs);white-space:nowrap;display:flex}.admin-swatches{align-items:center;gap:4px;display:flex}.admin-swatch{border-radius:var(--radius-sm);border:1px solid #0000001f;flex-shrink:0;width:20px;height:20px;display:block}.badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);align-items:center;padding:2px 8px;font-weight:500;display:inline-flex}.badge--success{color:#065f46;background:#d1fae5}.badge--muted{background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border)}.label--hint{cursor:help;position:relative}.label--hint:after{content:attr(data-tooltip);background:var(--color-text);color:#fff;font-size:11px;font-weight:var(--font-weight-normal);border-radius:var(--radius-sm);white-space:normal;pointer-events:none;opacity:0;z-index:20;width:max-content;max-width:220px;padding:6px 10px;line-height:1.5;transition:opacity .15s;position:absolute;bottom:calc(100% + 7px);left:0;box-shadow:0 2px 8px #0000002e}.label--hint:hover:after{opacity:1}.label--hint{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;-webkit-text-decoration-color:var(--color-text-faint);text-decoration-color:var(--color-text-faint);text-underline-offset:3px}.admin-form{max-width:900px}.admin-form__colors-row{margin-bottom:var(--spacing-lg)}.admin-form__colors{gap:var(--spacing-md);margin-top:var(--spacing-md);grid-template-columns:repeat(5,1fr);display:grid}.admin-form__colors .form__group{margin-bottom:0}.admin-form__colors .label{margin-bottom:4px}.admin-form__colors #generate-colors-btn{grid-column:1/-1;justify-self:start}@media (width<=800px){.admin-form__colors{grid-template-columns:repeat(3,1fr)}}@media (width<=500px){.admin-form__colors{grid-template-columns:repeat(2,1fr)}}.admin-form__preview-tabs{gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);display:flex}.admin-form__preview-tab{padding:4px var(--spacing-sm);font-size:var(--font-size-sm);border:1.5px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0}.admin-form__preview-tab:hover{border-color:var(--color-text);color:var(--color-text)}.admin-form__preview-tab--active{border-color:var(--color-text);color:var(--color-text);font-weight:var(--font-weight-semibold)}.admin-form__preview-spread{border-radius:var(--radius-md);border:1.5px solid var(--color-border);overflow:hidden}.admin-form__preview-spread .book-spread{zoom:.6;pointer-events:none}.admin-form__preview-spread--cover{padding:var(--spacing-lg);background:var(--color-surface-subtle);justify-content:center;align-items:center;display:flex}.admin-form__preview-spread--cover .book-cover{zoom:.6;pointer-events:none}.admin-form__meta{gap:var(--spacing-xl);margin-bottom:var(--spacing-lg);flex-wrap:wrap;align-items:flex-end;display:flex}.admin-form__actions{justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex}.form__group--inline,.color-input-wrap{align-items:center;gap:var(--spacing-sm);display:flex}.color-input-wrap input[type=color]{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;width:40px;height:40px;padding:2px}.color-input-hex{width:90px;font-family:monospace;font-size:var(--font-size-sm)}.admin-form__appearance{gap:var(--spacing-lg);flex-wrap:wrap;display:flex}.admin-form__appearance .form__group{margin-bottom:0}.option-pill-group{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.option-pill{cursor:pointer;align-items:center;display:flex}.option-pill input[type=radio]{opacity:0;width:0;height:0;position:absolute}.option-pill span{padding:5px var(--spacing-sm);border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-text-muted);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;display:inline-block}.option-pill input[type=radio]:checked+span{border-color:var(--color-text);color:var(--color-text);font-weight:var(--font-weight-semibold)}.option-pill:hover span{border-color:var(--color-text);color:var(--color-text)}.book-spread{--color-text:var(--book-color-text);padding:var(--spacing-sm) var(--spacing-md);padding-bottom:calc(var(--spacing-2xl) + 10px);justify-content:center;align-items:flex-start;display:flex}@media (width>=768px){.book-spread{padding:var(--spacing-md) var(--spacing-xl);padding-bottom:calc(var(--spacing-2xl) + 10px)}}.book-spread__inner{align-items:flex-start;gap:0;display:flex;position:relative}@media (width<=767px){.book-spread__inner{width:100%;max-width:var(--page-width);flex-direction:column}}@media (width>=768px){.book-spread__inner{border-radius:var(--radius-md);box-shadow:0 4px 0 0 color-mix(in srgb, var(--book-color-page-bg) 88%, #2d2a26), 0 7px 0 0 color-mix(in srgb, var(--book-color-page-bg) 80%, #2d2a26), 0 10px 0 0 color-mix(in srgb, var(--book-color-page-bg) 72%, #2d2a26), 0 14px 30px #00000024, 0 6px 10px #00000014}}.book-spread__page{width:var(--page-width);min-height:var(--page-height);background-color:var(--book-color-page-bg);color:var(--book-color-text);padding:var(--page-padding);position:relative;overflow:hidden}@media (width>=900px){.book-spread__page{width:clamp(340px,41vw,600px);min-height:680px}}@media (width<=767px){.book-spread__page{border-radius:var(--radius-xl);width:100%;min-height:0;box-shadow:var(--shadow-page);margin-bottom:var(--spacing-lg)}}@media (width>=768px){.book-spread__page--left{border-radius:var(--radius-md) 0 0 var(--radius-md);box-shadow:inset -4px 0 8px #0000000f}.book-spread__page--right{border-radius:0 var(--radius-md) var(--radius-md) 0;box-shadow:inset 4px 0 8px #0000000a}}.book-spread__page:after{content:"";pointer-events:none;background-image:repeating-linear-gradient(transparent, transparent 27px, color-mix(in srgb, var(--book-color-primary) 8%, transparent) 27px, color-mix(in srgb, var(--book-color-primary) 8%, transparent) 28px);background-position:0 var(--page-padding);z-index:0;position:absolute;inset:0}.book-spread__page>*{z-index:1;position:relative}.book-spread__page[data-deco]:before{content:"";pointer-events:none;z-index:0;background-position:0 0;background-repeat:no-repeat;background-size:500px 720px;position:absolute;inset:0}.book-spread__page[data-deco=lines]:before{background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 720' width='500' height='720'><defs><filter id='f'><feTurbulence type='fractalNoise' baseFrequency='0.013 0.005' numOctaves='5' seed='5' result='n'/><feDisplacementMap in='SourceGraphic' in2='n' scale='24' xChannelSelector='R' yChannelSelector='G'/></filter></defs><g fill='none' stroke='%23000' stroke-width='2.2' opacity='0.085' filter='url(%23f)'><line x1='-380' y1='-10' x2='350' y2='720'/><line x1='-348' y1='-10' x2='382' y2='720'/><line x1='-316' y1='-10' x2='414' y2='720'/><line x1='-284' y1='-10' x2='446' y2='720'/><line x1='-252' y1='-10' x2='478' y2='720'/><line x1='-220' y1='-10' x2='510' y2='720'/><line x1='-188' y1='-10' x2='542' y2='720'/><line x1='-156' y1='-10' x2='574' y2='720'/><line x1='-124' y1='-10' x2='606' y2='720'/><line x1='-92' y1='-10' x2='638' y2='720'/><line x1='-60' y1='-10' x2='670' y2='720'/><line x1='-28' y1='-10' x2='702' y2='720'/><line x1='4' y1='-10' x2='734' y2='720'/><line x1='36' y1='-10' x2='766' y2='720'/><line x1='68' y1='-10' x2='798' y2='720'/><line x1='100' y1='-10' x2='830' y2='720'/><line x1='132' y1='-10' x2='862' y2='720'/><line x1='164' y1='-10' x2='894' y2='720'/><line x1='196' y1='-10' x2='926' y2='720'/><line x1='228' y1='-10' x2='958' y2='720'/><line x1='260' y1='-10' x2='990' y2='720'/></g></svg>")}.book-spread__page[data-deco=waves]:before{background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 720' width='500' height='720'><defs><filter id='f'><feTurbulence type='fractalNoise' baseFrequency='0.011' numOctaves='6' seed='3' result='n'/><feDisplacementMap in='SourceGraphic' in2='n' scale='26' xChannelSelector='R' yChannelSelector='G'/></filter></defs><g fill='none' stroke='%23000' stroke-width='3.5' stroke-dasharray='20 9' opacity='0.075' filter='url(%23f)'><path d='M -30 -10 C 160 170 -50 420 130 730'/><path d='M 30 -10 C 220 170 10 420 190 730'/><path d='M 90 -10 C 280 170 70 420 250 730'/><path d='M 150 -10 C 340 170 130 420 310 730'/><path d='M 210 -10 C 400 170 190 420 370 730'/><path d='M 270 -10 C 460 170 250 420 430 730'/><path d='M 330 -10 C 520 170 310 420 490 730'/><path d='M 390 -10 C 580 170 370 420 550 730'/></g></svg>")}.book-spread__page[data-deco=loops]:before{background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 720' width='500' height='720'><defs><filter id='f'><feTurbulence type='fractalNoise' baseFrequency='0.028' numOctaves='5' seed='11' result='n'/><feDisplacementMap in='SourceGraphic' in2='n' scale='16' xChannelSelector='R' yChannelSelector='G'/></filter></defs><g fill='none' stroke='%23000' stroke-width='3.5' opacity='0.08' filter='url(%23f)'><ellipse cx='80' cy='85' rx='58' ry='42'/><ellipse cx='280' cy='65' rx='50' ry='37'/><ellipse cx='440' cy='105' rx='55' ry='40'/><ellipse cx='170' cy='195' rx='64' ry='47'/><ellipse cx='390' cy='210' rx='54' ry='40'/><ellipse cx='75' cy='310' rx='58' ry='43'/><ellipse cx='300' cy='295' rx='62' ry='46'/><ellipse cx='460' cy='345' rx='50' ry='37'/><ellipse cx='165' cy='425' rx='66' ry='49'/><ellipse cx='385' cy='445' rx='55' ry='41'/><ellipse cx='85' cy='545' rx='60' ry='44'/><ellipse cx='300' cy='530' rx='62' ry='46'/><ellipse cx='460' cy='605' rx='52' ry='38'/><ellipse cx='185' cy='650' rx='58' ry='43'/></g></svg>")}[data-page-lines=plain] .book-spread__page:after{display:none}[data-page-lines=dotted] .book-spread__page:after{background-image:radial-gradient(circle, color-mix(in srgb, var(--book-color-primary) 22%, transparent) 1.2px, transparent 1.2px);background-size:20px 20px;background-position:20px var(--page-padding)}[data-cover-texture=linen] .book-cover__face{background-image:repeating-linear-gradient(0deg,#ffffff1a 0 1px,#0000 0 4px),repeating-linear-gradient(90deg,#ffffff1a 0 1px,#0000 0 4px)}[data-cover-texture=canvas] .book-cover__face{background-image:repeating-linear-gradient(45deg,#ffffff1a 0 1px,#0000 0 6px),repeating-linear-gradient(-45deg,#ffffff1a 0 1px,#0000 0 6px)}[data-cover-texture=grain] .book-cover__face{background-image:radial-gradient(#0000001f 1px,#0000 1px);background-size:3px 3px}.book-spread__spine{width:var(--spine-width);background:linear-gradient(to right, color-mix(in srgb, var(--book-color-page-bg) 82%, #2d2a26), color-mix(in srgb, var(--book-color-page-bg) 92%, #2d2a26), color-mix(in srgb, var(--book-color-page-bg) 85%, #2d2a26));z-index:1;flex-shrink:0;align-self:stretch;display:none;position:relative}@media (width>=768px){.book-spread__spine{display:block}}.spread-canvas{pointer-events:none;z-index:10;width:100%;height:100%;position:absolute;inset:0}.spread-stickers{pointer-events:none;z-index:11;width:100%;height:100%;position:absolute;inset:0}[data-mode=draw] .spread-canvas{pointer-events:auto;cursor:crosshair;touch-action:none}[data-mode=draw] .book-spread__page{pointer-events:none}[data-mode=sticker] .spread-stickers{pointer-events:auto}[data-mode=sticker] .spread-sticker{touch-action:none}[data-mode=sticker] .book-spread__page{pointer-events:none}.page-number{bottom:var(--spacing-md);font-family:var(--font-handwriting);font-size:var(--font-size-md);color:var(--book-color-text,var(--color-text));opacity:.7;font-weight:var(--font-weight-semibold);z-index:2;position:absolute}.page-number--left{left:var(--page-padding)}.page-number--right{right:var(--page-padding)}.page-corner{opacity:.2;z-index:2;font-size:20px;position:absolute}.page-corner--tl{top:var(--spacing-md);left:var(--spacing-md)}.page-corner--tr{top:var(--spacing-md);right:var(--spacing-md)}.page-corner--bl{bottom:calc(var(--spacing-md) * 2);left:var(--spacing-md)}.page-corner--br{bottom:calc(var(--spacing-md) * 2);right:var(--spacing-md)}.spread-owner-banner{font-size:11px;font-weight:var(--font-weight-semibold);letter-spacing:.07em;text-transform:uppercase;color:var(--book-color-accent);opacity:.75;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1.5px solid color-mix(in srgb, var(--book-color-accent) 30%, transparent);pointer-events:none}.aob-field__pairs{flex-direction:column;gap:0;padding:2px 0;display:flex}.aob-field__pair{grid-template-columns:1fr auto 1fr;align-items:baseline;gap:0 2px;line-height:1.65;display:grid}.aob-field__sep{color:color-mix(in srgb, var(--book-color-accent) 55%, transparent);text-align:center;padding:0 2px;font-size:.75em}.aob-field__option{padding:1px 5px;font-size:11px;line-height:1.5;position:relative}.aob-field__option:first-child{text-align:right;justify-self:end}.aob-field__option:last-child{text-align:left;justify-self:start}.aob-field__option--interactive{cursor:pointer}.aob-field__option--interactive:hover:after{content:"";border:1.5px solid color-mix(in srgb, var(--book-color-accent) 38%, transparent);pointer-events:none;border-radius:50%;position:absolute;inset:-3px -6px;transform:rotate(3deg)scaleX(1.06)}.aob-field__option--chosen{color:var(--book-color-accent);font-weight:var(--font-weight-semibold)}.aob-field__option--chosen:after{content:"";border:1.5px solid var(--book-color-accent);pointer-events:none;border-radius:50%;position:absolute;inset:-3px -7px;transform:rotate(-2deg)scaleX(1.08)}.aob-field__option--unchosen{opacity:.28}.age-field{margin-bottom:var(--spacing-md)}.age-field__options{padding:var(--spacing-xs) 0;flex-wrap:wrap;align-items:flex-end;gap:2px;display:flex}.age-field__option{font-family:var(--font-handwriting);cursor:default;padding:6px 7px 4px;font-size:20px;line-height:1.3;position:relative}.age-field__option__etwa{display:none}.age-field__option--interactive{cursor:pointer}.age-field__option--interactive:hover:after{content:"";border:1.5px solid color-mix(in srgb, var(--book-color-accent) 40%, transparent);pointer-events:none;border-radius:50%;position:absolute;inset:-2px -5px;transform:rotate(2deg)scaleX(1.05)}.age-field__option--chosen{color:var(--book-color-accent);font-weight:var(--font-weight-semibold)}.age-field__option--chosen:after{content:"";border:1.5px solid var(--book-color-accent);pointer-events:none;border-radius:50%;position:absolute;inset:-2px -6px;transform:rotate(-2deg)scaleX(1.08)}.age-field__option--unchosen{opacity:.22}.age-field__etwa{font-family:var(--font-body);font-size:8px;font-weight:var(--font-weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--book-color-accent);opacity:0;white-space:nowrap;pointer-events:none;transition:opacity .15s;display:block;position:absolute;top:-2px;left:50%;transform:translate(-50%)}.age-field__option--interactive:hover .age-field__etwa{opacity:.7}.age-field__option--chosen .age-field__etwa{opacity:1}.paint-area{margin-bottom:var(--spacing-md)}.paint-area__box{background:color-mix(in srgb, var(--book-color-primary) 12%, var(--book-color-page-bg));border-radius:var(--radius-sm);border:1.5px dashed color-mix(in srgb, var(--book-color-primary) 35%, transparent);min-height:90px;position:relative}.paint-area__hint{letter-spacing:.06em;text-transform:uppercase;color:var(--book-color-primary);opacity:.5;pointer-events:none;justify-content:center;align-items:center;font-size:10px;display:flex;position:absolute;inset:0}.range-field{margin-bottom:var(--spacing-md)}.range-field__row{grid-template-columns:1fr 90px 1fr;align-items:center;gap:6px;margin-bottom:4px;display:grid}.range-field__term{font-size:10px;font-family:var(--font-body);font-weight:var(--font-weight-semibold);letter-spacing:.04em;color:color-mix(in srgb, var(--book-color-text,var(--color-text)) 55%, transparent);line-height:1.3}.range-field__term--left{text-align:right}.range-field__term--right{text-align:left}.range-field__track{cursor:crosshair;align-items:center;height:28px;display:flex;position:relative}.range-field__line{background:color-mix(in srgb, var(--book-color-primary) 50%, transparent);width:100%;height:1.5px}.range-field__marker{font-family:var(--font-handwriting);color:var(--book-color-accent);pointer-events:none;font-size:17px;line-height:1;display:none;position:absolute;top:50%;transform:translate(-50%,-50%)}.entry-card{background-color:var(--book-color-page-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-page);width:var(--page-width);position:relative;overflow:hidden}@media (width<=767px){.entry-card{width:100%}}.entry-card__photo{aspect-ratio:4/3;background-color:var(--book-color-secondary);justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.entry-card__photo img{object-fit:cover;width:100%;height:100%}.entry-card__photo-placeholder{opacity:.3;font-size:48px}.entry-card__body{padding:var(--spacing-lg);position:relative}.entry-card__name{font-family:var(--font-handwriting);font-size:var(--font-size-xl);color:var(--book-color-accent);margin-bottom:var(--spacing-xs);font-weight:700;line-height:1.2}.entry-card__date{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-md);font-family:var(--font-handwriting)}.entry-card__answers{gap:var(--spacing-md);flex-direction:column;display:flex}.entry-card__answer-question{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.entry-card__answer-value{font-family:var(--font-handwriting);font-size:var(--font-size-md);color:var(--book-color-text);line-height:var(--line-height-base)}.entry-card__drawing{width:100%;margin-top:var(--spacing-md);border-radius:var(--radius-sm);overflow:hidden}.entry-card__drawing img{width:100%;display:block}.entry-card__stickers{pointer-events:none;position:absolute;inset:0;overflow:hidden}.entry-card__sticker{transform-origin:50%;transform:translate(-50%, -50%) rotate(var(--sticker-rotation,0deg)) scale(var(--sticker-scale,1));-webkit-user-select:none;user-select:none;font-size:28px;line-height:1;position:absolute}.entry-card__sticker--image{font-size:0}.entry-card__sticker--image img{object-fit:contain;pointer-events:none;width:40px;height:40px;display:block}.entry-card__page-num{bottom:var(--spacing-sm);right:var(--spacing-md);font-family:var(--font-handwriting);font-size:var(--font-size-sm);color:var(--book-color-accent);opacity:.5;position:absolute}.page-slot{background-color:var(--book-color-page-bg);border-radius:var(--radius-xl);border:2px dashed color-mix(in srgb, var(--book-color-primary) 40%, transparent);width:var(--page-width);aspect-ratio:1/1.414;justify-content:center;align-items:center;gap:var(--spacing-sm);opacity:.5;flex-direction:column;display:flex}@media (width<=767px){.page-slot{width:100%}}.page-slot__icon{opacity:.4;font-size:32px}.page-slot__text{font-size:var(--font-size-sm);color:var(--color-text-muted)}.wizard{max-width:720px;margin:0 auto}.wizard__header{text-align:center;margin-bottom:var(--spacing-2xl)}.wizard__header h1{font-family:var(--font-handwriting);font-size:var(--font-size-2xl);color:var(--book-color-accent);margin-bottom:var(--spacing-xs)}.wizard__header p{color:var(--color-text-muted)}.wizard__progress{margin-bottom:var(--spacing-2xl);justify-content:center;align-items:flex-start;gap:0;max-width:360px;margin-left:auto;margin-right:auto;display:flex}.wizard__step-indicator{align-items:center;gap:var(--spacing-xs);flex-direction:column;flex:1;display:flex;position:relative}.wizard__step-indicator:not(:last-child):after{content:"";background-color:var(--color-border);z-index:0;height:2px;position:absolute;top:17px;left:calc(50% + 20px);right:calc(20px - 50%)}.wizard__step-indicator--done:after{background-color:var(--book-color-primary)!important}.wizard__step-dot{border-radius:var(--radius-full);border:2px solid var(--color-border);background-color:var(--color-surface);width:36px;height:36px;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-faint);z-index:1;transition:all var(--transition-base);justify-content:center;align-items:center;display:flex;position:relative}.wizard__step-indicator--active .wizard__step-dot{background-color:var(--book-color-primary);border-color:var(--book-color-primary);color:#fff;box-shadow:0 0 0 4px color-mix(in srgb, var(--book-color-primary) 25%, transparent)}.wizard__step-indicator--done .wizard__step-dot{background-color:var(--book-color-accent);border-color:var(--book-color-accent);color:#fff}.wizard__step-label{font-size:var(--font-size-xs);color:var(--color-text-faint);text-align:center;max-width:80px}.wizard__step-indicator--active .wizard__step-label{color:var(--book-color-accent);font-weight:var(--font-weight-semibold)}.wizard__step-indicator--done .wizard__step-label{color:var(--color-text-muted)}.wizard__steps{position:relative}.wizard__step{background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-md);animation:stepFadeIn var(--transition-base) ease-out;display:none}@media (width<=480px){.wizard__step{padding:var(--spacing-lg)}}.wizard__step[data-active]{display:block}.wizard__step__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-xs)}.wizard__step__subtitle{color:var(--color-text-muted);margin-bottom:var(--spacing-xl)}.wizard__nav{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1.5px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.wizard__nav-next{margin-left:auto}@keyframes stepFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.theme-picker__grid{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}@media (width<=480px){.theme-picker__grid{grid-template-columns:repeat(2,1fr)}}.theme-picker__option{border:2.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.theme-picker__option:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.theme-picker__option--selected{box-shadow:0 0 0 3px color-mix(in srgb, var(--book-color-accent) 20%, transparent);border-color:var(--book-color-accent)!important}.theme-picker__option--selected .theme-picker__checkmark{opacity:1}.theme-picker__option input[type=radio]{opacity:0;pointer-events:none;position:absolute}.theme-picker__preview{aspect-ratio:3/2;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.theme-picker__swatches{bottom:var(--spacing-sm);left:var(--spacing-sm);gap:4px;display:flex;position:absolute}.theme-picker__swatch{border-radius:var(--radius-full);border:1.5px solid #ffffff80;width:16px;height:16px}.theme-picker__svg{opacity:.7;width:60%;height:60%}.theme-picker__checkmark{top:var(--spacing-sm);right:var(--spacing-sm);background-color:var(--book-color-accent);border-radius:var(--radius-full);color:#fff;opacity:0;width:22px;height:22px;transition:opacity var(--transition-fast);justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute}.theme-picker__label{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);text-align:center}.theme-picker__ai{background-color:var(--color-surface-subtle);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.theme-picker__ai-header{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.theme-picker__ai-header h4{font-size:var(--font-size-base);font-weight:var(--font-weight-bold)}.theme-picker__ai-header-icon{font-size:20px}.theme-picker__ai-input{gap:var(--spacing-sm);display:flex}.theme-picker__ai-input input{flex:1}@media (width<=480px){.theme-picker__ai-input{flex-direction:column}}.theme-picker__ai-result{margin-top:var(--spacing-md);display:none}.theme-picker__ai-result[data-visible]{display:block}.theme-picker__ai-loading{align-items:center;gap:var(--spacing-sm);color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-md) 0;display:none}.theme-picker__ai-loading[data-visible]{display:flex}.theme-picker__ai-attempts{font-size:var(--font-size-xs);color:var(--color-text-faint);text-align:right;margin-top:var(--spacing-xs)}.spinner{border:2px solid var(--color-border);border-top-color:var(--book-color-accent);border-radius:var(--radius-full);flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.drawing-canvas__wrapper{border:2px solid var(--color-border);border-radius:var(--radius-md);touch-action:none;background-color:#fff;position:relative;overflow:hidden}.drawing-canvas__canvas{cursor:crosshair;width:100%;height:auto;display:block}.drawing-canvas__canvas--erasing{cursor:cell}.drawing-canvas__toolbar{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-surface-subtle);border-top:1px solid var(--color-border);flex-wrap:wrap;display:flex}.drawing-canvas__tool-group{align-items:center;gap:4px;display:flex}.drawing-canvas__tool-group:not(:last-child){padding-right:var(--spacing-sm);border-right:1px solid var(--color-border)}.drawing-canvas__tool-btn{border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background-color:var(--color-surface);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);color:var(--color-text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.drawing-canvas__tool-btn:hover{background-color:var(--book-color-secondary);border-color:var(--book-color-primary)}.drawing-canvas__tool-btn--active{background-color:var(--book-color-primary);border-color:var(--book-color-primary);color:#fff}.drawing-canvas__colors{align-items:center;gap:4px;display:flex}.drawing-canvas__color{border-radius:var(--radius-full);cursor:pointer;width:22px;height:22px;transition:transform var(--transition-fast);outline-offset:2px;border:2px solid #0000}.drawing-canvas__color:hover{transform:scale(1.15)}.drawing-canvas__color--active{border-color:var(--color-text);transform:scale(1.1)}.drawing-canvas__sizes{align-items:center;gap:4px;display:flex}.drawing-canvas__size{border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background-color:var(--color-surface);cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.drawing-canvas__size:hover{border-color:var(--book-color-primary)}.drawing-canvas__size--active{background-color:var(--book-color-secondary);border-color:var(--book-color-primary)}.drawing-canvas__size-dot{border-radius:var(--radius-full);background-color:var(--color-text);flex-shrink:0}.drawing-canvas__actions{gap:4px;margin-left:auto;display:flex}.sticker-picker{border:1.5px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-surface);overflow:hidden}.sticker-picker__body{max-height:300px;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md);scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;overflow-y:auto}.sticker-picker__body::-webkit-scrollbar{width:4px}.sticker-picker__body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.sticker-picker__section-header{font-size:10px;font-weight:var(--font-weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);padding:var(--spacing-xs) 0 4px;margin-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border)}.sticker-picker__section-header:not(:first-child){margin-top:var(--spacing-md)}.sticker-picker__grid{flex-wrap:wrap;gap:2px;margin-bottom:2px;display:flex}.sticker-picker__emoji{text-align:center;cursor:pointer;border-radius:var(--radius-sm);width:36px;height:36px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:22px;line-height:1;display:flex}.sticker-picker__emoji:hover{background-color:var(--book-color-secondary);transform:scale(1.2)}.sticker-picker__emoji:active{transform:scale(1.1)}.sticker-picker__image{cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);justify-content:center;align-items:center;width:72px;height:72px;padding:4px;display:flex}.sticker-picker__image img{object-fit:contain;pointer-events:none;width:62px;height:62px;display:block}.sticker-picker__image:hover{background-color:var(--book-color-secondary);transform:scale(1.15)}.sticker-picker__image:active{transform:scale(1.05)}.photo-upload__zone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-fast);background-color:var(--color-surface-subtle);display:block;position:relative}.photo-upload__zone:hover,.photo-upload__zone--drag-over{border-color:var(--book-color-primary);background-color:var(--book-color-secondary)}.photo-upload__input{clip:rect(0, 0, 0, 0);white-space:nowrap;pointer-events:none;width:1px;height:1px;position:absolute;overflow:hidden}.photo-upload__icon{margin-bottom:var(--spacing-sm);opacity:.5;font-size:40px}.photo-upload__text{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-xs)}.photo-upload__hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.photo-upload__preview{border-radius:var(--radius-lg);background-color:var(--color-surface-subtle);display:none;position:relative;overflow:hidden}.photo-upload__preview[data-visible]{display:block}.photo-upload__preview img{object-fit:cover;width:100%;max-height:300px;display:block}.photo-upload__preview-actions{top:var(--spacing-xs);right:var(--spacing-xs);gap:var(--spacing-xs);opacity:0;transition:opacity var(--transition-fast);display:flex;position:absolute}.photo-upload__preview:hover .photo-upload__preview-actions{opacity:1}.photo-upload__preview-actions .btn{color:#fff;text-align:center;cursor:pointer;width:24px;height:24px;transition:background var(--transition-fast);background:#000000bf;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:13px;line-height:24px;display:flex}.photo-upload__preview-actions .btn:hover{background:#000000f2}.lock-banner{border-radius:var(--radius-lg);padding:var(--spacing-lg) var(--spacing-xl);align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);background-color:#fdf3d4;border:1.5px solid #e8c470;display:flex}.lock-banner__icon{flex-shrink:0;margin-top:2px;font-size:28px}.lock-banner__body{flex:1}.lock-banner__title{font-weight:var(--font-weight-bold);color:#6b4a1a;margin-bottom:var(--spacing-xs)}.lock-banner__text{font-size:var(--font-size-sm);color:#7d5a22;line-height:var(--line-height-loose)}.lock-banner__refresh{align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:#6b4a1a;display:flex}.lock-banner__refresh-countdown{font-weight:var(--font-weight-semibold)}.share-banner{background:color-mix(in srgb, var(--book-color-secondary) 70%, transparent);border-bottom:1.5px solid color-mix(in srgb, var(--book-color-primary) 30%, transparent);padding:var(--spacing-md) var(--spacing-xl)}.share-banner__inner{max-width:900px;margin:0 auto}.share-banner__title{font-weight:var(--font-weight-bold);color:var(--color-text);margin-bottom:2px}.share-banner__text{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.share-banner__link-row{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.share-banner__url{font-size:var(--font-size-sm);color:var(--color-text-faint);text-overflow:ellipsis;white-space:nowrap;max-width:min(480px,60vw);font-family:monospace;overflow:hidden}.share-banner__copy-btn{background:var(--book-color-accent);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:opacity var(--transition-fast);border:none;flex-shrink:0;padding:5px 14px;font-family:inherit}.share-banner__copy-btn:hover{opacity:.85}.book-full-banner{text-align:center;padding:var(--spacing-3xl) var(--spacing-xl);background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);max-width:480px;margin:0 auto}.book-full-banner__icon{margin-bottom:var(--spacing-md);font-size:48px}.book-full-banner__title{font-family:var(--font-handwriting);font-size:var(--font-size-xl);color:var(--book-color-accent);margin-bottom:var(--spacing-sm);font-weight:700}.book-full-banner__text{color:var(--color-text-muted);line-height:var(--line-height-loose)}.progress-ring{align-items:center;gap:var(--spacing-xs);flex-direction:column;display:inline-flex}.progress-ring__svg{transform:rotate(-90deg)}.progress-ring__track{fill:none;stroke:var(--color-border);stroke-width:4px}.progress-ring__fill{fill:none;stroke:var(--book-color-primary);stroke-width:4px;stroke-linecap:round;transition:stroke-dashoffset var(--transition-slow)}.progress-ring__text{fill:var(--color-text);text-anchor:middle;dominant-baseline:central;font-size:14px;font-weight:700;font-family:var(--font-body);transform:rotate(90deg)translate(0)}.progress-ring__label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center;text-transform:uppercase;letter-spacing:.04em}.pages-remaining{align-items:center;gap:var(--spacing-sm);background-color:var(--book-color-secondary);border:1.5px solid color-mix(in srgb, var(--book-color-primary) 40%, transparent);border-radius:var(--radius-full);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--book-color-accent);display:flex}.pages-remaining__icon{font-size:16px}.page-top{align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md);display:flex}.page-top__fields{flex:1;min-width:0}.page-photo{transform-origin:top;flex-shrink:0;width:110px;margin-top:4px;transform:rotate(-2.5deg)}.page-photo .photo-upload{background:#fff;padding:7px 7px 22px;box-shadow:2px 3px 10px #0000002e,0 1px 3px #0000001a}.page-photo .photo-upload__zone{background:color-mix(in srgb, var(--book-color-primary) 12%, #f0ede8);border:none;border-radius:0;flex-direction:column;justify-content:center;align-items:center;min-height:100px;padding:0;display:flex}.page-photo .photo-upload__zone:hover,.page-photo .photo-upload__zone--drag-over{background:color-mix(in srgb, var(--book-color-primary) 22%, #f0ede8)}.page-photo .photo-upload__icon{opacity:.6;margin-bottom:2px;font-size:22px}.page-photo .photo-upload__text{opacity:.7;font-size:11px}.page-photo .photo-upload__hint{display:none}.page-photo .photo-upload__preview{border-radius:0}.page-photo .photo-upload__preview img{object-fit:cover;border-radius:0;width:100%;height:100px;display:block}.page-field{margin-bottom:var(--spacing-md)}.page-field__label{text-transform:uppercase;letter-spacing:.1em;color:color-mix(in srgb, var(--book-color-text,var(--color-text)) 60%, transparent);font-size:12px;font-family:var(--font-body);font-weight:var(--font-weight-semibold);margin-bottom:2px}.page-field__content{font-family:var(--font-handwriting);color:var(--book-color-text,var(--color-text));border-bottom:1.5px dashed color-mix(in srgb, var(--book-color-primary) 60%, transparent);word-break:break-word;outline:none;width:100%;min-height:1.5em;padding:1px 0 4px;font-size:20px;line-height:1.4em}.page-field__content:empty:before{content:attr(data-placeholder);color:var(--book-color-primary);opacity:.5;pointer-events:none}.page-field__content:focus{border-bottom-style:solid;border-bottom-color:var(--book-color-accent)}.page-field__content--multiline{background-image:repeating-linear-gradient(to bottom, transparent, transparent calc(1.4em - 1.5px), color-mix(in srgb, var(--book-color-primary) 45%, transparent) calc(1.4em - 1.5px), color-mix(in srgb, var(--book-color-primary) 45%, transparent) 1.4em);border-bottom:none;min-height:4.2em;padding:0;line-height:1.4em}.page-field__content--multiline:focus{background-image:repeating-linear-gradient(to bottom, transparent, transparent calc(1.4em - 1.5px), color-mix(in srgb, var(--book-color-accent) 55%, transparent) calc(1.4em - 1.5px), color-mix(in srgb, var(--book-color-accent) 55%, transparent) 1.4em)}.page-field__value{font-family:var(--font-handwriting);color:var(--book-color-text,var(--color-text));border-bottom:1.5px solid color-mix(in srgb, var(--book-color-primary) 30%, transparent);word-break:break-word;white-space:pre-wrap;min-height:1.5em;padding:1px 0 4px;font-size:20px;line-height:1.4em}.page-field__value--multiline{background-image:repeating-linear-gradient(to bottom, transparent, transparent calc(1.4em - 1.5px), color-mix(in srgb, var(--book-color-primary) 30%, transparent) calc(1.4em - 1.5px), color-mix(in srgb, var(--book-color-primary) 30%, transparent) 1.4em);border-bottom:none;min-height:2.8em;line-height:1.4em}.page-field--name .page-field__value{border-bottom-width:2px;font-size:28px;font-weight:700}.page-field--email .page-field__value{font-size:15px}.page-field--name .page-field__content{border-bottom-width:2px;min-height:1.3em;font-size:28px;font-weight:700}.page-field--email .page-field__content{font-size:15px}.page-field-group--pair{gap:var(--spacing-md);margin-bottom:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}.page-field-group--pair .page-field{margin-bottom:0}.page-field-group--accent{background:color-mix(in srgb, var(--book-color-secondary) 50%, transparent);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md)}.page-field-group--accent .page-field{margin-bottom:0}.book-tool-overlay{bottom:var(--spacing-lg);z-index:30;display:none;position:absolute;left:50%;transform:translate(-50%)}.book-tool-overlay--draw{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:color-mix(in srgb, var(--color-surface) 92%, transparent);border:1px solid color-mix(in srgb, var(--color-border) 60%, transparent);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);flex-wrap:wrap;justify-content:center;box-shadow:0 2px 16px #00000014}.book-tool-overlay--sticker{background:color-mix(in srgb, var(--color-surface) 92%, transparent);border:1px solid color-mix(in srgb, var(--color-border) 60%, transparent);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);flex-direction:column;width:min(420px,80vw);max-height:180px;overflow:hidden;box-shadow:0 2px 16px #00000014}.draw-toolbar__group{align-items:center;gap:4px;display:flex}.draw-toolbar__tool-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:13px;display:flex}.draw-toolbar__tool-btn--active,.draw-toolbar__tool-btn:hover{background:var(--book-color-secondary);border-color:var(--book-color-primary)}.draw-toolbar__color{cursor:pointer;width:20px;height:20px;transition:transform var(--transition-fast);border:2px solid #0000;border-radius:50%;flex-shrink:0}.draw-toolbar__color--active{box-shadow:0 0 0 2px var(--book-color-accent);border-color:#fff;transform:scale(1.15)}.draw-toolbar__color:hover:not(.draw-toolbar__color--active){transform:scale(1.1)}.draw-toolbar__size-btn{background:var(--color-text);cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0}.draw-toolbar__size-btn--active{border-color:var(--book-color-accent)}.draw-toolbar__size-btn:hover{opacity:.75}.draw-toolbar__action-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;white-space:nowrap;color:var(--color-text-muted);padding:4px 10px;font-size:11px}.draw-toolbar__action-btn:hover{background:var(--color-surface-subtle);color:var(--color-text)}.sticker-picker{flex-direction:column;width:100%;height:100%;display:flex}.sticker-picker__tabs{border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex;overflow-x:auto}.sticker-picker__tab{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:5px 12px}.sticker-picker__tab--active{color:var(--book-color-accent);border-bottom-color:var(--book-color-accent)}.sticker-picker__tab:hover:not(.sticker-picker__tab--active){color:var(--color-text)}.sticker-picker__panels{padding:var(--spacing-xs);flex:1;overflow-y:auto}.sticker-picker__panel{display:none}.sticker-picker__panel[data-active]{display:block}.sticker-picker__grid{flex-wrap:wrap;gap:2px;display:flex}.sticker-picker__emoji{cursor:pointer;border-radius:var(--radius-sm);transition:transform var(--transition-fast);padding:3px;font-size:22px;line-height:1}.sticker-picker__emoji:hover{background:var(--color-surface-subtle);transform:scale(1.2)}@media (width>=769px){.book-tool-overlay{z-index:200;border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:fixed;bottom:0;left:0;right:0;transform:none}.book-tool-overlay--draw{padding:var(--spacing-sm) var(--spacing-xl);border-bottom:none;border-left:none;border-right:none;justify-content:center}.book-tool-overlay--sticker{border-bottom:none;border-left:none;border-right:none;width:100%;max-width:100%;max-height:260px}}@media (width<=768px){.book-tool-overlay{border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:190;width:100%;max-height:50vh;position:fixed;inset:auto 0 48px;overflow-y:auto;transform:none}.book-tool-overlay--sticker{width:100%;max-width:100%;max-height:50vh}.book-tool-overlay--draw{padding:var(--spacing-sm) var(--spacing-md);flex-wrap:wrap;justify-content:center}}.page-actions{align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xs) 0;display:flex}.page-actions__cancel{font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:none;padding:0;font-family:inherit}.page-actions__cancel:hover{opacity:1}.page-actions__status{color:var(--color-text-muted);opacity:.5;text-align:center;flex:1;font-size:11px}.page-actions__submit{background:var(--book-color-accent);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:opacity var(--transition-fast), transform var(--transition-fast);white-space:nowrap;border:none;padding:9px 22px;font-family:inherit}.page-actions__submit:hover{opacity:.88;transform:translateY(-1px)}.page-actions__submit:active{transform:translateY(0)}.page-actions__submit:disabled{opacity:.5;cursor:default;transform:none}.spread-sticker{transform:translate(-50%, -50%) rotate(var(--sticker-rotation,0deg)) scale(var(--sticker-scale,1));cursor:grab;-webkit-user-select:none;user-select:none;pointer-events:inherit;z-index:1;background:#fff;border-radius:4px;padding:8px 10px;font-size:36px;line-height:1;position:absolute;box-shadow:0 3px 10px #0000002e,0 1px 3px #0000001f,0 0 0 1px #0000000a}.spread-sticker:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#ffffff40 0%,#0000 60%);position:absolute;inset:0}.spread-sticker--dragging{cursor:grabbing;transform:translate(-50%, -50%) rotate(var(--sticker-rotation,0deg)) scale(calc(var(--sticker-scale,1) * 1.1));box-shadow:0 8px 25px #00000038,0 3px 8px #00000026}.spread-sticker--image{box-shadow:none;background:0 0;border-radius:0;padding:0;font-size:0}.spread-sticker--image:after{display:none}.spread-sticker--image.spread-sticker--dragging{box-shadow:none}.spread-sticker--image img{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:72px;height:72px;display:block}.spread-sticker__delete{cursor:pointer;z-index:2;pointer-events:all;background:#e53e3e url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256' fill='none' stroke='white' stroke-width='24' stroke-linecap='round' stroke-linejoin='round'><line x1='200' y1='56' x2='56' y2='200'/><line x1='200' y1='200' x2='56' y2='56'/></svg>") 50%/10px 10px no-repeat;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:none;position:absolute;top:-8px;right:-8px}.spread-sticker__delete:hover{background-color:#c53030}.spread-sticker__resize,.spread-sticker__rotate{z-index:3;touch-action:none;pointer-events:all;background-color:#fff;background-position:50%;background-repeat:no-repeat;background-size:9px 9px;border:1.5px solid #00000047;border-radius:50%;width:14px;height:14px;display:none;position:absolute}.spread-sticker__resize{cursor:se-resize;background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256' fill='none' stroke='rgba(0,0,0,0.55)' stroke-width='24' stroke-linecap='round' stroke-linejoin='round'><polyline points='160 48 208 48 208 96'/><line x1='148' y1='108' x2='208' y2='48'/><polyline points='96 208 48 208 48 160'/><line x1='108' y1='148' x2='48' y2='208'/></svg>");bottom:-7px;right:-7px}.spread-sticker__rotate{cursor:grab;background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256' fill='none' stroke='rgba(0,0,0,0.55)' stroke-width='24' stroke-linecap='round' stroke-linejoin='round'><polyline points='24 56 24 104 72 104'/><path d='M67.59,192A88,88,0 1 0 65.77,65.77L24,104'/></svg>");bottom:-7px;left:-7px}[data-mode=sticker] .spread-sticker__delete,[data-mode=sticker] .spread-sticker__resize,[data-mode=sticker] .spread-sticker__rotate{display:block}.book-viewer{padding:0 var(--spacing-sm);justify-content:center;align-items:center;gap:0;display:flex}@media (width>=768px){.book-viewer{gap:var(--spacing-md)}}.book-viewer__stage{flex:1;min-width:0;position:relative}.book-viewer__spread{display:none}.book-viewer__spread--active{display:block}.book-viewer__spread--exiting{z-index:5;pointer-events:none;animation:.28s forwards bvFadeOut;display:block;position:absolute;inset:0}.book-viewer__spread--entering{opacity:0;transition:opacity .28s}@keyframes bvFadeOut{0%{opacity:1}to{opacity:0}}.book-viewer__spread--cover{justify-content:center}.book-viewer__spread--cover.book-viewer__spread--active,.book-viewer__spread--cover.book-viewer__spread--exiting{display:flex}.book-cover{aspect-ratio:5/8;cursor:pointer;align-items:stretch;width:min(260px,55%);display:flex}@media (width>=768px){.book-cover{aspect-ratio:5/7;width:min(300px,38%)}}.book-cover{-webkit-user-select:none;user-select:none;border-radius:var(--radius-lg);transition:transform .22s,box-shadow .22s;overflow:hidden;box-shadow:0 4px 6px #00000012,0 10px 32px #0000001f,0 2px #0000000a}.book-cover:hover{transform:translateY(-3px);box-shadow:0 8px 12px #0000001a,0 18px 40px #00000029,0 2px #0000000a}.book-cover__spine{background:color-mix(in srgb, var(--book-color-primary) 68%, #000);flex-shrink:0;width:14px}.book-cover__face{background:var(--book-color-primary);min-width:0;padding:var(--spacing-xl) var(--spacing-md);flex-direction:column;flex:1;justify-content:space-between;display:flex}.book-cover__content{text-align:center;justify-content:center;align-items:center;gap:var(--spacing-md);flex-direction:column;flex:1;display:flex}.book-cover__title{font-family:var(--font-handwriting);color:#fff;text-shadow:0 1px 4px #0000002e;word-break:normal;overflow-wrap:break-word;-webkit-hyphens:none;hyphens:none;font-size:clamp(18px,3.5vw,36px);line-height:1.25}.book-cover__author{font-size:var(--font-size-sm);letter-spacing:.05em;color:#ffffffb3}.book-cover__pages{background:repeating-linear-gradient(to right, color-mix(in srgb, var(--book-color-page-bg) 90%, #aaa) 0px, color-mix(in srgb, var(--book-color-page-bg) 90%, #aaa) 2px, color-mix(in srgb, var(--book-color-page-bg) 70%, #bbb) 2px, color-mix(in srgb, var(--book-color-page-bg) 70%, #bbb) 3px);flex-shrink:0;width:22px;box-shadow:inset -2px 0 4px #00000014}.book-viewer__nav{cursor:pointer;width:44px;min-height:200px;color:var(--color-text-faint);transition:color var(--transition-fast), background var(--transition-fast);border-radius:var(--radius-md);background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;align-self:stretch;align-items:center;display:flex;position:relative}.book-viewer__nav:hover:not(:disabled){color:var(--book-color-accent);background:color-mix(in srgb, var(--book-color-secondary) 60%, transparent)}.book-viewer__nav:disabled{opacity:.2;cursor:default}@media (width<=767px){.book-viewer__nav{width:32px;min-height:120px}}.book-viewer__nav-icon{font-size:32px;font-weight:300;line-height:1}@media (width>=768px){.book-viewer__nav-icon{font-size:42px}}.book-viewer__indicator{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) 0 var(--spacing-xl);flex-direction:column;display:flex}.book-viewer__dots{flex-wrap:wrap;justify-content:center;gap:6px;max-width:300px;display:flex}.book-viewer__dot{background:color-mix(in srgb, var(--book-color-primary) 35%, transparent);cursor:pointer;width:7px;height:7px;transition:background var(--transition-fast), transform var(--transition-fast);border:none;border-radius:50%;padding:0}.book-viewer__dot--active{background:var(--book-color-accent);transform:scale(1.3)}.book-viewer__dot:hover:not(.book-viewer__dot--active){background:var(--book-color-primary)}.book-viewer__counter{font-size:var(--font-size-sm);color:var(--color-text-faint);font-family:var(--font-handwriting);letter-spacing:.03em}.book-empty-state{text-align:center;height:100%;min-height:400px;padding:var(--spacing-2xl);opacity:.7;flex-direction:column;justify-content:center;align-items:center;display:flex}.book-empty-state__icon{margin-bottom:var(--spacing-md);font-size:52px}.book-empty-state__title{font-family:var(--font-handwriting);font-size:var(--font-size-xl);color:var(--book-color-accent);margin-bottom:var(--spacing-sm)}.book-empty-state__text{font-size:var(--font-size-sm);color:var(--color-text-muted)}.owner-bar{background:var(--color-surface);border-bottom:1.5px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-lg)}.owner-bar__inner{justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;max-width:1280px;margin:0 auto;display:flex}.owner-bar__left{align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.owner-bar__title{font-family:var(--font-handwriting);font-size:var(--font-size-lg);color:var(--book-color-accent);margin:0}.owner-bar__badges{gap:var(--spacing-xs);flex-wrap:wrap;display:flex}.owner-bar__right{gap:var(--spacing-sm);align-items:center;display:flex}.polaroid{background:#fff;padding:7px 7px 22px;box-shadow:2px 3px 10px #0000002e,0 1px 3px #0000001a}.polaroid img{object-fit:cover;width:100%;height:100px;display:block}.polaroid__placeholder{background:color-mix(in srgb, var(--book-color-page-bg) 60%, #ccc);opacity:.4;width:100%;height:100px}.spread-claim-overlay{z-index:20;background:color-mix(in srgb, var(--book-color-page-bg) 60%, transparent);opacity:0;border-radius:inherit;justify-content:center;align-items:center;text-decoration:none;transition:opacity .2s;display:flex;position:absolute;inset:0}.book-viewer__spread:hover .spread-claim-overlay{opacity:1}@media (hover:none){.spread-claim-overlay{opacity:0}}.spread-claim-overlay__btn{border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-body);transition:transform var(--transition-fast), opacity var(--transition-fast);background:#1a1a1a;padding:10px 24px;box-shadow:0 4px 16px #0000002e}.spread-claim-overlay:hover .spread-claim-overlay__btn{transform:scale(1.04)}.spread-drawing-overlay{object-fit:fill;pointer-events:none;z-index:10;width:100%;height:100%;position:absolute;inset:0}.template-carousel{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);-webkit-user-select:none;user-select:none;display:flex}.template-carousel__track{flex:1;overflow:hidden}.template-carousel__slide{flex-direction:column;align-items:center;width:100%;display:none}.template-carousel__slide--active{display:flex}.template-carousel__slide .book-spread{zoom:.48;pointer-events:none;width:100%}.template-carousel__name{font-family:var(--font-handwriting,"Gaegu", cursive);font-size:var(--font-size-xl);color:var(--color-text);text-align:center;margin-top:var(--spacing-md)}.template-carousel__arrow{border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:44px;height:44px;font-size:var(--font-size-lg);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;line-height:1;display:flex}.template-carousel__arrow:hover:not(:disabled){border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.template-carousel__arrow:disabled{opacity:.3;cursor:default}.template-carousel__dots{justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);display:flex}.template-carousel__dot{border-radius:var(--radius-full);background:var(--color-border);cursor:pointer;width:10px;height:10px;transition:background var(--transition-fast);border:none;padding:0}.template-carousel__dot--active{background:var(--book-color-accent,var(--color-text))}.book-create{max-width:860px;margin:0 auto}.book-create__header{text-align:center;margin-bottom:var(--spacing-xl)}.book-create__header h1{font-family:var(--font-handwriting,"Gaegu", cursive);font-size:var(--font-size-2xl)}.book-create__header p{color:var(--color-text-muted);margin-top:var(--spacing-xs)}.book-create__title-group{max-width:480px;margin:var(--spacing-xl) auto}.book-create__actions{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}
