*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f8f8;--surface:#fff;--border:#e5e5e5;--text:#333;--text-muted:#888;--accent:#003a85;--accent-hover:#002a65;--accent-light:#e8f0fe;--success:#46643f;--danger:#c0392b;--pink:#f1c3cc;--warm:#efebe0;font-family:var(--ca-font-ui,"DM Sans", system-ui, -apple-system, sans-serif);color:var(--text);background:var(--bg);font-size:14px}body{height:100vh;height:100dvh;margin:0;overflow:hidden}#root{height:100vh;flex-direction:column;height:100dvh;display:flex}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}h3{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:13px;font-weight:700}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--ca-blue:#003a85;--ca-blue-dark:#002a65;--ca-blue-light:#003a8514;--ca-green:#46643f;--ca-pink:#f1c3cc;--accent:#003a85;--ca-font-ui:"DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--ca-rose:#fad2e2;--ca-rose-soft:#fdeaf1;--ca-rose-ink:#8c4d66;--ca-butter:#fbeda0;--ca-butter-soft:#fef8dc;--ca-butter-ink:#8a6d1f;--ca-cream:#fbf8f3;--ca-ink-warm:#2a2521;--ca-success:#1b5e20;--ca-warning:#e65100;--ca-danger:#b71c1c;--ca-info:#003a85;--ca-bg-app:#f2ede6;--ca-bg-surface:#fff;--ca-bg-subtle:#f4f2ee;--ca-bg-elevated:#fffffff5;--ca-bg-hover:#0000000d;--ca-bg-active:#00000014;--ca-bg-grey-50:#f5f5f5;--ca-bg-grey-100:#f2f2f2;--ca-bg-grey-150:#f0f0f0;--ca-bg-grey-200:#eaeaea;--ca-text-primary:#1a1a1a;--ca-text-secondary:#555;--ca-text-muted:#6b6b6b;--ca-text-disabled:#bbb;--ca-text-on-dark:#fff;--ca-text-danger:#c0392b;--ca-text-danger-hover:#b0413e;--ca-text-danger-active:#962d22;--ca-bg-danger-tint:#fef0f0;--ca-text-link:#003a85;--ca-bg-info-tint:#f5f8ff;--ca-bg-success-tint:#f0f7f0;--ca-bg-warning-tint:#fff4e5;--ca-bg-success-icon:#e8f5e9;--ca-border-subtle:#0000000f;--ca-border-default:#e0ddd7;--ca-border-strong:#c8c8c8;--ca-border-focus:#003a85;--ca-space-1:4px;--ca-space-2:8px;--ca-space-3:12px;--ca-space-4:16px;--ca-space-5:20px;--ca-space-6:24px;--ca-space-8:32px;--ca-space-10:40px;--ca-space-12:48px;--ca-space-16:64px;--ca-radius-xs:4px;--ca-radius-sm:6px;--ca-radius-md:8px;--ca-radius-lg:12px;--ca-radius-xl:16px;--ca-radius-pill:999px;--ca-shadow-xs:0 1px 2px #2a25210d;--ca-shadow-sm:0 1px 3px #2a252112, 0 0 0 1px #2a25210a;--ca-shadow-md:0 1px 2px #2a25210d, 0 6px 16px -6px #2a25211f;--ca-shadow-lg:0 2px 4px #2a25210f, 0 14px 32px -12px #2a25212e;--ca-shadow-xl:0 4px 10px #2a252114, 0 28px 64px -20px #2a25214d;--ca-shadow-cta:0 2px 6px #46643f52;--ca-font-serif:"Playfair Display", Georgia, serif;--ca-font-display:"Londrina Solid", system-ui, sans-serif;--ca-text-xs:11px;--ca-text-sm:12.5px;--ca-text-base:14px;--ca-text-md:15px;--ca-text-lg:17px;--ca-text-xl:20px;--ca-text-2xl:24px;--ca-text-3xl:32px;--ca-font-weight-regular:400;--ca-font-weight-medium:500;--ca-font-weight-semibold:600;--ca-font-weight-bold:700;--ca-line-tight:1.2;--ca-line-snug:1.35;--ca-line-normal:1.5;--ca-line-relaxed:1.65;--ca-tracking-tight:-.02em;--ca-tracking-normal:0;--ca-tracking-wide:.02em;--ca-tracking-wider:.05em;--ca-ease-premium:cubic-bezier(.16, 1, .3, 1);--ca-tr-fast:.12s cubic-bezier(.4, 0, .2, 1);--ca-tr-default:.18s cubic-bezier(.4, 0, .2, 1);--ca-tr-slow:.32s cubic-bezier(.16, 1, .3, 1);--ca-ease-out:cubic-bezier(.16, 1, .3, 1);--ca-ease-in-out:cubic-bezier(.4, 0, .2, 1);--ca-ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ca-ease-settle:cubic-bezier(.26, 1.04, .38, 1);--ca-dur-fast:.16s;--ca-dur-med:.28s;--ca-dur-slow:.45s;--ca-ease-flip:cubic-bezier(.4, .05, .15, 1);--ca-z-canvas:1;--ca-z-handles:9;--ca-z-toolbars:50;--ca-z-sticky:100;--ca-z-modal:250;--ca-z-toast:9999}.app-error-fallback{font-family:var(--ca-font-ui), system-ui, sans-serif;text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.app-error-fallback h2{margin:0 0 12px}.app-error-fallback p{color:var(--ca-text-secondary);margin:0 0 20px}.app-error-fallback button{cursor:pointer;background:var(--ca-blue);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600}@keyframes spineInputFlash{0%{border-color:var(--ca-blue);background:#eef3fb;box-shadow:0 0 #003a858c}60%{border-color:var(--ca-blue);background:var(--ca-bg-surface);box-shadow:0 0 0 6px #003a8500}to{background:var(--ca-bg-surface);border-color:#e4e4e4;box-shadow:0 0 #003a8500}}.spine-input-flash{animation:1.4s ease-out spineInputFlash}@media (prefers-reduced-motion:reduce){.spine-input-flash{animation:none}}html,body{overscroll-behavior-y:none;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;font-family:var(--ca-font-ui)}.app{height:100vh;height:100dvh;font-family:var(--ca-font-ui);color:var(--ca-text-primary);background:var(--ca-bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;flex-direction:column;display:flex;overflow:hidden}button{transition:background var(--ca-tr-fast), color var(--ca-tr-fast), border-color var(--ca-tr-fast), box-shadow var(--ca-tr-fast), transform var(--ca-tr-fast), opacity var(--ca-tr-fast)}img{transition:opacity .2s}button:focus-visible{outline:2px solid var(--ca-blue);outline-offset:2px}input:focus-visible{outline:2px solid var(--ca-blue);outline-offset:2px}textarea:focus-visible{outline:2px solid var(--ca-blue);outline-offset:2px}select:focus-visible{outline:2px solid var(--ca-blue);outline-offset:2px}input:focus-visible{outline-offset:0}textarea:focus-visible{outline-offset:0}select:focus-visible{outline-offset:0}button,.mtab,.format-size-card,.format-pages-btn{touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.topbar{background:var(--ca-bg-surface);z-index:80;scrollbar-width:thin;border-bottom:1px solid #eaeaea;flex-shrink:0;justify-content:space-between;align-items:center;min-width:0;height:52px;padding:0 14px;display:flex;position:relative;overflow:auto hidden}.topbar::-webkit-scrollbar{height:2px}.topbar::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}.topbar-section{align-items:center;gap:8px;display:flex}.postcheckout-banner{color:var(--ca-text-primary);background:var(--ca-bg-info-tint);z-index:79;border-bottom:1px solid #2176d22e;flex-shrink:0;justify-content:center;align-items:center;gap:10px;padding:7px 14px;font-size:12.5px;line-height:1.4;display:flex}.postcheckout-banner svg{color:var(--ca-blue);flex-shrink:0}.postcheckout-banner.closed{background:var(--ca-bg-surface);color:var(--ca-text-secondary)}.postcheckout-banner.closed svg{color:var(--ca-success,#2e7d32)}.postcheckout-banner-btn{border:1px solid var(--ca-blue);color:var(--ca-blue);cursor:pointer;white-space:nowrap;background:0 0;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:600}.postcheckout-banner-btn:hover:not(:disabled){background:var(--ca-blue);color:#fff}.postcheckout-banner-btn:disabled{opacity:.55;cursor:default}@media (max-width:768px){.postcheckout-banner{text-align:center;flex-wrap:wrap;padding:6px 10px}}.topbar-center-section{gap:2px}.topbar-icon-btn{border-radius:var(--ca-radius-md);width:36px;height:36px;color:var(--ca-text-muted);justify-content:center;align-items:center;display:flex}.topbar-icon-btn:hover{background:var(--ca-bg-grey-100);color:var(--ca-text-primary)}.topbar-divider{background:#e8e8e8;width:1px;height:22px;margin:0 4px}.topbar-logo{color:var(--ca-text-primary);letter-spacing:-.4px;font-size:17px;font-weight:800}.topbar-order-btn{background:var(--ca-green);color:#fff;letter-spacing:.2px;transition:background .15s ease, box-shadow .15s ease, transform var(--ca-dur-fast) var(--ca-ease-spring);border-radius:24px;flex-shrink:0;align-items:center;gap:8px;padding:10px 22px;font-size:14px;font-weight:700;display:flex;box-shadow:0 2px 6px #46643f52,0 0 0 1px #46643f26}@media (hover:hover) and (pointer:fine){.topbar-order-btn:hover{background:#3d5837;transform:translateY(-1px);box-shadow:0 4px 14px #46643f6b,0 0 0 1px #46643f33}}.topbar-order-btn:active{transition:background .15s,box-shadow .15s,transform 80ms;transform:translateY(0)scale(.97);box-shadow:0 1px 3px #46643f4d}.topbar-order-btn:disabled{cursor:not-allowed;box-shadow:none;background:#b8c4b5}.topbar-actions{gap:2px}.topbar-action-btn{cursor:pointer;color:var(--ca-text-secondary);letter-spacing:0;border-radius:var(--ca-radius-md);transition:background var(--ca-tr-fast), color var(--ca-tr-fast), transform var(--ca-tr-fast);white-space:nowrap;background:0 0;border:none;justify-content:center;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:500;display:inline-flex}.topbar-action-btn svg{flex-shrink:0;display:block}@media (hover:hover) and (pointer:fine){.topbar-action-btn:hover{background:var(--ca-bg-hover);color:var(--ca-text-primary);transform:translateY(-1px)}}.topbar-action-btn:active{background:var(--ca-bg-active);transform:translateY(0)}.topbar-action-btn:disabled{opacity:.4;cursor:not-allowed}.topbar-action-btn:disabled:hover{color:var(--ca-text-secondary);background:0 0;transform:none}@media (max-width:768px){.topbar-undoredo{display:none}}@media (max-width:1100px){.topbar-action-btn{gap:0;padding:6px 8px}.topbar-action-btn span{display:none}}@media (max-width:480px){.topbar{padding:0 6px}.topbar-icon-btn{width:36px;min-width:36px;height:36px;min-height:36px}.topbar-action-btn{min-width:36px;min-height:36px;padding:6px}.topbar-action-btn svg{width:20px;height:20px}.topbar-section{gap:4px}.topbar-actions{gap:2px}.topbar-order-btn{min-height:36px;padding:8px 14px;font-size:13px}.topbar-order-price{padding:2px 5px;font-size:11px}.topbar-order-text{display:none}.topbar-order-btn{gap:4px}}.topbar-order-price{color:#2c4327;background:#fff;border-radius:5px;margin-left:6px;padding:3px 7px;font-size:12px;font-weight:700;display:inline-block}.topbar-mobile-only{display:none}.topbar-more-wrap{position:relative}.topbar-more-btn{padding:8px}.topbar-more-backdrop{z-index:199;-webkit-tap-highlight-color:transparent;background:0 0;position:fixed;top:0;bottom:0;left:0;right:0}.topbar-more-menu{background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-lg);z-index:200;min-width:200px;padding:6px;animation:.14s tmmIn;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0000001f}@keyframes tmmIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tmm-item{width:100%;color:var(--ca-text-primary);border-radius:var(--ca-radius-sm);text-align:left;cursor:pointer;background:0 0;border:0;align-items:center;gap:10px;padding:10px 12px;font-size:13.5px;display:flex}.tmm-item:hover:not(:disabled){background:var(--ca-bg-grey-50)}.tmm-item:disabled{opacity:.4;cursor:not-allowed}.tmm-item svg{color:var(--ca-text-secondary);flex-shrink:0}.tmm-item>span:first-of-type{flex:1}.tmm-shortcut{color:var(--ca-text-muted);background:var(--ca-bg-grey-50);border-radius:3px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.tmm-item:hover:not(:disabled) .tmm-shortcut{background:var(--ca-bg-surface)}.tmm-item.flash{animation:.3s tmmFlash}@keyframes tmmFlash{0%{background:#e8f0ff}to{background:0 0}}.tmm-sep{background:#eee;height:1px;margin:4px 6px}.topbar-more-menu--portal{min-width:240px}@media (max-width:768px){.topbar-more-menu--portal{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-width:thin;max-width:calc(100vw - 16px);max-height:calc(100dvh - 104px);overflow-y:auto}}@media (max-width:932px) and (orientation:landscape) and (max-height:500px){.topbar-more-menu--portal{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-width:thin;max-width:calc(100vw - 16px);max-height:calc(100dvh - 104px);overflow-y:auto}}.tmm-head{color:var(--ca-text-secondary);padding:8px 12px 4px;font-size:12px;font-weight:600}.tmm-item.danger,.tmm-item.danger svg{color:#c62828}.tmm-item-primary{font-weight:600;color:var(--ca-text-primary)!important}.tmm-item-primary svg{color:#f59e0b!important}.tmm-item-primary:hover:not(:disabled){background:#fef3c7}.topbar-name{color:var(--ca-text-primary);border-radius:var(--ca-radius-sm);text-overflow:ellipsis;white-space:nowrap;align-items:center;max-width:200px;min-height:36px;padding:5px 10px;font-size:14px;font-weight:600;display:inline-flex;overflow:hidden}.topbar-name:hover{background:var(--ca-bg-grey-100)}.topbar-name-input{color:var(--ca-text-primary);border:2px solid var(--accent);border-radius:var(--ca-radius-sm);outline:none;width:200px;padding:5px 10px;font-family:inherit;font-size:14px;font-weight:600}.topbar-save-status{color:var(--ca-text-muted);align-items:center;gap:5px;margin-left:4px;font-size:11px;animation:.3s fadeIn;display:inline-flex}.topbar-save-status svg{flex-shrink:0}.topbar-save-status.saving{color:var(--ca-blue)}.topbar-save-status.saving .topbar-save-text{font-weight:500}.topbar-save-status.just-saved svg{animation:saveTickPulse .7s var(--ca-ease-out)}@keyframes saveTickPulse{0%{transform:scale(1)}35%{filter:drop-shadow(0 0 4px #2e7d3299);transform:scale(1.35)}to{filter:none;transform:scale(1)}}.topbar-save-spinner{border:1.6px solid #003a8533;border-top-color:var(--ca-blue);border-radius:50%;flex-shrink:0;width:11px;height:11px;animation:.7s linear infinite topbarSaveSpin;display:inline-block}@keyframes topbarSaveSpin{to{transform:rotate(360deg)}}.export-warn-overlay{z-index:9999;background:#0000008c;justify-content:center;align-items:center;padding:16px;animation:.18s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.export-warn-modal{background:var(--ca-bg-surface);border-radius:10px;width:min(420px,100%);animation:.22s cubic-bezier(.2,.9,.3,1.1) ewmIn;overflow:hidden;box-shadow:0 12px 48px #00000040}@keyframes ewmIn{0%{opacity:0;transform:translateY(8px)scale(.97)}to{opacity:1;transform:none}}.ewm-head{align-items:center;gap:10px;padding:14px 18px 8px;display:flex}.ewm-head h3{color:var(--ca-text-primary);margin:0;font-size:15px;font-weight:700}.ewm-body{color:var(--ca-text-secondary);padding:4px 18px 14px;font-size:13px}.ewm-lead{color:var(--ca-text-secondary);margin:0 0 10px}.ewm-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.ewm-list li{border-radius:var(--ca-radius-xs);background:#fff7e6;border-left:3px solid #ffa726;padding:8px 10px}.ewm-list strong{color:var(--ca-text-primary);margin-bottom:2px;font-weight:600;display:block}.ewm-hint{color:var(--ca-text-muted);font-size:12px}.ewm-foot{border-top:1px solid #eee;justify-content:flex-end;gap:8px;padding:12px 18px 16px;display:flex}.ewm-btn{border-radius:var(--ca-radius-sm);cursor:pointer;border:1px solid #0000;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}.ewm-btn-ghost{background:var(--ca-bg-surface);color:var(--ca-text-secondary);border-color:#ddd}.ewm-btn-ghost:hover{background:var(--ca-bg-grey-50)}.ewm-btn-primary{background:var(--ca-blue);color:#fff}.ewm-btn-primary:hover{background:var(--ca-blue-dark)}.tutorial-overlay{z-index:var(--ca-z-modal);padding:var(--ca-space-4);animation:fadeIn var(--ca-dur-fast) ease;background:#2a25218c;justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.tutorial-modal{background:var(--ca-bg-surface);border-radius:var(--ca-radius-lg);width:min(720px,100%);box-shadow:var(--ca-shadow-xl);animation:tutorialIn var(--ca-dur-med) var(--ca-ease-spring);overflow:hidden}@keyframes tutorialIn{0%{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.tutorial-overlay,.tutorial-modal{animation:none}}.tutorial-head{align-items:center;gap:var(--ca-space-2);padding:var(--ca-space-3) var(--ca-space-4);display:flex}.tutorial-head h3{font-size:var(--ca-text-md);font-weight:var(--ca-font-weight-semibold);color:var(--ca-text-primary);text-transform:none;letter-spacing:var(--ca-tracking-normal);flex:1;margin:0}.tutorial-close{border-radius:var(--ca-radius-sm);width:32px;height:32px;color:var(--ca-text-secondary);cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast);background:0 0;border:0;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.tutorial-close:hover{background:var(--ca-bg-hover);color:var(--ca-text-primary)}.tutorial-video{aspect-ratio:16/9;background:#000}.tutorial-video iframe{border:0;width:100%;height:100%;display:block}.tutorial-hint{padding:var(--ca-space-3) var(--ca-space-4);font-size:var(--ca-text-sm);color:var(--ca-text-muted);margin:0}.empty-slots-warning{border-radius:var(--ca-radius-sm);color:var(--ca-text-primary);background:#fef3c7;border:1px solid #f59e0b;margin:12px 0 10px;padding:12px 14px;font-size:13px}.esw-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.esw-icon{flex-shrink:0}.esw-title{color:var(--ca-text-primary);font-weight:600;line-height:1.3}.esw-list{flex-direction:column;gap:4px;max-height:200px;margin:0 0 8px;padding:0;font-size:12.5px;list-style:none;display:flex;overflow-y:auto}.esw-item{border-bottom:1px dashed #b453092e;justify-content:space-between;align-items:baseline;padding:3px 0;display:flex}.esw-item:last-child{border-bottom:none}.esw-item-label{color:var(--ca-text-primary)}.esw-item-count{color:#b45309;font-variant-numeric:tabular-nums;flex-shrink:0;margin-left:12px;font-weight:500}.esw-expand-btn{color:#b45309;cursor:pointer;background:0 0;border:0;padding:4px 0;font-size:12.5px;font-weight:600;text-decoration:underline}.esw-expand-btn:hover{color:#92400e}.esw-reassurance{color:var(--ca-text-secondary);margin:6px 0 0;font-size:12px;line-height:1.45}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.topbar-status{color:var(--ca-text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.ca-tooltip{z-index:var(--ca-z-toast);color:var(--ca-text-on-dark);font-size:var(--ca-text-sm);letter-spacing:.1px;border-radius:var(--ca-radius-sm);box-shadow:var(--ca-shadow-md);pointer-events:none;white-space:nowrap;max-width:220px;animation:caTooltipIn .15s var(--ca-ease-out);background:#14121ceb;padding:6px 10px;font-weight:500}@keyframes caTooltipIn{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.ca-tooltip-bottom{transform:translate(-50%)}.ca-tooltip-top{transform:translate(-50%,-100%)}.ca-tooltip-left{transform:translate(-100%,-50%)}.ca-tooltip-right{transform:translateY(-50%)}.ca-tooltip:before{content:"";border:5px solid #0000;width:0;height:0;position:absolute}.ca-tooltip-bottom:before{top:-10px;left:calc(50% + var(--tail-x,0px));border-bottom-color:#14121ceb;margin-left:-5px}.ca-tooltip-top:before{bottom:-10px;left:calc(50% + var(--tail-x,0px));border-top-color:#14121ceb;margin-left:-5px}.ca-tooltip-left:before{border-left-color:#14121ceb;margin-top:-5px;top:50%;right:-10px}.ca-tooltip-right:before{border-right-color:#14121ceb;margin-top:-5px;top:50%;left:-10px}.topbar-spinner{border:2px solid #e0e0e0;border-top-color:var(--ca-text-secondary);border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.workspace{flex:1;display:flex;overflow:hidden}.sidebar{background:var(--ca-bg-surface);border-right:1px solid #eaeaea;flex-shrink:0;width:300px;display:flex}.sidebar-tabs{background:var(--ca-bg-subtle);border-right:1px solid #f0f0f0;flex-direction:column;gap:1px;width:54px;padding:6px 0;display:flex}.sidebar-tab{color:#b0b0b0;letter-spacing:.2px;flex-direction:column;align-items:center;gap:3px;padding:10px 0;font-size:9px;font-weight:600;display:flex;position:relative}.sidebar-tab svg{opacity:.6}.sidebar-tab:hover{color:var(--ca-text-secondary);background:var(--ca-bg-grey-150)}.sidebar-tab:hover svg{opacity:.8}.sidebar-tab.active{color:var(--ca-text-primary);background:var(--ca-bg-surface)}.sidebar-tab.active svg{opacity:1}.sidebar-tab.active:before{content:"";background:var(--ca-blue);border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:0}.sidebar-tab-badge{color:#fff;text-align:center;min-width:16px;height:16px;box-shadow:0 0 0 1.5px var(--ca-bg-surface);pointer-events:none;background:#f59e0b;border-radius:999px;padding:0 4px;font-size:9px;font-weight:700;line-height:16px;position:absolute;top:6px;right:6px}.sidebar-panel{flex:1;min-height:0;overflow:hidden}.panel-content{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex-direction:column;height:100%;min-height:0;display:flex;overflow:hidden auto}.panel-actions{flex-direction:column;gap:6px;padding:10px 10px 6px;display:flex}.panel-btn{color:var(--ca-text-secondary);border:1.5px solid #e4e4e4;border-radius:10px;justify-content:center;align-items:center;gap:7px;padding:10px;font-size:13px;font-weight:500;display:flex}.panel-btn:hover{color:var(--ca-text-primary);background:var(--ca-bg-subtle);border-color:#bababa}.panel-btn:disabled{opacity:.35;cursor:not-allowed}.autofill-pref{color:var(--ca-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:2px 2px 0;font-size:12px;display:flex}.autofill-pref input{width:15px;height:15px;accent-color:var(--ca-blue,#003a85);cursor:pointer;flex:none;margin:0}.autofill-pref:hover{color:var(--ca-text-primary)}.panel-btn.primary{border-color:#d0d0d0}.panel-btn.primary:hover{border-color:var(--ca-text-muted);background:var(--ca-bg-grey-50)}.panel-btn.shuffle{margin:8px 10px;font-size:12px}.images-options-toggle{display:none}.images-options{display:contents}.upload-zone{border-radius:var(--ca-radius-lg);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);border:2px dashed #d8d8d8;flex-direction:column;align-items:center;gap:4px;margin:6px 10px;padding:28px 16px;display:flex}.upload-zone:hover{border-color:var(--ca-text-muted);background:var(--ca-bg-subtle)}.upload-zone.dragging{border-color:var(--accent,var(--ca-blue));background:#eaf2ff;transform:scale(1.02)}.uz-text{color:var(--ca-text-muted);margin-top:8px;font-size:13px;font-weight:500}.uz-or{color:var(--ca-text-disabled);margin-top:2px;font-size:11px}.upload-sources{flex-direction:column;gap:6px;margin:8px 10px 10px;display:flex}.upload-source-btn{border-radius:var(--ca-radius-lg);background:var(--ca-bg-surface);cursor:pointer;text-align:left;width:100%;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);color:var(--ca-text-primary);border:1px solid #e0e0e0;align-items:center;gap:12px;padding:10px 12px;display:flex}@media (hover:hover) and (pointer:fine){.upload-source-btn:hover:not(:disabled){border-color:var(--accent,var(--ca-blue));background:#f5f9ff;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}}.upload-source-btn:disabled{opacity:.5;cursor:not-allowed}.upload-source-btn svg{color:var(--accent,var(--ca-blue));flex-shrink:0}.us-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.us-title{color:var(--ca-text-primary);font-size:13px;font-weight:700}.us-sub{color:var(--ca-text-muted);font-size:11px}.us-badge{color:#8b2e3e;letter-spacing:.02em;background:#f1c3cc;border-radius:10px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.phone-upload-modal{z-index:9999;background:#0000008c;justify-content:center;align-items:center;animation:.15s fadein;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes fadein{0%{opacity:0}to{opacity:1}}.pum-card{background:var(--ca-bg-surface);width:min(420px,92vw);max-height:92vh;border-radius:14px;max-height:92dvh;padding:24px;animation:.2s cubic-bezier(.2,.9,.3,1.2) popin;position:relative;overflow:auto;box-shadow:0 20px 60px #00000040}@keyframes popin{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.pum-close{background:var(--ca-bg-grey-50);width:36px;height:36px;color:var(--ca-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:22px;line-height:1;display:inline-flex;position:absolute;top:10px;right:10px}.pum-close:hover{color:#000;background:#e8e8e8}.pum-title{color:var(--ca-text-primary);margin:0 0 6px;font-size:18px;font-weight:700}.pum-desc{color:var(--ca-text-secondary);margin:0 0 16px;font-size:13px;line-height:1.4}.pum-qr{background:var(--ca-bg-subtle);border-radius:10px;justify-content:center;margin-bottom:14px;padding:14px;display:flex}.pum-qr img{width:220px;height:220px;display:block}.pum-ip-selector{align-items:center;gap:8px;margin-bottom:12px;font-size:12px;display:flex}.pum-ip-selector label{color:var(--ca-text-secondary);font-weight:500}.pum-ip-selector select{border-radius:var(--ca-radius-sm);background:var(--ca-bg-surface);border:1px solid #ddd;flex:1;padding:6px 8px;font-size:12px}.pum-link-row{gap:6px;margin-bottom:10px;display:flex}.pum-link-row input{border-radius:var(--ca-radius-sm);color:var(--ca-text-primary);border:1px solid #ddd;flex:1;min-width:0;padding:8px 10px;font-family:monospace;font-size:12px}.pum-note{color:var(--ca-text-muted);text-align:center;margin:0;font-size:11px;line-height:1.4}.album-progress{padding:8px 12px 4px}.progress-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.progress-text{color:var(--ca-text-muted);font-size:11px}.progress-pct{color:var(--ca-text-secondary);font-size:11px;font-weight:700}.progress-bar{background:#ececec;border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--ca-blue), #06d);border-radius:2px;height:100%;transition:width .4s}.photo-info{color:var(--ca-text-disabled);justify-content:space-between;align-items:center;padding:6px 12px;font-size:11px;display:flex}.placing-hint{color:var(--ca-blue);font-weight:600;animation:1s infinite placingBlink}@keyframes placingBlink{0%,to{opacity:1}50%{opacity:.5}}.photo-grid{background:var(--ca-bg-surface);contain:layout style;overscroll-behavior:contain;flex:1;grid-template-columns:repeat(3,1fr);align-content:start;gap:4px;min-height:0;padding:4px 10px 10px;display:grid;overflow-y:auto}.photo-cell{border-radius:var(--ca-radius-sm);cursor:grab;contain:layout style;background:#f0ece4;border:2px solid #0000;min-width:0;height:0;padding-top:100%;position:relative;overflow:hidden}.photo-cell:not(:has(img)):before{content:"";pointer-events:none;background:linear-gradient(90deg,#fff0 0%,#ffffff73 50%,#fff0 100%) 0 0/200% 100%;animation:1.4s ease-in-out infinite photoShimmer;position:absolute;top:0;bottom:0;left:0;right:0}@keyframes photoShimmer{0%{background-position:-100% 0}to{background-position:200% 0}}@media (hover:hover) and (pointer:fine){.photo-cell:hover{border-color:var(--accent);transform:scale(1.02)}}.photo-cell:active{cursor:grabbing;transform:scale(.96)}.photo-cell img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;top:0;bottom:0;left:0;right:0}.photo-cell.heic-converting{background:linear-gradient(135deg,#f3f0e8 0%,#e8e3d5 100%)}.photo-cell.heic-converting img{opacity:0}.photo-cell .heic-converting-overlay{color:#6b5f4a;pointer-events:none;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:4px;font-size:11px;font-weight:500;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.photo-cell .heic-converting-overlay .spinner{border:2px solid #6b5f4a33;border-top-color:#6b5f4a;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite heic-spin}@keyframes heic-spin{to{transform:rotate(360deg)}}.photo-cell.heic-converting-ios{background:0 0}.photo-cell.heic-converting-ios img{opacity:1}.photo-cell.heic-converting-ios .heic-converting-overlay{background:#ffffffeb;border-radius:10px;flex-direction:row;gap:5px;height:20px;padding:0 8px;font-size:10px;font-weight:600;top:auto;bottom:4px;left:4px;right:4px;box-shadow:0 1px 3px #00000026}.photo-cell.heic-converting-ios .heic-converting-overlay .spinner{border-width:1.5px;width:11px;height:11px}.photo-cell.used{opacity:.9}.photo-cell.used:active{opacity:1}@media (hover:hover) and (pointer:fine){.photo-cell.used:hover{opacity:1}}.photo-cell.selected{border-color:var(--ca-blue);opacity:1;cursor:pointer;transform:scale(1.02);box-shadow:0 0 0 2px #003a854d}.select-badge{background:var(--ca-blue);color:#fff;text-align:center;letter-spacing:.3px;padding:3px 0;font-size:9px;font-weight:600;position:absolute;bottom:0;left:0;right:0}.used-dot{color:#fff;background:#2e7d32;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:700;display:flex;position:absolute;bottom:3px;right:3px;box-shadow:0 1px 2px #00000040}.used-dot svg{width:10px;height:10px;display:block}.low-res-badge{color:#e0a100;filter:drop-shadow(0 1px 2px #00000059);pointer-events:auto;cursor:help;justify-content:center;align-items:center;width:16px;height:16px;display:flex;position:absolute;top:3px;right:3px}.photo-cell.low-res:after{content:"";pointer-events:none;border-radius:inherit;position:absolute;top:0;bottom:0;left:0;right:0;box-shadow:inset 0 0 0 1.5px #e0a1008c}.photo-quality-badge{border-radius:var(--ca-radius-md);letter-spacing:.2px;pointer-events:auto;cursor:help;-webkit-user-select:none;user-select:none;padding:1px 5px;font-size:9px;font-weight:700;line-height:1.4;position:absolute;top:4px;left:4px;box-shadow:0 1px 2px #0000002e}.photo-quality-badge.tier-good{color:#fff;background:#2e7d32d9}.photo-quality-badge.tier-warn{color:#1f1300;background:#f59e0beb}.photo-quality-badge.tier-bad{color:#fff;background:#c43232eb}.blurry-info{color:#c49000;border-radius:var(--ca-radius-sm);background:#fffbf0;align-items:center;gap:6px;margin:4px 10px;padding:8px 12px;font-size:11px;display:flex}.photo-cell.multi-selected{border-color:var(--ca-blue);box-shadow:0 0 0 2px #003a8559}.photo-cell.multi-selected img{opacity:.75}.photo-checkbox{background:#ffffffd9;border:1.5px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;transition:background .12s;display:flex;position:absolute;top:4px;left:4px;box-shadow:0 1px 3px #00000040}.photo-checkbox.checked{background:var(--ca-blue);border-color:var(--ca-blue)}.photo-bulk-bar{background:var(--ca-bg-surface);z-index:10;border-top:1px solid #eae6de;align-items:center;gap:8px;margin:8px -10px -10px;padding:10px 12px;display:flex;position:sticky;bottom:0;box-shadow:0 -6px 16px #00000014}.photo-bulk-count{color:var(--ca-blue);flex:1;font-size:12px;font-weight:600}.photo-bulk-btn{background:var(--ca-bg-surface);color:var(--ca-text-primary);border-radius:var(--ca-radius-pill);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border:1px solid #d0ccc4;align-items:center;gap:4px;padding:7px 12px;font-size:12px;font-weight:500;transition:transform .1s,background .12s;display:inline-flex}.photo-bulk-btn:active{background:#f4f3ef;transform:scale(.96)}.photo-bulk-btn.danger{background:var(--ca-text-danger);color:#fff;border-color:var(--ca-text-danger)}.photo-bulk-btn.danger:active{background:var(--ca-text-danger-active)}.photo-bulk-btn.danger:disabled{opacity:.5;cursor:not-allowed}.panel-section-label{color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:.4px;padding:14px 12px 8px;font-size:12px;font-weight:700}.panel-coming-soon{color:#ccc;text-align:center;padding:30px 12px;font-size:13px}.format-family-list{flex-direction:column;gap:14px;padding:0 12px 12px;display:flex}.format-family{border-radius:var(--ca-radius-md);background:var(--ca-bg-subtle);transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);border:1px solid #eee;padding:10px}.format-family.active{border-color:var(--ca-blue);background:#f0f7ff}.format-family.featured{background:linear-gradient(#fffbef 0%,#fff7dd 100%);border:1.5px solid #c9a961;padding-top:18px;position:relative;box-shadow:0 2px 10px #c9a9612e}.format-family.featured.active{background:linear-gradient(#fff7dd 0%,#f0f7ff 100%);border-color:#b58a3a;box-shadow:0 2px 14px #b58a3a40}.format-family-premium-badge{color:#fff;border-radius:var(--ca-radius-pill);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;background:linear-gradient(135deg,#d4af45 0%,#b58a3a 100%);align-items:center;gap:4px;padding:4px 10px 4px 8px;font-size:10px;font-weight:800;display:inline-flex;position:absolute;top:-10px;left:12px;box-shadow:0 2px 6px #b58a3a66}.format-family-highlight{color:#8b6914;background:#d4af451a;border-left:2px solid #d4af45;border-radius:3px;margin:-4px 0 8px;padding:6px 8px;font-size:11px;font-style:italic;line-height:1.4}.format-family-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px;display:flex}.format-family-titles{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.format-family-name{color:var(--ca-text-primary);font-size:13px;font-weight:600;line-height:1.25}.format-family-tagline{color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:10px;font-weight:600}.format-family-badge{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-pill);text-transform:uppercase;letter-spacing:.4px;padding:2px 6px;font-size:9px}.format-family-desc{color:var(--ca-text-muted);margin-bottom:8px;font-size:11px;line-height:1.4}.format-sizes{grid-template-columns:1fr 1fr;gap:6px;display:grid}.format-size-card{background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-sm);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);flex-direction:column;align-items:center;padding:8px 6px;display:flex;position:relative}.format-size-card:hover{border-color:var(--ca-blue);background:#f7faff}.format-size-card.active{border-color:var(--ca-blue);background:#f0f7ff;border-width:2px}.format-size-icon{justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:4px;display:flex}.format-icon-inner{background:#e0e0e0;border:1px solid #bbb;border-radius:2px;width:32px;max-width:100%;max-height:100%;display:block}.format-size-card.active .format-icon-inner{border-color:var(--ca-blue);background:#cfe4ff}.format-size-info{flex-direction:column;align-items:center;gap:1px;font-size:10px;display:flex}.format-size-name{color:var(--ca-text-primary);font-weight:500}.format-size-price{color:var(--ca-text-muted);font-size:10px}.format-size-check{background:var(--ca-blue);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:9px;display:flex;position:absolute;top:4px;right:4px}.format-total{background:var(--ca-bg-surface);border-radius:var(--ca-radius-sm);border:1px solid #ddd;margin:10px 12px;padding:10px 12px}.format-total-row{color:var(--ca-text-secondary);justify-content:space-between;padding:3px 0;font-size:12px;display:flex}.format-total-row.small{color:var(--ca-text-muted);font-size:11px}.format-total-row.total{color:var(--ca-text-primary);border-top:1px solid #eee;margin-top:4px;padding-top:6px}.format-total-hint{color:var(--ca-text-muted);text-align:center;margin-top:6px;font-size:10px}.format-pages-controls{gap:8px;margin-top:10px;display:flex}.format-pages-btn{background:var(--ca-bg-surface);min-height:48px;color:var(--ca-text-primary);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);border:1px solid #ddd;border-radius:10px;flex:1;padding:10px 12px;font-size:13px;font-weight:600}.format-pages-btn:hover:not(:disabled){border-color:var(--ca-blue);color:var(--ca-blue);background:#f5f8fd}.format-pages-btn.primary{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue)}.format-pages-btn.primary:hover:not(:disabled){background:var(--ca-blue-dark);color:#fff}.format-pages-btn:disabled{opacity:.4;cursor:not-allowed}.format-confirm{background:var(--ca-bg-surface);border-radius:var(--ca-radius-lg);z-index:250;border:1px solid #ffd54f;max-width:380px;padding:20px 24px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 50px #00000040}.format-confirm strong{color:var(--ca-text-primary);margin-bottom:6px;font-size:14px;display:block}.format-confirm p{color:var(--ca-text-secondary);margin:0 0 14px;font-size:12px;line-height:1.4}.format-confirm-btns{gap:8px;display:flex}.layout-target-toggle{background:var(--ca-bg-grey-150);border-radius:var(--ca-radius-pill);gap:0;margin:0 10px 8px;padding:2px;display:inline-flex}.layout-target-toggle .ltt-btn{border-radius:var(--ca-radius-pill);color:var(--ca-text-secondary);cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast), border-color var(--ca-tr-fast), box-shadow var(--ca-tr-fast), transform var(--ca-tr-fast), opacity var(--ca-tr-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:0;padding:5px 12px;font-size:11px;font-weight:500}.layout-target-toggle .ltt-btn:hover{color:var(--ca-text-primary)}.layout-target-toggle .ltt-btn.active{background:var(--ca-bg-surface);color:var(--ca-blue);font-weight:600;box-shadow:0 1px 3px #00000014}.layout-filter-chips{flex-wrap:wrap;gap:4px;padding:0 10px 8px;display:flex}.layout-chip{border-radius:var(--ca-radius-pill);background:var(--ca-bg-grey-50);color:var(--ca-text-secondary);cursor:pointer;white-space:nowrap;transition:background var(--ca-tr-fast), color var(--ca-tr-fast), border-color var(--ca-tr-fast), box-shadow var(--ca-tr-fast), transform var(--ca-tr-fast), opacity var(--ca-tr-fast);border:1px solid #0000;padding:4px 8px;font-size:10px}.layout-chip:hover{background:var(--ca-bg-grey-200);color:var(--ca-text-primary)}.layout-chip.active{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue);font-weight:500}.caption-ideas{padding:0 10px 16px}.cap-cats{flex-wrap:wrap;gap:4px;margin-bottom:10px;display:flex}.cap-cat-chip{border-radius:var(--ca-radius-pill);background:var(--ca-bg-grey-50);color:var(--ca-text-secondary);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;padding:4px 9px;font-size:10px;display:inline-flex}.cap-cat-chip:hover{background:var(--ca-bg-grey-200)}.cap-cat-chip.active{background:var(--ca-blue);color:#fff}.cap-cat-icon{margin-right:4px;font-size:11px}.cap-section-label{color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:.4px;margin:8px 0 4px;font-size:10px;font-weight:600}.cap-chips{flex-direction:column;gap:4px;display:flex}.cap-chip{text-align:left;border-radius:var(--ca-radius-sm);background:var(--ca-bg-subtle);color:var(--ca-text-primary);cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast), border-color var(--ca-tr-fast), box-shadow var(--ca-tr-fast), transform var(--ca-tr-fast), opacity var(--ca-tr-fast);border:1px solid #eee;padding:6px 10px;font-family:inherit;font-size:12px}.cap-chip:hover{background:var(--ca-bg-surface);border-color:var(--ca-blue);color:var(--ca-blue)}.cap-chip.long{color:var(--ca-text-secondary);font-size:11px;line-height:1.4}.text-section{margin:0 10px 12px;padding:0}.text-help{color:var(--ca-text-muted);margin-top:8px;padding:0 4px;font-size:10px;font-style:italic}.caption-ideas{margin:0 10px 10px}.caption-toggle{background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-md);width:100%;color:var(--ca-text-secondary);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);justify-content:space-between;align-items:center;padding:10px 12px;font-family:inherit;font-size:12px;font-weight:500;display:flex}.caption-toggle:hover{border-color:var(--ca-blue);color:var(--ca-blue);background:#f7faff}.caption-toggle-icon{color:var(--ca-text-muted);font-size:10px}.caption-body{background:var(--ca-bg-subtle);border-radius:var(--ca-radius-md);margin-top:8px;padding:10px;animation:.15s fadeIn}.bg-custom-color{color:var(--ca-text-muted);align-items:center;gap:10px;padding:8px 12px 0;font-size:11px;display:flex}.cp-wrapper{display:inline-block;position:relative}.cp-swatch{cursor:pointer;border:2px solid #fff;border-radius:5px;width:28px;height:28px;padding:0;box-shadow:0 0 0 1px #d0d0d0,0 1px 2px #0000000f}.cp-swatch:hover{box-shadow:0 0 0 1px #888,0 2px 4px #0000001a}.cp-popover{background:var(--ca-bg-surface);z-index:10002;border:1px solid #00000014;border-radius:10px;min-width:220px;padding:10px;animation:.12s fadeIn;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 6px 22px #00000024,0 1px 3px #0000000f}.cp-spectrum{margin-bottom:10px}.cp-spectrum .react-colorful{width:100%;height:156px}.cp-spectrum .react-colorful__saturation{border-radius:8px}.cp-spectrum .react-colorful__hue{border-radius:7px;height:20px;margin-top:9px}.cp-spectrum .react-colorful__pointer{width:18px;height:18px}.cp-row{align-items:center;gap:8px;display:flex}.cp-native{cursor:pointer;background:0 0;border:1px solid #ddd;border-radius:5px;width:36px;height:32px;padding:0}.cp-eyedropper{border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-md);background:var(--ca-bg-surface);width:32px;height:32px;color:var(--ca-text-primary);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.cp-eyedropper:hover{background:var(--ca-bg-grey-100,#f2f2f2)}.cp-hex-group{background:var(--ca-bg-subtle);border:1px solid #ddd;border-radius:5px;flex:1;align-items:center;padding:0 0 0 8px;display:flex}.cp-hex-prefix{color:var(--ca-text-muted);font-family:ui-monospace,monospace;font-size:12px}.cp-hex{text-transform:uppercase;color:var(--ca-text-primary);background:0 0;border:none;outline:none;flex:1;width:80px;padding:7px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:16px}.cp-quick{grid-template-columns:repeat(9,1fr);gap:4px;margin-top:10px;display:grid}.cp-quick-swatch{aspect-ratio:1;border-radius:var(--ca-radius-xs);cursor:pointer;border:1px solid #00000014;width:100%;padding:0}@media (hover:hover) and (pointer:fine){.cp-quick-swatch:hover{transform:scale(1.1)}}.cp-quick-swatch.active{box-shadow:0 0 0 2px var(--ca-blue), inset 0 0 0 2px #fff}.cp-section-label{letter-spacing:.5px;text-transform:uppercase;color:var(--ca-text-muted);margin-top:10px;font-size:10px;font-weight:600}.cp-recent{grid-template-columns:repeat(8,1fr);margin-top:4px}.cp-footer{color:var(--ca-text-muted);border-top:1px solid #eee;margin-top:10px;padding-top:8px;font-size:10px}.cp-footer code{background:var(--ca-bg-grey-100);color:var(--ca-text-secondary);border-radius:3px;padding:1px 4px;font-size:10px}.stickers-search-wrapper{margin:4px 10px 8px;position:relative}.stickers-search-icon{color:var(--ca-text-muted);pointer-events:none;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.stickers-search{border-radius:var(--ca-radius-sm);background:var(--ca-bg-surface);width:100%;color:var(--ca-text-primary);border:1px solid #ddd;padding:7px 26px;font-family:inherit;font-size:16px}.stickers-search:focus{border-color:var(--ca-blue);outline:none}.stickers-search-clear{color:var(--ca-text-muted);cursor:pointer;border-radius:var(--ca-radius-xs);background:0 0;border:none;padding:4px;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.stickers-search-clear:hover{background:var(--ca-bg-grey-100);color:var(--ca-text-primary)}.canva-import-box{margin:0 10px 12px}.canva-import-btn{border-radius:var(--ca-radius-md);background:var(--ca-bg-subtle);width:100%;color:var(--ca-text-secondary);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);border:1.5px dashed #bbb;align-items:center;gap:6px;padding:10px 12px;font-family:inherit;font-size:12px;font-weight:500;display:flex}.canva-import-btn:hover{border-color:var(--ca-blue);color:var(--ca-blue);background:#f0f7ff}.canva-import-form{border-radius:var(--ca-radius-md);background:#f7faff;border:1.5px solid #b4d0f0;padding:12px}.canva-import-title{color:var(--ca-blue);margin-bottom:6px;font-size:12px;font-weight:500}.canva-import-input{background:var(--ca-bg-surface);border:1px solid #ddd;border-radius:5px;width:100%;margin-bottom:6px;padding:8px 10px;font-family:inherit;font-size:16px}.canva-import-input:focus{border-color:var(--ca-blue);outline:none}.canva-import-hint{color:var(--ca-text-muted);margin-bottom:10px;font-size:10px;line-height:1.4}.canva-import-actions{gap:6px;display:flex}.templates-info{color:var(--ca-text-muted);padding:4px 12px 10px;font-size:11px;line-height:1.4}.templates-controls{flex-direction:column;gap:8px;margin:4px 0 10px;padding:0 4px;display:flex}@media (min-width:480px){.templates-controls{flex-direction:row;align-items:center}}.templates-chips{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:none;gap:6px;margin:4px 0 0;padding:2px 4px 8px;display:flex;overflow-x:auto}.templates-chips::-webkit-scrollbar{display:none}.template-chip{border:1px solid var(--ca-border-default);background:var(--ca-bg-surface);min-height:32px;color:var(--ca-text-primary);white-space:nowrap;cursor:pointer;transition:background .15s ease, border-color .15s ease, color .15s ease, transform var(--ca-dur-fast) var(--ca-ease-spring);border-radius:999px;flex:none;align-items:center;gap:5px;padding:5px 12px;font-size:12.5px;font-weight:500;display:inline-flex}.template-chip:hover{background:var(--ca-bg-grey-150)}.template-chip:active{transition-duration:.15s,.15s,.15s,80ms;transform:scale(.94)}.template-chip[aria-pressed=true]{background:var(--ca-blue-light);border-color:var(--ca-blue);color:var(--ca-blue);font-weight:600}.template-chip-count{color:var(--ca-text-muted);font-size:11px;font-weight:500}.template-chip[aria-pressed=true] .template-chip-count{color:var(--ca-blue)}.templates-subchips{margin-top:0;padding-top:0;padding-left:8px}.template-subchip{opacity:.9;min-height:28px;padding:4px 10px;font-size:11.5px}.template-subchip[aria-pressed=true]{opacity:1}@media (min-width:769px){.templates-chips{flex-wrap:wrap;row-gap:6px;overflow-x:visible}}.templates-search-wrapper{flex:auto;align-items:center;display:flex;position:relative}.templates-search-icon{color:var(--ca-text-muted);pointer-events:none;position:absolute;left:10px}.templates-search{border-radius:var(--ca-radius-md);border:1px solid var(--ca-border-default);background:var(--ca-bg-surface);color:var(--ca-text-primary);flex:1;min-height:36px;padding:8px 30px;font-size:13px}@media (max-width:768px){.templates-search{font-size:16px}}.templates-search:focus{outline:2px solid var(--ca-blue);outline-offset:-1px}.templates-search-clear{width:22px;height:22px;color:var(--ca-text-muted);cursor:pointer;background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;right:6px}.templates-search-clear:hover{background:var(--ca-bg-subtle);color:var(--ca-text-primary)}.templates-section{margin:0 0 14px}.templates-section-header{border-bottom:1px solid var(--ca-border-subtle,#0000000f);align-items:baseline;gap:8px;margin-bottom:8px;padding:10px 4px 6px;display:flex}.templates-section-title{color:var(--ca-text-primary);text-transform:uppercase;letter-spacing:.6px;font-size:12px;font-weight:700}.templates-section-count{color:var(--ca-text-muted);font-size:12px;font-weight:500}.templates-empty{text-align:center;color:var(--ca-text-muted);padding:24px 12px;font-size:13px}.templates-grid{grid-template-columns:1fr 1fr;grid-auto-rows:max-content;gap:10px;padding:4px 10px 16px;display:grid}@keyframes caPanelItemIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.templates-grid>.template-card,.stickers-grid>.sticker-cell{animation:caPanelItemIn .28s var(--ca-ease-out) backwards}.templates-grid>.template-card:first-child,.stickers-grid>.sticker-cell:first-child{animation-delay:20ms}.templates-grid>.template-card:nth-child(2),.stickers-grid>.sticker-cell:nth-child(2){animation-delay:40ms}.templates-grid>.template-card:nth-child(3),.stickers-grid>.sticker-cell:nth-child(3){animation-delay:60ms}.templates-grid>.template-card:nth-child(4),.stickers-grid>.sticker-cell:nth-child(4){animation-delay:80ms}.templates-grid>.template-card:nth-child(5),.stickers-grid>.sticker-cell:nth-child(5){animation-delay:.1s}.templates-grid>.template-card:nth-child(6),.stickers-grid>.sticker-cell:nth-child(6){animation-delay:.12s}.templates-grid>.template-card:nth-child(7),.stickers-grid>.sticker-cell:nth-child(7){animation-delay:.14s}.templates-grid>.template-card:nth-child(8),.stickers-grid>.sticker-cell:nth-child(8){animation-delay:.16s}.templates-grid>.template-card:nth-child(9),.stickers-grid>.sticker-cell:nth-child(9){animation-delay:.18s}.templates-grid>.template-card:nth-child(10),.stickers-grid>.sticker-cell:nth-child(10){animation-delay:.2s}.templates-grid>.template-card:nth-child(11),.stickers-grid>.sticker-cell:nth-child(11){animation-delay:.22s}.templates-grid>.template-card:nth-child(12),.stickers-grid>.sticker-cell:nth-child(12),.templates-grid>.template-card:nth-child(n+13),.stickers-grid>.sticker-cell:nth-child(n+13){animation-delay:.24s}@media (prefers-reduced-motion:reduce){.templates-grid>.template-card,.stickers-grid>.sticker-cell{animation:none}}.template-card{background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);transition:background var(--ca-tr-slow), color var(--ca-tr-slow), border-color var(--ca-tr-slow), box-shadow var(--ca-tr-slow), transform var(--ca-tr-slow), opacity var(--ca-tr-slow);border-radius:8px;overflow:hidden;box-shadow:0 1px 2px #0f172a0d}@media (hover:hover) and (pointer:fine){.template-card:hover{border-color:#00449447;transform:translateY(-2px);box-shadow:0 10px 28px #0f172a1f}}.template-card-clickable{text-align:center;cursor:pointer;flex-direction:column;width:100%;padding:0;font-family:inherit;display:flex;position:relative}.template-card-clickable.active{border-color:var(--ca-blue);box-shadow:0 0 0 2px #00449424,0 10px 28px #0f172a1f}.template-card-clickable:active{transform:translateY(0)}.template-apply-hint{display:none}.template-mockup{aspect-ratio:1/1.16;perspective:1100px;background:linear-gradient(#f8fafcf2,#ffffff8c);justify-content:center;align-items:center;padding:12px 8px 8px;display:flex;position:relative}.template-mockup:after{content:"";filter:blur(2px);z-index:0;background:radial-gradient(#0f172a33 0%,#0000 72%);height:9px;position:absolute;bottom:7px;left:24%;right:24%}.template-cover-thumb{aspect-ratio:19/27;width:min(82%,124px);transform-style:preserve-3d;transition:transform .35s var(--ca-ease-settle), box-shadow .35s ease;z-index:1;border:1px solid #0f172a14;border-radius:0;position:relative;overflow:hidden;transform:rotateY(-6deg)rotateX(1.5deg);box-shadow:0 8px 16px #0f172a2e,inset 5px 0 10px #0000001f,inset -1px 0 #ffffff2e}.template-cover-thumb:before{content:"";pointer-events:none;z-index:4;background:linear-gradient(90deg,#00000038,#ffffff14 55%,#0000);width:9%;position:absolute;top:0;bottom:0;left:0}.template-cover-thumb:after{content:"";pointer-events:none;z-index:5;background:linear-gradient(130deg,#ffffff3d 0%,#ffffff08 34%,#0000000d 100%);position:absolute;top:0;bottom:0;left:0;right:0}@media (hover:hover) and (pointer:fine){.template-card-clickable:hover .template-cover-thumb{transform:rotateY(0)rotateX(0)translateY(-1px);box-shadow:0 12px 24px #0f172a38,inset 5px 0 10px #0000001a,inset -1px 0 #fff3}}@media (max-width:768px),(hover:none) and (pointer:coarse){.template-mockup{perspective:none;aspect-ratio:auto;min-height:186px}.template-cover-thumb{transform-style:flat;aspect-ratio:auto;width:116px;height:165px;transform:none}}.template-cover-thumb-bg,.template-cover-thumb-sticker{object-fit:cover;pointer-events:none;display:block;position:absolute}.template-cover-thumb-bg{z-index:0;width:100%;height:100%;top:0;bottom:0;left:0;right:0}.template-cover-thumb-sticker{object-fit:contain;z-index:2}.template-cover-thumb-text{z-index:3;white-space:pre-line;text-wrap:balance;transform-origin:50%;pointer-events:none;align-items:center;line-height:.92;display:flex;position:absolute;overflow:hidden}.template-cover-thumb-photo{z-index:1;color:#ffffffb8;transform-origin:50%;background:#ffffff1a;border:1px dashed #ffffff6b;border-radius:0;justify-content:center;align-items:center;display:flex;position:absolute;overflow:hidden}.template-cover-thumb-photo.filled{background:0 0;border:none}.template-cover-thumb-photo-img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;top:0;bottom:0;left:0;right:0}.template-cover-thumb-fallback{z-index:2;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:16% 10%;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.template-spread{aspect-ratio:8/5;width:96%;transform-style:preserve-3d;transition:transform .35s var(--ca-ease-settle);border-radius:0;display:flex;position:relative;overflow:hidden;transform:rotateY(-3deg)rotateX(2deg);box-shadow:0 10px 22px #00000038,0 2px 4px #0000001a}@media (hover:hover) and (pointer:fine){.template-card-clickable:hover .template-spread{transform:rotateY(0)rotateX(0)translateY(-2px);box-shadow:0 14px 32px #00000047,0 2px 4px #0000001f}}.template-spread-page{background-position:50%;background-size:cover;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;height:100%;display:flex;position:relative;overflow:hidden}.template-spread-cover{text-align:center;border-right:1px solid #0000000f;padding:10% 8%}.template-spread-cover:before{content:"";pointer-events:none;z-index:2;background:linear-gradient(90deg,#00000038 0%,#0000000d 60%,#0000 100%);width:6%;position:absolute;top:0;bottom:0;left:0}.template-spread-cover:after{content:"";pointer-events:none;z-index:2;background:linear-gradient(90deg,#0000 0%,#00000024 100%);width:10%;position:absolute;top:0;bottom:0;right:0}.template-spread-cover-img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;top:0;bottom:0;left:0;right:0}.template-spread-interior{justify-content:center;align-items:stretch;gap:4px;padding:12% 9% 12% 11%}.template-spread-interior:before{content:"";pointer-events:none;z-index:2;background:linear-gradient(90deg,#0000002e 0%,#0000 100%);width:8%;position:absolute;top:0;bottom:0;left:0}.template-spread-interior:after{content:"";pointer-events:none;z-index:2;background:radial-gradient(at 100% 0,#fff3,#0000 70%);width:40%;height:30%;position:absolute;top:-8%;right:-8%}.template-spread-photo{border-radius:2px;flex-shrink:0}.template-spread-photo--big{width:100%;height:42%}.template-spread-photo--small{align-self:flex-start;width:60%;height:22%}.template-spread-caption{letter-spacing:.4px;text-transform:uppercase;opacity:.55;white-space:nowrap;text-overflow:ellipsis;align-self:flex-end;max-width:100%;margin-top:2px;font-size:6px;font-weight:700;overflow:hidden}.template-cover{aspect-ratio:3/4;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:16% 10%;display:flex;position:relative}.template-cover-image{aspect-ratio:3/4;background:var(--ca-bg-grey-50);position:relative;overflow:hidden}.template-cover-image img{object-fit:cover;width:100%;height:100%;display:block}.template-source-badge{color:#fff;border-radius:var(--ca-radius-pill);letter-spacing:.4px;text-transform:uppercase;background:#000000b3;padding:2px 8px;font-size:9px;font-weight:600;position:absolute;top:6px;right:6px}.template-type-badge.type-photo{color:#1565c0}.template-type-badge.type-illustration{color:#6a1b9a}.template-cover-title{text-shadow:0 2px 4px #0000002e;word-wrap:break-word;z-index:1;max-width:100%;font-size:12px;font-weight:600;line-height:1.05}.template-cover-subtitle{opacity:.9;text-shadow:0 1px 2px #00000026;z-index:1;font-size:7px;font-style:italic;line-height:1.15}.template-meta{text-align:center;padding:6px 4px 2px}.template-name{color:var(--ca-text-primary);-webkit-line-clamp:2;word-break:break-word;-webkit-box-orient:vertical;font-size:12px;font-weight:600;line-height:1.25;display:-webkit-box;overflow:hidden}.template-category-badge{color:#fff;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;border-radius:999px;margin-top:6px;padding:2px 8px;font-size:10px;font-weight:600;line-height:1.4;display:inline-block}.template-desc{color:var(--ca-text-muted);margin-top:2px;font-size:11px;line-height:1.3}.template-season{display:none}.template-type-badge{background:#ffffffeb;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;display:flex;position:absolute;top:4px;right:4px;box-shadow:0 1px 2px #0003}.template-use-btn{background:var(--ca-blue);color:#fff;cursor:pointer;border:none;border-top:1px solid #eee;width:100%;margin:4px 0 0;padding:8px;font-size:12px;font-weight:500;transition:background .15s}.template-use-btn:hover{background:#002550}.template-confirm{color:#7c5900;background:#fff8e1;border-top:1px solid #fde68a;padding:8px 10px;font-size:12px}.template-confirm>span{margin-bottom:6px;display:block}.template-confirm-btns{gap:6px;display:flex}.template-apply-btn{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-xs);cursor:pointer;border:none;flex:1;padding:6px;font-size:12px;font-weight:500}.template-cancel-btn{background:var(--ca-bg-surface);color:var(--ca-text-secondary);border-radius:var(--ca-radius-xs);cursor:pointer;border:1px solid #ddd;flex:1;padding:6px;font-size:12px}.layout-grid-panel{grid-template-columns:repeat(3,1fr);gap:8px;padding:4px 10px;display:grid}.layout-cell{aspect-ratio:1;border-radius:var(--ca-radius-md);background:var(--ca-bg-surface);border:2px solid #ececec;padding:6px}.layout-cell:hover{border-color:var(--ca-text-muted);background:var(--ca-bg-subtle)}.layout-cell.active{border-color:var(--ca-text-primary);background:var(--ca-bg-grey-50)}.layout-cell-inner{border-radius:3px;width:100%;height:100%;position:relative;overflow:hidden}.layout-cell-ph{background:#ddd;border-radius:2px;position:absolute}.layout-cell-pano{border-color:var(--ca-blue,#003a85);position:relative}.layout-cell-pano .layout-cell-ph{background:#bbd0ea}.layout-cell-pano-label{text-align:center;color:var(--ca-blue,#003a85);pointer-events:none;background:#ffffffd1;border-radius:3px;font-size:8.5px;font-weight:700;line-height:1.3;position:absolute;bottom:3px;left:4px;right:4px}.bg-color-grid{grid-template-columns:repeat(6,1fr);gap:6px;padding:4px 10px;display:grid}.bg-swatch{aspect-ratio:1;border-radius:var(--ca-radius-md);border:2px solid #e8e8e8}@media (hover:hover) and (pointer:fine){.bg-swatch:hover{border-color:var(--ca-text-muted);transform:scale(1.1)}}.bg-swatch.active{border-color:var(--ca-text-primary);box-shadow:0 0 0 2px #1a1a1a33}.bg-apply-btns{gap:6px;padding:4px 10px;display:flex}.bg-apply-btns .panel-btn{flex:1;padding:7px;font-size:11px}.text-btns{flex-direction:column;gap:6px;padding:4px 10px;display:flex}.text-preset{text-align:left;border:1.5px solid #e8e8e8;border-radius:10px;flex-direction:column;gap:2px;padding:12px 14px;display:flex}.text-preset:hover{border-color:var(--ca-text-muted);background:var(--ca-bg-subtle)}.tp-preview{color:var(--ca-text-primary);font-family:Georgia,serif;font-size:20px;font-weight:700}.tp-preview.sub{color:var(--ca-text-secondary);font-size:16px;font-weight:600}.tp-preview.cap{color:var(--ca-text-muted);font-size:12px;font-weight:400}.tp-preview.date-p{color:var(--ca-text-muted);font-size:14px;font-style:italic;font-weight:500}.tp-desc{color:var(--ca-text-disabled);font-size:10px}.stickers-categories{flex-wrap:wrap;gap:4px;padding:4px 10px 8px;display:flex}.stickers-cat{border-radius:var(--ca-radius-lg);background:var(--ca-bg-surface);color:var(--ca-text-secondary);cursor:pointer;border:1px solid #e0e0e0;padding:4px 8px;font-size:11px}.stickers-cat:hover{background:var(--ca-bg-grey-150)}.stickers-cat{transition:background .15s ease, border-color .15s ease, color .15s ease, transform var(--ca-dur-fast) var(--ca-ease-spring)}.stickers-cat:active{transition-duration:.15s,.15s,.15s,80ms;transform:scale(.94)}.stickers-cat.active{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue)}.stickers-grid{grid-template-columns:repeat(4,1fr);gap:6px;padding:4px 10px 10px;display:grid;overflow-y:auto}.sticker-cell{aspect-ratio:1;background:var(--ca-bg-subtle);border-radius:var(--ca-radius-md);cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast), border-color var(--ca-tr-fast), box-shadow var(--ca-tr-fast), transform var(--ca-tr-fast), opacity var(--ca-tr-fast);border:2px solid #0000;justify-content:center;align-items:center;display:flex}@media (hover:hover) and (pointer:fine){.sticker-cell:hover{background:var(--ca-bg-grey-150);border-color:#bababa;transform:scale(1.05)}}.sticker-cell.active{border-color:var(--ca-blue);background:#003a8514;box-shadow:0 0 0 2px #003a8526}.sticker-cell svg{width:48px;height:48px}.font-list{flex-direction:column;gap:3px;padding:4px 10px;display:flex}.font-item{border-radius:var(--ca-radius-sm);text-align:left;color:var(--ca-text-secondary);padding:8px 12px;font-size:15px}.font-item:hover{background:var(--ca-bg-grey-100)}.canvas-area{background:var(--ca-bg-app);padding:var(--ca-space-2);transition:background-color var(--ca-tr-default);overscroll-behavior:contain;background-image:radial-gradient(circle at 1px 1px,#9b5a720a 1px,#0000 0);background-size:20px 20px;flex:1;justify-content:safe center;align-items:safe center;display:flex;position:relative;overflow:auto}body.is-dragging-photo .canvas-area{background:#003a850f}body.is-dragging-photo .canvas-area:after{content:"";border-radius:var(--ca-radius-md);pointer-events:none;animation:dragPhotoFadeIn .18s var(--ca-ease-out);z-index:4;border:2px dashed #003a8559;position:absolute;top:8px;bottom:8px;left:8px;right:8px}@keyframes dragPhotoFadeIn{0%{opacity:0}to{opacity:1}}.canvas-unplaced-hint{z-index:5;pointer-events:none;animation:cuhSlide .3s var(--ca-ease-out);max-width:calc(100% - 32px);position:absolute;top:64px;left:50%;transform:translate(-50%)}@keyframes cuhSlide{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.cuh-card{pointer-events:auto;align-items:center;gap:var(--ca-space-3);background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-left:3px solid var(--ca-blue);border-radius:var(--ca-radius-md);box-shadow:var(--ca-shadow-md);font-size:var(--ca-text-sm);padding:10px 14px 10px 16px;display:inline-flex}.cuh-arrow{color:var(--ca-blue);justify-content:center;align-items:center;animation:1.6s ease-in-out infinite cuhArrowNudge;display:inline-flex}@keyframes cuhArrowNudge{0%,to{transform:translate(0)}50%{transform:translate(-3px)}}.cuh-text{flex-direction:column;gap:2px;display:inline-flex}.cuh-text strong{color:var(--ca-text-primary);font-weight:600}.cuh-text span{color:var(--ca-text-secondary);font-size:var(--ca-text-xs)}.cuh-close{color:var(--ca-text-muted);border-radius:var(--ca-radius-sm);cursor:pointer;min-width:44px;min-height:44px;margin-left:var(--ca-space-2);background:0 0;border:0;justify-content:center;align-items:center;font-size:18px;line-height:1;display:inline-flex}.cuh-close:hover{color:var(--ca-text-secondary);background:var(--ca-bg-hover)}@media (max-width:768px){.cuh-arrow svg{transform:rotate(90deg)}@keyframes cuhArrowNudge{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}}.canvas-wrapper{flex-direction:column;align-items:center;gap:8px;min-height:min-content;margin:auto;display:flex}.canvas-interaction{min-height:240px;position:relative}.canvas-interaction:has(.canvas-container){z-index:2;cursor:default;min-height:0;transition:opacity .22s var(--ca-ease-out), transform .22s var(--ca-ease-out);isolation:isolate;contain:layout style;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:none;border-radius:0;box-shadow:0 1px 2px #0f172a1a,0 12px 34px #0f172a29,0 28px 72px #0f172a1a}.canvas-interaction.is-changing{animation:canvasSpreadChange .22s var(--ca-ease-out)}@keyframes canvasSpreadChange{0%{opacity:.55;transform:scale(.985)}60%{opacity:1;transform:scale(1.003)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.canvas-interaction.is-changing{animation:none}}.canvas-interaction *{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.canvas-interaction>.canvas-container{z-index:2;background:0 0}.canvas-interaction>.template-bg-overlay{z-index:0}.sticker-hit-target{transform-origin:50%;pointer-events:auto;cursor:grab;touch-action:none;background:0 0;position:absolute}.sticker-hit-target:active{cursor:grabbing}.canvas-interaction{background:var(--panel-bg,#e8e8e8)}.canvas-interaction.placing{cursor:copy;outline:2px dashed var(--accent);outline-offset:3px;animation:1.5s infinite placingPulse}@keyframes placingPulse{0%,to{outline-color:var(--accent)}50%{outline-color:#003a854d}}.canvas-label{color:var(--ca-text-muted);text-align:center;letter-spacing:.3px;margin-top:12px;font-size:12px;font-weight:500}.canvas-cover-labels{color:var(--ca-text-muted);letter-spacing:.4px;text-transform:uppercase;opacity:.7;justify-content:space-between;align-items:center;margin:12px auto 0;font-size:10px;font-weight:400;display:flex}.canvas-binding-warning{max-width:480px;color:var(--ca-text-muted);box-shadow:none;background:0 0;border:none;border-left:2px solid #d4d4d4;border-radius:0;align-items:flex-start;gap:6px;margin:4px auto 10px;padding:4px 10px;font-size:11px;line-height:1.3;display:flex;position:relative}.canvas-binding-warning .cbw-icon{opacity:.55;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.canvas-binding-warning .cbw-icon svg{width:12px;height:12px}.canvas-binding-warning .cbw-text{flex-direction:column;gap:0;min-width:0;display:flex}.canvas-binding-warning .cbw-text strong{color:#6b6b6b;font-size:11px;font-weight:500}.canvas-binding-warning .cbw-sub{color:var(--ca-text-muted);font-size:10.5px}.canvas-binding-warning .cbw-arrow{display:none}@media (max-width:768px){.canvas-binding-warning{gap:8px;margin:4px 6px 12px;padding:6px 10px;font-size:11.5px}.canvas-binding-warning .cbw-icon svg{width:16px;height:16px}.canvas-binding-warning .cbw-sub{font-size:10.5px}}.handle{background:var(--ca-blue);z-index:10;pointer-events:none;border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;box-shadow:0 0 0 2px #ffffff73,0 1px 3px #0000004d}.image-selection{pointer-events:none;z-index:9;box-sizing:border-box;border:1.5px solid #ffffffe6;border-radius:2px;position:absolute;transform:translateZ(0);box-shadow:0 0 0 1px #003a8599,0 1px 6px #00000029}.canvas-interaction.is-dragging .image-selection,.canvas-interaction.is-dragging .handle,.canvas-interaction.is-dragging .handle-corner,.canvas-interaction.is-dragging .handle-side{will-change:transform, left, top, width, height}.canvas-interaction.is-dragging *{transition:none!important}.image-selection .handle-corner{background:var(--ca-bg-surface);border:1.5px solid var(--ca-blue);z-index:12;pointer-events:auto;border-radius:2px;width:12px;height:12px;box-shadow:0 0 0 1px #ffffffb3,0 1px 3px #00000059}.image-selection .handle-corner:first-child{cursor:nwse-resize;transform:translate(-50%,-50%);top:0!important;left:0!important}.image-selection .handle-corner:nth-child(2){cursor:nesw-resize;transform:translate(50%,-50%);top:0!important;left:auto!important;right:0!important}.image-selection .handle-corner:nth-child(3){cursor:nesw-resize;transform:translate(-50%,50%);top:auto!important;bottom:0!important;left:0!important}.image-selection .handle-corner:nth-child(4){cursor:nwse-resize;transform:translate(50%,50%);top:auto!important;bottom:0!important;left:auto!important;right:0!important}.image-selection .handle-side{background:var(--ca-bg-surface);border:1.5px solid var(--ca-blue);border-radius:var(--ca-radius-xs);z-index:12;pointer-events:auto;position:absolute;box-shadow:0 0 0 1px #fff9,0 1px 3px #0000004d}.image-selection .handle-side-w{cursor:ew-resize;width:8px;height:28px;top:50%;left:0;transform:translate(-50%,-50%)}.image-selection .handle-side-e{cursor:ew-resize;width:8px;height:28px;top:50%;right:0;transform:translate(50%,-50%)}.image-selection .handle-side-n{cursor:ns-resize;width:28px;height:8px;top:0;left:50%;transform:translate(-50%,-50%)}.image-selection .handle-side-s{cursor:ns-resize;width:28px;height:8px;bottom:0;left:50%;transform:translate(-50%,50%)}.image-selection[data-small="1"] .handle-side{display:none}@media (hover:none) and (pointer:coarse){.image-selection .handle-corner{border-width:2px;border-radius:3px;width:18px;height:18px}.image-selection .handle-side{border-width:2px}.image-selection .handle-side-w,.image-selection .handle-side-e{width:10px;height:38px}.image-selection .handle-side-n,.image-selection .handle-side-s{width:38px;height:10px}}.image-selection-hint{background:var(--ca-blue);color:#fff;white-space:nowrap;opacity:.9;pointer-events:none;border-radius:3px;margin-top:4px;padding:3px 8px;font-size:10px;animation:3s forwards hintFade;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #00000026}@keyframes hintFade{0%{opacity:0;transform:translate(-50%,-4px)}15%{opacity:.95;transform:translate(-50%)}70%{opacity:.95}to{opacity:0;transform:translate(-50%,-2px)}}.image-action-bar{box-shadow:var(--ca-shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:auto;z-index:16;background:#fbf8f3b8;border:1px solid #fff9;border-radius:10px;align-items:center;gap:4px;padding:5px 7px;animation:.18s iabFadeIn;display:inline-flex;position:absolute;transform:translate(-50%)}@keyframes iabFadeIn{0%{opacity:0;transform:translate(-50%,4px)}to{opacity:1;transform:translate(-50%)}}.image-action-bar .iab-btn{color:#374151;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;padding:0;transition:background .12s,color .12s,transform .1s;display:inline-flex}.image-action-bar .iab-btn:hover{color:#111827;background:#f3f4f6}.image-action-bar .iab-btn:active{transform:scale(.96)}.image-action-bar .iab-btn svg{flex:none}.image-action-bar .iab-btn.active{color:var(--ca-blue);background:#e8f0fb}.image-action-bar .iab-btn.iab-delete{color:var(--ca-text-danger)}.image-action-bar .iab-btn.iab-delete:hover{background:var(--ca-bg-danger-tint);color:var(--ca-text-danger)}.image-action-bar .iab-divider{background:#0f172a1f;width:1px;height:20px;margin:0 2px}@media (max-width:768px){.image-action-bar .iab-btn{flex:none;width:40px;height:40px}.image-action-bar{overscroll-behavior-x:contain;scrollbar-width:none;border-radius:10px;flex-wrap:nowrap;justify-content:flex-start;gap:6px;max-width:calc(100vw - 16px);padding:6px 8px;right:8px;overflow:auto hidden;left:8px!important;transform:none!important}.image-action-bar::-webkit-scrollbar{display:none}}.iab-filter-pop{z-index:18;background:#fffffffc;border:1px solid #0f172a14;border-radius:12px;flex-direction:column;gap:8px;padding:10px;animation:.16s iabFadeIn;display:flex;position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 12px 32px #0f172a2e,0 1px 2px #0f172a14}.iab-filter-pop.below{top:auto;bottom:calc(100% + 6px)}.iab-filter-row{gap:6px;display:flex}.iab-filter-chip{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:9px;flex-direction:column;align-items:center;gap:4px;width:52px;padding:4px 3px 5px;transition:background .12s;display:flex}.iab-filter-chip:hover{background:#f3f4f6}.iab-filter-chip.active{background:#e8f0fb}.iab-filter-thumb{background:#e5e7eb;border:2px solid #0000;border-radius:7px;width:44px;height:44px;display:block;overflow:hidden}.iab-filter-chip.active .iab-filter-thumb{border-color:var(--ca-blue)}.iab-filter-thumb img{object-fit:cover;width:100%;height:100%;display:block}.iab-filter-thumb-ph{background:linear-gradient(135deg,#93c5fd,#c4b5fd);width:100%;height:100%;display:block}.iab-filter-label{color:#374151;font-size:11px;font-weight:600;line-height:1}.iab-filter-chip.active .iab-filter-label{color:var(--ca-blue)}.iab-filter-all{color:#1f2937;cursor:pointer;background:#f3f4f6;border:none;border-radius:8px;padding:8px;font-size:12px;font-weight:600;transition:background .12s}.iab-filter-all:hover{background:#e5e7eb}@media (max-width:768px){.iab-filter-pop{max-width:calc(100vw - 16px)}.iab-filter-row{flex-wrap:wrap;justify-content:center}.iab-filter-chip{width:58px}.iab-filter-thumb{width:50px;height:50px}.iab-filter-all{padding:11px;font-size:13px}}.rotating-selection{outline-offset:0;pointer-events:none;z-index:9;transform-origin:50%;box-sizing:border-box;border:1.5px dashed #003a85f2;outline:1px solid #ffffffb3;position:absolute}.rotating-selection.text-selection{border-style:dashed;border-color:#003a85d9;border-radius:2px}.rotating-selection .handle{pointer-events:none}.rotation-line{pointer-events:none;background:#003a8599;width:1px;position:absolute;left:50%;transform:translate(-50%)}.rotation-handle{background:var(--ca-blue);pointer-events:none;z-index:11;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 0 0 2px #ffffff73,0 2px 4px #00000059}.text-side-handle{background:var(--ca-blue);border-radius:var(--ca-radius-pill);pointer-events:none;z-index:11;border:2px solid #fff;justify-content:center;align-items:center;width:18px;height:28px;display:flex;position:absolute;transform:translateY(-50%);box-shadow:0 0 0 2px #ffffff73,0 2px 4px #00000059}@media (hover:none) and (pointer:coarse){.rotation-handle{border-width:3px;width:32px;height:32px}.handle{border-width:3px;width:18px;height:18px}.text-side-handle{border-width:3px;width:24px;height:38px}.rotation-line{width:2px}}.bleed-warning-sticky{text-align:center;pointer-events:none;z-index:14;height:0;position:sticky;top:8px;overflow:visible}.bleed-warning-banner{color:#fff;border-radius:var(--ca-radius-pill);pointer-events:none;white-space:nowrap;background:#141414eb;align-items:center;gap:6px;max-width:calc(100vw - 24px);padding:7px 14px;font-size:12px;font-weight:500;display:inline-flex;box-shadow:0 4px 12px #00000040}@media (max-width:768px){.bleed-warning-sticky{top:6px}.bleed-warning-banner{padding:6px 12px;font-size:11px}}.zoom-controls{z-index:5;border-radius:var(--ca-radius-md);-webkit-backdrop-filter:blur(6px);opacity:.85;background:#ffffffeb;align-items:center;gap:0;padding:3px;transition:opacity .15s,background .15s,box-shadow .15s;display:flex;position:absolute;bottom:12px;right:12px;box-shadow:0 1px 4px #00000014,0 0 0 1px #0000000d}.zoom-controls:hover{opacity:1;background:#fffffffa;box-shadow:0 2px 10px #0000001f,0 0 0 1px #0000000f}.zoom-controls>.zoom-btn,.zoom-controls>span[aria-hidden=true]{opacity:0;width:0;margin:0;padding:0;transition:width .18s,opacity .15s,padding .15s,margin .15s;overflow:hidden}.zoom-controls:hover>.zoom-btn{opacity:1;width:24px}.zoom-controls:hover>span[aria-hidden=true]{opacity:1;width:1px;margin:0 2px}.zoom-slider{display:none}.zoom-reset{font-size:13px}.zoom-btn{height:24px;color:var(--ca-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;display:flex}.zoom-btn:hover{color:var(--ca-text-primary);background:#0000000f}.zoom-label{color:var(--ca-text-secondary);text-align:center;letter-spacing:.2px;cursor:pointer;-webkit-user-select:none;user-select:none;min-width:38px;padding:2px 6px;font-size:11.5px;font-weight:600}.zoom-controls:hover .zoom-label{color:var(--ca-text-primary)}.zoom-label:hover{color:var(--ca-blue)!important}@media (max-width:768px){.zoom-controls{display:none!important}}.canvas-right-toolbar{z-index:5;overscroll-behavior:contain;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-direction:column;flex:none;justify-content:center;align-self:center;align-items:center;gap:6px;width:64px;max-height:100%;margin-right:4px;padding:6px 2px;display:flex;overflow-y:auto}.canvas-right-toolbar::-webkit-scrollbar{display:none}.crt-btn{cursor:pointer;width:54px;min-height:43px;color:var(--ca-text-secondary);letter-spacing:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffffa;border:1px solid #0f172a14;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:5px 3px;font-size:9.5px;font-weight:600;line-height:1.1;transition:background .12s,color .12s,box-shadow .12s,transform .12s;display:flex;box-shadow:0 2px 8px #0f172a1a,0 1px 1px #0f172a0f}.crt-btn svg{width:20px;height:20px;display:block}.crt-btn span{text-overflow:ellipsis;white-space:nowrap;max-width:48px;display:block;overflow:hidden}@media (hover:hover) and (pointer:fine){.crt-btn:hover{color:var(--ca-text-primary);background:#fff;transform:translateY(-1px);box-shadow:0 5px 16px #0f172a24,0 0 0 1px #003a851a}}.crt-btn:active{background:#f6f8fa;transform:translateY(0)scale(.98)}@media (max-width:768px){.canvas-right-toolbar{display:none}}.crt-btn.is-open{color:var(--ca-text-primary);background:#fff;box-shadow:0 5px 16px #0f172a29,0 0 0 1px #003a852e}.crt-flyout-backdrop{z-index:60;position:fixed;top:0;bottom:0;left:0;right:0}.crt-flyout{z-index:61;background:#fff;border:1px solid #0f172a14;border-radius:12px;flex-direction:column;gap:1px;width:162px;padding:6px;animation:.12s crtFlyoutIn;display:flex;position:fixed;box-shadow:0 14px 36px #0f172a33,0 1px 2px #0f172a14}@keyframes crtFlyoutIn{0%{opacity:0;transform:translate(4px)}to{opacity:1;transform:translate(0)}}.crt-flyout-item{cursor:pointer;width:100%;font:inherit;color:var(--ca-text-primary,#2f2b27);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:9px 11px;font-size:13px;font-weight:500;display:flex}.crt-flyout-item svg{width:22px;height:22px;color:var(--ca-text-secondary);flex:none}.crt-flyout-item:hover{background:#f2efe9}.crt-flyout-item:active{background:#e9e5dd}.canvas-interaction.crop-mode{outline-offset:3px;outline:2px solid #ff8f00}.floating-toolbar{box-shadow:var(--ca-shadow-lg);z-index:25;white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fbf8f3b8;border:1px solid #fff9;border-radius:10px;flex-wrap:nowrap;align-items:center;gap:5px;padding:5px 9px;animation:.12s fadeIn;display:flex;position:absolute;transform:translate(-50%)}.floating-toolbar:after{content:"";-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fbf8f3b8;border-bottom:1px solid #fff9;border-right:1px solid #fff9;width:10px;height:10px;position:absolute;left:50%;transform:translate(-50%)}.floating-toolbar.above:after{bottom:-5px;transform:translate(-50%)rotate(45deg)}.floating-toolbar.below:after{top:-5px;transform:translate(-50%)rotate(-135deg)}@media (max-width:768px){.floating-toolbar{bottom:calc(env(safe-area-inset-bottom,0px) + 60px + 48px + 8px);-webkit-overflow-scrolling:touch;scrollbar-width:none;z-index:95;border-radius:10px;flex-wrap:nowrap;justify-content:flex-start;column-gap:4px;max-width:calc(100vw - 16px);padding:4px 6px;overflow:auto hidden;position:fixed!important;top:auto!important;left:8px!important;right:8px!important;transform:none!important}.floating-toolbar::-webkit-scrollbar{display:none}.floating-toolbar:after{display:none!important}.floating-toolbar>*{flex-shrink:0}.floating-toolbar .tt-btn{min-width:32px;height:32px;padding:0 6px}.floating-toolbar .tt-size-group{padding:0}.floating-toolbar .tt-size-input{width:32px;height:28px;padding:0;font-size:16px}.floating-toolbar .tt-delete{color:var(--ca-text-danger)}.floating-toolbar .tt-font{max-width:90px;height:32px;padding:4px 6px;font-size:16px}.floating-toolbar .st-divider{height:16px;margin:0 2px}}@media (max-width:480px){.floating-toolbar{box-sizing:border-box;-webkit-overflow-scrolling:touch;max-width:calc(100vw - 16px);overflow-x:auto}}.sticker-toolbar .st-color{cursor:pointer;background:0 0;border:1px solid #ddd;border-radius:5px;width:28px;height:28px;padding:0}.sticker-toolbar .st-divider{background:#00000014;width:1px;height:20px;margin:0 2px}.sticker-toolbar .sticker-quick-size .tt-btn{min-width:36px;min-height:36px;padding:6px 8px;font-size:11px}.st-opacity-control{color:var(--ca-text-secondary);align-items:center;gap:6px;font-size:11px;font-weight:700;display:inline-flex}.st-opacity-control input{width:72px;accent-color:var(--ca-blue)}.tt-btn-text{line-height:1}.tt-font{background:var(--ca-bg-surface);color:var(--ca-text-primary);cursor:pointer;border:1px solid #ddd;border-radius:5px;max-width:130px;padding:4px 6px;font-size:12px}.tt-font:hover{border-color:var(--ca-text-muted)}.tt-size-group{border:1px solid #e8e8e8;border-radius:5px;align-items:center;gap:2px;padding:1px;display:flex}.tt-size-input{width:40px;color:var(--ca-text-primary);text-align:center;border-radius:var(--ca-radius-xs);background:var(--ca-bg-surface);-moz-appearance:textfield;border:1px solid #ddd;padding:2px;font-size:12px;font-weight:600}.tt-size-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.tt-size-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.tt-size-input:focus{border-color:var(--ca-blue);outline:none}.tt-btn{border-radius:var(--ca-radius-xs);color:var(--ca-text-secondary);cursor:pointer;background:0 0;border:none;padding:3px 8px;font-size:12px;font-weight:600}.tt-btn:hover{background:var(--ca-bg-grey-150);color:var(--ca-text-primary)}.tt-btn.active{color:var(--ca-blue);background:#e8f0fb}.tt-btn:active{transform:scale(.96)}.tt-color{cursor:pointer;border:1px solid #ddd;border-radius:5px;width:24px;height:24px;padding:1px}.tt-align-group{border:1px solid #e8e8e8;border-radius:5px;display:flex;overflow:hidden}.tt-align-group .tt-btn{border-radius:0;padding:3px 7px;font-size:11px}.tt-edit{background:var(--ca-blue);color:#fff;cursor:pointer;border:none;border-radius:5px;align-items:center;gap:4px;padding:5px 10px;font-size:12px;font-weight:500;display:inline-flex}.tt-edit:hover{background:#002550}.tt-divider{background:#0000001a;width:1px;height:20px;margin:0 2px}.tt-delete{color:#c44;margin-left:4px}.tt-delete:hover{background:var(--ca-bg-danger-tint);color:var(--ca-text-danger)}.tt-bold{font-weight:900}.tt-italic{font-family:Georgia,serif;font-style:italic}.text-preset.active{border-color:var(--ca-blue);background:#003a850d;box-shadow:0 0 0 2px #003a8526}.text-tool-hint{border-radius:var(--ca-radius-md);color:#7a4800;background:#fff4e0;border:1px solid #f5c16c;flex-direction:column;gap:8px;margin:8px 4px 0;padding:10px;font-size:12px;display:flex}.text-tool-cancel{background:var(--ca-bg-surface);border-radius:var(--ca-radius-sm);color:var(--ca-text-secondary);cursor:pointer;border:1px solid #ddd;align-self:flex-start;padding:5px 10px;font-size:11px}.text-tool-cancel:hover{background:var(--ca-bg-grey-50)}.inline-text-edit{resize:none;z-index:20;box-shadow:none;background:0 0;border:1px dashed #003a858c;border-radius:2px;outline:none;padding:2px 3px;line-height:1.3;position:absolute}.onboarding-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;background:#0000008c;animation:.2s fadeIn;position:fixed;top:0;bottom:0;left:0;right:0}.onboarding-card{background:var(--ca-bg-surface);border-radius:var(--ca-radius-lg);z-index:301;text-align:center;width:min(480px,92vw);padding:28px 30px 22px;animation:.25s onboardingIn;position:fixed;box-shadow:0 20px 50px #0000004d}.onboarding-card.center{top:50%;left:50%;transform:translate(-50%,-50%)}.onboarding-card.right{top:50%;left:calc(var(--sidebar-w,250px) + 40px);transform:translateY(-50%)}.onboarding-card.bottom{top:90px;left:50%;transform:translate(-50%)}.onboarding-card.left{top:50%;right:40px;transform:translateY(-50%)}@media (max-width:768px){.onboarding-card,.onboarding-card.center,.onboarding-card.right,.onboarding-card.bottom,.onboarding-card.left{width:min(420px,100vw - 24px);max-height:calc(100dvh - 48px);padding:22px 22px 18px;overflow-y:auto;top:50%!important;bottom:auto!important;left:50%!important;right:auto!important;transform:translate(-50%,-50%)!important}}@keyframes onboardingIn{0%{opacity:0;transform:scale(.92) translate(var(--tx,-50%), var(--ty,-50%))}to{opacity:1}}.onboarding-icon{justify-content:center;margin-bottom:12px;display:flex}.onboarding-card h2{color:var(--ca-text-primary);margin:0 0 10px;font-size:20px;font-weight:600}.onboarding-card p{color:var(--ca-text-secondary);margin:0 0 18px;font-size:14px;line-height:1.5}.onboarding-progress{justify-content:center;gap:6px;margin-bottom:20px;display:flex}.onboarding-dot{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e0e0e0;border:none;border-radius:50%;flex-shrink:0;width:8px;height:8px;padding:0;transition:background .15s,transform .15s}@media (hover:hover) and (pointer:fine){.onboarding-dot:hover{transform:scale(1.25)}}.onboarding-dot.done{background:#9ec4f0}.onboarding-dot.active{background:var(--ca-blue);border-radius:var(--ca-radius-xs);width:22px}.onboarding-actions{justify-content:space-between;gap:10px;display:flex}.onboarding-btn{border-radius:var(--ca-radius-sm);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);border:none;flex:1;padding:10px 18px;font-size:13px;font-weight:500}.onboarding-btn.primary{background:var(--ca-blue);color:#fff}.onboarding-btn.primary:hover{background:#002550}.onboarding-btn.secondary{background:var(--ca-bg-grey-50);color:var(--ca-text-secondary);border:1px solid #e0e0e0}.onboarding-btn.secondary:hover{color:var(--ca-text-primary);background:#eee}.onboarding-highlight{border-radius:var(--ca-radius-sm);animation:1.4s infinite pulseHighlight;position:relative;z-index:302!important;box-shadow:0 0 0 4px #ffd54f,0 0 0 8px #ffd54f66!important}@keyframes pulseHighlight{0%,to{box-shadow:0 0 0 4px #ffd54f,0 0 0 8px #ffd54f66}50%{box-shadow:0 0 0 6px #ffd54f,0 0 0 14px #ffd54f40}}.onboarding-swipe-hint{color:var(--ca-text-muted);letter-spacing:.02em;margin-top:10px;font-size:11px}.mobile-fit-zoom,.canvas-edge-pager,.canvas-edge-history,.canvas-edge-nav,.canvas-edge-label,.canvas-edge-more{display:none}@media (max-width:768px){:root{--ca-mobile-canvas-controls-top:calc(env(safe-area-inset-top,0) + 78px);--ca-edge-side-reserve:100px}.mobile-fit-zoom{top:calc(var(--ca-mobile-canvas-controls-top) + 46px);border-radius:var(--ca-radius-pill);min-height:36px;color:var(--ca-blue);cursor:pointer;-webkit-backdrop-filter:blur(6px);z-index:50;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:#fffffff2;border:1px solid #e0dcd4;justify-content:center;align-items:center;gap:6px;padding:7px 11px;font-size:11px;font-weight:600;animation:.2s fitZoomIn;position:fixed;right:10px;box-shadow:0 4px 12px #0000001f;display:none!important}.mobile-fit-zoom:active{background:#efebe0;transform:scale(.94)}.canvas-edge-history{top:var(--ca-mobile-canvas-controls-top);border-radius:var(--ca-radius-pill);-webkit-backdrop-filter:blur(6px);z-index:50;background:#fffffff2;border:1px solid #e0dcd4;align-items:stretch;animation:.18s fadeIn;display:inline-flex;position:fixed;left:10px;overflow:hidden;box-shadow:0 4px 12px #0000001f}.canvas-edge-history .canvas-edge-nav+.canvas-edge-nav{border-left:1px solid #e0dcd4b3}.canvas-edge-pager{top:var(--ca-mobile-canvas-controls-top);max-width:calc(100vw - 2 * var(--ca-edge-side-reserve));border-radius:var(--ca-radius-pill);-webkit-backdrop-filter:blur(6px);z-index:50;background:#fffffff2;border:1px solid #e0dcd4;align-items:stretch;gap:0;animation:.18s fadeIn;display:inline-flex;position:fixed;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 4px 12px #0000001f}.canvas-edge-nav{width:40px;height:40px;color:var(--ca-blue);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:background .12s,transform .12s,opacity .12s;display:inline-flex}.canvas-edge-nav:active:not(:disabled){background:#efebe0;transform:scale(.92)}.canvas-edge-nav:disabled{opacity:.28;cursor:not-allowed}.canvas-edge-nav svg{display:block}.canvas-edge-nav.prev{padding-left:4px}.canvas-edge-nav.next{padding-right:4px}.canvas-edge-label{color:var(--ca-text-primary);letter-spacing:.02em;pointer-events:none;white-space:nowrap;border-left:1px solid #e0dcd4b3;border-right:1px solid #e0dcd4b3;align-items:center;gap:6px;min-width:0;padding:6px 10px;font-size:11px;font-weight:700;display:inline-flex;overflow:hidden}.canvas-edge-label .cel-text{color:var(--ca-text-primary);text-overflow:ellipsis;overflow:hidden}.canvas-edge-label .cel-counter{color:var(--ca-blue);border-radius:var(--ca-radius-pill);background:#f1f5fc;padding:2px 7px;font-size:10px;font-weight:600}.canvas-edge-more{top:var(--ca-mobile-canvas-controls-top);border-radius:var(--ca-radius-pill);width:40px;height:40px;color:var(--ca-blue);cursor:pointer;-webkit-backdrop-filter:blur(6px);z-index:50;-webkit-tap-highlight-color:transparent;background:#fffffff2;border:1px solid #e0dcd4;justify-content:center;align-items:center;transition:background .12s,transform .12s;animation:.18s fadeIn;display:inline-flex;position:fixed;right:10px;box-shadow:0 4px 12px #0000001f}.canvas-edge-more:active{background:#efebe0;transform:scale(.92)}.canvas-edge-more svg{display:block}}.canvas-edge-more-menu{background:var(--ca-bg-surface);border-radius:var(--ca-radius-lg);z-index:200;border:1px solid #e0dcd4;min-width:220px;padding:6px;animation:.14s fadeIn;box-shadow:0 12px 32px #0000002e}.canvas-edge-more-menu .cemm-head{color:#6b6963;border-bottom:1px solid #f0ede6;margin-bottom:4px;padding:6px 10px 8px;font-size:11px}.canvas-edge-more-menu .cemm-head strong{color:var(--ca-text-primary)}.canvas-edge-more-menu .cemm-range{color:var(--ca-text-muted);font-weight:400}.canvas-edge-more-menu .cemm-item{border-radius:var(--ca-radius-md);width:100%;color:var(--ca-text-primary);text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:background .1s;display:flex}.canvas-edge-more-menu .cemm-item:hover:not(:disabled){background:#f5f2ec}.canvas-edge-more-menu .cemm-item:focus-visible:not(:disabled){background:#f5f2ec}.canvas-edge-more-menu .cemm-item:disabled{opacity:.4;cursor:not-allowed}.canvas-edge-more-menu .cemm-item svg{color:var(--ca-blue);flex-shrink:0}.canvas-edge-more-menu .cemm-item.danger,.canvas-edge-more-menu .cemm-item.danger svg{color:var(--ca-text-danger-hover)}.canvas-edge-more-menu .cemm-item.danger:hover:not(:disabled){background:#fcefee}.canvas-edge-more-menu .cemm-sep{background:#f0ede6;height:1px;margin:4px 6px}@media (max-width:768px){.canvas-edge-more-menu{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;max-width:calc(100vw - 16px);max-height:calc(100dvh - 184px);overflow-y:auto}}@media (max-width:932px) and (orientation:landscape) and (max-height:500px){.canvas-edge-more-menu{max-height:calc(100dvh - 184px)}}@keyframes fitZoomIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.offline-indicator{top:calc(env(safe-area-inset-top,0) + 10px);border-radius:var(--ca-radius-pill);color:#fff;z-index:400;align-items:center;gap:8px;max-width:calc(100vw - 24px);padding:8px 14px;font-size:12px;font-weight:500;animation:.25s offlineSlide;display:inline-flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 6px 20px #0000002e}.offline-indicator.offline{background:var(--ca-text-danger)}.offline-indicator.online,.offline-indicator.reconnecting{background:#2e7d32}.offline-dot{background:var(--ca-bg-surface);border-radius:50%;width:8px;height:8px;animation:1.2s infinite pulseDot}@keyframes pulseDot{0%,to{opacity:1}50%{opacity:.4}}@keyframes offlineSlide{0%{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%)}}.mtab-badge{border-radius:var(--ca-radius-pill);background:var(--ca-blue);color:#fff;text-align:center;pointer-events:none;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:600;line-height:16px;position:absolute;top:3px;right:calc(50% - 22px);box-shadow:0 0 0 2px #fff}.empty-hint{--tail-x:0px;background:var(--ca-bg-surface);border-radius:var(--ca-radius-lg);color:var(--ca-text-primary);z-index:180;pointer-events:auto;border:1px solid #e0dcd4;max-width:200px;padding:10px 30px 10px 14px;font-size:13px;line-height:1.35;animation:.4s cubic-bezier(.2,.9,.3,1.15) emptyHintPulse;position:fixed;box-shadow:0 10px 24px #0000002e}.empty-hint.mobile{text-align:left;max-width:200px;padding:10px 30px 10px 14px}.empty-hint.desktop{max-width:240px;padding:12px 30px 12px 16px}.empty-hint-text{flex-direction:column;gap:2px;display:flex}.empty-hint-text strong{color:var(--ca-blue);margin-bottom:1px;font-size:13.5px;font-weight:700;display:block}.empty-hint-text span{color:var(--ca-text-secondary);font-size:12px}.empty-hint-close{color:var(--ca-text-disabled);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;font-size:18px;line-height:1;display:inline-flex;position:absolute;top:4px;right:6px}.empty-hint-close:hover{color:var(--ca-text-secondary)}.empty-hint.mobile:before,.empty-hint.mobile:after{content:"";pointer-events:none;width:0;height:0;position:absolute;left:50%}.empty-hint.mobile:before{margin-left:calc(-9px + var(--tail-x));border-top:9px solid #e0dcd4;border-left:9px solid #0000;border-right:9px solid #0000;animation:1.8s ease-in-out infinite tailBounceV;bottom:-9px}.empty-hint.mobile:after{margin-left:calc(-8px + var(--tail-x));border-top:8px solid #fff;border-left:8px solid #0000;border-right:8px solid #0000;animation:1.8s ease-in-out infinite tailBounceV;bottom:-7px}.empty-hint.desktop:before,.empty-hint.desktop:after{content:"";pointer-events:none;width:0;height:0;position:absolute;top:50%}.empty-hint.desktop:before{border-top:9px solid #0000;border-bottom:9px solid #0000;border-right:9px solid #e0dcd4;margin-top:-9px;animation:1.8s ease-in-out infinite tailBounceH;left:-9px}.empty-hint.desktop:after{border-top:8px solid #0000;border-bottom:8px solid #0000;border-right:8px solid #fff;margin-top:-8px;animation:1.8s ease-in-out infinite tailBounceH;left:-7px}@keyframes tailBounceV{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}@keyframes tailBounceH{0%,to{transform:translate(0)}50%{transform:translate(-4px)}}@keyframes emptyHintPulse{0%{opacity:0}to{opacity:1}}.autofill-bar{left:50%;bottom:calc(72px + env(safe-area-inset-bottom,0));background:linear-gradient(135deg, var(--ca-blue) 0%, #00529b 100%);color:#fff;border-radius:var(--ca-radius-pill);z-index:240;pointer-events:auto;white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:10px;width:max-content;max-width:min(640px,100vw - 24px);padding:10px 14px 10px 16px;font-size:13px;line-height:1.35;display:flex;position:fixed;overflow:hidden;transform:translate(-50%);box-shadow:0 14px 32px #003a8552,0 4px 10px #0000001f}.autofill-bar.entering{animation:.4s cubic-bezier(.2,.9,.3,1.15) backwards autofillBarIn}.autofill-bar.leaving{animation:.3s ease-in forwards autofillBarOut}@keyframes autofillBarIn{0%{opacity:0;transform:translate(-50%,18px)}to{opacity:1;transform:translate(-50%)}}@keyframes autofillBarOut{0%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,14px)}}.autofill-bar-icon{color:#ffe680;flex:none;display:flex}.autofill-bar-text{text-overflow:ellipsis;white-space:nowrap;flex:auto;overflow:hidden}.autofill-bar-undo{color:#fff;border-radius:var(--ca-radius-pill);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:#ffffff29;border:1px solid #ffffff47;flex:none;padding:5px 12px;font-size:12px;font-weight:600;transition:background .12s,transform .12s}.autofill-bar-undo:hover{background:#ffffff42}.autofill-bar-undo:active{transform:scale(.95)}.autofill-bar-close{color:#ffffffd9;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;flex:none;justify-content:center;align-items:center;width:32px;height:32px;margin-left:-2px;padding:0;font-size:20px;line-height:1;transition:background .12s;display:flex}.autofill-bar-close:hover{background:#ffffff29}.install-banner{left:12px;right:12px;bottom:calc(60px + env(safe-area-inset-bottom,0) + 12px);background:var(--ca-bg-surface);z-index:260;border:1px solid #e0dcd4;border-radius:14px;align-items:center;gap:12px;padding:12px 14px;animation:.32s cubic-bezier(.2,.9,.3,1.15) installBannerIn;display:flex;position:fixed;box-shadow:0 10px 28px #0000002e}@keyframes installBannerIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.install-banner-icon{flex:none;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.install-banner-text{color:var(--ca-text-primary);flex-direction:column;flex:auto;gap:2px;font-size:12px;line-height:1.3;display:flex}.install-banner-text strong{color:var(--ca-text-primary);font-size:13px;font-weight:600}.install-banner-actions{flex:none;align-items:center;gap:6px;display:flex}.install-banner-btn{border-radius:var(--ca-radius-pill);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border:none;padding:8px 12px;font-size:12px;font-weight:600;transition:transform .12s,background .12s}.install-banner-btn:active{transform:scale(.95)}.install-banner-btn.primary{background:var(--ca-blue);color:#fff}.install-banner-btn.primary:active{background:#002550}.install-banner-btn.secondary{color:var(--ca-text-muted);background:0 0;min-width:32px;padding:8px 10px;font-size:16px}@media (min-width:769px){.install-banner{display:none}}.ca-progress{height:24px;color:var(--ca-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;background:#fbfbfb;border-bottom:1px solid #ececec;flex-shrink:0;align-items:center;gap:10px;padding:0 14px;font-size:11px;transition:background .15s;display:flex;position:relative}.ca-progress:hover{background:var(--ca-bg-grey-50)}.ca-progress-track{background:var(--ca-bg-grey-200);border-radius:var(--ca-radius-xs);flex:auto;height:4px;position:relative;overflow:hidden}.ca-progress-fill{background:linear-gradient(90deg, var(--ca-blue) 0%, #2d5fb3 100%);border-radius:var(--ca-radius-xs);height:100%;transition:width .28s cubic-bezier(.22,1,.36,1);position:relative}.ca-progress-fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff38 50%,#0000 100%);animation:2.4s ease-in-out infinite caShimmer;position:absolute;top:0;bottom:0;left:0;right:0}@keyframes caShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.ca-progress-text{white-space:nowrap;font-variant-numeric:tabular-nums;align-items:center;gap:3px;font-size:11px;display:inline-flex}.ca-progress-text strong{color:var(--ca-blue);font-weight:700}.ca-progress-sep{color:#ccc;margin:0 2px}.ca-progress-label{color:var(--ca-text-muted);margin-left:3px}.ca-progress.complete{color:#2e7d32;cursor:default;background:#f1f8f1;border-bottom-color:#d4e8d4}.ca-progress.complete:hover{background:#f1f8f1}.ca-progress.complete .ca-progress-track{display:none}.ca-progress.complete .ca-progress-text{flex:auto;justify-content:center;font-size:12px;font-weight:600}.ca-progress-check{color:#fff;background:#2e7d32;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;margin-right:6px;animation:.4s cubic-bezier(.3,1.4,.5,1) caCheckPop;display:inline-flex}@keyframes caCheckPop{0%{transform:scale(0)}60%{transform:scale(1.25)}to{transform:scale(1)}}@media (max-width:600px){.ca-progress{gap:8px;height:22px;padding:0 10px}.ca-progress-label{display:none}.ca-progress-text{font-size:10.5px}}.photo-picker-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:300;background:#0000008c;justify-content:center;align-items:flex-end;animation:.18s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.photo-picker-sheet{background:var(--ca-bg-surface);overscroll-behavior:contain;width:100%;max-width:760px;max-height:82dvh;padding-bottom:env(safe-area-inset-bottom,0);border-radius:18px 18px 0 0;flex-direction:column;transition:transform .18s;animation:.24s cubic-bezier(.22,1,.36,1) pickerSlideUp;display:flex;overflow:hidden;box-shadow:0 -12px 40px #00000047}@keyframes pickerSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.photo-picker-grabber{border-radius:var(--ca-radius-xs);cursor:grab;background:#ddd;width:44px;height:4px;margin:8px auto 4px}.photo-picker-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:10px 18px 12px;display:flex}.photo-picker-header h3{color:var(--ca-text-primary);margin:0;font-size:17px;font-weight:600}.photo-picker-header p{color:var(--ca-text-muted);margin:2px 0 0;font-size:12px}.photo-picker-close{background:var(--ca-bg-grey-50);width:36px;height:36px;color:var(--ca-text-secondary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.photo-picker-close:hover{background:var(--ca-bg-grey-200);color:var(--ca-text-primary)}.photo-picker-body{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:auto;padding:14px 14px 18px;overflow-y:auto}.photo-picker-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.photo-picker-item{aspect-ratio:1;background:var(--ca-bg-grey-150);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:10px;padding:0;transition:transform .12s;position:relative;overflow:hidden}.photo-picker-item:active{transform:scale(.94)}.photo-picker-item img{object-fit:cover;width:100%;height:100%;transition:opacity .18s;display:block}.photo-picker-item.used img{opacity:.45}.photo-picker-used-badge{color:#fff;letter-spacing:.3px;text-transform:uppercase;background:#1e1e1ec7;border-radius:10px;padding:3px 7px;font-size:9.5px;font-weight:600;position:absolute;top:5px;right:5px}.photo-picker-upload{aspect-ratio:1;background:var(--ca-bg-subtle);color:var(--ca-blue);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);border:2px dashed #ccc;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.photo-picker-upload:hover{border-color:var(--ca-blue);background:#f2f6ff}@media (max-width:520px){.photo-picker-grid{grid-template-columns:repeat(3,1fr);gap:7px}.photo-picker-header{padding:8px 16px 10px}.photo-picker-header h3{font-size:16px}}@media (min-width:761px){.photo-picker-backdrop{align-items:center}.photo-picker-sheet{border-radius:14px;width:720px;max-height:78vh;animation:.2s pickerFadeUp}@keyframes pickerFadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.photo-picker-grabber{display:none}.photo-picker-grid{grid-template-columns:repeat(5,1fr)}}.consent-banner{z-index:240;background:var(--ca-text-primary);color:#fff;animation:consentSlideUp .32s var(--ca-ease-out);padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0));position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #0003}.consent-banner-inner{flex-wrap:wrap;align-items:center;gap:16px;max-width:920px;margin:0 auto;display:flex}.consent-text{flex-direction:column;flex:320px;gap:4px;font-size:13px;line-height:1.4;display:flex}.consent-text strong{color:#fff;font-size:14px;font-weight:700}.consent-text span{color:#ffffffd9}.consent-link{color:#fff;text-underline-offset:2px;font-weight:500;text-decoration:underline}.consent-link:hover{text-decoration-thickness:2px}.consent-actions{flex-shrink:0;gap:8px;display:flex}.consent-btn{border-radius:var(--ca-radius-pill);cursor:pointer;transition:background var(--ca-tr-fast), border-color var(--ca-tr-fast), transform var(--ca-tr-fast);border:1.5px solid #0000;padding:9px 16px;font-size:13px;font-weight:600}.consent-btn-secondary{color:#fff;background:0 0;border-color:#ffffff4d}.consent-btn-secondary:hover{background:#ffffff14;border-color:#ffffff73}.consent-btn-primary{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue)}.consent-btn-primary:hover{background:var(--ca-blue-dark);border-color:var(--ca-blue-dark);transform:translateY(-1px)}@keyframes consentSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-width:540px){.consent-banner-inner{flex-direction:column;align-items:stretch}.consent-actions{justify-content:flex-end}}@media (max-width:768px){body:has(.mobile-tabbar) .consent-banner{bottom:calc(112px + env(safe-area-inset-bottom,0));max-height:calc(100dvh - 216px - env(safe-area-inset-bottom,0));overscroll-behavior:contain;overflow-y:auto}}@media (max-width:932px) and (orientation:landscape) and (max-height:500px){body:has(.mobile-tabbar) .consent-banner{bottom:calc(100px + env(safe-area-inset-bottom,0))}}.toast-host{bottom:calc(24px + env(safe-area-inset-bottom,0px));z-index:250;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;left:50%;transform:translate(-50%)}@media (max-width:768px){.toast-host{bottom:calc(80px + env(safe-area-inset-bottom,0px));align-items:stretch;left:8px;right:8px;transform:none}.toast{width:100%;max-width:none}}.toast{--toast-accent:var(--ca-text-secondary);background:var(--ca-bg-surface);color:var(--ca-text-primary);border:1px solid var(--ca-border-default);border-left:3px solid var(--toast-accent);text-align:left;white-space:normal;word-wrap:break-word;pointer-events:auto;border-radius:12px;align-items:center;gap:10px;max-width:min(100vw - 16px,480px);padding:11px 16px;font-size:13.5px;line-height:1.45;animation:.2s toastIn;display:inline-flex;box-shadow:0 2px 6px #1f1b1614,0 12px 28px #1f1b161f}.toast>span,.toast>div{flex:1;min-width:0}.toast svg{color:var(--toast-accent);flex-shrink:0}.toast-success{--toast-accent:#2e7d32}.toast-info{--toast-accent:var(--ca-blue)}.toast-warning{--toast-accent:#b45309}.toast-error{--toast-accent:#b3261e}.toast-action{border:none;border-left:1px solid var(--ca-border-default);color:var(--toast-accent);cursor:pointer;letter-spacing:.2px;background:0 0;border-radius:0;margin-left:6px;padding:4px 4px 4px 12px;font-size:13px;font-weight:700;transition:opacity .15s}.toast-action:hover{opacity:.78}.toast-action:active{opacity:.6}.toast-close{width:22px;height:22px;color:var(--ca-text-muted);cursor:pointer;background:0 0;border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;margin-left:4px;margin-right:-4px;padding:0;transition:background .15s,color .15s;display:inline-flex}.toast-close:hover{background:var(--ca-bg-hover);color:var(--ca-text-primary)}.toast-close:active{background:var(--ca-bg-active)}@media (max-width:768px){.toast-close{width:30px;height:30px;margin-right:-6px}}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}.toast.is-leaving{pointer-events:none;animation:.2s forwards toastOut}.shortcuts-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;background:#0000008c;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.shortcuts-modal{background:var(--ca-bg-surface);border-radius:14px;flex-direction:column;width:100%;max-width:720px;max-height:86vh;animation:.2s slideUp;display:flex;overflow:hidden;box-shadow:0 20px 50px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.shortcuts-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.shortcuts-header h2{color:var(--ca-text-primary);margin:0;font-size:18px;font-weight:600}.shortcuts-close{border-radius:var(--ca-radius-sm);color:var(--ca-text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:4px;display:inline-flex}.shortcuts-close:hover{background:var(--ca-bg-grey-100);color:var(--ca-text-primary)}.shortcuts-body{grid-template-columns:1fr 1fr;gap:20px 28px;padding:18px 22px;display:grid;overflow-y:auto}.shortcuts-group h3{color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:.6px;margin:0 0 8px;font-size:12px;font-weight:600}.shortcuts-rows{flex-direction:column;gap:6px;display:flex}.shortcuts-row{justify-content:space-between;align-items:center;gap:16px;padding:4px 0;display:flex}.shortcuts-keys{flex-shrink:0;gap:4px;display:flex}.shortcuts-keys kbd{background:var(--ca-bg-grey-50);border-radius:var(--ca-radius-xs);color:var(--ca-text-primary);white-space:nowrap;border:1px solid #ddd;border-bottom-width:2px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.shortcuts-desc{color:var(--ca-text-secondary);text-align:right;font-size:13px}.shortcuts-footer{color:var(--ca-text-muted);text-align:center;background:var(--ca-bg-subtle);border-top:1px solid #eee;padding:12px 22px;font-size:12px}@media (max-width:640px){.shortcuts-body{grid-template-columns:1fr}.shortcuts-desc{font-size:12px}}.inspiration-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f121c9e;justify-content:center;align-items:center;padding:24px;animation:.18s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.inspiration-modal{background:var(--ca-bg-surface);width:100%;max-width:1100px;max-height:92vh;border-radius:16px;flex-direction:column;max-height:92dvh;animation:.22s slideUp;display:flex;overflow:hidden;box-shadow:0 24px 60px #00000052}.inspiration-header{border-bottom:1px solid #efefef;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:22px 28px 16px;display:flex}.inspiration-title h2{color:var(--ca-text-primary);letter-spacing:-.2px;margin:0 0 4px;font-size:22px;font-weight:600}.inspiration-title p{color:var(--ca-text-muted);margin:0;font-size:13.5px}.inspiration-close{border-radius:var(--ca-radius-md);color:var(--ca-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:6px;display:inline-flex}.inspiration-close:hover{background:var(--ca-bg-grey-100);color:var(--ca-text-primary)}.inspiration-filters{background:var(--ca-bg-subtle);border-bottom:1px solid #f0f0f0;flex-wrap:wrap;flex-shrink:0;gap:8px;padding:14px 28px;display:flex}.inspiration-chip{background:var(--ca-bg-surface);border-radius:var(--ca-radius-pill);color:var(--ca-text-secondary);cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);border:1px solid #e2e2e2;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:inline-flex}.inspiration-chip:hover{border-color:var(--ca-blue);color:var(--ca-blue)}.inspiration-chip.active{background:var(--ca-blue);border-color:var(--ca-blue);color:#fff}.inspiration-chip-count{color:inherit;border-radius:var(--ca-radius-pill);background:#00000012;padding:1px 7px;font-size:11px;font-weight:600}.inspiration-chip.active .inspiration-chip-count{background:#ffffff38}.inspiration-grid{background:var(--ca-bg-surface);flex:auto;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;padding:22px 28px 28px;display:grid;overflow-y:auto}.inspiration-card{border-radius:var(--ca-radius-lg);background:var(--ca-bg-surface);border:1px solid #ececec;flex-direction:column;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;overflow:hidden}@media (hover:hover) and (pointer:fine){.inspiration-card:hover{border-color:#003a8533;transform:translateY(-3px);box-shadow:0 14px 30px #003a851f}}.inspiration-card-preview{aspect-ratio:2/3;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.inspiration-card-img{object-fit:cover;width:100%;height:100%;display:block}.inspiration-card-fallback{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:18px;display:flex}.inspiration-card-cover-title{letter-spacing:.3px;font-size:26px;font-weight:600;line-height:1.1}.inspiration-card-cover-subtitle{opacity:.85;margin-top:6px;font-size:13px;font-style:italic}.inspiration-card-tag{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--ca-text-primary);border-radius:var(--ca-radius-pill);background:#ffffffeb;align-items:center;gap:4px;padding:4px 9px;font-size:11.5px;font-weight:500;display:inline-flex;position:absolute;top:10px;left:10px;box-shadow:0 2px 6px #00000014}.inspiration-card-body{flex-direction:column;gap:6px;padding:12px 14px 14px;display:flex}.inspiration-card-title{color:var(--ca-text-primary);font-size:14.5px;font-weight:600;line-height:1.25}.inspiration-card-desc{color:#707070;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12.5px;line-height:1.4;display:-webkit-box;overflow:hidden}.inspiration-card-apply{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-md);cursor:pointer;border:none;margin-top:8px;padding:9px 14px;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.inspiration-card-apply:hover{background:#002a63}.inspiration-card-apply:active{transform:scale(.97)}.inspiration-footer{background:var(--ca-bg-subtle);color:var(--ca-text-secondary);border-top:1px solid #efefef;flex-wrap:wrap;flex-shrink:0;justify-content:center;align-items:center;gap:12px;padding:14px 28px;font-size:13px;display:flex}.inspiration-ig-link{color:var(--ca-blue);border-radius:var(--ca-radius-md);border:1px solid #003a8533;align-items:center;gap:6px;padding:6px 12px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.inspiration-ig-link:hover{background:#003a850f;border-color:#003a8566}.snap-guide{pointer-events:none;z-index:15;background:#e91e63;position:absolute;box-shadow:0 0 4px #e91e6373}.snap-guide.v{width:1px}.snap-guide.h{height:1px}.snap-guide.edge{background:var(--ca-blue);box-shadow:0 0 4px #003a8559}.drop-highlight{pointer-events:none;border:3px dashed var(--ca-blue);border-radius:var(--ca-radius-xs);z-index:12;box-sizing:border-box;background:#003a8526;position:absolute}.drop-highlight:after{content:"Largar aqui";color:var(--ca-blue);font-family:var(--ca-font-ui);text-shadow:0 1px 2px #fffc;letter-spacing:.2px;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.placeholder-hover-ring{pointer-events:none;z-index:11;box-sizing:border-box;border:2px solid #fff;border-radius:5px;transition:box-shadow .12s ease-out,border-color .12s ease-out;position:absolute;box-shadow:0 0 0 1px #003a858c,0 0 0 4px #003a851f,0 6px 18px #0000001f}.bleed-hint{color:var(--ca-text-disabled);align-items:center;gap:5px;margin-top:2px;font-size:10px;display:flex}.login-screen-v2{-webkit-overflow-scrolling:touch;height:100dvh;min-height:100dvh;font-family:var(--ca-font-ui), -apple-system, system-ui, sans-serif;color:#1f1b16;background-blend-mode:normal, normal, multiply;background-color:#f4efe6;background-image:radial-gradient(80% 60% at 30% 30%,#fffaf099 0%,#0000 70%),radial-gradient(70% 50% at 80% 70%,#f1c3cc2e 0%,#0000 60%),url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.12  0 0 0 0 0.10  0 0 0 0 0.08  0 0 0 0.06 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;grid-template-columns:1.2fr 1fr;display:grid;position:relative;overflow-y:auto}@media (max-width:860px){.login-screen-v2{grid-template-rows:auto 1fr;grid-template-columns:1fr}}.login-aside{justify-content:flex-end;align-items:center;padding:64px 56px 64px 8vw;display:flex;position:relative}.login-aside:before{content:"";background:#1f1b161f;width:1px;position:absolute;top:16%;bottom:16%;right:0}.login-aside-inner{width:100%;max-width:540px}.login-aside-inner>*{opacity:0;will-change:transform, opacity;animation:.7s cubic-bezier(.16,1,.3,1) forwards loginReveal;transform:translateY(14px)}.login-aside-inner>:first-child{animation-delay:80ms}.login-aside-inner>:nth-child(2){animation-delay:.2s}.login-aside-inner>:nth-child(3){animation-delay:.34s}.login-aside-inner>:nth-child(4){animation-delay:.48s}.login-card-v2{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) .6s forwards loginReveal;transform:translateY(20px)scale(.985)}@keyframes loginReveal{to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.login-aside-inner>*,.login-card-v2{opacity:1!important;animation:none!important;transform:none!important}}.login-mark{font-family:var(--ca-font-ui), sans-serif;letter-spacing:.32em;color:#003a85;border-bottom:1px solid #003a85;margin-bottom:32px;padding-bottom:6px;font-size:11px;font-weight:600;display:inline-block}.login-display{letter-spacing:-.02em;color:#1f1b16;flex-direction:column;align-items:flex-start;margin:0 0 28px;font-family:Cormorant Garamond,Playfair Display,Georgia,serif;font-size:max(56px,min(9vw,124px));font-weight:400;line-height:.92;display:flex}.login-display em{color:#003a85;margin-left:-.04em;font-style:italic;font-weight:500}.login-display-amp{color:#b66a52;margin:-.08em 0 -.06em .5em;font-family:Cormorant Garamond,serif;font-size:.6em;font-style:italic;font-weight:500}.login-tagline{color:#4a413a;letter-spacing:.005em;max-width:380px;margin:0 0 56px;font-family:Cormorant Garamond,serif;font-size:19px;font-weight:400;line-height:1.45}.login-tagline em{color:#003a85;font-style:italic;font-weight:500}.login-aside-deco{align-items:center;gap:14px;display:flex}.login-rule{opacity:.6;background:#1f1b16;width:56px;height:1px;display:block}.login-aside-meta{font-family:var(--ca-font-ui), sans-serif;letter-spacing:.18em;text-transform:uppercase;color:#1f1b16;opacity:.55;font-size:11px}@media (max-width:860px){.login-aside{justify-content:flex-start;padding:48px 28px 24px}.login-aside:before{display:none}.login-display{font-size:max(52px,min(14vw,88px))}.login-tagline{margin-bottom:24px;font-size:17px}}.login-stage{justify-content:flex-start;align-items:center;padding:64px 8vw 64px 56px;display:flex}@media (max-width:860px){.login-stage{justify-content:stretch;padding:12px 28px 48px}}.login-email-input{box-sizing:border-box;color:#1f1b16;background:#fff;border:1px solid #d8d2c6;border-radius:10px;outline:none;width:100%;padding:13px 16px;font-family:inherit;font-size:16px}.login-email-input:focus{border-color:#1f3a5f;box-shadow:0 0 0 3px #1f3a5f1f}.login-card-v2{-webkit-backdrop-filter:blur(8px);background:linear-gradient(#fffcf6f5,#fffcf6f5) padding-box padding-box,linear-gradient(#1f1b160a,#1f1b160a) border-box;border:8px solid #0000;border-radius:28px;width:100%;max-width:400px;padding:36px 32px;box-shadow:0 0 0 1px #1f1b160f,inset 0 1px 1px #ffffff8c,0 24px 48px -16px #1f1b161f,0 4px 12px -4px #1f1b160f}@media (max-width:860px){.login-card-v2{max-width:100%;padding:32px 24px}}.login-card-eyebrow{font-family:var(--ca-font-ui), sans-serif;letter-spacing:.2em;text-transform:uppercase;color:#b66a52;background:#b66a5214;border:1px solid #b66a522e;border-radius:999px;align-items:center;gap:6px;margin-bottom:16px;padding:4px 10px;font-size:10px;font-weight:500;display:inline-flex}.login-card-eyebrow:before{content:"";background:#b66a52;border-radius:999px;width:5px;height:5px;animation:2.4s cubic-bezier(.4,0,.6,1) infinite eyebrowDot}@keyframes eyebrowDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}@media (prefers-reduced-motion:reduce){.login-card-eyebrow:before{animation:none}}.login-card-title{color:#1f1b16;margin:0 0 8px;font-family:Cormorant Garamond,serif;font-size:32px;font-style:italic;font-weight:500;line-height:1.1}.login-card-v2 .login-lede{color:#4a413a;margin:0 0 28px;font-size:13.5px;line-height:1.55}.login-card-v2 .login-form{gap:22px}.login-card-v2 .login-form label{gap:8px}.login-card-v2 .login-form label span{letter-spacing:0;text-transform:none;color:#4a413a;font-family:Cormorant Garamond,serif;font-size:14px;font-style:italic;font-weight:500}.login-card-v2 .login-form input{font-size:16px;font-family:var(--ca-font-ui), sans-serif;color:#1f1b16;background:0 0;border:none;border-bottom:1.5px solid #1f1b162e;border-radius:0;padding:8px 0 10px;transition:border-color .18s}.login-card-v2 .login-form input::placeholder{color:#1f1b1652}.login-card-v2 .login-form input:focus{border-bottom-color:#003a85;outline:none}.login-card-v2 .login-btn{color:#fff;font-family:var(--ca-font-ui), sans-serif;letter-spacing:.06em;text-transform:none;background:#003a85;border:1px solid #003a85;border-radius:999px;justify-content:space-between;align-items:center;gap:16px;margin-top:8px;padding:8px 8px 8px 24px;font-size:12.5px;font-weight:500;transition:all .5s cubic-bezier(.32,.72,0,1);display:flex;box-shadow:inset 0 1px #ffffff2e,0 2px 8px -2px #003a8566}.login-card-v2 .login-btn:after{content:"";background:#fffffff2 linear-gradient(#0000,#0000);border-radius:999px;flex-shrink:0;width:36px;height:36px;transition:transform .4s cubic-bezier(.32,.72,0,1);-webkit-mask-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Cpath d='M14 22 L22 14 M14 14 L22 14 L22 22' fill='none' stroke='white' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Cpath d='M14 22 L22 14 M14 14 L22 14 L22 22' fill='none' stroke='white' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");-webkit-mask-size:contain;mask-size:contain}.login-card-v2 .login-btn{position:relative}.login-card-v2 .login-btn:hover{background:#002a65;transform:translateY(-1px);box-shadow:inset 0 1px #ffffff38,0 6px 16px -4px #003a8580}.login-card-v2 .login-btn:hover:after{background-color:#fff;transform:translate(2px,-2px)scale(1.06)}.login-card-v2 .login-btn:active{transition-duration:80ms;transform:scale(.98)translateY(1px);box-shadow:0 1px 4px -1px #003a8566}.login-card-v2 .login-demo-divider{align-items:center;gap:12px;margin:24px 0 16px;display:flex}.login-card-v2 .login-demo-divider:before,.login-card-v2 .login-demo-divider:after{content:"";background:#1f1b161f;flex:1;height:1px}.login-card-v2 .login-demo-divider span{color:#4a413a;letter-spacing:.04em;font-family:Cormorant Garamond,serif;font-size:13px;font-style:italic}.login-card-v2 .login-demo-btn{color:#1f1b16;width:100%;font-family:var(--ca-font-ui), sans-serif;letter-spacing:.04em;cursor:pointer;background:0 0;border:1.5px solid #1f1b1652;border-radius:2px;padding:12px 20px;font-size:13px;font-weight:500;transition:background .16s,border-color .16s}.login-card-v2 .login-demo-btn:hover{color:#003a85;background:#003a850a;border-color:#003a85}.login-card-v2 .login-demo-hint{color:#1f1b168c;text-align:center;margin:12px 0 0;font-family:Cormorant Garamond,serif;font-size:13.5px;font-style:italic;line-height:1.35}.login-card-v2 .login-reset-details{border-top:1px solid #1f1b1614;margin-top:28px;padding-top:16px}.login-card-v2 .login-reset-summary{font-family:var(--ca-font-ui), sans-serif;letter-spacing:.16em;text-transform:uppercase;color:#1f1b1673;cursor:pointer;font-size:11px;list-style:none}.login-card-v2 .login-reset-summary::-webkit-details-marker{display:none}.login-card-v2 .login-reset-summary:hover{color:#003a85}.login-screen{min-height:100vh;background:linear-gradient(135deg,#faf9f6 0%,#efebe0 100%);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.login-card{background:var(--ca-bg-surface);border-radius:16px;width:100%;max-width:420px;padding:40px;box-shadow:0 4px 30px #00000014}.login-card h1{color:var(--ca-blue);margin:0 0 8px;font-family:Londrina Solid,cursive;font-size:32px}.login-lede{color:var(--ca-text-secondary);margin:0 0 24px;font-size:14px;line-height:1.5}.login-form{flex-direction:column;gap:14px;display:flex}.login-form label{color:var(--ca-text-muted);flex-direction:column;gap:5px;font-size:12px;font-weight:600;display:flex}.login-form label span{text-transform:uppercase;letter-spacing:.4px;font-size:11px}.login-form input{border-radius:var(--ca-radius-md);border:1.5px solid #e4e4e4;padding:10px 12px;font-family:inherit;font-size:16px}.login-form input:focus{border-color:var(--ca-blue);outline:none}.login-btn{background:var(--ca-text-primary);color:#fff;border-radius:var(--ca-radius-md);cursor:pointer;text-align:center;border:none;padding:12px 20px;font-size:14px;font-weight:600;text-decoration:none;display:inline-block}.login-btn:hover{background:#333}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{color:#c44;background:var(--ca-bg-danger-tint);border-radius:var(--ca-radius-sm);margin:0;padding:10px;font-size:12px}.projects-screen{min-height:100vh;background:radial-gradient(120% 80% at 50% 0%, var(--ca-rose-soft) 0%, var(--ca-cream) 55%), url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.12  0 0 0 0 0.10  0 0 0 0 0.08  0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-blend-mode:normal, multiply;min-height:100dvh;padding:32px}.projects-header{justify-content:space-between;align-items:flex-start;max-width:1200px;margin:0 auto 32px;display:flex}.projects-header h1{color:var(--ca-blue);margin:0;font-family:Londrina Solid,cursive;font-size:36px}.projects-user{color:var(--ca-text-muted);margin:4px 0 0;font-size:13px}.projects-header-actions{gap:10px;display:flex}.projects-new-btn{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-md);cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:600}.projects-new-btn:hover{background:var(--ca-blue-dark)}.projects-new-btn:disabled{opacity:.5;cursor:not-allowed}.projects-new-secondary{color:var(--ca-text-muted);cursor:pointer;background:0 0;border:none;margin:12px auto 0;padding:6px 10px;font-size:13px;text-decoration:underline;display:block}.projects-new-secondary:hover{color:var(--ca-text-secondary)}.projects-new-secondary:disabled{opacity:.5;cursor:not-allowed}.projects-logout-btn{color:var(--ca-text-muted);border-radius:var(--ca-radius-md);cursor:pointer;background:0 0;border:1px solid #ddd;padding:10px 16px;font-size:13px}.projects-logout-btn:hover{background:var(--ca-bg-grey-150);color:var(--ca-text-secondary)}.projects-loading,.projects-empty{text-align:center;max-width:1200px;color:var(--ca-text-muted);margin:80px auto}.projects-empty p{margin-bottom:16px;font-size:15px}.projects-seasonal-hero{background:linear-gradient(135deg,#faf9f6 0%,#f1e7e9 100%);border:1px solid #f1c3cc;border-radius:16px;max-width:520px;margin:0 auto 24px;padding:28px 24px}.projects-seasonal-emoji{filter:drop-shadow(0 2px 4px #0000001a);margin-bottom:12px;font-size:56px;line-height:1}.projects-seasonal-hero h2{color:var(--ca-text-primary);margin:0 0 8px;font-size:22px;font-weight:700}.projects-seasonal-hero p{color:var(--ca-text-secondary);margin:0;font-size:15px}.projects-seasonal-banner{border-radius:var(--ca-radius-lg);max-width:1200px;color:var(--ca-text-primary);background:linear-gradient(135deg,#faf9f6 0%,#f1e7e9 100%);border:1px solid #f1c3cc;align-items:center;gap:12px;margin:0 auto 16px;padding:12px 16px;font-size:14px;display:flex}.projects-seasonal-banner-emoji{font-size:22px;line-height:1}.projects-seasonal-banner span:nth-of-type(2){flex:1}.projects-seasonal-banner-btn{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-md);cursor:pointer;white-space:nowrap;border:none;padding:8px 16px;font-size:13px;font-weight:600}.projects-seasonal-banner-btn:hover{background:var(--ca-blue-dark)}.projects-seasonal-banner-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width:600px){.projects-seasonal-banner{flex-wrap:wrap;padding:12px}.projects-seasonal-banner span:nth-of-type(2){flex-basis:calc(100% - 34px)}.projects-seasonal-banner-btn{width:100%;padding:10px}}.projects-error{background:var(--ca-bg-danger-tint);max-width:1200px;color:var(--ca-text-danger);border-radius:var(--ca-radius-md);justify-content:space-between;align-items:center;gap:12px;margin:0 auto 16px;padding:12px 16px;font-size:13px;display:flex}.projects-error-retry{background:var(--ca-text-danger);color:#fff;border-radius:var(--ca-radius-sm);cursor:pointer;transition:background var(--ca-tr-fast);border:none;flex-shrink:0;padding:6px 14px;font-size:12.5px;font-weight:600}.projects-error-retry:hover{background:#800}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;max-width:1200px;margin:0 auto;display:grid}@media (max-width:600px){.projects-screen{padding:16px 12px}.projects-header{flex-direction:column;align-items:stretch;gap:16px;margin-bottom:20px}.projects-header h1{font-size:28px}.projects-header-actions{justify-content:flex-end;width:100%}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}.projects-loading,.projects-empty{margin:40px auto;padding:0 8px}.projects-error{padding:10px 12px;font-size:12.5px}}.project-card{background:var(--ca-bg-surface);cursor:pointer;transition:transform .3s var(--ca-ease-premium), box-shadow .3s var(--ca-ease-premium);border-radius:16px;position:relative;overflow:hidden;box-shadow:0 1px 2px #2a25210a,0 12px 28px -12px #2a252124}@media (hover:hover) and (pointer:fine){.project-card:hover{transform:translateY(-4px)scale(1.01);box-shadow:0 18px 40px -16px #9b5a7238}}.project-thumb{aspect-ratio:1;background:#f0ece4;justify-content:center;align-items:center;display:flex}.project-thumb img{object-fit:cover;width:100%;height:100%}.project-thumb:has(.project-thumb-empty){background:linear-gradient(135deg, var(--ca-rose-soft), var(--ca-butter-soft))}.project-thumb-empty{opacity:.5;color:var(--ca-rose-ink);font-size:48px}.project-meta{padding:14px}.project-meta h3{color:var(--ca-text-primary);cursor:text;margin:0 0 6px;font-size:15px;font-weight:600}.project-meta h3:hover{color:var(--ca-blue)}.project-name-input{width:100%;color:var(--ca-text-primary);border:1px solid var(--ca-blue);border-radius:var(--ca-radius-xs);background:var(--ca-bg-surface);box-sizing:border-box;outline:none;margin:0 0 6px;padding:2px 4px;font-family:inherit;font-size:16px;font-weight:600}.project-meta-row{color:var(--ca-text-muted);justify-content:space-between;margin-bottom:4px;font-size:11px;display:flex}.project-status{text-transform:uppercase;letter-spacing:.3px;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600}.project-status.s-draft{background:var(--ca-bg-grey-150);color:var(--ca-text-secondary)}.project-status.s-submitted,.project-status.s-rendering{color:#a05500;background:#fff4e0}.project-status.s-ordered,.project-status.s-printed,.project-status.s-shipped{color:#2d6a34;background:#e5f5e8}.project-status.s-failed{background:var(--ca-bg-danger-tint);color:var(--ca-text-danger)}.project-date{color:var(--ca-text-disabled);margin:0;font-size:11px}.project-actions{opacity:0;gap:6px;transition:opacity .15s;display:flex;position:absolute;top:8px;right:8px}.project-card:hover .project-actions{opacity:1}@media (hover:none){.project-actions{opacity:1}}.project-delete-btn{color:#c44;cursor:pointer;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.project-delete-btn:hover{color:#fff;background:#c44}.project-dup-btn{color:#7a4a36;cursor:pointer;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:17px;display:flex}.project-dup-btn:hover{color:#fff;background:#7a4a36}.project-dup-btn:disabled{opacity:.6;cursor:default}.confirm-backdrop{-webkit-backdrop-filter:blur(6px)saturate(1.1);backdrop-filter:blur(6px)saturate(1.1);z-index:280;background:#2a252173;justify-content:center;align-items:center;padding:16px;animation:.18s confirmBackdropIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.confirm-backdrop.is-closing{animation:.18s forwards confirmBackdropOut}.confirm-dialog{background:var(--ca-bg-surface);box-shadow:var(--ca-shadow-xl);width:100%;max-width:420px;animation:confirmDialogIn .26s var(--ca-ease-spring);border-radius:20px;padding:24px}.confirm-dialog.is-closing{animation:.18s forwards confirmDialogOut}.confirm-title{font-family:var(--ca-font-serif);letter-spacing:-.01em;color:var(--ca-ink-warm);margin:0 0 8px;font-size:21px;font-weight:600;line-height:1.25}.confirm-message{color:var(--ca-text-secondary);white-space:pre-line;margin:0 0 20px;font-size:14px;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:8px;display:flex}.confirm-btn{border-radius:var(--ca-radius-md);cursor:pointer;transition:background var(--ca-tr-fast), border-color var(--ca-tr-fast), transform var(--ca-tr-fast);border:1.5px solid #0000;padding:9px 18px;font-size:14px;font-weight:600}.confirm-btn-secondary{color:var(--ca-text-primary);border-color:var(--ca-border-default);background:0 0}.confirm-btn-secondary:hover{background:var(--ca-bg-subtle);border-color:var(--ca-border-strong)}.confirm-btn-primary{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue)}.confirm-btn-primary:hover{background:var(--ca-blue-dark);border-color:var(--ca-blue-dark);transform:translateY(-1px)}.confirm-btn-danger{background:var(--ca-danger);color:#fff;border-color:var(--ca-danger)}.confirm-btn-danger:hover{background:#8e1414;border-color:#8e1414;transform:translateY(-1px)}.confirm-dialog-choice{max-width:460px}.confirm-choice-list{flex-direction:column;gap:10px;margin:0 0 16px;display:flex}.confirm-choice-btn{border-radius:var(--ca-radius-md);border:1.5px solid var(--ca-border-default);background:var(--ca-bg-surface);text-align:left;cursor:pointer;transition:border-color var(--ca-tr-fast), background var(--ca-tr-fast), transform var(--ca-tr-fast);flex-direction:column;align-items:flex-start;gap:4px;min-height:56px;padding:14px 16px;display:flex}.confirm-choice-btn:hover{border-color:var(--ca-blue);background:var(--ca-bg-subtle)}.confirm-choice-btn:active{transform:scale(.99)}.confirm-choice-primary{border-color:var(--ca-blue)}.confirm-choice-primary:hover{background:rgba(var(--ca-blue-rgb,30, 90, 175), .06)}.confirm-choice-label{color:var(--ca-text-primary);font-size:14.5px;font-weight:600;line-height:1.3}.confirm-choice-desc{color:var(--ca-text-secondary);font-size:12.5px;line-height:1.4}.confirm-actions-single{justify-content:flex-end}.confirm-dialog-prompt{max-width:440px}.confirm-prompt-field{flex-direction:column;gap:7px;margin:0 0 18px;display:flex}.confirm-prompt-field span{color:var(--ca-text-secondary);font-size:12px;font-weight:650}.confirm-prompt-field input,.confirm-prompt-field textarea{box-sizing:border-box;border:1.5px solid var(--ca-border-default);border-radius:var(--ca-radius-md);width:100%;font:inherit;color:var(--ca-text-primary);background:var(--ca-bg-surface);outline:none;padding:10px 12px;font-size:16px}.confirm-prompt-field textarea{resize:vertical;min-height:96px}.confirm-prompt-field input:focus,.confirm-prompt-field textarea:focus{border-color:var(--ca-blue);box-shadow:0 0 0 3px rgba(var(--ca-blue-rgb,30, 90, 175), .14)}.confirm-btn:disabled{opacity:.48;cursor:not-allowed;transform:none}@media (max-width:480px){.confirm-choice-btn{min-height:60px;padding:12px 14px}.confirm-choice-label{font-size:14px}.confirm-actions{flex-direction:column-reverse;gap:8px}.confirm-actions .confirm-btn{width:100%;min-height:48px}}@keyframes confirmBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes confirmBackdropOut{0%{opacity:1}to{opacity:0}}@keyframes confirmDialogIn{0%{opacity:0;transform:scale(.94)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes confirmDialogOut{0%{opacity:1;transform:scale(1)translateY(0)}to{opacity:0;transform:scale(.96)translateY(-4px)}}.editor-loading{min-height:100vh;min-height:100dvh;color:var(--ca-text-secondary);background:#faf9f6;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid #e0e0e0;border-top-color:var(--ca-blue);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.bottombar{padding-bottom:env(safe-area-inset-bottom,0);background:#e6ebef;border-top:1px solid #0f172a1a;flex-direction:column;flex-shrink:0;display:flex}.bottom-strip{scroll-behavior:smooth;contain:layout style;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;background:#dde5ea;border-bottom:1px solid #0f172a14;gap:12px;padding:9px 20px 6px;display:flex;overflow-x:auto}.strip-item{cursor:pointer;-webkit-user-select:none;user-select:none;contain:layout style;border:2px solid #0000;border-radius:5px;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:4px;transition:border-color .1s,background .1s;display:flex;position:relative}.strip-item:hover{background:#ffffff75}.strip-item:focus-visible{outline:2px solid var(--ca-blue);outline-offset:2px}.strip-item.active{border-color:var(--ca-blue);background:#ffffffbd}.strip-item.dragging{opacity:.4}.strip-item.drop-target{border-color:var(--ca-blue);background:#003a8514}.strip-item.drop-target:before{content:"";background:var(--ca-blue);border-radius:2px;width:3px;position:absolute;top:2px;bottom:2px;left:-3px}.strip-actions{opacity:0;pointer-events:none;gap:3px;transition:opacity .1s;display:flex;position:absolute;top:3px;right:3px}.strip-item:hover .strip-actions{opacity:1;pointer-events:auto}@media (hover:none){.strip-actions{opacity:1;pointer-events:auto}}.strip-action{width:28px;height:28px;color:var(--ca-text-secondary);cursor:pointer;background:#fffffff2;border:1px solid #ddd;border-radius:6px;justify-content:center;align-items:center;padding:0;display:flex;box-shadow:0 2px 6px #0f172a24}.strip-action:hover:not(:disabled){background:var(--ca-text-primary);color:#fff;border-color:var(--ca-text-primary)}.strip-action.danger:hover:not(:disabled){background:#c44;border-color:#c44}.strip-action:disabled{opacity:.32;cursor:default;box-shadow:none}.strip-spread{gap:1px;height:50px;display:flex}.ms{height:50px;aspect-ratio:var(--page-aspect,1);background:var(--ca-bg-surface);border:1px solid #0f172a21;border-radius:3px;position:relative;overflow:hidden;box-shadow:0 2px 6px #0f172a1a}.ms.endpaper{background:#edebe8}.ms.cover-ms{background:#f0ece4}.ms.cover-ms img{object-fit:cover;width:100%;height:100%;display:block}.ms.interior-ms{position:relative}.ms-slot{background:var(--ca-bg-grey-150);position:absolute;overflow:hidden}.ms-slot img{object-fit:cover;width:100%;height:100%;display:block}.strip-label{color:var(--ca-text-disabled);letter-spacing:.2px;font-size:9px;font-weight:500}.bottom-nav-row{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:65;background:#ffffffc7;justify-content:space-between;align-items:center;height:40px;padding:0 20px;display:flex;position:relative}.bnr-left,.bnr-center,.bnr-right{align-items:center;gap:8px;display:flex}.bnr-center{gap:20px}.bnr-sep{background:#0000001a;width:1px;height:18px;margin:0 4px;display:inline-block}.bnr-mode-btn{border-radius:var(--ca-radius-md);min-height:32px;color:var(--ca-text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.bnr-mode-btn:hover{color:var(--ca-text-primary);background:#0000000a}.bnr-mode-btn.active{background:var(--ca-bg-grey-50);color:var(--ca-text-primary);border-color:#e0e0e0}.bnr-mode-btn svg{flex-shrink:0}.bnr-nav-btn{border-radius:var(--ca-radius-md);min-height:32px;color:var(--ca-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:6px 12px;font-size:12.5px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.bnr-nav-btn:hover:not(:disabled){color:var(--ca-text-primary);background:#0000000a}.bnr-nav-btn:disabled{opacity:.3;cursor:not-allowed}.bnr-nav-btn svg{flex-shrink:0}.bnr-canvas-actions{border-radius:var(--ca-radius-md);align-items:center;gap:2px;padding:2px 4px;display:inline-flex}.bnr-canvas-btn{border-radius:var(--ca-radius-sm);min-height:32px;font-size:var(--ca-text-sm);color:var(--ca-text-secondary);cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast), transform var(--ca-tr-fast);background:0 0;border:0;align-items:center;gap:5px;padding:6px 10px;font-weight:500;display:inline-flex}.bnr-canvas-btn:hover{background:var(--ca-bg-hover);color:var(--ca-text-primary);transform:translateY(-1px)}.bnr-canvas-btn-danger{color:var(--ca-danger)}.bnr-canvas-btn-danger:hover{color:var(--ca-danger);background:#b71c1c14}.bnr-canvas-btn:active{transform:translateY(0)}.bnr-canvas-btn svg{flex-shrink:0}.bnr-zoom-btn{border-radius:var(--ca-radius-sm);width:32px;height:32px;color:var(--ca-text-secondary);cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast);background:0 0;border:0;justify-content:center;align-items:center;display:inline-flex}.bnr-zoom-btn:hover{background:var(--ca-bg-hover);color:var(--ca-text-primary)}.bnr-zoom-label{border-radius:var(--ca-radius-sm);min-width:40px;min-height:32px;font-size:var(--ca-text-xs);color:var(--ca-text-secondary);font-variant-numeric:tabular-nums;text-align:center;cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast);background:0 0;border:0;padding:4px 6px;font-weight:600}.bnr-zoom-label:hover{background:var(--ca-bg-hover);color:var(--ca-text-primary)}@media (max-width:768px){.bnr-canvas-btn span{display:none}.bnr-canvas-btn{min-width:36px;min-height:36px;padding:6px 8px}.bnr-canvas-actions .bnr-zoom-btn,.bnr-canvas-actions .bnr-zoom-label{display:none!important}}.bnr-toggle-btn{border-radius:var(--ca-radius-md);min-height:32px;color:var(--ca-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;padding:6px 10px;font-size:12px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.bnr-toggle-btn:hover{color:var(--ca-text-primary);background:#0000000d}@media (max-width:768px){.bnr-mode-btn span,.bnr-toggle-btn span,.bnr-nav-btn span{display:none}.bnr-mode-btn,.bnr-toggle-btn,.bnr-nav-btn{justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:6px 8px;display:inline-flex}}.bnr-label{color:var(--ca-text-secondary);text-align:center;min-width:90px;font-size:13px;font-weight:600}.bnr-label-btn{border-radius:var(--ca-radius-sm);cursor:pointer;background:0 0;border:1px dashed #0000;align-items:center;gap:6px;min-height:32px;padding:3px 8px;transition:border-color .15s,background .15s;display:inline-flex}.bnr-label-btn:hover{background:var(--ca-bg-subtle);color:var(--ca-text-primary);border-color:#c8c8c8}.bnr-label-text{color:inherit;font-weight:600}.bnr-label-counter{color:#6b7280;border-radius:var(--ca-radius-pill);letter-spacing:.02em;background:#f3f4f6;padding:2px 7px;font-size:10px;font-weight:600}.bnr-label-btn:hover .bnr-label-counter{color:var(--ca-blue);background:#e8eef9}.goto-backdrop{z-index:250;background:#14121c8c;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.goto-modal{background:var(--ca-bg-surface);border-radius:var(--ca-radius-lg);width:min(360px,92vw);padding:22px 22px 18px;animation:.18s scaleIn;box-shadow:0 20px 60px #00000040}.goto-modal h3{color:var(--ca-text-primary);margin:0 0 6px;font-size:16px;font-weight:600}.goto-help{color:var(--ca-text-secondary);margin:0 0 14px;font-size:12.5px;line-height:1.45}.goto-help strong{color:var(--ca-text-primary)}.goto-row{align-items:stretch;gap:8px;margin-bottom:12px;display:flex}.goto-input{background:var(--ca-bg-surface);color:var(--ca-text-primary);-moz-appearance:textfield;border:1px solid #d8d8d8;border-radius:7px;outline:none;flex:1;padding:9px 12px;font-size:16px;font-weight:500}.goto-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.goto-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.goto-input:focus{border-color:var(--ca-blue);box-shadow:0 0 0 3px #003a851f}.goto-quick{flex-wrap:wrap;gap:6px;display:flex}.goto-quick-btn{min-width:80px;color:var(--ca-text-secondary);background:var(--ca-bg-grey-50);border-radius:var(--ca-radius-sm);cursor:pointer;border:1px solid #e0e0e0;flex:1;padding:7px 10px;font-size:12px;font-weight:500;transition:background .15s,color .15s}.goto-quick-btn:hover{color:var(--ca-text-primary);background:#e8e8e8}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.bnr-pages-cta{border-radius:var(--ca-radius-md);min-height:36px;color:var(--ca-blue);cursor:pointer;background:#f4f6fa;border:1px solid #dce3ee;justify-content:center;align-items:center;gap:6px;padding:7px 12px;font-size:12.5px;font-weight:600;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;display:inline-flex}.bnr-pages-cta:hover:not(:disabled){background:#e8effa;border-color:#b8c7e0;box-shadow:0 1px 3px #003a851a}.bnr-pages-cta:disabled{opacity:.4;cursor:not-allowed;background:var(--ca-bg-grey-50);color:var(--ca-text-muted);border-color:#e0e0e0}.strip-add-card{border-radius:var(--ca-radius-sm);cursor:pointer;background:0 0;border:2px dashed #0000;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:4px;transition:border-color .15s,background .15s;display:flex}.strip-add-card:hover:not(:disabled){background:#f4f6fa;border-color:#b8c7e0}.strip-add-card:disabled{opacity:.35;cursor:not-allowed}.strip-add-card .sac-spread{gap:1px;height:50px;display:flex}.strip-add-card .sac-side{width:calc(50px / var(--page-aspect,1));color:#6b7e9a;background:#f8fafc;border:1px dashed #c8d2e0;border-radius:3px;justify-content:center;align-items:center;display:flex}.strip-add-card:hover .sac-side{color:var(--ca-blue);background:#eef3fb;border-color:#a5b5ce}.strip-add-card .sac-label{color:#6b7e9a;letter-spacing:.2px;font-size:10.5px;font-weight:600}.strip-add-card:hover .sac-label{color:var(--ca-blue)}.bnr-pages-wrap{position:relative}.bnr-add-circle{background:var(--ca-blue);color:#fff;border:0;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,box-shadow .15s,transform .1s;display:inline-flex;box-shadow:0 2px 6px #003a8552}@media (hover:hover) and (pointer:fine){.bnr-add-circle:hover:not(:disabled){background:var(--ca-blue-dark);transform:translateY(-1px);box-shadow:0 4px 12px #003a8573}}.bnr-add-circle:active:not(:disabled){transform:translateY(0)}.bnr-add-circle:disabled{cursor:not-allowed;box-shadow:none;background:#c5cdd9}.bnr-pages-menu{background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-lg);width:300px;box-shadow:var(--ca-shadow-lg);padding:var(--ca-space-4);z-index:200;animation:bnrPagesIn var(--ca-dur-med) var(--ca-ease-spring);position:absolute;bottom:calc(100% + 8px);left:0;right:auto}@keyframes bnrPagesIn{0%{opacity:0;transform:translateY(6px)scale(.97)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.bnr-pages-menu{animation:none}}.apm-question{font-size:var(--ca-text-md);font-weight:var(--ca-font-weight-semibold);color:var(--ca-text-primary);line-height:var(--ca-line-snug);text-transform:none;letter-spacing:var(--ca-tracking-normal);margin:0}.apm-sub{margin:2px 0 var(--ca-space-3);font-size:var(--ca-text-sm);color:var(--ca-text-muted)}.apm-maxed{margin:0 0 var(--ca-space-2);font-size:var(--ca-text-sm);color:var(--ca-text-secondary);line-height:var(--ca-line-normal)}.apm-options{flex-direction:column;gap:10px;display:flex}.apm-option{justify-content:space-between;align-items:baseline;gap:var(--ca-space-2);background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-md);cursor:pointer;text-align:left;width:100%;transition:border-color var(--ca-tr-fast), background var(--ca-tr-fast), transform var(--ca-dur-fast) var(--ca-ease-spring);padding:12px 14px;font-family:inherit;display:flex;position:relative}.apm-option:hover:not(:disabled){border-color:var(--ca-border-strong);background:var(--ca-bg-hover)}.apm-option:active:not(:disabled){transform:scale(.98)}.apm-option:disabled{opacity:.45;cursor:not-allowed}.apm-option strong{font-size:var(--ca-text-md);font-weight:var(--ca-font-weight-bold);color:var(--ca-text-primary);white-space:nowrap}.apm-option-price{font-size:var(--ca-text-sm);color:var(--ca-text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.apm-option.is-featured{border-color:var(--ca-blue);background:var(--ca-bg-info-tint)}.apm-badge{background:var(--ca-butter);color:var(--ca-butter-ink);font-size:10px;font-weight:var(--ca-font-weight-bold);letter-spacing:var(--ca-tracking-wide);border-radius:var(--ca-radius-pill);white-space:nowrap;padding:2px 8px;position:absolute;top:-9px;right:10px}.apm-other{margin-top:var(--ca-space-3);padding-top:var(--ca-space-3);border-top:1px solid var(--ca-border-subtle)}.apm-other-label{margin-bottom:var(--ca-space-2);font-size:var(--ca-text-xs);font-weight:var(--ca-font-weight-semibold);color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:var(--ca-tracking-wider);display:block}.apm-stepper{align-items:center;gap:var(--ca-space-2);display:flex}.apm-step-btn{background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-sm);width:32px;height:32px;color:var(--ca-text-primary);cursor:pointer;transition:background var(--ca-tr-fast), border-color var(--ca-tr-fast);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.apm-step-btn:hover:not(:disabled){background:var(--ca-bg-hover);border-color:var(--ca-border-strong)}.apm-step-btn:disabled{opacity:.35;cursor:not-allowed}.apm-step-value{text-align:center;min-width:40px;font-size:var(--ca-text-md);font-weight:var(--ca-font-weight-bold);color:var(--ca-text-primary);font-variant-numeric:tabular-nums}.apm-step-add{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-md);font-size:var(--ca-text-sm);font-weight:var(--ca-font-weight-semibold);cursor:pointer;transition:background var(--ca-tr-fast), transform var(--ca-dur-fast) var(--ca-ease-spring);border:0;flex:1;padding:8px 12px;font-family:inherit}.apm-step-add:hover{background:var(--ca-blue-dark)}.apm-step-add:active{transform:scale(.97)}.apm-step-price{margin:var(--ca-space-2) 0 0;font-size:var(--ca-text-sm);color:var(--ca-text-secondary);font-variant-numeric:tabular-nums}.apm-incentive{margin:var(--ca-space-3) 0 0;font-size:var(--ca-text-xs);color:var(--ca-text-muted);line-height:var(--ca-line-normal)}.apm-remove{margin-top:var(--ca-space-2);font-size:var(--ca-text-xs);color:var(--ca-text-danger);cursor:pointer;text-align:left;background:0 0;border:0;padding:4px 0 0;font-family:inherit;display:block}.apm-remove:hover:not(:disabled){color:var(--ca-text-danger-hover);text-decoration:underline}.apm-remove:disabled{opacity:.4;cursor:not-allowed}.apg-backdrop{z-index:250;background:#0009;justify-content:center;align-items:center;padding:16px;animation:.18s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.apg-modal{background:var(--ca-bg-subtle);border-radius:14px;flex-direction:column;width:min(1100px,100%);height:min(86vh,760px);animation:.22s cubic-bezier(.2,.9,.3,1.1) apgIn;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000059}@keyframes apgIn{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:none}}.apg-head{background:var(--ca-bg-surface);border-bottom:1px solid #eee;flex-shrink:0;align-items:center;gap:12px;padding:14px 18px;display:flex}.apg-head h3{color:var(--ca-text-primary);margin:0;font-size:16px;font-weight:700}.apg-count{color:var(--ca-text-muted);font-size:12px}.apg-hint{color:var(--ca-text-muted);border-radius:var(--ca-radius-pill);background:var(--ca-bg-grey-50);margin-left:12px;padding:4px 10px;font-size:11.5px}.apg-close{width:36px;height:36px;color:var(--ca-text-secondary);background:0 0;border-radius:50%;justify-content:center;align-items:center;margin-left:auto;display:inline-flex}.apg-close:hover{background:var(--ca-bg-grey-100);color:var(--ca-text-primary)}.apg-body{-webkit-overflow-scrolling:touch;flex:1;padding:18px 22px 22px;overflow-y:auto}.apg-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px;display:grid}.apg-card{background:var(--ca-bg-surface);cursor:pointer;border:2px solid #eaeaea;border-radius:10px;flex-direction:column;align-items:stretch;gap:8px;padding:10px;transition:border-color .15s,box-shadow .15s,transform .1s,opacity .15s;display:flex;position:relative}@media (hover:hover) and (pointer:fine){.apg-card:hover{border-color:#b8c7e0;transform:translateY(-2px);box-shadow:0 4px 12px #003a851f}}.apg-card.active{border-color:var(--ca-blue);box-shadow:0 0 0 3px #003a852e}.apg-card:focus-visible{outline:2px solid var(--ca-blue);outline-offset:2px}.apg-card.drop-target{border-color:var(--ca-green);border-style:dashed;box-shadow:0 0 0 3px #46643f2e}.apg-card.dragging{opacity:.4}.apg-card[draggable=true]{cursor:grab}.apg-card[draggable=true]:active{cursor:grabbing}.apg-spread{width:100%;aspect-ratio:calc(2 * var(--page-aspect,1));background:var(--ca-bg-grey-100);border-radius:var(--ca-radius-xs);pointer-events:none;display:flex;overflow:hidden}.apg-spread .ms{flex:1;height:100%}.apg-label-row{justify-content:space-between;align-items:center;gap:6px;display:flex}.apg-label{color:var(--ca-text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12.5px;font-weight:600;overflow:hidden}.apg-num{color:var(--ca-text-muted);border-radius:var(--ca-radius-pill);background:var(--ca-bg-grey-100);flex-shrink:0;padding:1px 6px;font-size:10.5px;font-weight:700}.apg-card.active .apg-label{color:var(--ca-blue)}.apg-card.active .apg-num{color:var(--ca-blue);background:#eaf1fb}.apg-actions{flex-shrink:0;gap:2px;display:inline-flex}@media (hover:hover) and (pointer:fine){.apg-actions{opacity:0;transition:opacity .12s}.apg-card:hover .apg-actions,.apg-card:focus-within .apg-actions{opacity:1}}@media (pointer:coarse){.apg-act.move{display:none}}.apg-act{border-radius:var(--ca-radius-xs);width:26px;height:26px;color:var(--ca-text-secondary);background:0 0;justify-content:center;align-items:center;display:inline-flex}.apg-act:hover:not(:disabled){background:var(--ca-bg-grey-100);color:var(--ca-text-primary)}.apg-act.danger{color:var(--ca-text-danger)}.apg-act.danger:hover:not(:disabled){background:var(--ca-bg-danger-tint)}.apg-card.dragging{opacity:.45;transform:scale(.97)}.apg-act:disabled{opacity:.3;cursor:default}@media (max-width:768px){.apg-modal{border-radius:var(--ca-radius-lg);height:92vh;max-height:none}.apg-body{padding:14px}.apg-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.apg-card{padding:8px}.apg-label{font-size:11.5px}.apg-num{padding:1px 5px;font-size:10px}.apg-hint{display:none}.apg-card .apg-actions{display:flex}.apg-act{width:30px;height:30px}}@media (max-width:420px){.apg-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.apg-actions{gap:2px;padding:2px}.apg-act{width:28px;height:28px}}.preview-overlay{z-index:200;background:radial-gradient(#2a2438 0%,#161020 100%);flex-direction:column;animation:.2s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.preview-topbar{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000004d;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;gap:20px;padding:14px 22px;display:flex}.preview-topbar-left,.preview-topbar-right{flex:1;align-items:center;gap:10px;display:flex}.preview-topbar-right{justify-content:flex-end}.preview-topbar-center{flex-direction:column;align-items:center;gap:2px;display:flex}.preview-topbar-center strong{letter-spacing:.01em;font-size:14px;font-weight:600}.preview-counter{color:#ffffff8c;letter-spacing:.05em;font-size:11px}.preview-btn{color:#fff;cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;display:flex}.preview-btn:hover{background:#ffffff2e;border-color:#ffffff4d}.preview-btn.primary{background:var(--ca-bg-surface);color:#2a2438;border-color:#0000}.preview-btn.primary:hover{background:var(--ca-bg-grey-150)}.preview-mode-toggle{background:#ffffff14;border:1px solid #ffffff1a;border-radius:20px;padding:3px;display:flex}.preview-mode-toggle button{color:#ffffffb3;cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);background:0 0;border:none;border-radius:18px;padding:6px 14px;font-size:12px;font-weight:500}.preview-mode-toggle button.active{background:var(--ca-bg-surface);color:#2a2438}.preview-mode-toggle button:hover:not(.active){color:#fff}.problems-btn{cursor:pointer;color:#ffffffd9;background:#ffffff0f;border:1px solid #ffffff2e;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.problems-btn:hover{color:#fff;background:#ffffff24}.problems-btn.has-problems{color:#ffe08a;background:#e0a10033;border-color:#e0a10099}.problems-btn.has-problems:hover{background:#e0a1004d}.problems-btn.all-good{color:#b8e6c4;background:#3fa85a1f;border-color:#3fa85a66}.problems-panel{z-index:220;color:#efeaf8;background:#1f1a2a;border:1px solid #ffffff1f;border-radius:14px;flex-direction:column;width:min(340px,92vw);animation:.18s slideInRight;display:flex;position:fixed;top:72px;bottom:16px;right:16px;box-shadow:0 24px 60px #00000080}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.problems-panel-head{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.problems-panel-head strong{font-size:14px}.problems-close{color:#ffffffb3;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:22px;line-height:1;display:inline-flex}.problems-close:hover{color:#fff}.problems-summary{flex-wrap:wrap;gap:6px;padding:12px 16px 8px;display:flex}.problems-chip{border-radius:var(--ca-radius-lg);padding:4px 10px;font-size:11px;font-weight:600}.problems-chip.empty{color:#d0d0da;background:#78788c40}.problems-chip.lowres{color:#ffe08a;background:#e0a10033}.problems-list{flex-direction:column;flex:1;gap:8px;padding:4px 12px 12px;display:flex;overflow-y:auto}.problems-item{text-align:left;width:100%;color:inherit;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;padding:10px 12px;transition:background .15s,border-color .15s}.problems-item:hover{background:#ffffff1a;border-color:#ffffff2e}.problems-item-head{justify-content:space-between;align-items:center;margin-bottom:4px;font-size:13px;display:flex}.problems-item-count{color:#ffffff80;font-size:11px}.problems-item ul{margin:0;padding:0;list-style:none}.problems-item li{color:#ffffffb3;flex-wrap:wrap;align-items:center;gap:6px;margin-top:3px;font-size:11px;display:flex}.problems-side{color:#ffffff8c}.problems-tag{border-radius:var(--ca-radius-md);padding:2px 8px;font-size:10px;font-weight:600}.problems-tag.empty{color:#d0d0da;background:#78788c40}.problems-tag.lowres{color:#ffe08a;background:#e0a10033}.problems-empty{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:30px 20px;display:flex}.problems-empty p{color:#ffffffb3;margin:0;font-size:13px}.problems-foot{color:#ffffff73;border-top:1px solid #ffffff14;padding:10px 16px;font-size:11px}@media (max-width:768px){.problems-panel{width:auto;top:60px;bottom:8px;left:8px;right:8px}}.preview-book-stage{perspective:1800px;perspective-origin:50% 42%;flex:1;justify-content:center;align-items:center;padding:2vh 80px;display:flex;position:relative}.preview-book-scene{transform-style:preserve-3d;position:relative}.preview-book-scene:before{content:"";filter:blur(7px);z-index:-1;pointer-events:none;opacity:1;height:30px;transition:opacity var(--flip-dur,1.05s) var(--ca-ease-flip);background:radial-gradient(46% 42%,#140c1e66,#0000 70%),radial-gradient(#140c1e52,#0000 74%);position:absolute;bottom:-24px;left:4%;right:4%}.preview-book-scene:after{content:"";filter:blur(6px);z-index:-1;pointer-events:none;opacity:0;height:28px;transition:opacity var(--flip-dur,1.05s) var(--ca-ease-flip);background:radial-gradient(52% 46%,#0000006b,#0000 70%),radial-gradient(#00000057,#0000 76%);position:absolute;bottom:-24px;left:54%;right:-6%}.preview-book-scene.closed:before{opacity:0}.preview-book-scene.closed:after{opacity:1}.preview-book-base{background:0 0;width:100%;height:100%;display:flex;position:relative}.preview-book-base:before{content:"";pointer-events:none;z-index:5;opacity:1;transition:opacity var(--ca-dur-med) var(--ca-ease-out);background:linear-gradient(160deg,#fffaf01a,#0000 40%);position:absolute;top:0;bottom:0;left:0;right:0}.preview-book-scene.closed .preview-book-base:before{opacity:0}.preview-book-page{background:#fbfaf7;flex:1;position:relative;overflow:hidden;transform:translateZ(0);container-type:inline-size}.preview-book-page-left{border-radius:2px 0 0 2px}.preview-book-page-right{border-radius:0 6px 6px 0}.preview-book-spine{z-index:2;background:linear-gradient(90deg,#00000014,#00000047,#00000014);width:2px;height:100%}.preview-book-fold{pointer-events:none;z-index:3;background:radial-gradient(#0000002e 0%,#0000000a 40%,#0000 72%);width:14%;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.preview-book-base:after{content:"";pointer-events:none;z-index:4;background:linear-gradient(90deg,#0000000a,#00000029),linear-gradient(#f7f2e8,#e9e2d1 45%,#f1ebde 70%,#e6decd);border-radius:0 3px 3px 0;width:7px;position:absolute;top:1.5%;bottom:1.5%;right:-7px;box-shadow:1px 0 3px #0000002e}.preview-book-scene.closed{transform-origin:50%;transition:transform .52s var(--ca-ease-settle);transform:translate(-25%)rotateX(4deg)rotateY(-14deg)}.preview-book-scene.opening,.preview-book-scene.closing{transition:transform var(--flip-dur,1.05s) var(--ca-ease-flip)}.preview-book-spine,.preview-book-fold{transition:opacity .18s var(--ca-ease-out)}.preview-book-scene.closed .preview-book-page-left,.preview-book-scene.opening .preview-book-page-left,.preview-book-scene.closing .preview-book-page-left,.preview-book-scene.closed .preview-book-spine,.preview-book-scene.opening .preview-book-spine,.preview-book-scene.closing .preview-book-spine,.preview-book-scene.closed .preview-book-fold,.preview-book-scene.opening .preview-book-fold,.preview-book-scene.closing .preview-book-fold{opacity:0}.preview-book-page-right:before{content:"";z-index:5;pointer-events:none;opacity:0;width:12px;transition:opacity var(--ca-dur-slow) var(--ca-ease-out);background:linear-gradient(90deg,#00000057,#0000001a 60%,#0000);position:absolute;top:0;bottom:0;left:0}.preview-book-page-right:after{content:"";pointer-events:none;z-index:6;opacity:0;transition:opacity var(--ca-dur-slow) var(--ca-ease-out);background:linear-gradient(118deg,#ffffff29 0%,#ffffff0d 28%,#0000 46%,#0000000d 100%);position:absolute;top:0;bottom:0;left:0;right:0}.preview-book-scene.closed .preview-book-page-right:before,.preview-book-scene.closed .preview-book-page-right:after{opacity:1}@media (hover:hover) and (pointer:fine){.preview-book-scene.closed:hover{transform:translate(-25%)rotateX(2deg)rotateY(-8deg)}}.preview-leaf{width:50%;height:100%;transform-style:preserve-3d;z-index:10;pointer-events:none;will-change:transform;position:absolute;top:0}.preview-leaf-face{-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#fbfaf7;position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;box-shadow:0 0 1px #0006}.preview-leaf-front{transform:rotateY(0)}.preview-leaf-back{transform:rotateY(180deg)}.preview-leaf-shade{pointer-events:none;opacity:0;background:linear-gradient(270deg,#00000038 0%,#0000 40%);position:absolute;top:0;bottom:0;left:0;right:0}.preview-leaf-shade-back{background:linear-gradient(90deg,#00000038 0%,#0000 40%)}.preview-leaf-next{transform-origin:0;animation:pageFlipNext var(--flip-dur,1.05s) var(--ca-ease-flip) forwards;right:0}.preview-leaf-next .preview-leaf-front .preview-leaf-shade{animation:shadeFadeIn var(--flip-dur,1.05s) ease-in-out forwards}.preview-leaf-next .preview-leaf-back .preview-leaf-shade{animation:shadeFadeOut var(--flip-dur,1.05s) ease-in-out forwards}.preview-leaf-prev{transform-origin:100%;animation:pageFlipPrev var(--flip-dur,1.05s) var(--ca-ease-flip) forwards;left:0}.preview-leaf-prev .preview-leaf-front .preview-leaf-shade{animation:shadeFadeIn var(--flip-dur,1.05s) ease-in-out forwards}.preview-leaf-prev .preview-leaf-back .preview-leaf-shade{animation:shadeFadeOut var(--flip-dur,1.05s) ease-in-out forwards}.preview-book-scene.opening .preview-leaf-front:after,.preview-book-scene.closing .preview-leaf-back:after{content:"";pointer-events:none;background:linear-gradient(118deg,#ffffff29 0%,#ffffff0d 28%,#0000 46%,#0000000d 100%);position:absolute;top:0;bottom:0;left:0;right:0}.preview-book-scene.opening .preview-leaf-front:after{animation:leafGlossOut var(--flip-dur,1.05s) var(--ca-ease-flip) forwards}.preview-book-scene.closing .preview-leaf-back:after{animation:leafGlossIn var(--flip-dur,1.05s) var(--ca-ease-flip) forwards}@keyframes leafGlossOut{0%{opacity:1}to{opacity:0}}@keyframes leafGlossIn{0%{opacity:0}to{opacity:1}}@keyframes pageFlipNext{0%{transform:rotateY(0)}to{transform:rotateY(-180deg)}}@keyframes pageFlipPrev{0%{transform:rotateY(0)}to{transform:rotateY(180deg)}}@keyframes shadeFadeIn{0%{opacity:0}50%{opacity:.8}to{opacity:0}}@keyframes shadeFadeOut{0%{opacity:.8}50%{opacity:.45}to{opacity:0}}.preview-nav{color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;width:52px;height:52px;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);z-index:20;background:#1a1426d1;border:1.5px solid #ffffffd9;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 4px 14px #00000073,0 0 0 1px #00000040}@media (hover:hover) and (pointer:fine){.preview-nav:hover:not(:disabled){background:#1a1426f2;transform:translateY(-50%)scale(1.06);box-shadow:0 6px 18px #0000008c,0 0 0 1px #0000004d}}.preview-nav:disabled{opacity:.3;cursor:not-allowed}.preview-nav-prev{left:16px}.preview-nav-next{right:16px}.preview-endpaper{background:#f8f4ec;width:100%;height:100%}.preview-hint{color:#ffffff73;letter-spacing:.04em;pointer-events:none;align-items:center;gap:6px;font-size:11px;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.preview-hint kbd{border-radius:var(--ca-radius-xs);color:#fffc;background:#ffffff1f;border:1px solid #fff3;padding:2px 6px;font-family:inherit;font-size:10px}.preview-grid{overscroll-behavior:contain;flex:1;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));align-content:start;gap:20px;padding:32px;display:grid;overflow-y:auto}.preview-grid-item{cursor:pointer;transition:background var(--ca-tr-default), color var(--ca-tr-default), border-color var(--ca-tr-default), box-shadow var(--ca-tr-default), transform var(--ca-tr-default), opacity var(--ca-tr-default);color:#ffffffd9;background:#ffffff0a;border:2px solid #0000;border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:10px;display:flex}.preview-grid-item:hover{background:#ffffff1a;border-color:#fff3}.preview-grid-item.active{background:#ffffff1f;border-color:#fff}.preview-grid-pages{background:var(--ca-bg-surface);width:100%;display:flex;box-shadow:0 4px 12px #0006}.preview-grid-page{background:var(--ca-bg-surface);flex:1;position:relative;overflow:hidden}.preview-grid-label{letter-spacing:.02em;font-size:12px;font-weight:500}.bpp{background-position:50%;background-repeat:no-repeat;background-size:contain;width:100%;height:100%;position:relative}.bpp-slot{position:absolute;overflow:hidden}.bpp-slot img{object-fit:cover;width:100%;height:100%;display:block}.bpp-text{font-family:Georgia,serif;line-height:1.2;position:absolute;overflow:hidden}.bpp-sticker{pointer-events:none;position:absolute}.bpp-sticker img,.bpp-sticker svg{width:100%;height:100%;display:block}.bpp-logo{pointer-events:none;background-position:50%;background-repeat:no-repeat;background-size:contain;width:40%;height:5%;position:absolute;top:82%;left:30%}.ctx-backdrop{z-index:300;position:fixed;top:0;bottom:0;left:0;right:0}.ctx-menu{z-index:301;background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-md);overscroll-behavior:contain;min-width:160px;padding:4px;animation:.1s fadeIn;position:fixed;box-shadow:0 4px 16px #0000001f}.ctx-item{color:var(--ca-text-secondary);text-align:left;border-radius:5px;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:13px;display:flex}.ctx-item:hover{background:var(--ca-bg-grey-100)}.ctx-item:disabled{opacity:.3;cursor:not-allowed}.ctx-item.danger{color:#c44}.ctx-item.danger:hover{background:var(--ca-bg-danger-tint)}.ctx-icon{color:var(--ca-text-muted);align-items:center;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--ca-radius-pill);transition:background var(--ca-tr-fast);background:#0000002e}::-webkit-scrollbar-thumb:hover{background:#00000052}*{scrollbar-width:thin;scrollbar-color:#0000002e transparent}::selection{color:var(--ca-ink-warm);background:#fad2e2d9}:where(a,[role=button],summary,label){-webkit-tap-highlight-color:transparent}.mobile-toolbar-btn{display:none!important}.mobile-tabbar{z-index:91;height:calc(60px + env(safe-area-inset-bottom,0));padding-bottom:env(safe-area-inset-bottom,0);background:var(--ca-bg-surface);border-top:1px solid var(--ca-border-default);display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 14px #0000000f}.mobile-tabbar-scroll{overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;scrollbar-width:none;align-items:stretch;width:100%;height:100%;padding:0 4px;display:flex;overflow:auto hidden}.mobile-tabbar-scroll::-webkit-scrollbar{display:none}.mobile-tabbar .mtab{cursor:pointer;color:#8a8a8a;background:0 0;border:none;flex-direction:column;flex:none;justify-content:center;align-items:center;gap:2px;min-width:64px;min-height:58px;padding:6px 4px;display:flex;position:relative}.mobile-tabbar .mtab:active{background:#efebe0;transform:scale(.96)}.mobile-tabbar .mtab.active{color:var(--ca-blue)}.mobile-tabbar .mtab.active .mtab-icon{transform:translateY(-1px)}.mobile-tabbar .mtab.active:before{content:"";background:var(--ca-blue);border-radius:0 0 3px 3px;height:3px;position:absolute;top:0;left:20%;right:20%}.mobile-tabbar .mtab-icon{justify-content:center;align-items:center;width:24px;height:24px;display:flex}.mobile-tabbar .mtab-icon svg{width:22px;height:22px}.mobile-tabbar .mtab-label{letter-spacing:.1px;font-size:10.5px;font-weight:600;line-height:1}.mobile-tabbar .mtab.pulse .mtab-icon{animation:1.6s ease-in-out infinite tabPulse}@keyframes tabPulse{0%,to{color:var(--ca-blue);transform:scale(1)}50%{color:#0055c4;transform:scale(1.15)}}.mobile-panel-header{display:none}.mobile-backdrop{z-index:88;background:#00000059;display:none;position:fixed;top:0;bottom:0;left:0;right:0}@media (max-width:768px){.app{padding-bottom:calc(60px + env(safe-area-inset-bottom,0))}.mobile-tabbar{display:flex}.topbar{height:calc(48px + env(safe-area-inset-top,0));padding:env(safe-area-inset-top,0) calc(8px + env(safe-area-inset-right,0)) 0 calc(8px + env(safe-area-inset-left,0));gap:4px;overflow-x:hidden}.topbar-section:first-child{flex-shrink:1;min-width:0}.topbar-section.topbar-center-section,.topbar-section:last-child{flex-shrink:0}.topbar-section{gap:4px}.topbar-logo{display:none}.topbar-name,.topbar-name-input{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:calc(100vw - 220px);font-size:12px;overflow:hidden}.topbar-name-input{font-size:16px}.topbar-save-status{gap:0;margin-left:2px;font-size:0;position:relative}.topbar-save-status .topbar-save-text{display:none}.topbar-save-status svg{width:14px;height:14px}.topbar-save-status .topbar-save-spinner{width:13px;height:13px}.topbar-save-status.saved{color:#6aa84f}.topbar-save-status.dirty{color:#d97706}.topbar-save-status.saving{color:var(--ca-blue)}.topbar-save-status.dirty:after{content:"";background:#d97706;border-radius:50%;width:6px;height:6px;animation:1.2s infinite savePulse;position:absolute;top:-2px;right:-3px}@keyframes savePulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.topbar-order-btn{border-radius:22px;gap:5px;padding:9px 14px;font-size:13px;font-weight:700;box-shadow:0 2px 8px #46643f66}.topbar-order-btn svg{width:14px;height:14px}.topbar-order-price{white-space:nowrap;margin-left:4px;padding:2px 6px;font-size:11.5px;font-weight:700}.sidebar{left:0;right:0;bottom:calc(60px + env(safe-area-inset-bottom,0));width:100%;height:62vh;height:62dvh;max-height:520px;transition:transform var(--ca-dur-med) var(--ca-ease-settle), height var(--ca-dur-med) var(--ca-ease-out);z-index:89;background:var(--ca-bg-surface);border-top:1px solid #eaeaea;border-right:none;border-top-left-radius:18px;border-top-right-radius:18px;flex-direction:column;position:fixed;overflow:hidden;transform:translateY(calc(100% + 60px));box-shadow:0 -10px 30px #0000002e}.sidebar.open{transform:translateY(0)}.sidebar.tall{height:86vh;height:86dvh;max-height:calc(100dvh - 96px)}.sidebar-panel{background:var(--ca-bg-surface);flex-direction:column;flex:1;width:100%;min-height:0;display:flex;overflow:hidden}.panel-content{background:var(--ca-bg-surface);-webkit-overflow-scrolling:touch;flex:1;width:100%;height:auto;min-height:0}.mobile-panel-header{position:static}.images-options-toggle{background:var(--ca-bg-subtle);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-pill);color:var(--ca-text-secondary);cursor:pointer;align-self:flex-start;align-items:center;gap:6px;margin:0;padding:5px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.images-options-toggle:hover{background:var(--ca-bg-grey-150);color:var(--ca-text-primary)}.images-options-toggle .images-options-chevron{transition:transform .18s var(--ca-ease-spring);display:inline-flex}.images-options{opacity:0;pointer-events:none;max-height:0;transition:max-height .22s var(--ca-ease-out), opacity .18s ease, transform .18s var(--ca-ease-out);flex-direction:column;gap:6px;display:flex;overflow:hidden;transform:translateY(-4px)}.images-options.open{opacity:1;pointer-events:auto;max-height:320px;margin-top:2px;transform:translateY(0)}.photo-place-hint{display:none}.layout-grid-panel{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:1;align-content:start;min-height:0;padding-bottom:12px;overflow-y:auto}.layout-cell{min-width:0}.panel-btn.shuffle{background:var(--ca-bg-surface);z-index:10;border:none;border-top:1px solid #eae6de;border-radius:0;flex-shrink:0;margin:0;padding:12px;position:sticky;bottom:0;box-shadow:0 -6px 16px #00000014}.sidebar-tabs{display:none}.mobile-panel-header{background:var(--ca-bg-surface);z-index:2;border-bottom:1px solid #f0f0f0;flex-direction:column;padding:0 0 6px;display:flex;position:static}.mpp-drag-handle{background:#d8d8d8;border-radius:2px;width:42px;height:4px;margin:8px auto 10px}.mpp-title-row{justify-content:space-between;align-items:center;padding:0 14px 4px;display:flex}.mpp-title{color:var(--ca-text-primary);align-items:center;gap:8px;font-size:15px;font-weight:700;display:inline-flex}.mpp-title svg{width:18px;height:18px}.mpp-close{background:var(--ca-bg-grey-100);width:36px;height:36px;color:var(--ca-text-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.mpp-close:active{background:var(--ca-border-default)}.sidebar.open~.mobile-backdrop,.sidebar.open+.mobile-backdrop{display:block}.canvas-area{background-size:24px 24px;justify-content:safe center;align-items:safe center;padding:10px 12px}.canvas-wrapper{gap:4px;margin:auto}.canvas-label{display:none}.zoom-controls{display:none!important}.bleed-hint{display:none}.bottombar{z-index:45;flex-shrink:0;position:relative}.bottom-strip{display:none}.bottom-nav-row{gap:8px;height:48px;padding:0 10px}.bnr-left{flex-shrink:0;gap:6px}.bnr-left>.bnr-mode-btn,.bnr-left>.bnr-sep{display:none}.bnr-pages-cta{padding:7px 12px;font-size:12.5px}.bnr-right{flex-shrink:0;gap:6px;display:flex}.bnr-right>.bnr-toggle-btn,.bnr-right>span[aria-hidden=true]{display:none}.bnr-pages-menu{top:auto;left:10px;right:auto;bottom:calc(env(safe-area-inset-bottom,0px) + 60px + 48px + 10px);z-index:210;width:300px;min-width:0;max-width:calc(100vw - 20px);max-height:calc(100dvh - 220px);position:fixed;overflow-y:auto}.bnr-add-circle{width:32px;height:32px}.bnr-add-circle svg{width:17px;height:17px}.bnr-center{flex:1;justify-content:center;gap:8px;min-width:0}.bnr-center>.bnr-nav-btn,.bnr-label-btn{display:none}.login-card{max-width:100%;padding:24px 20px}.login-card h1{font-size:26px}.projects-screen{padding:16px}.projects-header{flex-direction:column;align-items:stretch;gap:12px}.projects-header h1{font-size:26px}.projects-header-actions{justify-content:space-between}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.project-meta{padding:10px}.project-meta h3{font-size:13px}.floating-toolbar{gap:6px;padding:5px 8px}.tt-btn{justify-content:center;align-items:center;min-width:38px;min-height:38px;padding:6px 8px;font-size:14px;display:inline-flex}.tt-btn svg{width:18px;height:18px}.tt-align-group{border-radius:var(--ca-radius-md)}.tt-align-group .tt-btn{min-width:38px;min-height:38px;padding:6px 8px;font-size:13px}.tt-size-group{border-radius:var(--ca-radius-md);padding:2px}.tt-size-input{width:40px;padding:5px 4px;font-size:16px}.tt-font{max-width:120px;min-height:38px;padding:6px 8px;font-size:13px}.tt-edit{min-height:38px;padding:6px 12px;font-size:13px}.tt-color{width:34px;height:34px}}@media (max-width:410px){.topbar-hide-narrow{display:none!important}.topbar-name,.topbar-name-input{max-width:110px}.topbar-order-btn{gap:3px;padding:7px 8px}.topbar-order-price{margin-left:2px;padding:1px 4px}.topbar-inspiration-btn{display:none!important}}@media (max-width:360px){.topbar-name{max-width:80px;font-size:11px}.topbar-name-input{max-width:140px;font-size:16px}.topbar-order-btn{padding:6px 7px;font-size:11px}.topbar-order-price{padding:1px 3px;font-size:10px}}@media (max-width:420px){.mobile-tabbar .mtab-label{font-size:10px}.bottom-nav-row{height:48px;padding:0 8px}.bnr-btn{padding:6px 10px;font-size:12px}.bnr-label{font-size:12px}}@media (max-width:768px){.ctx-menu{max-width:calc(100vw - 16px);max-height:calc(100dvh - 16px);overflow-y:auto}.shortcuts-backdrop{padding:10px}.shortcuts-modal{max-width:calc(100vw - 20px);max-height:92vh;max-height:92dvh}.inspiration-backdrop{padding:8px}.inspiration-modal{max-width:calc(100vw - 16px);max-height:96vh;border-radius:var(--ca-radius-lg);max-height:96dvh}.inspiration-header{padding:16px 18px 12px}.inspiration-title h2{font-size:18px}.inspiration-title p{font-size:12px}.inspiration-filters{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding:10px 14px;overflow-x:auto}.inspiration-chip{flex-shrink:0;padding:5px 10px;font-size:12px}.inspiration-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:14px 14px 18px}.inspiration-card-body{padding:10px 12px 12px}.inspiration-card-title{font-size:13px}.inspiration-card-desc{font-size:11.5px}.inspiration-card-apply{padding:8px 12px;font-size:12px}.inspiration-card-tag{padding:3px 7px;font-size:10.5px}.inspiration-card-cover-title{font-size:20px}.inspiration-footer{padding:10px 14px;font-size:12px}.preview-book-stage{padding:2vh 12px}.preview-topbar{flex-wrap:wrap;gap:8px;padding:10px 12px}.preview-topbar-left,.preview-topbar-right{flex:0 auto;gap:6px}.preview-topbar-center{flex:100%;order:3;margin-top:4px}.preview-topbar-center strong{font-size:12px}.preview-btn{padding:6px 10px;font-size:12px}.preview-btn span:not(:first-child){display:none}.preview-mode-toggle button{min-height:36px;padding:8px 14px;font-size:11px}.preview-nav-prev,.preview-nav-next{width:40px;height:40px}.preview-nav-prev{left:6px}.preview-nav-next{right:6px}.preview-hint,.preview-book-base:after,.preview-book-page-right:before{display:none}.preview-book-scene.closed{transform-origin:50%;transform:translate(-32.5%)scale(1.3)}.preview-book-scene.closed .preview-book-page-right{border-radius:3px}.preview-book-scene.closed:after{background:radial-gradient(#00000073,#0000 72%);height:20px;bottom:-16px;left:54%;right:4%}.preview-book-scene.closed:hover{transform:translate(-32.5%)scale(1.3)}.preview-book-scene:before{height:20px;bottom:-16px;left:6%;right:6%}.preview-grid{padding:16px 14px calc(16px + env(safe-area-inset-bottom,0));grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}.autofill-bar{bottom:calc(60px + env(safe-area-inset-bottom,0) + 60px);white-space:normal;border-radius:14px;flex-wrap:nowrap;gap:8px;width:auto;max-width:calc(100vw - 16px);padding:10px 8px 10px 14px;font-size:12.5px;left:8px;right:8px;transform:none}.autofill-bar.entering{animation:.4s cubic-bezier(.2,.9,.3,1.15) backwards autofillBarInMobile}.autofill-bar.leaving{animation:.3s ease-in forwards autofillBarOutMobile}@keyframes autofillBarInMobile{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes autofillBarOutMobile{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(14px)}}.autofill-bar-text{white-space:normal;line-height:1.3}.autofill-bar-undo{padding:5px 10px;font-size:11.5px}.toast-host{bottom:calc(60px + env(safe-area-inset-bottom,0) + 52px + 16px)}.sidebar.open~.toast-host{bottom:calc(62vh + 72px)}.empty-canvas-hint{max-width:calc(100vw - 24px);padding:10px 12px;font-size:12px;display:flex;top:12px;left:12px;right:12px}.ech-arrow-desktop{display:none}.ech-arrow-mobile{display:block}.ech-text-desktop{display:none}.ech-text-mobile{display:inline}.zoom-controls{display:none!important}.onboarding-card,.shortcuts-modal,.inspiration-modal,.preview-topbar,.ctx-menu,.toast-host{box-sizing:border-box}.cp-popover{min-width:min(220px,100vw - 16px);max-width:calc(100vw - 16px)}.format-confirm{width:calc(100vw - 24px);max-width:calc(100vw - 24px)}}@media (max-width:420px){.preview-topbar{padding:8px 10px}.preview-btn{min-height:36px;padding:5px 8px}.preview-mode-toggle{padding:2px}.preview-book-stage{padding:1vh 8px}.preview-nav-prev,.preview-nav-next{width:42px;height:42px}.empty-canvas-hint{padding:8px 10px;font-size:11px}}.radial-menu-backdrop{z-index:9000;-webkit-backdrop-filter:blur(2px);touch-action:none;background:#00000052;animation:.14s ease-out radialBackdropFade;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes radialBackdropFade{0%{opacity:0}to{opacity:1}}.radial-menu-anchor{pointer-events:none;width:0;height:0;position:absolute}.radial-menu-pulse{pointer-events:none;background:#003a8547;border:2px solid #ffffffeb;border-radius:50%;width:24px;height:24px;animation:.9s ease-out infinite radialPulse;position:absolute;top:0;left:0;transform:translate(-50%,-50%)}@keyframes radialPulse{0%{transform:translate(-50%,-50%)scale(.85);box-shadow:0 0 #003a8573}70%{transform:translate(-50%,-50%)scale(1.05);box-shadow:0 0 0 18px #003a8500}to{transform:translate(-50%,-50%)scale(.85);box-shadow:0 0 #003a8500}}.radial-menu-item{background:var(--ca-bg-surface);width:56px;height:56px;color:var(--ca-text-primary);cursor:pointer;pointer-events:auto;-webkit-user-select:none;user-select:none;animation:radialItemPop .22s var(--ca-ease-spring) backwards;border:1px solid #0000000f;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:1px;padding:0;font-family:inherit;transition:transform 80ms ease-out,background .1s;display:flex;position:absolute;top:0;left:0;box-shadow:0 8px 22px #0000002e,0 2px 6px #0000001f}.radial-menu-item:active{filter:brightness(.95);background:#f0f4fb}.radial-menu-item.danger{background:var(--ca-bg-surface);color:var(--ca-text-danger)}.radial-menu-item.danger:active{background:var(--ca-bg-danger-tint)}.radial-menu-icon{justify-content:center;align-items:center;margin-top:-2px;display:inline-flex}.radial-menu-label{letter-spacing:.02em;color:inherit;white-space:nowrap;margin-top:1px;font-size:9.5px;font-weight:600}@keyframes radialItemPop{0%{opacity:0}to{opacity:1}}@media (max-width:480px){.radial-menu-item{width:60px;height:60px}.radial-menu-label{font-size:10px}}.ca-placeholder-pulse{pointer-events:none;z-index:14;background:#9b5a72d9;border-radius:50%;width:22px;height:22px;margin-top:-11px;margin-left:-11px;animation:1.6s ease-in-out infinite caPulseDot;position:absolute}.ca-placeholder-pulse:before,.ca-placeholder-pulse:after{content:"";border:2px solid #9b5a72b3;border-radius:50%;animation:1.6s ease-out infinite caPulseRing;position:absolute;top:0;bottom:0;left:0;right:0}.ca-placeholder-pulse:after{animation-delay:.55s}@keyframes caPulseDot{0%,to{opacity:.95;transform:scale(1)}50%{opacity:.7;transform:scale(.85)}}@keyframes caPulseRing{0%{opacity:.65;transform:scale(.9)}80%{opacity:0;transform:scale(2.6)}to{opacity:0;transform:scale(2.6)}}.ca-celebration{z-index:9998;pointer-events:none;position:fixed;top:0;bottom:0;left:0;right:0;overflow:hidden}.ca-celebration-petal{top:-6%;left:var(--x,50%);background:var(--ca-rose);opacity:0;will-change:transform, opacity;width:12px;height:12px;animation:caPetalFall 1.2s var(--ca-ease-premium) var(--d,0s) forwards;border-radius:80% 20% 75% 25%;position:absolute}.ca-celebration-petal:nth-child(3n){background:var(--ca-butter)}.ca-celebration-petal:nth-child(3n+1){background:var(--ca-cream)}.ca-celebration-petal:nth-child(4n){width:9px;height:9px}.ca-celebration-petal:nth-child(5n){border-radius:30% 70% 25% 75%;width:15px;height:15px}.ca-celebration-petal:nth-child(7n+2){border-radius:60% 40% 65% 35%;width:7px;height:11px}@keyframes caPetalFall{0%{opacity:0;transform:translateY(-10vh) rotate(0deg) scale(calc(var(--ca-petal-scale,1) * .6))}12%{opacity:1}85%{opacity:1}to{opacity:0;transform:translateY(108vh) rotate(var(--r,220deg)) scale(var(--ca-petal-scale,1))}}@media (prefers-reduced-motion:reduce){.ca-celebration{display:none}}.photo-reorder-toggle{width:24px;height:24px;color:var(--ca-text-muted);border-radius:var(--ca-radius-pill);cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;gap:4px;margin-left:auto;padding:4px;font-family:inherit;font-size:11px;font-weight:600;transition:background .1s,border-color .1s,color .1s;display:inline-flex}.photo-reorder-toggle:hover{background:var(--ca-bg-grey-50);color:var(--ca-blue);border-color:#cfd9eb}.photo-reorder-toggle .photo-reorder-toggle-label{display:none}.photo-reorder-toggle.active{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue);width:auto;padding:4px 9px}.photo-reorder-toggle.active .photo-reorder-toggle-label{display:inline}.photo-place-hint{border-radius:var(--ca-radius-md);color:var(--ca-blue);background:#f5f8fe;border:1px dashed #cfd9eb;align-items:center;gap:6px;margin:0 12px 6px;padding:8px 10px;font-size:11px;line-height:1.3;display:flex}.photo-place-hint svg{flex-shrink:0}.photo-filter-toggle{color:var(--ca-blue);background:var(--ca-bg-surface);border-radius:var(--ca-radius-pill);cursor:pointer;border:1px solid #cfd9eb;align-items:center;padding:4px 9px;font-family:inherit;font-size:11px;font-weight:600;transition:background .1s,border-color .1s;display:inline-flex}.photo-filter-toggle:hover{background:#f1f5fc}.photo-filter-toggle.active{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue)}.photo-actions-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.photo-action-btn{min-width:0;color:var(--ca-text-primary);background:var(--ca-bg-subtle);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-md);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;flex:1 1 0;justify-content:center;align-items:center;gap:5px;padding:6px 8px;font-family:inherit;font-size:11px;font-weight:600;transition:background .12s,border-color .12s,color .12s;display:inline-flex;overflow:hidden}.photo-action-btn:hover:not(:disabled){border-color:var(--ca-blue);color:var(--ca-blue);background:#f1f5fc}.photo-action-btn:disabled{opacity:.45;cursor:not-allowed}.photo-action-btn.danger:hover:not(:disabled){background:var(--ca-bg-danger-tint);border-color:var(--ca-text-danger);color:var(--ca-text-danger)}.photo-grid.reorder-mode .photo-cell{cursor:grab;transform-origin:50%;animation:.45s ease-in-out infinite alternate photoWiggle}.photo-grid.reorder-mode .photo-cell:nth-child(odd){animation-direction:alternate-reverse;animation-delay:.12s}.photo-grid.reorder-mode.is-dragging .photo-cell{animation:none}@keyframes photoWiggle{0%{transform:rotate(-.6deg)}to{transform:rotate(.6deg)}}.photo-grip{width:22px;height:22px;color:var(--ca-text-secondary);pointer-events:none;background:#ffffffeb;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:4px;right:4px;box-shadow:0 1px 3px #0000001f}.photo-cell.drag-source{opacity:.35;transform:scale(.96)}.photo-cell.drag-over{outline:2px solid var(--ca-blue);outline-offset:-2px;box-shadow:0 0 0 4px #003a8526}.photo-reorder-ghost{pointer-events:none;z-index:9999;border-radius:var(--ca-radius-sm);width:64px;height:64px;margin-top:-32px;margin-left:-32px;transition:transform 80ms;position:fixed;overflow:hidden;transform:rotate(-3deg)scale(1.05);box-shadow:0 8px 22px #00000052,0 2px 6px #0000002e}.photo-reorder-ghost img{object-fit:cover;width:100%;height:100%;display:block}.photo-touch-ghost{pointer-events:none;z-index:9999;border-radius:var(--ca-radius-md);border:2px solid #fff;width:80px;height:80px;margin-top:-40px;margin-left:-40px;transition:box-shadow .12s,transform .12s;position:fixed;overflow:visible;transform:rotate(-2deg)scale(1.06);box-shadow:0 10px 28px #00000059,0 3px 8px #0003}.photo-touch-ghost img{object-fit:cover;border-radius:var(--ca-radius-sm);width:100%;height:100%;display:block}.photo-touch-ghost.over-target{box-shadow:0 0 0 3px var(--accent), 0 12px 32px #003a8566;transform:rotate(0)scale(1.12)}.photo-touch-ghost .ptg-hint{background:var(--accent);color:#fff;border-radius:var(--ca-radius-lg);white-space:nowrap;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:none;position:absolute;bottom:-28px;left:50%;transform:translate(-50%);box-shadow:0 4px 10px #003a8566}.photo-touch-ghost.over-target .ptg-hint{display:inline-flex}.canvas-swap-ghost{pointer-events:none;z-index:9999;border-radius:var(--ca-radius-md);background:var(--ca-bg-surface);opacity:.92;border:2px solid #fff;width:88px;height:88px;margin-top:-44px;margin-left:-44px;transition:transform .12s,box-shadow .12s;position:fixed;overflow:hidden;transform:rotate(-3deg)scale(1.04);box-shadow:0 12px 32px #0006,0 4px 10px #00000040}.canvas-swap-ghost img{object-fit:cover;width:100%;height:100%;display:block}.canvas-swap-ghost.over-target{box-shadow:0 0 0 3px var(--accent), 0 14px 36px #003a8580;opacity:1;transform:rotate(0)scale(1.12)}.canvas-swap-ghost.hint-swap.over-target{box-shadow:0 0 0 3px #f1c3cc,0 14px 36px #f1c3cc80}.canvas-swap-ghost .csg-hint{background:var(--accent);color:#fff;border-radius:var(--ca-radius-lg);white-space:nowrap;pointer-events:none;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex;position:absolute;bottom:-28px;left:50%;transform:translate(-50%);box-shadow:0 4px 10px #003a8566}.canvas-swap-ghost.hint-swap .csg-hint{background:var(--ca-rose-ink);box-shadow:0 4px 10px #9b5a7266}.canvas-swipe-hint{left:50%;bottom:calc(76px + env(safe-area-inset-bottom,0));color:#fff;z-index:60;white-space:nowrap;pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none;background:#003a85eb;border-radius:22px;align-items:center;gap:10px;padding:8px 14px;font-size:12.5px;font-weight:600;animation:.4s forwards cshFadeIn,1.6s ease-in-out .4s infinite cshArrowsPulse;display:inline-flex;position:fixed;transform:translate(-50%);box-shadow:0 4px 14px #003a8559}.canvas-swipe-hint .csh-arrow{font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:20px;font-weight:700;line-height:1;display:inline-block}@keyframes cshFadeIn{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@keyframes cshArrowsPulse{0%,to{box-shadow:0 4px 14px #003a8559}50%{box-shadow:0 4px 14px #003a8559,0 0 0 6px #003a8526}}@media (min-width:769px){.canvas-swipe-hint{display:none!important}}@media (max-width:932px) and (orientation:landscape) and (max-height:500px){.app{padding-bottom:calc(52px + env(safe-area-inset-bottom,0))}.topbar{height:calc(40px + env(safe-area-inset-top,0))}.topbar-name{max-width:120px;font-size:11.5px}.topbar-name-input{max-width:180px;font-size:16px}.topbar-text-btn{padding:5px 6px}.topbar-section:last-child .topbar-preview-btn{padding:5px 8px;font-size:0}.topbar-section:last-child .topbar-preview-btn:after{font-size:11px}.topbar-order-btn{padding:7px 12px;font-size:12.5px}.topbar-order-btn svg{width:13px;height:13px}.mobile-tabbar{height:calc(52px + env(safe-area-inset-bottom,0));padding-bottom:env(safe-area-inset-bottom,0);display:flex}.mobile-tabbar .mtab{min-height:50px;padding:4px 2px}.mobile-tabbar .mtab-icon svg{width:18px;height:18px}.mobile-tabbar .mtab-label{font-size:9.5px}.sidebar{left:0;right:0;bottom:calc(52px + env(safe-area-inset-bottom,0));width:100%;height:58vh;height:58dvh;max-height:calc(100dvh - 112px);transition:transform var(--ca-dur-med) var(--ca-ease-settle);z-index:89;background:var(--ca-bg-surface);border-top:1px solid #eaeaea;border-right:none;border-top-left-radius:18px;border-top-right-radius:18px;flex-direction:column;position:fixed;overflow:hidden;transform:translateY(calc(100% + 52px));box-shadow:0 -10px 30px #0000002e}.sidebar.open{transform:translateY(0)}.sidebar.tall{height:86vh;height:86dvh}.sidebar-tabs{display:none}.sidebar-panel{-webkit-overflow-scrolling:touch;background:var(--ca-bg-surface);flex:1;width:100%;min-height:0;overflow:hidden auto}.mobile-panel-header{background:var(--ca-bg-surface);z-index:2;border-bottom:1px solid #f0f0f0;flex-direction:column;padding:0 0 6px;display:flex;position:sticky;top:0}.mpp-drag-handle{background:#d8d8d8;border-radius:2px;width:42px;height:4px;margin:8px auto 10px}.mpp-title-row{justify-content:space-between;align-items:center;padding:0 14px 4px;display:flex}.mpp-title{color:var(--ca-text-primary);align-items:center;gap:8px;font-size:15px;font-weight:700;display:inline-flex}.mpp-title svg{width:18px;height:18px}.mpp-close{background:var(--ca-bg-grey-100);width:36px;height:36px;color:var(--ca-text-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.mobile-backdrop{z-index:88;background:#0000003d;display:none;position:fixed;top:0;bottom:0;left:0;right:0}.canvas-area{justify-content:safe center;align-items:safe center;padding:8px 10px}.bottom-strip{display:none}.bottom-nav-row{gap:8px;height:48px;padding:0 10px}.bnr-left{flex-shrink:0;gap:4px}.bnr-left>.bnr-mode-btn,.bnr-left>.bnr-sep{display:none}.bnr-pages-cta{padding:6px 10px;font-size:12px}.bnr-pages-cta>span{display:none}.bnr-center{flex:1;justify-content:center;min-width:0}.bnr-center>.bnr-nav-btn,.bnr-label-btn{display:none}.bnr-right{flex-shrink:0;gap:6px;max-width:42vw;display:flex;overflow:hidden}.preview-overlay{overflow:hidden}.preview-topbar{flex-wrap:nowrap;gap:8px;padding:6px 10px}.preview-topbar-left,.preview-topbar-right{flex:1 1 0;gap:6px;min-width:0}.preview-topbar-center{flex:none;order:initial;min-width:70px;margin-top:0}.preview-btn{min-height:34px;padding:5px 9px;font-size:11.5px}.preview-mode-toggle button{min-height:34px;padding:5px 10px}.preview-book-stage{min-height:0;padding:6px 52px;overflow:hidden}.preview-book-scene{max-height:calc(100dvh - 84px)!important}.canvas-binding-warning{margin:2px 6px 6px;padding:4px 8px;font-size:10.5px}.canvas-binding-warning .cbw-icon svg{width:14px;height:14px}.canvas-binding-warning .cbw-sub{display:none}.canvas-zoom-pill,.canvas-page-pill{bottom:8px!important}}@media (max-width:768px){.photo-reorder-toggle{width:auto;height:auto;color:var(--ca-blue);background:var(--ca-bg-surface);border:1px solid #cfd9eb;padding:6px 11px;font-size:11.5px;box-shadow:0 1px 3px #003a8514}.photo-reorder-toggle .photo-reorder-toggle-label{display:inline}.photo-reorder-toggle:not(.active){animation:2.4s ease-in-out 1.5s 2 reorderHintPulse}@keyframes reorderHintPulse{0%,to{box-shadow:0 1px 3px #003a8514}50%{box-shadow:0 0 0 4px #003a852e,0 1px 3px #003a8526}}.photo-place-hint span:before{content:""}}.cover-suggestion-chip{pointer-events:auto;animation:.28s ease-out coverSuggestionFadeIn}.cover-suggestion-chip-inner{-webkit-backdrop-filter:blur(6px);background:#fffffff5;border:1px solid #003a852e;border-radius:10px;align-items:center;gap:8px;max-width:230px;padding:6px 8px 6px 6px;display:flex;box-shadow:0 4px 14px #0000002e,0 1px 3px #0000001a}.cover-suggestion-thumb{border-radius:var(--ca-radius-sm);object-fit:cover;border:1px solid #00000014;flex-shrink:0;width:44px;height:44px}.cover-suggestion-body{flex-direction:column;gap:2px;min-width:0;display:flex}.cover-suggestion-title{color:var(--ca-blue);letter-spacing:.1px;font-size:12px;font-weight:600;line-height:1.2}.cover-suggestion-reason{color:var(--ca-text-secondary);font-size:10.5px;line-height:1.2}.cover-suggestion-actions{align-items:center;gap:4px;margin-top:4px;display:flex}.cover-suggestion-apply{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-sm);cursor:pointer;border:none;padding:4px 10px;font-size:11px;font-weight:600;transition:background .12s}.cover-suggestion-apply:hover{background:#00489f}.cover-suggestion-apply:active{background:#002d68}.cover-suggestion-dismiss{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:var(--ca-text-muted);cursor:pointer;border-radius:var(--ca-radius-xs);background:0 0;border:none;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:16px;line-height:1;display:inline-flex}.cover-suggestion-dismiss:hover{color:var(--ca-text-primary);background:#0000000f}@keyframes coverSuggestionFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.cover-suggestion-chip-inner{max-width:200px;padding:5px 7px 5px 5px}.cover-suggestion-thumb{width:38px;height:38px}.cover-suggestion-title{font-size:11px}.cover-suggestion-reason{font-size:10px}.cover-suggestion-apply{padding:3px 8px;font-size:10.5px}}.upload-progress-overlay{z-index:9000;pointer-events:none;animation:.22s ease-out uploadProgressFadeIn;position:fixed;bottom:16px;right:16px}.upload-progress-card{pointer-events:auto;background:var(--ca-bg-surface);border-radius:var(--ca-radius-lg);width:320px;max-width:calc(100vw - 32px);font-family:var(--ca-font-ui);border:1px solid #003a851f;padding:14px 16px 12px;box-shadow:0 10px 30px #0000002e,0 2px 6px #0000000f}.upload-progress-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.upload-progress-title{color:var(--ca-blue);align-items:center;gap:8px;font-size:14px;display:flex}.upload-progress-title strong{font-weight:700}.upload-progress-pct{color:var(--ca-text-muted);font-size:13px;font-weight:500}.upload-progress-eta{color:var(--ca-text-muted);font-variant-numeric:tabular-nums;font-size:12px}.upload-progress-spinner{border:2px solid #003a852e;border-top-color:var(--ca-blue);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite uploadProgressSpin}.upload-progress-bar{border-radius:var(--ca-radius-pill);background:#003a8514;height:6px;margin-bottom:10px;overflow:hidden}.upload-progress-bar-fill{background:linear-gradient(90deg, var(--ca-blue), #2660bd);border-radius:var(--ca-radius-pill);height:100%;transition:width .22s ease-out}.upload-progress-status{color:var(--ca-text-secondary);margin:0 0 8px;font-size:13px;line-height:1.35}.upload-progress-phases{flex-wrap:wrap;gap:6px;display:flex}.upload-progress-chip{border-radius:var(--ca-radius-pill);letter-spacing:.02em;padding:3px 8px;font-size:11px;font-weight:600}.upload-progress-chip.heic{color:#92364a;background:#f1c3cc66}.upload-progress-chip.prep{color:var(--ca-blue);background:#003a8514}.upload-progress-chip.up{color:var(--ca-green);background:#46643f1f}@keyframes uploadProgressFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes uploadProgressSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width:768px){.upload-progress-overlay{bottom:calc(60px + 48px + 8px + env(safe-area-inset-bottom,0px));left:12px;right:12px}.upload-progress-card{width:100%;max-width:none}}.variant-picker-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9100;background:#2a252173;animation:.2s ease-out variantPickerFadeIn;position:fixed;top:0;bottom:0;left:0;right:0}.variant-picker-modal{z-index:9101;background:var(--ca-bg-surface);width:min(720px,100vw - 32px);max-height:calc(100dvh - 32px);box-shadow:var(--ca-shadow-xl);font-family:var(--ca-font-ui);animation:variantPickerSlideIn .24s var(--ca-ease-premium);border-radius:20px;padding:28px 28px 22px;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}.variant-picker-close{width:36px;height:36px;color:var(--ca-text-muted);cursor:pointer;border-radius:var(--ca-radius-md);background:0 0;border:0;font-size:26px;line-height:1;transition:background .14s;position:absolute;top:14px;right:14px}.variant-picker-close:hover{color:var(--ca-text-primary);background:#f0f0f0}.variant-picker-title{font-family:var(--ca-font-serif);letter-spacing:-.01em;color:var(--ca-blue);margin:0 0 6px;font-size:26px;font-weight:600}.variant-picker-subtitle{color:var(--ca-text-secondary);margin:0 0 22px;font-size:14px;line-height:1.45}.variant-picker-families{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px;display:grid}@media (max-width:640px){.variant-picker-families{grid-template-columns:1fr}}.variant-family-card{border-radius:var(--ca-radius-lg);background:var(--ca-bg-surface);border:1.5px solid #e6e6e6;transition:border-color .16s,box-shadow .16s,transform .1s;overflow:hidden}.variant-family-card.featured{border-color:#003a8552;box-shadow:0 2px 12px #003a8514}.variant-family-card.open{border-color:var(--ca-blue);box-shadow:0 4px 16px #003a8524}.variant-family-card:hover{border-color:var(--ca-blue)}.variant-family-header{text-align:center;cursor:pointer;background:0 0;border:0;flex-direction:column;align-items:center;gap:6px;width:100%;padding:16px 12px 14px;font-family:inherit;display:flex;position:relative}.variant-family-card.open .variant-family-header{background:var(--ca-rose-soft)}.variant-family-icon{color:#1a1a1a;justify-content:center;align-items:center;width:96px;height:56px;margin:10px 0 6px;display:flex}.variant-family-icon svg{width:100%;height:100%;display:block}.variant-family-badge{background:var(--ca-rose);color:var(--ca-rose-ink);letter-spacing:.06em;border-radius:var(--ca-radius-pill);text-transform:uppercase;padding:3px 8px;font-size:10px;font-weight:700;position:absolute;top:8px;right:8px}.variant-family-name{font-family:var(--ca-font-serif);color:var(--ca-blue);margin:0;font-size:17px;font-weight:600;line-height:1.25}.variant-family-tagline{color:var(--ca-text-muted);margin:0;font-size:12px}.variant-family-price{color:var(--ca-blue);margin-top:4px;font-size:13px;font-weight:700}.variant-sizes{border:1.5px solid var(--ca-blue);border-radius:var(--ca-radius-lg);background:#fafbfc;margin-bottom:12px;padding:16px 18px;animation:.22s ease-out variantSizesSlideDown}.variant-sizes-hint{color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:.06em;margin:0 0 10px;font-size:11px;font-weight:600}.variant-sizes-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;display:grid}.variant-size-option{background:var(--ca-bg-surface);cursor:pointer;text-align:center;border:1.5px solid #e6e6e6;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:12px 10px;font-family:inherit;transition:border-color .16s,transform .1s,box-shadow .16s;display:flex}.variant-size-option:hover{border-color:var(--ca-blue);transform:translateY(-1px);box-shadow:0 4px 12px #003a851a}.variant-size-option:active{transform:translateY(0)}.variant-size-name{color:var(--ca-blue);font-size:13px;font-weight:700}.variant-size-price{color:var(--ca-green);font-size:12px;font-weight:600}.vp-size-thumb{justify-content:center;align-items:center;margin-bottom:2px;display:flex}.vp-size-thumb-inner{background:#fff;border:1.5px solid #003a85;border-radius:2px}.variant-size-option:hover .vp-size-thumb-inner{background:#f0f6ff}.variant-picker-footer{text-align:center;color:var(--ca-text-muted);margin:18px 0 0;font-size:12.5px}.variant-picker-footer strong{color:var(--ca-blue)}@keyframes variantPickerFadeIn{0%{opacity:0}to{opacity:1}}@keyframes variantPickerSlideIn{0%{opacity:0;transform:translate(-50%,calc(8px - 50%))}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes variantSizesSlideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:600px}}@media (max-width:768px){.variant-picker-modal{border-radius:14px;padding:22px 18px 18px}.variant-picker-title{font-size:19px}.variant-picker-subtitle{font-size:13.5px}.variant-family-header{padding:14px}.variant-sizes{padding:4px 14px 14px}.variant-sizes-grid{grid-template-columns:1fr 1fr}}.login-demo-divider{color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:12px;margin:22px 0 14px;font-size:12px;display:flex}.login-demo-divider:before,.login-demo-divider:after{content:"";background:var(--ca-border-default);flex:1;height:1px}.login-demo-btn{width:100%;color:var(--ca-text-primary);cursor:pointer;background:linear-gradient(135deg,#f1c3cc 0%,#f8dde2 100%);border:1.5px solid #00000014;border-radius:10px;padding:13px 16px;font-size:15px;font-weight:600;transition:transform .15s,box-shadow .15s}.login-demo-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #f1c3cc80}.login-demo-btn:disabled{opacity:.5;cursor:not-allowed}.login-demo-hint{text-align:center;color:var(--ca-text-muted);margin:8px 0 0;font-size:12.5px}.login-reset-details{border-top:1px solid #0000000f;margin-top:24px;padding-top:16px}.login-reset-summary{cursor:pointer;color:var(--ca-text-muted);text-align:center;-webkit-user-select:none;user-select:none;padding:4px 0;font-size:12.5px;list-style:none;transition:color .12s ease-out}.login-reset-summary:hover{color:var(--ca-blue)}.login-reset-summary::-webkit-details-marker{display:none}.login-reset-inner{border-radius:var(--ca-radius-md);background:#c0392b0a;border:1px solid #c0392b1a;margin-top:12px;padding:12px}.login-reset-hint{color:#6b6864;margin:0 0 10px;font-size:12px;line-height:1.45}.login-reset-btn{width:100%;color:var(--ca-text-danger);background:var(--ca-bg-surface);border-radius:var(--ca-radius-md);cursor:pointer;border:1px solid #c0392b4d;padding:10px 14px;font-size:13px;font-weight:600;transition:background .12s ease-out,border-color .12s ease-out}.login-reset-btn:hover:not(:disabled){background:#c0392b14;border-color:#c0392b80}.login-reset-btn:disabled{opacity:.5;cursor:not-allowed}.demo-banner{z-index:9000;padding:calc(8px + env(safe-area-inset-top,0)) 16px 8px;background:var(--ca-butter-soft);border-bottom:1px solid var(--ca-butter);color:var(--ca-butter-ink);box-shadow:var(--ca-shadow-sm);align-items:center;gap:12px;font-size:13.5px;display:flex;position:fixed;top:0;left:0;right:0}.demo-banner-icon{flex-shrink:0;font-size:16px}.demo-banner-text{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.demo-banner-text strong{font-weight:600}.demo-banner-cta{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-pill);letter-spacing:.1px;cursor:pointer;min-height:36px;transition:transform var(--ca-tr-fast), box-shadow var(--ca-tr-fast), background var(--ca-tr-fast);border:none;flex-shrink:0;padding:8px 18px;font-size:13.5px;font-weight:600;box-shadow:0 1px 3px #2a252129}.demo-banner-cta:hover{background:var(--ca-blue-dark);transform:translateY(-1px);box-shadow:0 4px 12px #2a252138}.demo-banner-cta:active{transform:translateY(0);box-shadow:0 1px 3px #2a252129}.demo-banner-collapse{width:36px;height:36px;color:var(--ca-butter-ink);cursor:pointer;transition:background var(--ca-tr-fast), color var(--ca-tr-fast);background:#8a6d1f1a;border:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.demo-banner-collapse:hover{color:var(--ca-ink-warm);background:#8a6d1f2e}.demo-banner-chip{top:calc(56px + env(safe-area-inset-top,0));z-index:9000;background:linear-gradient(90deg, var(--ca-blue) 0%, #0056c7 100%);color:#fff;letter-spacing:.2px;border-radius:var(--ca-radius-pill);cursor:pointer;animation:chipIn .22s var(--ca-ease-out);transition:transform var(--ca-tr-fast), box-shadow var(--ca-tr-fast);border:0;align-items:center;gap:6px;padding:5px 11px 5px 9px;font-size:12px;font-weight:600;display:inline-flex;position:fixed;left:12px;box-shadow:0 2px 8px #0000002e}.demo-banner-chip:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000003d}.demo-banner-chip svg{flex-shrink:0}@keyframes chipIn{0%{opacity:0;transform:translateY(-6px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (max-width:480px){.demo-banner-chip{display:none}}body:has(.demo-banner){box-sizing:border-box;padding-top:48px}body:has(.demo-banner) #root{min-height:calc(100vh - 48px)}body:has(.demo-banner) .app{min-height:calc(100vh - 48px)}body:has(.demo-banner) .app{height:calc(100vh - 48px);height:calc(100dvh - 48px)}@media (max-width:768px){body:has(.demo-banner){--ca-mobile-canvas-controls-top:calc(env(safe-area-inset-top,0) + 126px)}}.demo-paywall-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:10000;background:#2a252173;justify-content:center;align-items:center;padding:20px;animation:.18s ease-out demoPaywallFadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes demoPaywallFadeIn{0%{opacity:0}to{opacity:1}}.demo-paywall-modal{background:var(--ca-bg-surface);width:100%;max-width:420px;box-shadow:var(--ca-shadow-xl);text-align:center;border-radius:20px;padding:28px 24px 22px;animation:.22s cubic-bezier(.16,1,.3,1) demoPaywallSlideIn}@keyframes demoPaywallSlideIn{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.demo-paywall-icon{margin-bottom:10px;font-size:38px}.demo-paywall-modal h3{font-family:var(--ca-font-ui);letter-spacing:-.01em;color:var(--ca-ink-warm);margin:0 0 10px;font-size:20px;font-weight:700}.demo-paywall-modal p{color:var(--ca-text-secondary);margin:0 0 22px;font-size:14.5px;line-height:1.55}.demo-paywall-actions{flex-direction:column;gap:10px;display:flex}.demo-paywall-primary{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-md);cursor:pointer;border:none;padding:12px 18px;font-size:15px;font-weight:600;transition:background .15s}.demo-paywall-primary:hover{background:var(--ca-blue-dark)}.demo-paywall-cancel{color:var(--ca-text-secondary);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-md);cursor:pointer;background:0 0;padding:11px 18px;font-size:14px;font-weight:500;transition:background .15s}.demo-paywall-cancel:hover{background:var(--ca-bg-subtle)}@media (max-width:640px){.demo-banner{gap:8px;padding:7px 10px;font-size:12.5px}.demo-banner-icon{font-size:14px}.demo-banner-cta{padding:5px 10px;font-size:12px}.demo-paywall-modal{padding:24px 18px 18px}.demo-paywall-icon{font-size:32px}.demo-paywall-modal h3{font-size:18px}.demo-paywall-modal p{font-size:14px}}.carryover-overlay{z-index:10001;background:linear-gradient(#f7f4ee 0%,#efe7d8 100%);justify-content:center;align-items:center;padding:24px;animation:.2s ease-out carryoverFadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes carryoverFadeIn{0%{opacity:0}to{opacity:1}}.carryover-card{background:var(--ca-bg-surface);text-align:center;border-radius:16px;width:100%;max-width:460px;padding:32px 28px 26px;animation:.24s cubic-bezier(.16,1,.3,1) carryoverSlideIn;box-shadow:0 20px 60px #0000002e}@keyframes carryoverSlideIn{0%{opacity:0;transform:translateY(16px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.carryover-icon{margin-bottom:10px;font-size:40px}.carryover-card h2{color:var(--ca-blue);margin:0 0 10px;font-size:22px;font-weight:700}.carryover-card p{color:var(--ca-text-secondary);margin:0 0 18px;font-size:14.5px;line-height:1.55}.carryover-progress{border-radius:var(--ca-radius-pill);background:#e8e0cf;height:6px;margin:8px 0 12px;overflow:hidden}.carryover-progress-bar{background:linear-gradient(90deg, var(--ca-blue) 0%, #1c5cb8 100%);border-radius:var(--ca-radius-pill);height:100%;transition:width .25s ease-out}.carryover-status{font-style:italic;color:#888!important;margin:4px 0 0!important;font-size:13px!important}.carryover-actions{flex-direction:column;gap:10px;margin-top:8px;display:flex}.carryover-primary,.carryover-secondary{cursor:pointer;border:none;border-radius:10px;padding:12px 18px;font-size:14.5px;font-weight:600;transition:background .15s,transform 80ms}.carryover-primary{background:var(--ca-blue);color:#fff}.carryover-primary:hover{background:var(--ca-blue-dark)}.carryover-primary:active{transform:scale(.98)}.carryover-secondary{color:var(--ca-text-secondary);background:#f0ece2}.carryover-secondary:hover{background:#e6e0d2}@media (max-width:480px){.carryover-card{padding:26px 18px 20px}.carryover-icon{font-size:32px}.carryover-card h2{font-size:18px}.carryover-card p{font-size:13.5px}}.feature-error{background:var(--ca-bg-surface);text-align:center;box-sizing:border-box;border:1px solid #e8e2d3;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:12px;max-width:420px;height:100%;margin:auto;padding:32px 24px;display:flex;box-shadow:0 2px 12px #0000000a}.feature-error-icon{font-size:36px;line-height:1}.feature-error h3{color:var(--ca-blue);margin:4px 0 0;font-size:17px;font-weight:600}.feature-error p{color:var(--ca-text-secondary);margin:0;font-size:14px;line-height:1.5}.feature-error-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:6px;display:flex}.feature-error-actions button{border-radius:var(--ca-radius-md);cursor:pointer;border:none;padding:9px 16px;font-size:14px;font-weight:500;transition:background .15s}.feature-error-primary{background:var(--ca-blue);color:#fff}.feature-error-primary:hover{background:#002b66}.feature-error-secondary{color:var(--ca-text-secondary);background:#f0ece2}.feature-error-secondary:hover{background:#e6e0d2}@media (max-width:480px){.feature-error{padding:24px 16px}.feature-error-icon{font-size:30px}.feature-error h3{font-size:15px}.feature-error p{font-size:13px}}.admin-canva-shell{height:100vh;color:#1a1a1a;background:#f7f7fa;height:100dvh;padding:24px;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-y:auto}.admin-canva-header{align-items:center;gap:16px;max-width:960px;margin:0 auto 24px;display:flex}.admin-canva-header h1{flex:1;margin:0;font-size:24px}.admin-canva-token-form{background:#fff;border-radius:8px;max-width:480px;margin:40px auto;padding:24px;box-shadow:0 2px 8px #0000000d}.admin-canva-token-form input{box-sizing:border-box;border:1px solid #ccc;border-radius:6px;width:100%;margin:12px 0;padding:10px 12px;font-family:monospace;font-size:14px;display:block}.admin-canva-token-form button{color:#fff;cursor:pointer;background:#003a85;border:0;border-radius:6px;padding:10px 18px;font-size:14px}.admin-canva-token-form button:disabled{opacity:.5;cursor:not-allowed}.admin-canva-note{color:#666;margin-top:16px;font-size:12px;line-height:1.5}.admin-canva-note code{background:#eef;border-radius:3px;padding:1px 6px;font-size:12px}.admin-canva-error{color:#c0392b;background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;max-width:960px;margin:0 auto 16px;padding:12px;font-size:14px}.admin-canva-list{flex-direction:column;gap:12px;max-width:960px;margin:0 auto;padding:0;list-style:none;display:flex}.admin-canva-item{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000000d}.admin-canva-item-head{align-items:center;gap:12px;margin-bottom:8px;display:flex}.admin-canva-status{color:#fff;letter-spacing:.3px;text-transform:uppercase;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-block}.admin-canva-date{color:#888;font-size:12px}.admin-canva-url{color:#003a85;word-break:break-all;margin-bottom:6px;font-family:monospace;font-size:13px;text-decoration:none;display:block}.admin-canva-url:hover{text-decoration:underline}.admin-canva-meta{color:#666;flex-wrap:wrap;gap:16px;margin-bottom:8px;font-size:12px;display:flex}.admin-canva-meta .anon{color:#aaa;font-style:italic}.admin-canva-notes{background:#fffbe6;border-left:3px solid #f0c419;border-radius:0 4px 4px 0;margin-bottom:8px;padding:8px 12px;font-size:13px}.admin-canva-actions{flex-wrap:wrap;gap:8px;display:flex}.admin-canva-actions button{cursor:pointer;color:#333;background:#fff;border:1px solid #d0d0d8;border-radius:6px;padding:6px 12px;font-size:13px}.admin-canva-actions button.primary{color:#fff;background:#28a745;border-color:#28a745}.admin-canva-actions button.danger{color:#fff;background:#dc3545;border-color:#dc3545}.admin-canva-actions button:disabled{opacity:.5;cursor:not-allowed}.admin-variant-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.admin-variant-modal{background:#fff;border-radius:8px;flex-direction:column;width:100%;max-width:720px;max-height:90vh;display:flex;overflow-y:auto}.admin-variant-modal-head{z-index:1;background:#fff;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.admin-variant-modal-head h3{margin:0;font-size:16px}.admin-variant-modal-foot{background:#fff;border-top:1px solid #eee;justify-content:flex-end;gap:8px;padding:16px 20px;display:flex;position:sticky;bottom:0}.admin-variant-modal-foot .primary{color:#fff;background:#1056ae;border:1px solid #1056ae}.admin-variant-form{gap:16px;padding:20px;display:grid}.admin-variant-form fieldset{border:1px solid #eee;border-radius:6px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;padding:12px 16px;display:grid}.admin-variant-form legend{color:#666;text-transform:uppercase;letter-spacing:.5px;padding:0 6px;font-size:12px}.admin-variant-form label{flex-direction:column;gap:4px;font-size:13px;display:flex}.admin-variant-form label>span{color:#555;font-size:12px}.admin-variant-form input,.admin-variant-form select{border:1px solid #ccc;border-radius:4px;padding:6px 8px;font-family:inherit;font-size:13px}.admin-variant-form input:focus,.admin-variant-form select:focus,.admin-variant-form textarea:focus{outline-offset:-1px;outline:2px solid #1056ae}.admin-variant-form textarea{resize:vertical;border:1px solid #ccc;border-radius:4px}.admin-nav{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-wrap:wrap;gap:2px;width:max-content;max-width:1200px;margin:0 auto 24px;padding:4px;display:flex;box-shadow:0 1px 3px #0000000a}.admin-nav-item{cursor:pointer;color:#6b7280;background:0 0;border:0;border-radius:7px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.admin-nav-item:hover{color:#111827;background:#f3f4f6}.admin-nav-item.is-active{color:#fff;background:#1056ae;font-weight:600;box-shadow:0 1px 2px #1056ae40}.admin-nav-item svg{flex-shrink:0;width:16px;height:16px}.adm-page-header{align-items:center;gap:16px;max-width:1200px;margin:0 auto 20px;display:flex}.adm-page-header h1{letter-spacing:-.3px;color:#111827;margin:0;font-size:24px;font-weight:700}.adm-page-header-flex{flex:1}.adm-page-stats{color:#6b7280;gap:14px;margin-top:4px;font-size:12px;display:flex}.adm-page-stats strong{color:#111827;font-weight:600}.adm-btn-back,.adm-btn-logout{cursor:pointer;color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500}.adm-btn-back:hover,.adm-btn-logout:hover{background:#f9fafb}.adm-empty-emoji{opacity:.6;margin-bottom:12px;font-size:48px;line-height:1}.adm-empty-title{color:#111827;margin:0 0 6px;font-size:18px;font-weight:600}.adm-empty-hint{color:#6b7280;margin:0 0 20px;font-size:13px;line-height:1.55}.adm-empty-hint code{color:#374151;background:#f3f4f6;border-radius:4px;padding:2px 6px;font-size:12px}.adm-section{max-width:1200px;margin:0 auto 32px}.adm-section-title{text-transform:uppercase;letter-spacing:.6px;color:#6b7280;border-bottom:1px solid #e5e7eb;align-items:center;gap:8px;margin:0 0 14px;padding-bottom:8px;font-size:13px;font-weight:600;display:flex}.adm-section-count{color:#374151;letter-spacing:0;text-transform:none;background:#e5e7eb;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500}.adm-stats{color:#6b7280;gap:16px;margin-top:4px;font-size:12px;display:flex}.adm-stats strong{color:#111827;font-weight:600}.adm-primary-cta{color:#fff;cursor:pointer;background:#1056ae;border:0;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:background .12s,transform .12s,box-shadow .12s;display:inline-flex;box-shadow:0 1px 3px #1056ae40}.adm-primary-cta:hover:not(:disabled){background:#0d4a96;transform:translateY(-1px);box-shadow:0 3px 8px #1056ae4d}.adm-primary-cta:disabled{opacity:.5;cursor:not-allowed}.adm-search{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:8px;width:200px;padding:8px 12px;font-family:inherit;font-size:13px}.adm-search:focus{border-color:#1056ae;outline:0;box-shadow:0 0 0 3px #1056ae26}.adm-select{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:7px 10px;font-family:inherit;font-size:13px}.adm-select:focus{border-color:#1056ae;outline:0}.adm-icon-btn{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #d1d5db;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.adm-icon-btn:hover:not(:disabled){color:#111827;background:#f3f4f6}.adm-icon-btn:disabled{opacity:.5;cursor:not-allowed}.adm-empty{text-align:center;background:#fff;border:1px dashed #d1d5db;border-radius:12px;max-width:480px;margin:60px auto;padding:48px 24px}.adm-group{max-width:1200px;margin:0 auto 32px}.adm-group-title{text-transform:uppercase;letter-spacing:.6px;color:#6b7280;border-bottom:1px solid #e5e7eb;align-items:center;gap:8px;margin:0 0 14px;padding-bottom:8px;font-size:13px;font-weight:600;display:flex}.adm-group-count{color:#374151;letter-spacing:0;text-transform:none;background:#e5e7eb;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500}.adm-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;display:grid}.adm-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;transition:box-shadow .15s,border-color .15s,transform .15s;display:flex;overflow:hidden;box-shadow:0 1px 2px #00000008}.adm-card:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 6px 16px #00000014}.adm-card.is-disabled{opacity:.55}.adm-card.is-disabled:hover{transform:none}.adm-card-thumb-wrap{position:relative}.adm-card-overlay-top{z-index:2;pointer-events:none;justify-content:space-between;align-items:center;gap:6px;display:flex;position:absolute;top:8px;left:8px;right:8px}.adm-card-overlay-top>*{pointer-events:auto}.adm-thumb{aspect-ratio:5/7;background:#f3f4f6;width:100%;position:relative;overflow:hidden}.adm-thumb img,.adm-thumb-bg{object-fit:cover;width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.adm-thumb-svg{width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.adm-thumb-empty{color:#ffffffd9;text-align:center;text-shadow:0 1px 3px #0003;justify-content:center;align-items:center;padding:12px;font-size:16px;font-weight:600;display:flex}.adm-card-body{flex-direction:column;gap:10px;padding:12px 14px 14px;display:flex}.adm-name{color:#111827;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;line-height:1.2;overflow:hidden}.adm-status{letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;-webkit-backdrop-filter:blur(8px);border-radius:999px;padding:3px 9px;font-size:10px;font-weight:600;display:inline-block}.adm-status-published{color:#047857;background:#d1fae5f2}.adm-status-draft{color:#b45309;background:#fef3c7f2}.adm-status-disabled{color:#6b7280;background:#e5e7ebf2}.adm-cta-design{color:#fff;cursor:pointer;background:#1056ae;border:0;border-radius:8px;width:100%;padding:9px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:background .1s}.adm-cta-design:hover{background:#0d4a96}.adm-cta-design:disabled{opacity:.5;cursor:not-allowed}.adm-btn-ghost{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500}.adm-btn-ghost:hover:not(:disabled){background:#f9fafb}.adm-btn-ghost:disabled{opacity:.5;cursor:not-allowed}.adm-menu-wrap{position:relative}.adm-menu-trigger{cursor:pointer;color:#374151;-webkit-backdrop-filter:blur(8px);background:#fffffff2;border:0;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;padding-bottom:4px;font-size:18px;line-height:1;display:flex;box-shadow:0 1px 3px #00000026}.adm-menu-trigger:hover:not(:disabled){background:#fff}.adm-menu-trigger:disabled{opacity:.5;cursor:not-allowed}.adm-menu{z-index:50;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;min-width:180px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 4px 16px #0000001f}.adm-menu button{text-align:left;cursor:pointer;color:#374151;background:0 0;border:0;border-radius:5px;padding:8px 12px;font-family:inherit;font-size:13px}.adm-menu button:hover{background:#f3f4f6}.adm-menu hr{border:0;border-top:1px solid #f3f4f6;margin:4px 0}.adm-menu .adm-menu-danger{color:#dc2626}.adm-menu .adm-menu-danger:hover{background:#fef2f2}.adm-modal-overlay,.admin-variant-modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.adm-modal,.admin-variant-modal{background:#fff;border-radius:14px;width:100%;max-width:420px;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 20px 50px #00000040}.admin-variant-modal{max-width:640px}.admin-variant-modal-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.admin-variant-modal-head h3{color:#111827;margin:0;font-size:18px;font-weight:700}.admin-variant-modal-head h3 code{color:#9ca3af;margin-left:8px;font-family:SFMono-Regular,Consolas,monospace;font-size:12px;font-weight:400}.admin-variant-modal-head>button{cursor:pointer;color:#6b7280;background:0 0;border:0;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:14px}.admin-variant-modal-head>button:hover{color:#111827;background:#f3f4f6}.admin-variant-modal-foot{border-top:1px solid #f3f4f6;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;display:flex}.admin-variant-modal-foot button{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500}.admin-variant-modal-foot button:hover:not(:disabled){background:#f9fafb}.admin-variant-modal-foot button.primary{color:#fff;background:#1056ae;border-color:#1056ae}.admin-variant-modal-foot button.primary:hover:not(:disabled){background:#0d4a96}.admin-variant-modal-foot button:disabled{opacity:.5;cursor:not-allowed}.admin-variant-form{grid-template-columns:1fr 1fr;gap:12px 16px;display:grid}.admin-variant-form>fieldset{border:1px solid #e5e7eb;border-radius:8px;grid-column:1/-1;margin:0;padding:12px 14px}.admin-variant-form legend{color:#6b7280;text-transform:uppercase;letter-spacing:.3px;padding:0 6px;font-size:12px;font-weight:600}.admin-variant-form label{flex-direction:column;gap:4px;display:flex}.admin-variant-form label>span{color:#374151;font-size:12px;font-weight:500}.admin-variant-form input,.admin-variant-form select,.admin-variant-form textarea{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:7px 10px;font-family:inherit;font-size:13px}.admin-variant-form input:focus,.admin-variant-form select:focus,.admin-variant-form textarea:focus{border-color:#1056ae;outline:0;box-shadow:0 0 0 3px #1056ae26}.adm-modal-title{color:#111827;letter-spacing:-.2px;margin:0;font-size:20px;font-weight:700}.adm-modal-hint{color:#6b7280;margin:6px 0 22px;font-size:13px}.adm-modal-field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.adm-modal-field>span{color:#374151;font-size:13px;font-weight:500}.adm-modal-field input{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px}.adm-modal-field input:focus{border-color:#1056ae;outline:0;box-shadow:0 0 0 3px #1056ae26}.adm-modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.adm-modal-details{background:#f9fafb;border-radius:8px;margin-top:16px;padding:10px 12px;font-size:12px}.adm-modal-details summary{cursor:pointer;color:#374151;list-style:revert;font-weight:600}.adm-modal-details ul{color:#4b5563;margin:10px 0 0;padding-left:18px}.adm-modal-details li{margin-bottom:3px}.adm-modal-details code{background:#e5e7eb;border-radius:3px;padding:1px 5px;font-size:11px}.topbar-tplb-bar{color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;align-items:center;gap:10px;padding:4px 12px 4px 14px;font-size:13px;display:inline-flex}.topbar-tplb-label{align-items:center;gap:6px;display:inline-flex}.topbar-tplb-label>span:first-child{color:#6b7280;font-size:12px}.topbar-tplb-select{color:#111827;cursor:pointer;background:0 0;border:0;padding:4px 4px 4px 0;font-family:inherit;font-size:13px;font-weight:600}.topbar-tplb-select:focus{outline:0}.topbar-tplb-badge{letter-spacing:.3px;text-transform:uppercase;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:700}.topbar-tplb-badge.is-default{color:#1d4ed8;background:#dbeafe}.topbar-tplb-badge.is-override{color:#047857;background:#d1fae5}.topbar-tplb-badge.is-adapted{color:#6b21a8;background:#f3e8ff}.topbar-tplb-badge.is-virgin{color:#b45309;background:#fef3c7}.topbar-tplb-remove{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:999px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500}.topbar-tplb-remove:hover{background:#fef2f2}.topbar-tplb-ratio{justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex}.topbar-tplb-ratio>span{background:#1056ae;border-radius:1.5px;display:block}.topbar-tplb-revert{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:999px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500}.topbar-tplb-revert:hover{color:#111827;background:#f3f4f6}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.skeleton-shimmer,.skeleton-line{background:#f3f4f6!important;animation:none!important}.adm-card:hover,.admin-clipart-card:hover,.adm-clipart-card:hover,.project-card:hover{transform:none!important}.project-progress-badge.is-near-done,.topbar-order-savings{animation:none!important}}.skeleton-shimmer{border-radius:inherit;background:linear-gradient(90deg,#f3f4f6 0%,#e5e7eb 50%,#f3f4f6 100%) 0 0/200% 100%;width:100%;height:100%;animation:1.4s linear infinite skeleton-shimmer}.skeleton-line{background:linear-gradient(90deg,#f3f4f6 0%,#e5e7eb 50%,#f3f4f6 100%) 0 0/200% 100%;border-radius:4px;height:12px;margin:4px 0;animation:1.4s linear infinite skeleton-shimmer}.skeleton-line-title{width:65%;height:14px}.skeleton-line-meta{width:40%;height:10px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.project-card-skeleton,.adm-card-skeleton{pointer-events:none;opacity:.85}.project-card-skeleton .project-thumb,.adm-card-skeleton .adm-card-thumb-wrap{background:#f3f4f6}.topbar-production-time{color:#475569;white-space:nowrap;background:#f3f4f6;border-radius:999px;align-items:center;margin-left:12px;padding:4px 10px;font-size:11px;font-weight:500;display:inline-flex}@media (max-width:900px){.topbar-production-time{display:none}}body.mode-focus .topbar,body.mode-focus .sidebar,body.mode-focus .bottombar{display:none!important}body.mode-focus .canvas-area{padding:0!important}.focus-exit-fab{z-index:200;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ad9;border:0;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:500;display:none;position:fixed;top:16px;right:16px;box-shadow:0 4px 12px #0003}body.mode-focus .focus-exit-fab{display:inline-flex}.focus-exit-fab:hover{background:#0f172af2}.cmd-palette-overlay{z-index:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;justify-content:center;align-items:flex-start;padding-top:12vh;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.cmd-palette{background:#fff;border-radius:14px;flex-direction:column;width:100%;max-width:580px;max-height:70vh;display:flex;overflow:hidden;box-shadow:0 20px 50px #00000040}.cmd-palette-input-row{color:#6b7280;border-bottom:1px solid #e5e7eb;align-items:center;gap:10px;padding:14px 16px;display:flex}.cmd-palette-input{color:#111827;background:0 0;border:0;outline:0;flex:1;font-family:inherit;font-size:15px}.cmd-palette-kbd,.cmd-palette-foot kbd{color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;padding:2px 6px;font-family:SFMono-Regular,Consolas,monospace;font-size:11px}.cmd-palette-results{flex:1;margin:0;padding:4px;list-style:none;overflow-y:auto}.cmd-palette-empty{text-align:center;color:#9ca3af;padding:24px;font-size:13px}.cmd-palette-item{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;display:flex}.cmd-palette-item.is-selected{background:#eef2f7}.cmd-palette-icon{text-align:center;width:22px;font-size:16px}.cmd-palette-name{color:#111827;text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.cmd-palette-meta{color:#9ca3af;flex-shrink:0;font-size:11px}.cmd-palette-foot{color:#6b7280;border-top:1px solid #e5e7eb;gap:16px;padding:10px 16px;font-size:11px;display:flex}.theme-hover-preview{z-index:300;pointer-events:none;background:#fff;border-radius:12px;animation:.15s theme-preview-in;overflow:hidden;box-shadow:0 10px 32px #0003}@media (hover:none) and (pointer:coarse){.theme-hover-preview{display:none!important}}@keyframes theme-preview-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.theme-hover-preview-thumb{width:100%;position:relative;overflow:hidden}.theme-hover-preview-thumb img{object-fit:cover;width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.theme-hover-preview-info{border-top:1px solid #f3f4f6;flex-direction:column;gap:2px;padding:10px 12px;display:flex}.theme-hover-preview-info strong{color:#111827;font-size:14px;font-weight:600}.theme-hover-preview-info span{color:#6b7280;font-size:11px}.adm-card-select-checkbox{z-index:3;cursor:pointer;accent-color:#1056ae;opacity:0;width:18px;height:18px;transition:opacity .1s;position:absolute;top:10px;left:10px}.adm-card:hover .adm-card-select-checkbox,.adm-card.is-selected .adm-card-select-checkbox{opacity:1}.adm-card.is-selected{border-color:#1056ae;box-shadow:0 0 0 3px #1056ae33}.upsell-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(6px)saturate(1.1);backdrop-filter:blur(6px)saturate(1.1);background:#2a252173;justify-content:center;align-items:center;padding:16px;animation:.18s confirmBackdropIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.upsell-modal{background:var(--ca-bg-surface);width:100%;max-width:720px;box-shadow:var(--ca-shadow-xl);max-height:92vh;animation:confirmDialogIn .26s var(--ca-ease-spring);border-radius:20px;padding:32px;position:relative;overflow-y:auto}.upsell-close{color:var(--ca-text-muted);cursor:pointer;width:32px;height:32px;transition:background var(--ca-tr-fast), color var(--ca-tr-fast);background:0 0;border:0;border-radius:50%;font-size:22px;line-height:1;position:absolute;top:14px;right:14px}.upsell-close:hover{background:var(--ca-bg-subtle);color:var(--ca-ink-warm)}.upsell-modal h2{font-family:var(--ca-font-serif);color:var(--ca-ink-warm);letter-spacing:-.01em;margin:0 0 4px;font-size:26px;font-weight:600}.upsell-subtitle{color:var(--ca-text-secondary);margin:0 0 24px;font-size:14px;line-height:1.5}.upsell-options{grid-template-columns:1fr 1.2fr;gap:14px;display:grid}.upsell-option{border:1px solid var(--ca-border-default);background:var(--ca-bg-surface);border-radius:16px;flex-direction:column;padding:18px 16px;display:flex;position:relative}.upsell-option-tag{background:var(--ca-bg-surface);border:1px solid var(--ca-border-default);color:var(--ca-text-muted);text-transform:uppercase;letter-spacing:.5px;border-radius:999px;padding:2px 10px;font-size:10px;font-weight:600;position:absolute;top:-10px;left:14px}.upsell-tag-best{background:var(--ca-blue);color:#fff;border-color:var(--ca-blue)}.upsell-option h3{color:var(--ca-ink-warm);margin:6px 0 2px;font-size:15px;font-weight:600}.upsell-option-size{color:var(--ca-text-muted);margin-bottom:12px;font-size:12px}.upsell-highlights{flex-direction:column;gap:6px;margin:0 0 14px;padding:0;list-style:none;display:flex}.upsell-highlights li{color:var(--ca-text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.upsell-highlights svg{color:var(--ca-green);flex-shrink:0}.upsell-option-price{color:var(--ca-ink-warm);letter-spacing:-.5px;margin-top:auto;margin-bottom:12px;font-size:22px;font-weight:700}.upsell-diff{color:var(--ca-green);margin-top:2px;font-size:12px;font-weight:500;display:block}.upsell-diff small{color:var(--ca-text-muted);font-weight:400}.upsell-savings{color:var(--ca-green);background:var(--ca-bg-success-tint);border-radius:6px;margin-top:6px;padding:4px 8px;font-size:11.5px;font-weight:600;line-height:1.3;display:block}.upsell-btn-continue,.upsell-btn-accept{cursor:pointer;border:0;border-radius:8px;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .1s}.upsell-btn-continue{background:var(--ca-bg-surface);border:1px solid var(--ca-border-strong);color:var(--ca-text-secondary)}.upsell-btn-continue:hover{background:var(--ca-bg-subtle)}.upsell-btn-accept{background:var(--ca-blue);color:#fff;box-shadow:0 1px 3px #003a854d}.upsell-btn-accept:hover{background:var(--ca-blue-dark)}.upsell-upgrade{border-color:var(--ca-rose-ink);background:var(--ca-rose-soft);box-shadow:var(--ca-shadow-xl);border-radius:20px}.upsell-footnote{color:var(--ca-text-muted);text-align:center;margin:18px 0 0;font-size:11px}@media (max-width:600px){.upsell-options{grid-template-columns:1fr}}.smart-suggestion-banner{z-index:50;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:999px;align-items:center;gap:10px;max-width:600px;padding:10px 14px;font-size:13px;animation:.28s smart-suggestion-in;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000014}@keyframes smart-suggestion-in{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.smart-suggestion-emoji{flex-shrink:0;font-size:16px}.smart-suggestion-text{line-height:1.35}.smart-suggestion-cta{color:#fff;cursor:pointer;background:#92400e;border:0;border-radius:999px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:600}.smart-suggestion-close{color:#92400e;cursor:pointer;opacity:.6;background:0 0;border:0;padding:0 4px;font-size:18px;line-height:1}.smart-suggestion-close:hover{opacity:1}body.mode-focus .smart-suggestion-banner{display:none}.project-progress-badge{color:#fff;letter-spacing:.2px;-webkit-backdrop-filter:blur(8px);background:#0f172abf;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:600;position:absolute;bottom:8px;left:8px}.project-progress-badge.is-mid{background:#f59e0beb}.project-progress-badge.is-near-done{background:#10b981eb;animation:2.4s ease-in-out infinite badge-pulse}@keyframes badge-pulse{0%,to{box-shadow:0 0 #10b98100}50%{box-shadow:0 0 0 4px #10b98133}}.project-thumb{position:relative}.seasonal-urgency{color:#92400e;background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);border:1px solid #fde68a;border-radius:12px;align-items:center;gap:12px;max-width:880px;margin:0 auto 16px;padding:12px 16px;display:flex}.seasonal-urgency.is-urgent{color:#991b1b;background:linear-gradient(135deg,#fef2f2 0%,#fecaca 100%);border-color:#fca5a5}.seasonal-urgency-emoji{flex-shrink:0;font-size:24px}.seasonal-urgency-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.seasonal-urgency-text strong{font-size:14px;font-weight:600}.seasonal-urgency-text small{opacity:.85;font-size:12px;line-height:1.4}.seasonal-urgency-close{color:currentColor;cursor:pointer;opacity:.5;background:0 0;border:0;padding:0 4px;font-family:inherit;font-size:22px;line-height:1}.seasonal-urgency-close:hover{opacity:1}.trust-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;max-width:880px;margin:24px auto;display:grid}.trust-cards-compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.trust-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;align-items:center;gap:10px;padding:12px 14px;display:flex}.trust-card-icon{color:#1056ae;background:#eef2f7;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.trust-card-text{flex-direction:column;gap:1px;min-width:0;display:flex}.trust-card-text strong{color:#111827;font-size:13px;font-weight:600}.trust-card-text small{color:#6b7280;font-size:11px;line-height:1.35}.topbar-order-perphoto{opacity:.9;background:#fff3;border-radius:999px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:500;display:inline-block}.topbar-order-strikethrough{opacity:.65;font-variant-numeric:tabular-nums;margin-right:6px;font-size:.85em;font-weight:500;text-decoration:line-through;text-decoration-thickness:1.5px;display:inline-block}.topbar-order-savings{color:#fff;background:#10b981;border-radius:999px;margin-left:8px;padding:2px 9px;font-size:11px;font-weight:700;display:inline-block;box-shadow:0 1px 2px #10b98166}.adm-card-usage{color:#fff;letter-spacing:.2px;-webkit-backdrop-filter:blur(8px);z-index:2;background:#0f172ad9;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:600;position:absolute;bottom:8px;right:8px}.adm-toolbar{flex-wrap:wrap;align-items:center;gap:10px;max-width:1200px;margin:0 auto 18px;display:flex}.adm-toolbar-filters{flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto;display:flex}.adm-checkbox-label{color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #d1d5db;border-radius:8px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;display:inline-flex}.adm-checkbox-label input{margin:0}.adm-btn-sm{padding:6px 10px!important;font-size:12px!important}.adm-progress-banner{color:#fff;background:#1056ae;border-radius:8px;align-items:center;gap:10px;max-width:1200px;margin:0 auto 16px;padding:10px 14px;font-size:13px;display:flex}.adm-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite adm-spin;display:inline-block}@keyframes adm-spin{to{transform:rotate(360deg)}}.adm-bulk-bar{z-index:20;color:#fff;background:#1056ae;border-radius:10px;align-items:center;gap:12px;max-width:1200px;margin:0 auto 16px;padding:12px 16px;display:flex;position:sticky;top:8px;box-shadow:0 4px 12px #1056ae4d}.adm-bulk-cta{color:#1056ae;cursor:pointer;background:#fff;border:0;border-radius:6px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:600}.adm-bulk-clear{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff80;border-radius:6px;margin-left:auto;padding:7px 14px;font-family:inherit;font-size:13px}.adm-bulk-clear:hover{background:#ffffff1a}.adm-clipart-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;display:grid}.adm-clipart-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;gap:8px;padding:14px 12px 10px;transition:box-shadow .15s,border-color .15s,transform .15s;display:flex;position:relative;box-shadow:0 1px 2px #00000008}.adm-clipart-card:hover{border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.adm-clipart-card.is-disabled{opacity:.55}.adm-clipart-card.is-selected{border-color:#1056ae;box-shadow:0 0 0 3px #1056ae26}.adm-clipart-checkbox{cursor:pointer;accent-color:#1056ae;z-index:2;width:16px;height:16px;position:absolute;top:8px;left:8px}.adm-clipart-preview-wrap{aspect-ratio:1;background:#f9fafb;border-radius:8px;justify-content:center;align-items:center;width:100%;padding:12px;display:flex}.adm-clipart-info{flex-direction:column;gap:4px;min-height:32px;display:flex}.adm-clipart-info strong{color:#111827;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;line-height:1.2;overflow:hidden}.adm-clipart-subcat{color:#1056ae;font-size:11px;font-weight:500}.adm-clipart-tags{flex-wrap:wrap;gap:3px;display:flex}.adm-tag{color:#475569;background:#eef2f7;border-radius:999px;padding:1px 6px;font-size:10px}.adm-clipart-actions{border-top:1px solid #f3f4f6;align-items:center;gap:6px;padding-top:8px;display:flex}.adm-clipart-actions .adm-toggle{margin-right:auto}.adm-variant-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.adm-variant-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;gap:12px;padding:16px;transition:box-shadow .15s,border-color .15s;display:flex;box-shadow:0 1px 2px #00000008}.adm-variant-card:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #0000000f}.adm-variant-card.is-disabled{opacity:.55}.adm-variant-head{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.adm-variant-head strong{color:#111827;font-size:15px;font-weight:600}.adm-variant-id{color:#9ca3af;font-family:SFMono-Regular,Consolas,monospace;font-size:11px}.adm-variant-fields{color:#374151;grid-template-columns:max-content 1fr;gap:4px 12px;margin:0;font-size:12px;display:grid}.adm-variant-fields dt{color:#6b7280;font-weight:500}.adm-variant-fields dd{color:#111827;margin:0}.adm-variant-actions{border-top:1px solid #f3f4f6;align-items:center;gap:8px;padding-top:10px;display:flex}.adm-variant-actions .adm-toggle{margin-right:auto}.adm-connection-bar{background:#fff;border:1px solid #e5e7eb;border-radius:12px;align-items:center;gap:12px;max-width:1200px;margin:0 auto 20px;padding:14px 18px;display:flex;box-shadow:0 1px 2px #00000008}.adm-connection-status{flex:1;align-items:center;gap:12px;display:flex}.adm-connection-status>div{flex-direction:column;gap:2px;display:flex}.adm-connection-status strong{color:#111827;font-size:14px;font-weight:600}.adm-connection-status small{color:#6b7280;font-size:12px}.adm-connection-status small code{background:#f3f4f6;border-radius:3px;padding:1px 5px;font-family:SFMono-Regular,Consolas,monospace}.adm-connection-dot{background:#10b981;border-radius:50%;width:10px;height:10px;box-shadow:0 0 0 4px #10b98126}.adm-toolbar-label{color:#374151;align-items:center;gap:6px;font-size:13px;display:inline-flex}.adm-canva-theme-panel{background:#fff;border:1px solid #dbeafe;border-radius:8px;grid-template-columns:minmax(220px,.8fr) minmax(0,1.8fr);align-items:start;gap:14px;max-width:1200px;margin:0 auto 16px;padding:14px;display:grid}.adm-canva-theme-panel h2{color:#111827;margin:0 0 4px;font-size:15px;font-weight:700}.adm-canva-theme-panel p{color:#6b7280;margin:0;font-size:12px;line-height:1.45}.adm-canva-theme-form{grid-template-columns:minmax(220px,1.4fr) minmax(140px,.8fr) minmax(110px,.55fr) minmax(100px,.55fr) auto auto;align-items:center;gap:8px;display:grid}@media (max-width:900px){.adm-canva-theme-panel,.adm-canva-theme-form{grid-template-columns:1fr}}.adm-tab-switcher{background:#fff;border:1px solid #e5e7eb;border-radius:10px;gap:4px;width:max-content;max-width:1200px;margin:0 auto 16px;padding:4px;display:flex}.adm-tab{cursor:pointer;color:#6b7280;background:0 0;border:0;border-radius:7px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.adm-tab:hover{color:#111827;background:#f3f4f6}.adm-tab.is-active{color:#fff;background:#1056ae;font-weight:600}.adm-search-bar{flex-wrap:wrap;align-items:center;gap:10px;max-width:1200px;margin:0 auto 16px;display:flex}.adm-success-banner{color:#047857;background:#d1fae5;border:1px solid #a7f3d0;border-radius:8px;max-width:1200px;margin:0 auto 16px;padding:10px 14px;font-size:13px}.adm-filter-chip{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #d1d5db;border-radius:999px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500}.adm-filter-chip:hover{color:#111827;background:#f9fafb}.adm-filter-chip.is-active{color:#fff;background:#1056ae;border-color:#1056ae}.panel-add-photo-slot{color:#1056ae;cursor:pointer;background:#fff;border:1.5px dashed #1056ae;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:14px;padding:10px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:background .1s,border-color .1s;display:inline-flex}.panel-add-photo-slot:hover{background:#1056ae0d;border-color:#0d4a96}.adm-canva-kind{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:9px;font-weight:700}.adm-canva-actions{border-top:1px solid #f3f4f6;flex-direction:column;gap:6px;padding-top:10px;display:flex}.adm-canva-import-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:7px 10px;font-family:inherit;font-size:12px;font-weight:500}.adm-canva-import-btn:hover:not(:disabled){background:#f9fafb}.adm-canva-import-btn:disabled{opacity:.5;cursor:not-allowed}.adm-canva-import-page{color:#fff;background:#1056ae;border-color:#1056ae}.adm-canva-import-page:hover:not(:disabled){background:#0d4a96}.adm-canva-import-all{color:#fff;background:#10b981;border-color:#10b981;font-weight:600}.adm-canva-import-all:hover:not(:disabled){background:#059669}.gift-crosssell{background:linear-gradient(135deg, var(--ca-rose-soft) 0%, var(--ca-cream) 70%);border:1px solid var(--ca-rose);border-radius:var(--ca-radius-xl);justify-content:space-between;align-items:center;gap:24px;max-width:1200px;margin:28px auto 0;padding:22px 28px;display:flex;box-shadow:0 1px 2px #2a25210a,0 16px 38px -18px #9b5a7247}.gift-crosssell-body{min-width:0}.gift-crosssell-title{font-family:var(--ca-font-serif);color:var(--ca-ink-warm);margin:0;font-size:24px;font-weight:600;line-height:1.2}.gift-crosssell-sub{color:var(--ca-text-secondary);margin:6px 0 0;font-size:14px}.gift-crosssell-cta{background:var(--ca-rose-ink);color:#fff;border-radius:var(--ca-radius-pill);cursor:pointer;white-space:nowrap;transition:background var(--ca-tr-fast), transform .3s var(--ca-ease-premium);border:none;flex-shrink:0;padding:11px 22px;font-size:14px;font-weight:600}.gift-crosssell-cta:hover{background:#874c61;transform:translateY(-1px)}.gift-crosssell-cta:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width:600px){.gift-crosssell{flex-direction:column;align-items:flex-start;gap:16px;padding:20px}.gift-crosssell-title{font-size:21px}.gift-crosssell-cta{width:100%;padding:12px}}.start-choice-overlay{z-index:280;-webkit-backdrop-filter:blur(6px)saturate(1.1);backdrop-filter:blur(6px)saturate(1.1);background:#2a252180;justify-content:center;align-items:center;padding:24px;animation:.2s confirmBackdropIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.start-choice-modal{background:linear-gradient(160deg, var(--ca-cream) 0%, var(--ca-bg-surface) 60%);border:1px solid var(--ca-border-default);border-radius:var(--ca-radius-xl);width:100%;max-width:720px;max-height:calc(100dvh - 48px);box-shadow:var(--ca-shadow-xl);text-align:center;animation:confirmDialogIn .28s var(--ca-ease-spring);padding:40px 36px 28px;position:relative;overflow-y:auto}.start-choice-head{margin-bottom:26px}.start-choice-title{font-family:var(--ca-font-serif);font-size:var(--ca-text-3xl);color:var(--ca-ink-warm);font-weight:700;line-height:var(--ca-line-tight);letter-spacing:var(--ca-tracking-tight);margin:0 0 8px}.start-choice-sub{font-size:var(--ca-text-md);color:var(--ca-text-secondary);line-height:var(--ca-line-snug);margin:0}.start-choice-cards{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px;display:grid}.start-choice-card{text-align:center;background:var(--ca-bg-surface);border:1.5px solid var(--ca-border-default);border-radius:var(--ca-radius-lg);cursor:pointer;transition:border-color .18s ease, box-shadow .18s ease, transform var(--ca-dur-fast) var(--ca-ease-spring);flex-direction:column;align-items:center;gap:10px;padding:28px 22px 24px;font-family:inherit;display:flex;position:relative}.start-choice-card:hover{border-color:var(--ca-blue);box-shadow:var(--ca-shadow-lg);transform:translateY(-2px)}.start-choice-card:active{transform:translateY(0)scale(.99)}.start-choice-card:focus-visible{outline:2px solid var(--ca-border-focus);outline-offset:2px}.start-choice-card-auto{background:linear-gradient(165deg, var(--ca-rose-soft) 0%, var(--ca-bg-surface) 70%);border-color:var(--ca-rose)}.start-choice-card-auto:hover{border-color:var(--ca-rose-ink)}.start-choice-badge{background:var(--ca-rose);color:var(--ca-rose-ink);border-radius:var(--ca-radius-pill);font-size:var(--ca-text-xs);letter-spacing:var(--ca-tracking-wide);text-transform:uppercase;white-space:nowrap;padding:3px 12px;font-weight:700;position:absolute;top:-11px;left:50%;transform:translate(-50%)}.start-choice-icon{background:var(--ca-bg-subtle);width:60px;height:60px;color:var(--ca-blue);border-radius:50%;justify-content:center;align-items:center;margin-bottom:2px;display:inline-flex}.start-choice-card-auto .start-choice-icon{color:var(--ca-rose-ink);background:#fad2e28c}.start-choice-card-title{font-size:var(--ca-text-xl);color:var(--ca-text-primary);font-weight:700;line-height:var(--ca-line-tight)}.start-choice-card-desc{font-size:var(--ca-text-sm);color:var(--ca-text-secondary);line-height:var(--ca-line-normal);max-width:24ch}.start-choice-cta{background:var(--ca-blue);color:#fff;border-radius:var(--ca-radius-pill);width:100%;font-size:var(--ca-text-sm);margin-top:auto;padding:9px 18px;font-weight:600;line-height:1.2}.start-choice-card:hover .start-choice-cta{background:var(--ca-blue-dark)}.start-choice-cta-ghost{color:var(--ca-blue);border:1.5px solid var(--ca-blue);background:0 0}.start-choice-card:hover .start-choice-cta-ghost{background:var(--ca-blue-light);color:var(--ca-blue)}.start-choice-skip{color:var(--ca-text-muted);font-size:var(--ca-text-sm);cursor:pointer;border-radius:var(--ca-radius-sm);background:0 0;border:none;margin:4px auto 0;padding:8px 14px;font-family:inherit;transition:color .15s,background .15s}.start-choice-skip:hover{color:var(--ca-text-primary);background:var(--ca-bg-hover)}@media (max-width:768px){.start-choice-overlay{align-items:flex-end;padding:14px}.start-choice-modal{border-bottom-left-radius:var(--ca-radius-lg);border-bottom-right-radius:var(--ca-radius-lg);max-height:calc(100dvh - 28px);padding:30px 20px 20px}.start-choice-title{font-size:var(--ca-text-2xl)}.start-choice-head{margin-bottom:22px}.start-choice-cards{grid-template-columns:1fr;gap:22px}.start-choice-card{padding:22px 18px 18px}.start-choice-icon{width:52px;height:52px}}@media (prefers-reduced-motion:reduce){.start-choice-overlay,.start-choice-modal{animation:none}.start-choice-card{transition:border-color .18s,box-shadow .18s}}
