:root{--coral: #d4522a;--coral-lt: #fbeee9;--coral-dk: #b33d1c;--navy: #1a1f3c;--gold: #e8b84b;--warm-bg: #faf8f5;--white: #ffffff;--border: #e8e4df;--txt-1: #1a1814;--txt-2: #6b6560;--txt-3: #a8a29e;--serif: "DM Serif Display", serif;--sans: "Plus Jakarta Sans", sans-serif;--max-w: 1280px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--sans);color:var(--txt-1);background:var(--warm-bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:var(--sans);cursor:pointer;border:none;background:none}.app-nav{position:sticky;top:0;z-index:50;background:#ffffffe0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(232,228,223,.7);padding:0 40px;height:68px;display:flex;align-items:center;justify-content:space-between}.app-logo{font-family:var(--serif);font-size:1.5rem;color:var(--txt-1);letter-spacing:-.02em}.app-nav-right{display:flex;align-items:center;gap:16px}.app-nav-user{font-size:.875rem;color:var(--txt-2)}.app-nav-signout{font-size:.875rem;color:var(--txt-2);padding:8px 14px;border-radius:100px;transition:background .2s,color .2s}.app-nav-signout:hover{background:var(--warm-bg);color:var(--txt-1)}.app-main{max-width:var(--max-w);margin:0 auto;padding:48px 40px}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--warm-bg)}.auth-card{width:100%;max-width:420px;padding:48px;background:#fff;border-radius:20px;box-shadow:0 4px 40px #0000000a;border:1px solid var(--border)}.auth-logo{display:block;font-family:var(--serif);font-size:1.75rem;text-align:center;margin-bottom:32px}.auth-title{font-family:var(--serif);font-size:1.875rem;text-align:center;letter-spacing:-.02em;margin-bottom:28px}.auth-google{width:100%;padding:13px;border-radius:100px;background:#fff;color:var(--txt-1);border:1.5px solid var(--border);font-weight:500;font-size:.9375rem;transition:background .2s,border-color .2s}.auth-google:hover{background:var(--warm-bg);border-color:var(--txt-3)}.auth-divider{display:flex;align-items:center;gap:12px;margin:24px 0;color:var(--txt-3);font-size:.8125rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-input{padding:13px 16px;border-radius:12px;border:1.5px solid var(--border);font-family:var(--sans);font-size:.9375rem;background:var(--warm-bg);transition:border-color .2s,background .2s}.auth-input:focus{outline:none;border-color:var(--coral);background:#fff}.auth-submit{padding:13px;border-radius:100px;background:var(--coral);color:#fff;font-weight:600;font-size:.9375rem;transition:background .2s}.auth-submit:hover:not(:disabled){background:var(--coral-dk)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-error{padding:10px 14px;border-radius:10px;background:#fce8e3;color:var(--coral-dk);font-size:.8125rem}.auth-toggle{display:block;margin:20px auto 0;color:var(--txt-2);font-size:.875rem;text-decoration:underline;text-underline-offset:4px}.auth-toggle:hover{color:var(--txt-1)}.settings-shell{max-width:720px;margin:0 auto;padding:24px 0 80px}.settings-head{margin-bottom:40px}.settings-title{font-family:var(--serif);font-size:2.25rem;letter-spacing:-.02em;line-height:1.1}.settings-sub{color:var(--txt-2);margin-top:6px;font-size:.9375rem}.settings-section{background:#fff;border:1px solid var(--border);border-radius:14px;padding:24px 28px;margin-bottom:20px}.settings-section-title{font-family:var(--serif);font-size:1.25rem;margin:0 0 14px}.settings-dl{display:grid;grid-template-columns:160px 1fr;gap:8px 16px;font-size:.9375rem}.settings-dl dt{color:var(--txt-3);font-size:.8125rem;text-transform:uppercase;letter-spacing:.04em}.settings-dl dd{color:var(--txt-1);margin:0}.settings-danger{border:1px solid #f5c5b3;background:#fdf6f2}.settings-danger .settings-section-title{color:#c44420}.settings-danger-text{color:var(--txt-2);font-size:.9375rem;line-height:1.6;margin-bottom:18px}.settings-danger-text strong{color:var(--txt-1)}.settings-danger-btn{padding:10px 18px;border-radius:100px;background:#c44420;color:#fff;font-weight:600;font-size:.875rem;transition:background .15s,transform .15s,opacity .15s;box-shadow:0 2px 8px #c4442040}.settings-danger-btn:hover:not(:disabled){background:#a13718;transform:translateY(-1px)}.settings-danger-btn:disabled{opacity:.4;cursor:not-allowed}.settings-cancel-btn{padding:10px 18px;border-radius:100px;background:transparent;color:var(--txt-2);border:1px solid var(--border);font-weight:600;font-size:.875rem;transition:border-color .15s,color .15s}.settings-cancel-btn:hover{border-color:var(--txt-1);color:var(--txt-1)}.settings-confirm-box{display:flex;flex-direction:column;gap:12px;padding-top:8px}.settings-confirm-label{font-size:.875rem;color:var(--txt-2);margin:0}.settings-confirm-label strong{color:#c44420;font-family:JetBrains Mono,ui-monospace,monospace}.settings-confirm-actions{display:flex;gap:10px}.settings-progress{font-size:.9375rem;color:var(--txt-2);font-style:italic}.app-nav-user{text-decoration:none;color:inherit;padding:4px 10px;border-radius:100px;transition:background .15s}.app-nav-user:hover{background:var(--warm-bg)}.app-nav-admin{text-decoration:none;color:var(--coral);font-size:.8125rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;border:1px solid var(--coral-lt);border-radius:100px;margin-right:8px;transition:background .15s,border-color .15s}.app-nav-admin:hover{background:var(--coral-lt);border-color:var(--coral)}.admin-shell{max-width:1100px;margin:0 auto;padding:24px 0 80px}.admin-head{margin-bottom:18px}.admin-title{font-family:var(--serif);font-size:2.25rem;letter-spacing:-.02em;line-height:1.1}.admin-sub{color:var(--txt-2);margin-top:6px;font-size:.9375rem}.admin-controls{margin-bottom:18px}.admin-search{width:100%;max-width:420px;padding:10px 16px;border-radius:100px;border:1px solid var(--border);background:#fff;font-size:.875rem;font-family:var(--sans)}.admin-search:focus{outline:none;border-color:var(--coral)}.admin-empty{text-align:center;padding:60px 24px;color:var(--txt-2)}.admin-table{width:100%;background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;border-collapse:separate;border-spacing:0;font-size:.875rem}.admin-table thead th{text-align:left;padding:12px 14px;background:var(--warm-bg);border-bottom:1px solid var(--border);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--txt-3);font-weight:700}.admin-table th.num,.admin-table td.num{text-align:right}.admin-table tbody td{padding:14px;border-bottom:1px solid var(--border);color:var(--txt-1)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:var(--warm-bg)}.admin-row--self td{background:#d4522a0a}.admin-row--self:hover td{background:#d4522a14}.admin-email{font-weight:600}.admin-uid{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.6875rem;color:var(--txt-3);margin-top:2px}.admin-provider{font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--txt-3)}.admin-action-col{text-align:right}.admin-delete-btn{width:28px;height:28px;border-radius:50%;background:transparent;color:var(--txt-3);font-size:.875rem;transition:background .15s,color .15s}.admin-delete-btn:hover:not(:disabled){background:#fce8e3;color:#c44420}.admin-delete-btn:disabled{opacity:.5}.admin-badge{display:inline-block;padding:3px 9px;border-radius:100px;background:var(--coral);color:#fff;font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.admin-no-results{text-align:center;padding:32px;color:var(--txt-3);font-style:italic}.dashboard{padding:8px 0 60px}.dashboard-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:24px;gap:24px;flex-wrap:wrap}.dashboard-title{font-family:var(--serif);font-size:2.5rem;letter-spacing:-.03em;line-height:1.1}.dashboard-sub{color:var(--txt-2);margin-top:6px;font-size:.9375rem}.dashboard-cta{display:inline-flex;align-items:center;gap:6px;padding:11px 20px;border-radius:100px;background:var(--coral);color:#fff;font-weight:600;font-size:.9375rem;box-shadow:0 4px 16px #d4522a33;transition:background .2s,transform .2s}.dashboard-cta:hover{background:var(--coral-dk);transform:translateY(-1px)}.dashboard-controls{display:flex;align-items:center;gap:12px;margin-bottom:28px;flex-wrap:wrap}.dashboard-search{flex:1;min-width:220px;max-width:380px;padding:10px 16px;border-radius:100px;border:1px solid var(--border);background:#fff;font-size:.875rem;font-family:var(--sans);transition:border-color .15s}.dashboard-search:focus{outline:none;border-color:var(--coral)}.dashboard-sort{padding:10px 14px;border-radius:100px;border:1px solid var(--border);background:#fff;font-size:.875rem;font-family:var(--sans);color:var(--txt-1);cursor:pointer}.dashboard-sort:focus{outline:none;border-color:var(--coral)}.dashboard-empty{text-align:center;padding:60px 24px;color:var(--txt-2);background:#fff;border-radius:16px;border:1px dashed var(--border)}.dashboard-empty-state{text-align:center;padding:80px 24px;background:#fff;border-radius:20px;border:1px dashed var(--border);display:flex;flex-direction:column;align-items:center;gap:14px}.dashboard-empty-art{font-size:56px;line-height:1}.dashboard-empty-title{font-family:var(--serif);font-size:1.75rem;margin:0}.dashboard-empty-text{color:var(--txt-2);max-width:420px;margin:0;line-height:1.6}.dashboard-no-results{grid-column:1 / -1;text-align:center;color:var(--txt-3);padding:32px;font-size:.9375rem;font-style:italic}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px}.project-card{background:#fff;border-radius:14px;overflow:hidden;border:1px solid var(--border);transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px #0000001a;border-color:var(--coral-lt)}.project-cover{aspect-ratio:3 / 4;padding:18px 16px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;text-align:center;color:#faf8f5;position:relative;overflow:hidden}.project-cover:after{content:"";position:absolute;inset:6px;border:1px solid rgba(255,255,255,.18);border-radius:2px;pointer-events:none}.project-cover-title{font-size:1.3rem;font-weight:700;line-height:1;letter-spacing:.02em;text-shadow:0 1px 3px rgba(0,0,0,.18)}.project-cover-sticker{flex:1;display:flex;align-items:center;justify-content:center;width:55%;padding:8px 0}.project-cover-sticker svg{width:100%;height:100%;max-height:90px;display:block}.project-cover-sticker-gap{flex:1}.project-cover-subtitle{font-size:.5625rem;font-weight:700;letter-spacing:.16em;opacity:.9}.project-meta{display:flex;flex-direction:column;gap:6px;padding:12px 14px 14px;font-size:.8125rem;border-top:1px solid var(--border)}.project-meta-line{display:flex;justify-content:space-between;align-items:center;gap:8px}.project-photos{color:var(--txt-3);font-size:.75rem}.project-edited{color:var(--txt-3);font-size:.6875rem}.project-status-pill{display:inline-flex;align-items:center;padding:3px 9px;border-radius:100px;font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.project-status-pill--gray{background:#f0ede8;color:#6b6560}.project-status-pill--amber{background:#fbf2dc;color:#a17518}.project-status-pill--teal{background:#d9f1ec;color:#1f7565}.project-status-pill--blue{background:#dde9f7;color:#2968ba}.project-status-pill--green{background:#dcefd0;color:#4f8c2a}.project-create-card{background:var(--warm-bg);border:2px dashed var(--border);border-radius:14px;aspect-ratio:3 / 4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--txt-2);font-weight:600;font-size:.9375rem;transition:border-color .2s,color .2s,background .2s,transform .2s}.project-create-card:hover{border-color:var(--coral);color:var(--coral);background:#fff;transform:translateY(-4px)}.project-create-icon{width:56px;height:56px;border-radius:50%;background:#fff;border:1.5px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:300;line-height:1}.wizard{max-width:480px;margin:0 auto;padding:40px 0}.wizard-title{font-family:var(--serif);font-size:2.25rem;letter-spacing:-.03em;line-height:1.1}.wizard-sub{color:var(--txt-2);margin-top:8px;margin-bottom:36px}.wizard-form{display:flex;flex-direction:column;gap:20px}.wizard-label{display:flex;flex-direction:column;gap:8px;font-size:.8125rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--txt-2)}.wizard-input{padding:14px 18px;border-radius:12px;border:1.5px solid var(--border);font-family:var(--sans);font-size:1rem;background:#fff;transition:border-color .2s}.wizard-input:focus{outline:none;border-color:var(--coral)}.wizard-error{padding:12px;border-radius:10px;background:#fce8e3;color:var(--coral-dk);font-size:.875rem}.wizard-submit{margin-top:8px;padding:14px;border-radius:100px;background:var(--coral);color:#fff;font-weight:600;font-size:.9375rem;transition:background .2s}.wizard-submit:hover:not(:disabled){background:var(--coral-dk)}.wizard-submit:disabled{opacity:.5;cursor:not-allowed}.project-shell{max-width:960px;margin:0 auto}.project-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px}.project-title{font-family:var(--serif);font-size:2.25rem;letter-spacing:-.03em}.project-status-pill{padding:6px 14px;border-radius:100px;background:var(--coral-lt);color:var(--coral);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.project-section{background:#fff;border-radius:16px;padding:32px;border:1px solid var(--border);margin-bottom:20px}.project-section-title{font-family:var(--serif);font-size:1.5rem;margin-bottom:16px}.project-empty{color:var(--txt-2);padding:32px;text-align:center;border:1px dashed var(--border);border-radius:12px}.project-empty code{font-family:Inconsolata,monospace;background:var(--warm-bg);padding:2px 6px;border-radius:4px;font-size:.875em}.curate-btn{padding:10px 20px;border-radius:100px;background:var(--navy);color:#fff;font-weight:600;font-size:.875rem;transition:background .2s,transform .2s;box-shadow:0 4px 16px #1a1f3c33}.curate-btn:hover{background:#2d3560;transform:translateY(-1px)}.curate-btn-secondary{padding:8px 16px;border-radius:100px;background:transparent;color:var(--txt-2);border:1px solid var(--border);font-weight:500;font-size:.8125rem;transition:background .15s,color .15s,border-color .15s}.curate-btn-secondary:hover{background:var(--warm-bg);color:var(--coral);border-color:var(--coral-lt)}.curate-progress-bar{position:relative;height:8px;background:var(--border);border-radius:100px;overflow:hidden;margin-bottom:20px}.curate-progress-fill{height:100%;background:linear-gradient(90deg,var(--coral),var(--gold));border-radius:100px;transition:width .4s ease}.curate-progress-label{display:block;font-size:.8125rem;color:var(--txt-2);margin-top:6px;text-align:center}.photo-thumb--curated{position:relative}.photo-badge{position:absolute;bottom:4px;left:4px;background:#0009;color:#fff;font-size:.625rem;font-weight:700;padding:2px 5px;border-radius:6px;display:flex;gap:4px;align-items:center}.photo-badge-cover{color:var(--gold)}.photo-scene{position:absolute;top:4px;right:4px;font-size:.75rem;background:#00000073;padding:2px 4px;border-radius:6px}.layout-btn{padding:10px 20px;border-radius:100px;background:var(--coral);color:#fff;font-weight:600;font-size:.875rem;transition:background .2s,transform .2s;box-shadow:0 4px 16px #d4522a33}.layout-btn:hover:not(:disabled){background:var(--coral-dk);transform:translateY(-1px)}.layout-btn:disabled{opacity:.6;cursor:not-allowed}.regen-btn{padding:8px 16px;border-radius:100px;border:1.5px solid var(--border);color:var(--txt-2);font-size:.875rem;font-weight:500;transition:border-color .2s,color .2s}.regen-btn:hover:not(:disabled){border-color:var(--txt-2);color:var(--txt-1)}.regen-btn:disabled{opacity:.5;cursor:not-allowed}.layout-cover{position:relative;width:160px;height:200px;border-radius:10px;overflow:hidden;margin-bottom:24px;box-shadow:0 8px 24px #00000026}.layout-cover img{width:100%;height:100%;object-fit:cover;display:block}.layout-cover-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);color:#fff;padding:20px 12px 10px;display:flex;flex-direction:column;gap:2px;font-size:.8125rem;font-weight:600}.spreads-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.spread-row{display:flex;align-items:center;gap:14px;padding:8px 0;border-bottom:1px solid var(--border)}.spread-row:last-child{border-bottom:none}.spread-num{font-size:.75rem;color:var(--txt-3);font-weight:600;width:28px;text-align:right;flex-shrink:0}.spread-canvas{position:relative;width:120px;height:80px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--border)}.spread-meta{display:flex;flex-direction:column;gap:3px}.spread-template{font-size:.8125rem;font-weight:500;color:var(--txt-1)}.spread-divider{padding:10px 0 10px 42px;font-family:var(--serif);font-size:1rem;color:var(--txt-2);border-bottom:1px solid var(--border);font-style:italic}.upload-zone{border:2px dashed var(--border);border-radius:16px;padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--warm-bg)}.upload-zone:hover,.upload-zone--active{border-color:var(--coral);background:var(--coral-lt)}.upload-zone--busy{cursor:default;pointer-events:none}.upload-icon{font-size:2rem;margin-bottom:12px;color:var(--txt-3)}.upload-prompt-title{font-weight:600;color:var(--txt-1);margin-bottom:6px}.upload-prompt-sub{font-size:.8125rem;color:var(--txt-3)}.upload-progress{padding:8px 0}.upload-progress-bar-track{height:6px;background:var(--border);border-radius:100px;overflow:hidden;margin-bottom:12px}.upload-progress-bar{height:6px;background:var(--coral);border-radius:100px;transition:width .2s;position:relative}.upload-progress-label{font-size:.875rem;color:var(--txt-2)}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:24px}.photo-thumb{aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--border)}.photo-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.photo-thumb:hover img{transform:scale(1.05)}.photo-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.625rem;color:var(--txt-3);background:var(--warm-bg)}.editor-shell{display:flex;flex-direction:column;height:calc(100vh - 68px);overflow:hidden}.editor-toolbar{display:flex;align-items:center;gap:16px;padding:0 24px;height:52px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0}.editor-back{font-size:.875rem;color:var(--txt-2)}.editor-back:hover{color:var(--txt-1)}.editor-project-name{font-family:var(--serif);font-size:1.125rem;flex:1}.editor-toolbar-actions{display:flex;align-items:center;gap:10px}.editor-action-btn{width:34px;height:34px;border-radius:8px;font-size:1rem;border:1.5px solid var(--border);color:var(--txt-2);transition:background .15s,color .15s}.editor-action-btn:hover:not(:disabled){background:var(--warm-bg);color:var(--txt-1)}.editor-action-btn:disabled{opacity:.35;cursor:not-allowed}.editor-save-status{font-size:.8125rem;color:var(--txt-3);min-width:100px;text-align:right}.editor-download-btn{padding:7px 14px;border-radius:100px;background:var(--coral);color:#fff;font-size:.8125rem;font-weight:600;margin-left:8px;transition:background .15s,transform .15s,opacity .15s;box-shadow:0 2px 8px #d4522a40}.editor-download-btn:hover:not(:disabled){background:var(--coral-dk);transform:translateY(-1px)}.editor-download-btn:disabled{opacity:.6;cursor:not-allowed}.pdf-modal{background:#fff;border-radius:14px;width:min(90vw,480px);padding:28px 28px 24px;box-shadow:0 30px 80px #00000059}.pdf-progress-label{font-size:.9375rem;color:var(--txt-2);margin:14px 0 16px}.pdf-progress-bar{position:relative;height:6px;background:var(--border);border-radius:100px;overflow:hidden;margin-bottom:18px}.pdf-progress-fill{height:100%;background:var(--coral);border-radius:100px;transition:width .4s ease}.pdf-hint{font-size:.75rem;color:var(--txt-3);line-height:1.55;margin:0}.pdf-error{font-size:.875rem;color:var(--coral-dk);background:#fce8e3;padding:12px;border-radius:8px;margin:14px 0 18px;white-space:pre-wrap;word-break:break-word}.editor-body{display:flex;flex:1;overflow:hidden}.editor-left-panel{width:232px;flex-shrink:0;overflow:hidden;background:var(--warm-bg);border-right:1px solid var(--border);display:flex;flex-direction:column}.editor-photos-header{display:flex;flex-direction:column;gap:2px;padding:14px 14px 4px}.editor-photos-title{font-family:var(--serif);font-size:1.05rem;margin:0;color:var(--txt-1)}.editor-photos-count{font-size:.7rem;color:var(--txt-3)}.editor-photos-hint{margin:0;padding:0 14px 10px;font-size:.6875rem;color:var(--txt-3);font-style:italic}.editor-photos-grid{flex:1;overflow-y:auto;padding:0 12px 14px;display:grid;grid-template-columns:repeat(2,1fr);gap:16px;align-content:start}.editor-photos-grid::-webkit-scrollbar{width:6px}.editor-photos-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:100px}.editor-photo-card{position:relative;aspect-ratio:5 / 4;border-radius:8px;overflow:hidden;cursor:grab;background:#e8e4df;border:1px solid var(--border);box-shadow:0 2px 6px #0000001f,0 1px 2px #0000000f;transition:transform .15s,box-shadow .15s,opacity .15s}.editor-photo-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px #0003;border-color:var(--coral-lt)}.editor-photo-card:active{cursor:grabbing;transform:translateY(0)}.editor-photo-card--used{opacity:.42}.editor-photo-card--used:hover{opacity:.7}.editor-photo-card img{width:100%;height:100%;object-fit:cover;pointer-events:none;display:block}.editor-photo-placeholder{width:100%;height:100%;background:var(--border)}.editor-photo-quality{position:absolute;bottom:6px;left:6px;background:#000000b8;color:#fff;font-size:.625rem;font-weight:700;padding:2px 6px;border-radius:100px;line-height:1.4;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.editor-photo-used-badge{position:absolute;top:6px;right:6px;background:var(--coral);color:#fff;font-size:.625rem;font-weight:800;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.editor-photo-delete{position:absolute;top:4px;left:4px;width:20px;height:20px;background:#140f0a8c;color:#fff;border-radius:50%;font-size:.75rem;font-weight:600;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s;cursor:pointer;z-index:2}.editor-photo-card:hover .editor-photo-delete{opacity:1}.editor-photo-delete:hover{background:var(--coral)}.editor-spread-actions{display:flex;gap:6px;align-items:center;padding:6px 18px;background:#fff;border-top:1px solid var(--border);flex-shrink:0}.editor-spread-action{padding:5px 12px;border-radius:100px;background:var(--warm-bg);border:1px solid var(--border);color:var(--txt-1);font-size:.75rem;font-weight:600;transition:border-color .15s,background .15s,color .15s}.editor-spread-action:hover:not(:disabled){background:#fff;border-color:var(--coral);color:var(--coral)}.editor-spread-action:disabled{opacity:.4;cursor:not-allowed}.editor-spread-action--danger:hover:not(:disabled){border-color:#c44420;color:#c44420}.editor-style-toggle{display:inline-flex;align-items:center;gap:6px;margin-left:auto}.editor-style-toggle-label{font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--txt-3);margin-right:4px}.editor-style-pill{padding:5px 12px;border-radius:100px;background:var(--warm-bg);border:1px solid var(--border);color:var(--txt-2);font-size:.75rem;font-weight:600;transition:border-color .15s,background .15s,color .15s}.editor-style-pill:hover{color:var(--txt-1)}.editor-style-pill--active{background:var(--coral);border-color:var(--coral);color:#fff}.editor-spread-canvas--bleed .editor-slot{border-radius:0;box-shadow:none}.editor-spread-canvas--bleed .editor-slot:hover{transform:none;box-shadow:0 0 0 2px var(--coral) inset}.editor-main{flex:1;overflow-y:auto;display:flex;align-items:flex-start;justify-content:center;padding:24px 28px}.editor-spread-panel{display:flex;flex-direction:column;gap:14px;align-items:stretch;width:100%;max-width:920px}.editor-spread-info{display:flex;justify-content:space-between;width:100%}.editor-canvas-mat{background:var(--navy);background-image:radial-gradient(ellipse at center top,rgba(255,255,255,.04),transparent 60%);padding:22px 26px 30px;border-radius:10px;box-shadow:0 18px 50px #140f0a38,0 4px 12px #140f0a14}.editor-spread-canvas{position:relative;width:100%;aspect-ratio:7 / 5;background:#f5f1eb;border-radius:3px;box-shadow:0 8px 24px #00000059,0 2px 6px #0000002e;overflow:hidden}.editor-spread-spine{position:absolute;left:50%;top:0;bottom:0;width:7%;transform:translate(-50%);background:linear-gradient(90deg,#0000,#0000000a 25%,#0000002e 45%,#0000006b,#0000002e 55%,#0000000a 75%,#0000);mix-blend-mode:multiply;pointer-events:none;z-index:2}.editor-slot{position:absolute;cursor:pointer;overflow:hidden;background:#e8e4df;border-radius:2px;box-shadow:0 1px 3px #0000001f;transition:transform .15s,box-shadow .15s;z-index:1}.editor-slot:hover{transform:scale(1.005);box-shadow:0 4px 12px #0000002e}.editor-slot>img{width:100%;height:100%;object-fit:cover;pointer-events:none;display:block}.editor-slot-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#a8a29e;border:2px dashed #d4cfc9;background:#faf8f5}.editor-slot-overlay{position:absolute;inset:0;background:#d4522a38;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.06em;opacity:0;transition:opacity .15s;text-transform:uppercase;pointer-events:none}.editor-slot:hover .editor-slot-overlay{opacity:1}.editor-divider-spread{position:relative;width:100%;aspect-ratio:7 / 5;background:#faf8f5;border-radius:3px;box-shadow:0 8px 24px #00000059,0 2px 6px #0000002e;overflow:hidden;display:flex}.editor-divider-blank{width:50%;height:100%;background:#f5f1eb}.editor-divider-title{width:50%;height:100%;display:flex;align-items:center;justify-content:center;padding:0 8%}.editor-divider-title span{font-size:clamp(1.4rem,3.5vw,2.5rem);font-style:italic;color:var(--txt-2);text-align:center;line-height:1.15}.stickers-backdrop{position:fixed;inset:0;background:#140f0a52;z-index:90;animation:fadeIn .15s ease-out}.stickers-panel{position:fixed;top:0;right:0;bottom:0;width:360px;max-width:90vw;background:var(--warm-bg);z-index:91;display:flex;flex-direction:column;box-shadow:-8px 0 32px #140f0a33;animation:slideInRight .2s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.stickers-head{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 20px 12px;border-bottom:1px solid var(--border)}.stickers-title{font-family:var(--serif);font-size:1.5rem;color:var(--txt-1)}.stickers-sub{color:var(--txt-3);font-size:.8rem;margin-top:2px}.stickers-close{background:transparent;color:var(--txt-3);border:none;font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px}.stickers-close:hover{background:var(--border);color:var(--txt-1)}.stickers-search{margin:12px 20px 0;padding:10px 14px;border:1.5px solid var(--border);border-radius:100px;background:#fff;font-size:.875rem;font-family:var(--sans);color:var(--txt-1)}.stickers-search:focus{outline:none;border-color:var(--coral)}.stickers-cats{display:flex;flex-wrap:wrap;gap:6px;padding:12px 20px 8px}.stickers-cat{padding:5px 12px;border-radius:100px;background:#fff;border:1px solid var(--border);color:var(--txt-2);font-size:.75rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.stickers-cat:hover{color:var(--txt-1)}.stickers-cat--active{background:var(--coral);border-color:var(--coral);color:#fff}.stickers-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:8px 20px 20px}.stickers-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:#fff;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s,transform .1s}.stickers-item:hover{border-color:var(--coral);transform:translateY(-1px)}.stickers-item img{width:42px;height:42px;display:block;pointer-events:none}.stickers-item span{font-size:.7rem;color:var(--txt-2);text-align:center;line-height:1.2}.stickers-empty{grid-column:1 / -1;padding:40px 16px;text-align:center;color:var(--txt-3);font-size:.875rem}.stickers-foot{padding:10px 20px;border-top:1px solid var(--border);font-size:.7rem;color:var(--txt-3)}.stickers-foot a{color:var(--txt-2);text-decoration:underline}.sticker-on-spread{position:absolute;aspect-ratio:1 / 1;cursor:grab;z-index:4;user-select:none;-webkit-user-select:none}.sticker-on-spread:active{cursor:grabbing}.sticker-on-spread img{width:100%;height:100%;display:block;pointer-events:none;-webkit-user-drag:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.18))}.sticker-on-spread--selected{outline:1.5px dashed var(--coral);outline-offset:2px}.sticker-handle{position:absolute;width:14px;height:14px;background:#fff;border:1.5px solid var(--coral);border-radius:50%;z-index:5}.sticker-handle--resize{right:-7px;bottom:-7px;cursor:nwse-resize}.sticker-handle--rotate{left:50%;top:-22px;transform:translate(-50%);cursor:grab}.sticker-handle--rotate:after{content:"";position:absolute;left:50%;top:100%;width:1.5px;height:8px;background:var(--coral);transform:translate(-50%)}.sticker-toolbar{position:absolute;top:8px;left:12px;display:flex;align-items:center;gap:6px;padding:6px 8px;background:#fff;border-radius:10px;box-shadow:0 4px 12px #00000040;z-index:6}.sticker-toolbar-group{position:relative;display:flex}.sticker-color-swatch{width:28px;height:28px;border-radius:6px;border:2px solid white;outline:1px solid var(--border);cursor:pointer;padding:0}.sticker-color-picker{position:absolute;top:calc(100% + 6px);left:0;display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:6px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000002e;z-index:7}.sticker-swatch{width:22px;height:22px;border-radius:4px;border:1.5px solid;cursor:pointer;padding:0}.sticker-tool-btn{background:transparent;border:none;cursor:pointer;padding:4px 8px;font-size:.875rem;color:var(--txt-2);border-radius:6px}.sticker-tool-btn:hover{background:var(--warm-bg);color:var(--txt-1)}.sticker-tool-btn--danger:hover{background:#fce8e3;color:var(--coral-dk)}.editor-canvas-mat{position:relative}.editor-cover-panel{display:flex;flex-direction:column;gap:12px;width:100%;max-width:1040px}.editor-cover-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.editor-panel-title{font-family:var(--serif);font-size:1.375rem;margin:0}.editor-cover-tabs{display:inline-flex;background:#fff;border:1px solid var(--border);border-radius:100px;padding:3px;gap:2px}.editor-cover-tab{padding:6px 18px;font-size:.8125rem;font-weight:600;color:var(--txt-2);border-radius:100px;transition:background .15s,color .15s}.editor-cover-tab:hover{color:var(--txt-1)}.editor-cover-tab--active{background:var(--coral);color:#fff}.editor-field-hint{font-size:.6875rem;color:var(--txt-3);margin:0;line-height:1.5}.editor-cover-controls .wizard-label{font-size:.6875rem;letter-spacing:.12em;gap:5px}.editor-cover-controls .wizard-input{padding:9px 12px;border-radius:8px;border-width:1px;font-size:.875rem}.editor-cover-controls .editor-field{gap:5px}.editor-back-textarea{resize:vertical;min-height:88px;font-family:var(--sans);line-height:1.5}.editor-cover-layout{display:grid;grid-template-columns:minmax(240px,.8fr) minmax(340px,1fr);gap:28px;align-items:start}.editor-cover-controls{display:flex;flex-direction:column;gap:14px}@media(max-width:880px){.editor-cover-layout{grid-template-columns:1fr}}.editor-cover-preview{container-type:inline-size;position:relative;aspect-ratio:7 / 10;width:100%;max-height:calc(100vh - 240px);max-width:calc((100vh - 240px)*.7);margin:0 auto;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:7.9cqw 5.6cqw;text-align:center;color:#faf8f5;box-shadow:0 14px 36px #140f0a38,0 2px 8px #140f0a1a;overflow:hidden}.editor-cover-preview:after{content:"";position:absolute;inset:8px;border:1px solid rgba(255,255,255,.18);border-radius:2px;pointer-events:none}.editor-cover-title{font-family:var(--serif);font-size:13.5cqw;font-weight:700;line-height:1;letter-spacing:.01em;word-spacing:.05em}.editor-cover-subtitle{font-family:var(--sans);font-size:max(.65rem,2.8cqw);font-weight:700;letter-spacing:.18em;opacity:.92}.editor-cover-sticker{flex:1;display:flex;align-items:center;justify-content:center;width:75cqw;color:#faf8f5;padding:3.4cqw 0}.editor-cover-sticker svg{width:100%;height:100%;max-height:67.5cqw;display:block}.editor-cover-preview--back{padding:28px 22px}.editor-back-text{flex:1;display:flex;align-items:center;justify-content:center;font-size:.875rem;line-height:1.55;color:#faf8f5;max-width:88%;margin:0 auto;text-align:center;font-style:italic;opacity:.92}.editor-back-year{align-self:flex-end;font-size:.6875rem;font-weight:700;letter-spacing:.22em;color:#faf8f5;opacity:.85}.editor-spine-preview{position:relative;width:88px;height:100%;max-height:calc(100vh - 280px);aspect-ratio:1 / 6;margin:0 auto;border-radius:3px;box-shadow:0 14px 36px #140f0a38,0 2px 8px #140f0a1a;display:flex;align-items:center;justify-content:center;overflow:hidden}.editor-spine-text{writing-mode:vertical-rl;transform:rotate(180deg);font-weight:700;font-size:1rem;letter-spacing:.22em;white-space:nowrap;padding:18px 0}.editor-colors,.editor-stickers{display:flex;flex-direction:column;gap:8px}.editor-colors-label{font-size:.6875rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--txt-2);margin:0}.editor-swatches{display:flex;gap:8px;flex-wrap:wrap}.editor-swatch{width:28px;height:28px;border-radius:50%;border:2.5px solid transparent;transition:transform .15s,border-color .15s;cursor:pointer}.editor-swatch:hover{transform:scale(1.12)}.editor-swatch--active{border-color:var(--txt-1);transform:scale(1.12)}.editor-sticker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.editor-sticker-tile{aspect-ratio:1 / 1;background:#fff;border:1px solid var(--border);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;color:var(--txt-1);transition:border-color .15s,transform .15s,background .15s}.editor-sticker-tile:hover{border-color:var(--coral-lt);transform:translateY(-1px)}.editor-sticker-tile--active{border-color:var(--coral);background:#d4522a0f}.editor-sticker-tile svg{width:100%;height:100%;display:block}.editor-sticker-tile--none{color:var(--txt-3);font-weight:600;font-size:.875rem}.editor-stickers-head{display:flex;justify-content:space-between;align-items:center}.editor-sticker-color-row{display:flex;gap:6px}.editor-sticker-color-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);transition:transform .15s,border-color .15s;cursor:pointer;box-shadow:0 1px 2px #00000014}.editor-sticker-color-dot:hover{transform:scale(1.15)}.editor-sticker-color-dot--active{border-color:var(--coral);transform:scale(1.15)}.editor-font-chips{display:flex;gap:6px;flex-wrap:wrap}.editor-font-chip{padding:6px 12px;background:#fff;border:1px solid var(--border);border-radius:100px;font-size:.8125rem;font-weight:600;color:var(--txt-1);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.editor-font-chip:hover{border-color:var(--coral-lt)}.editor-font-chip--active{border-color:var(--coral);background:var(--coral);color:#fff}.editor-cover-preview-wrap{display:flex;flex-direction:column;gap:8px;align-self:stretch}.cover-wraparound-btn{align-self:stretch;padding:7px 12px;background:#fff;border:1px dashed var(--border);border-radius:7px;font-size:.75rem;font-weight:600;color:var(--txt-2);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.cover-wraparound-btn:hover{border-color:var(--coral);color:var(--coral);background:var(--coral-lt)}.editor-field{display:flex;flex-direction:column;gap:6px}.wraparound-modal{background:#fff;border-radius:14px;width:min(90vw,920px);max-height:86vh;display:flex;flex-direction:column;box-shadow:0 30px 80px #00000059;overflow:hidden}.wraparound-head{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border)}.wraparound-meta{font-size:.75rem;color:var(--txt-3);margin-top:3px;font-family:JetBrains Mono,ui-monospace,monospace}.wraparound-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;background:#f5f1eb;overflow:auto}.wraparound-canvas{position:relative;width:100%;max-width:880px;max-height:calc(86vh - 180px);border-radius:3px;box-shadow:0 16px 40px #00000040;overflow:hidden}.wraparound-bleed{position:absolute;border:2px dashed rgba(255,100,130,.85);pointer-events:none;z-index:5}.wraparound-hinge{position:absolute;background:repeating-linear-gradient(45deg,#ff8c3c1f 0 4px,#ff8c3c38 4px 8px);pointer-events:none;z-index:3}.wraparound-spine{position:absolute;display:flex;align-items:center;justify-content:center;z-index:4;border-left:1px solid rgba(255,255,255,.18);border-right:1px solid rgba(255,255,255,.18)}.wraparound-spine span{writing-mode:vertical-rl;transform:rotate(180deg);font-weight:700;font-size:.75rem;letter-spacing:.18em;white-space:nowrap}.wraparound-panel{container-type:inline-size;position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:space-between;color:#faf8f5;padding:7.9cqw 5.6cqw;text-align:center;z-index:2}.wraparound-front .wraparound-title{font-size:13.5cqw;font-weight:700;line-height:1}.wraparound-sticker{flex:1;display:flex;align-items:center;justify-content:center;width:75cqw;padding:3.4cqw 0}.wraparound-sticker svg{width:100%;height:100%;max-height:67.5cqw;display:block}.wraparound-front .wraparound-subtitle{font-size:max(.6rem,2.8cqw);font-weight:700;letter-spacing:.18em;opacity:.92}.wraparound-back{text-align:center}.wraparound-back-blurb{flex:1;display:flex;align-items:center;justify-content:center;font-size:.75rem;line-height:1.55;font-style:italic;margin:0 auto;max-width:88%;opacity:.92;text-align:center}.wraparound-back-year{margin-top:auto;align-self:flex-end;font-size:.625rem;font-weight:700;letter-spacing:.22em;opacity:.85}.wraparound-label{position:absolute;font-size:.625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffffff8c;z-index:6;pointer-events:none}.wraparound-footnote{padding:12px 24px 18px;font-size:.75rem;color:var(--txt-3);border-top:1px solid var(--border);background:var(--warm-bg);line-height:1.5}.editor-bottom-strip{height:94px;flex-shrink:0;background:#fff;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;padding:10px 18px;overflow-x:auto}.editor-bottom-strip::-webkit-scrollbar{height:6px}.editor-bottom-strip::-webkit-scrollbar-thumb{background:var(--border);border-radius:100px}.editor-strip-item{flex-shrink:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;border-radius:6px;padding:4px;border:2px solid transparent;transition:border-color .15s,transform .15s}.editor-strip-item:hover{border-color:var(--coral-lt)}.editor-strip-item--active{border-color:var(--coral)}.editor-strip-item[draggable=true]:active{cursor:grabbing;transform:scale(.97)}.editor-strip-item>span{font-size:.625rem;color:var(--txt-3);font-weight:600}.editor-strip-item--cover .editor-strip-cover{position:relative;width:42px;height:60px;border-radius:3px;box-shadow:0 2px 6px #00000026;display:flex;align-items:center;justify-content:center;color:#faf8f5;overflow:hidden}.editor-strip-cover-sticker{width:70%;height:70%}.editor-strip-cover-sticker svg{width:100%;height:100%;display:block}.editor-strip-spread{position:relative;width:88px;height:60px;background:#f5f1eb;border-radius:2px;display:flex;box-shadow:0 2px 6px #0000001f;overflow:hidden}.editor-strip-spread:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:6px;transform:translate(-50%);background:linear-gradient(90deg,transparent,rgba(0,0,0,.18) 50%,transparent);z-index:2;pointer-events:none}.editor-strip-page{flex:1;height:100%;background:#e8e4df;overflow:hidden}.editor-strip-page:first-child{margin-right:1px}.editor-strip-page:last-child{margin-left:1px}.editor-strip-page img{width:100%;height:100%;object-fit:cover;display:block}.editor-strip-divider{width:88px;height:60px;border-radius:3px;background:repeating-linear-gradient(45deg,#faf8f5,#faf8f5 6px,var(--warm-bg) 6px,var(--warm-bg) 12px);border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:.7rem;color:var(--txt-3);padding:0 6px;text-align:center}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{background:#fff;border-radius:20px;width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px #0003}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-title{font-family:var(--serif);font-size:1.375rem;margin:0}.modal-close{font-size:1.25rem;color:var(--txt-3);padding:4px 8px;border-radius:8px}.modal-close:hover{background:var(--warm-bg);color:var(--txt-1)}.modal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:20px 24px;overflow-y:auto}.modal-photo{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;cursor:pointer;background:var(--border);transition:transform .15s,box-shadow .15s}.modal-photo:hover{transform:scale(1.04);box-shadow:0 4px 16px #00000026}.modal-photo img{width:100%;height:100%;object-fit:cover;display:block}.modal-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.625rem;color:var(--txt-3)}.modal-photo-score{position:absolute;bottom:4px;left:4px;background:#0009;color:#fff;font-size:.625rem;font-weight:700;padding:2px 5px;border-radius:6px}@media(max-width:720px){.app-nav{padding:0 20px}.app-main{padding:32px 20px}.dashboard-head{flex-direction:column;align-items:flex-start}.auth-card{padding:32px 24px}}
