@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=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=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=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=url]:disabled,textarea:disabled,select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-surface-subtle)}textarea{resize:vertical;min-height:80px}.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(.92)}.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:calc(84px + var(--spacing-lg))}.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;pointer-events:none;justify-content:center;padding:4px 0;display:flex;position:fixed;top:40px;left:0;right:0}.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}.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}.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%}}.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)}.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}.book-spread{padding:var(--spacing-xl) 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-2xl) 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-sm);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);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{box-shadow:inset -4px 0 8px #0000000f}.book-spread__page--right{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__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}[data-mode=draw] .book-spread__page{pointer-events:none}[data-mode=sticker] .spread-stickers{pointer-events:auto}[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}.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__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-board{position:relative}.sticker-board__canvas-area{min-height:200px;position:relative}.sticker-board__layer{pointer-events:none;border-radius:var(--radius-md);position:absolute;inset:0;overflow:hidden}.sticker-board__sticker{cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;pointer-events:all;transform-origin:50%;transform:translate(-50%, -50%) rotate(var(--sticker-rotation,0deg)) scale(var(--sticker-scale,1));transition:filter var(--transition-fast);filter:drop-shadow(0 2px 4px #0003);font-size:32px;line-height:1;position:absolute}.sticker-board__sticker:hover{filter:drop-shadow(0 3px 8px #0000004d)}.sticker-board__sticker--dragging{cursor:grabbing;filter:drop-shadow(0 6px 12px #00000059)}.sticker-board__sticker__delete{border-radius:var(--radius-full);color:#fff;cursor:pointer;z-index:1;pointer-events:all;background-color:#e85a5a;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;display:none;position:absolute;top:-8px;right:-8px}.sticker-board__sticker:hover .sticker-board__sticker__delete{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__tabs{border-bottom:1.5px solid var(--color-border);scrollbar-width:none;display:flex;overflow-x:auto}.sticker-picker__tabs::-webkit-scrollbar{display:none}.sticker-picker__tab{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);cursor:pointer;white-space:nowrap;color:var(--color-text-muted);transition:all var(--transition-fast);border-bottom:2px solid #0000;flex-shrink:0}.sticker-picker__tab:hover{color:var(--color-text);background-color:var(--color-surface-subtle)}.sticker-picker__tab--active{color:var(--book-color-accent);border-bottom-color:var(--book-color-accent);font-weight:var(--font-weight-semibold)}.sticker-picker__panel{padding:var(--spacing-md);display:none}.sticker-picker__grid{gap:var(--spacing-xs);grid-template-columns:repeat(8,1fr);display:grid}@media (width<=480px){.sticker-picker__grid{grid-template-columns:repeat(6,1fr)}}.sticker-picker__emoji{text-align:center;padding:var(--spacing-xs);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:24px;line-height:1}.sticker-picker__emoji:hover{background-color:var(--book-color-secondary);transform:scale(1.2)}.sticker-picker__emoji:active{transform:scale(1.1)}.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)}.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:var(--book-color-text,var(--color-text));opacity:.5;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}.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)}.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__delete{color:#fff;text-align:center;cursor:pointer;z-index:2;background:#e53e3e;border-radius:50%;width:18px;height:18px;font-size:11px;font-style:normal;line-height:18px;display:none;position:absolute;top:-8px;right:-8px}.spread-sticker__delete:hover{background:#c53030}[data-mode=sticker] .spread-sticker__delete{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:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;font-size:clamp(22px,4vw,40px);line-height:1.2}.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}
