@import"https://fonts.googleapis.com/css2?family=Frank+Ruhl+Libre:wght@400;500;700&family=Heebo:wght@300;400;500;700&family=Secular+One&display=swap";@import"https://fonts.googleapis.com/css2?family=Frank+Ruhl+Libre:wght@400;700&family=Heebo:wght@300;400;500;700&family=Secular+One&display=swap";@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@400;600&family=Heebo:wght@300;400;700;900&family=Secular+One&display=swap";@import"https://fonts.googleapis.com/css2?family=Frank+Ruhl+Libre:wght@300;400;700&family=Heebo:wght@300;400;700;900&family=Secular+One&display=swap";@import"https://fonts.googleapis.com/css2?family=Heebo:wght@300;400;700;900&family=Secular+One&display=swap";@import"https://fonts.googleapis.com/css2?family=Pinyon+Script&family=Cormorant+Garamond:wght@400;500;600&family=Montserrat:wght@300;400;500&display=swap";:root{--bg-dark: #0f172a;--bg-panel: #1e293b;--bg-hover: #334155;--accent: #8b5cf6;--accent-hover: #7c3aed;--text-main: #f8fafc;--text-muted: #94a3b8;--border: #334155;--sidebar-width: 320px;--sidebar-collapsed: 64px;--properties-width: 280px;--timeline-height: 140px;--header-height: 60px}*{box-sizing:border-box}body{margin:0;padding:0;font-family:Inter,sans-serif;background-color:var(--bg-dark);color:var(--text-main);overflow:hidden;height:100vh}#app-container{display:grid;grid-template-columns:auto 1fr var(--properties-width);grid-template-rows:1fr var(--timeline-height);height:100vh;width:100vw}#sidebar-left{grid-column:1;grid-row:1 / -1;display:flex;background-color:var(--bg-panel);border-right:1px solid var(--border);z-index:10;min-height:0;overflow:hidden}.sidebar-nav{width:var(--sidebar-collapsed);background-color:#0f172a;display:flex;flex-direction:column;align-items:center;padding-top:20px;gap:20px;border-right:1px solid var(--border)}.nav-item{width:44px;height:44px;border-radius:12px;border:none;background:transparent;color:var(--text-muted);font-size:1.2rem;cursor:pointer;transition:all .2s}.nav-item:hover{background-color:var(--bg-hover);color:var(--text-main)}.nav-item.active{background-color:var(--accent);color:#fff}.sidebar-content{width:calc(var(--sidebar-width) - var(--sidebar-collapsed));display:flex;flex-direction:column;height:100%;overflow:hidden}.tab-pane{display:none;height:100%;flex-direction:column}.tab-pane.active{display:flex}.panel-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid var(--border)}.panel-header h3{margin:0;font-size:1rem;font-weight:600}.asset-grid,.asset-list{padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:12px;overflow-y:auto;flex:1;min-height:0}.asset-item{aspect-ratio:1;background-color:var(--bg-hover);border-radius:8px;overflow:hidden;cursor:grab;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s cubic-bezier(.175,.885,.32,1.275);background-position:center;background-size:cover;box-shadow:0 4px 6px #0000001a;position:relative;z-index:1}.asset-item.dealing{animation:solitaire-deal .45s cubic-bezier(.23,1,.32,1) forwards;animation-delay:calc(var(--deal-index, 0) * 60ms);opacity:0;transform:translate(-80px,-60px) rotate(-15deg) scale(.6)}@keyframes solitaire-deal{0%{opacity:0;transform:translate(-80px,-60px) rotate(-15deg) scale(.6);box-shadow:0 20px 40px #00000080}60%{opacity:1;transform:translate(4px,-4px) rotate(2deg) scale(1.04);box-shadow:-4px 10px 20px #0000004d}80%{transform:translate(-2px,2px) rotate(-1deg) scale(.98)}to{opacity:1;transform:translate(0) rotate(0) scale(1);box-shadow:0 4px 6px #0000001a}}.asset-item:hover,.cover-gallery-item:hover{transform:translateY(-8px) scale(1.05) rotate(2deg);box-shadow:-5px 15px 25px #0006;z-index:10}.cover-gallery-item{transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s cubic-bezier(.175,.885,.32,1.275)}.text-style-item span{font-size:32px!important;pointer-events:none}#workspace{grid-column:2;grid-row:1;background-color:#020617;position:relative;display:flex;flex-direction:column;overflow:hidden;min-height:0;min-width:0}.toolbar-top{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:5}.btn-tool{background:transparent;border:1px solid var(--border);color:var(--text-main);width:40px;height:40px;border-radius:8px;cursor:pointer;margin-right:8px}.btn-tool:hover{background:var(--bg-hover)}.btn-pill{background:linear-gradient(135deg,var(--accent),#ec4899);border:none;color:#fff;padding:10px 20px;border-radius:20px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #8b5cf64d;transition:transform .2s}.btn-pill:hover{transform:translateY(-1px)}.btn-primary{background-color:#fff;color:#000;border:none;padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer}.btn-secondary{background:transparent;color:#fff;border:1px solid var(--border);padding:10px 20px;border-radius:6px;margin-left:10px;cursor:pointer}#canvas-viewport{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}#canvas-container{width:80%;height:80%;display:flex;align-items:center;justify-content:center}.force-ltr{direction:ltr!important}.shoso-page{background:#fff;box-shadow:0 20px 50px #00000080;position:relative;width:600px;height:400px;transform-origin:center center;transition:transform .3s cubic-bezier(.25,.8,.25,1)}.album-page{background:#fff;box-shadow:0 20px 50px #00000080;position:relative;width:800px;height:600px;transform-origin:center center;margin:0 auto;overflow:hidden}.drop-target-active{outline:2px dashed var(--accent);outline-offset:-4px}.drag-over-slot{outline:3px solid var(--accent)!important;outline-offset:-2px;box-shadow:0 0 15px #8b5cf699;background-color:#8b5cf61a;transform:scale(1.02);transition:all .1s ease;z-index:10}#sidebar-right{grid-column:3;grid-row:1;background-color:var(--bg-panel);border-left:1px solid var(--border);display:flex;flex-direction:column;min-height:0;overflow:hidden}#properties-panel{padding:20px;overflow-y:auto}#timeline-bar{grid-column:2 / -1;grid-row:2;background-color:var(--bg-panel);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px}#page-timeline{flex:1;display:flex;gap:12px;overflow-x:auto;padding:10px 0;scrollbar-width:none}.timeline-page{width:100px;aspect-ratio:4/3;background:#334155;border-radius:4px;flex-shrink:0;cursor:pointer;border:2px solid transparent;overflow:hidden;position:relative}.timeline-page.active{border-color:var(--accent);box-shadow:0 0 0 2px #8b5cf64d}.btn-add-page{background:var(--bg-hover);border:1px dashed var(--text-muted);color:var(--text-muted);padding:0 20px;height:80px;border-radius:4px;cursor:pointer}.btn-add-page:hover{background:#334155;color:#fff;border-color:#fff}.empty-state{color:var(--text-muted);text-align:center;margin-top:40px;font-size:.9rem}.selected{box-shadow:0 0 0 2px var(--accent);z-index:100!important}.prop-group{margin-bottom:24px}.prop-group label{display:block;color:var(--text-muted);font-size:.85rem;margin-bottom:12px;font-weight:500}.prop-group input[type=range],.prop-group textarea,.prop-group select,.prop-group input[type=text],.full-width{width:100%;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:10px;border-radius:8px;font-family:inherit;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:border-color .2s}.prop-group input:focus,.prop-group select:focus,.prop-group textarea:focus{outline:none;border-color:var(--accent);background:#ffffff1a}.layout-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.layout-btn{aspect-ratio:4/3;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.layout-btn:hover{background:#ffffff26;border-color:#ffffff4d}.layout-btn.active{background:#8b5cf633;border-color:var(--accent);box-shadow:0 0 10px #8b5cf61a}input[type=range]{-webkit-appearance:none;appearance:none;background:transparent;padding:0;margin:10px 0;border:none;-webkit-backdrop-filter:none;backdrop-filter:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;height:16px;width:16px;border-radius:50%;background:var(--accent);cursor:pointer;margin-top:-6px;box-shadow:0 0 10px #00000080}input[type=range]::-webkit-slider-runnable-track{width:100%;height:4px;cursor:pointer;background:#fff3;border-radius:2px}.color-picker-wrapper{display:flex;align-items:center;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899);border-radius:8px;padding:2px;cursor:pointer;height:40px;position:relative}.color-input-hidden{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.color-icon{margin-left:auto;margin-right:12px;color:#fff;filter:drop-shadow(0 2px 2px rgba(0,0,0,.5))}body.preview-mode #sidebar-left,body.preview-mode #sidebar-right,body.preview-mode .toolbar-top,body.preview-mode #timeline-bar{display:none!important}body.preview-mode #app-container{grid-template-columns:1fr;grid-template-rows:1fr}body.preview-mode #workspace{grid-column:1 / -1;grid-row:1 / -1}#btn-preview{z-index:999}body.preview-mode .toolbar-top{display:flex!important;position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#00000080;border-radius:20px;width:auto;padding:10px;height:auto}body.preview-mode .toolbar-top .toolbar-group:not(:last-child){display:none}.modal{display:none;position:fixed;z-index:100000;left:0;top:0;width:100%;height:100%;background-color:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal.active{display:flex;align-items:center;justify-content:center}.modal-content{background-color:var(--bg-panel);padding:30px;border-radius:16px;max-width:400px;width:90%;text-align:center;position:relative;color:var(--text-main);border:1px solid var(--border);box-shadow:0 20px 50px #00000080;animation:modalPop .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes modalPop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.close-btn{position:absolute;right:15px;top:10px;font-size:24px;border:none;background:none;cursor:pointer;color:var(--text-muted);transition:color .2s}.close-btn:hover{color:#fff}.modal-body h2{margin-top:0;font-family:Playfair Display,serif}#btn-download-trigger{display:inline-flex;justify-content:center;align-items:center;text-decoration:none;margin-top:10px;width:100%}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000b3;z-index:100001;display:none;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-overlay[style*="display: block"]{display:flex!important}#magic-create-modal{z-index:200000!important}#magic-create-modal .modal-content{background:#1e293b;background:linear-gradient(to bottom,#1e293b,#0f172a);border:1px solid rgba(139,92,246,.2);box-shadow:0 25px 50px -12px #000000b3;padding:0;overflow:hidden;max-width:550px}#magic-create-modal .modal-header{background:linear-gradient(135deg,#a855f7,#6366f1);color:#fff;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1)}#magic-create-modal .modal-header h3{margin:0;font-size:1.2rem;font-weight:600;display:flex;align-items:center;gap:10px}#magic-create-modal .modal-body{padding:24px;text-align:left}#magic-create-modal p{color:#94a3b8;margin-top:0;line-height:1.5}#magic-create-modal textarea{width:100%;background:#0f172a80;border:1px solid #334155;color:#f8fafc;padding:16px;border-radius:8px;font-family:inherit;font-size:1rem;resize:vertical;margin:16px 0 24px;transition:all .2s;outline:none}#magic-create-modal textarea:focus{border-color:#a855f7;background:#0f172acc;box-shadow:0 0 0 2px #a855f733}#magic-create-modal .button-group{display:flex;justify-content:flex-end;gap:12px}.smart-crop-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:32px;height:32px;border:3px solid rgba(255,255,255,.4);border-top:3px solid #fff;border-radius:50%;animation:smart-crop-spin 1s linear infinite;z-index:10;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}@keyframes smart-crop-spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.photo-slot.crop-active{box-shadow:0 0 0 2px #4285f4,0 0 0 4px #4285f44d;z-index:100!important}.photo-slot.crop-active img{opacity:.9;filter:brightness(1.1);pointer-events:none}@keyframes spin{to{transform:rotate(360deg)}}.online-users-container{display:flex;align-items:center;gap:4px;margin-right:12px}.online-avatar{width:32px;height:32px;border-radius:50%;background-color:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border:2px solid var(--bg-dark);position:relative;cursor:pointer;background-size:cover;background-position:center;margin-left:-8px;transition:transform .2s}.online-avatar:first-child{margin-left:0}.online-avatar:hover{transform:translateY(-2px);z-index:10!important}.online-avatar:after{content:"";position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;background-color:#22c55e;border-radius:50%;border:2px solid var(--bg-dark)}.mobile-menu-toggle{display:none}.album-page.photography-portfolio,.shoso-page.photography-portfolio-v1{background-color:#fff}.album-page .page-header,.shoso-page .page-header{pointer-events:none}.album-page .page-header .studio-name,.album-page .page-header .year,.shoso-page .page-header .studio-name,.shoso-page .page-header .year{font-family:Poppins,sans-serif;color:#fff}.album-page .photo-slot,.shoso-page .photo-slot{z-index:1}.album-page .photo-slot.rounded,.shoso-page .photo-slot.rounded{border-radius:8px;overflow:hidden}.album-page .photo-slot.pill,.shoso-page .photo-slot.pill{border-radius:100px;overflow:hidden}.album-page .photo-slot img,.shoso-page .page-slot img{display:block;width:100%;height:100%;object-fit:cover}.album-page .text-element,.shoso-page .text-element{z-index:10;color:#fff}.album-page .text-title,.album-page .text-categoryTitle,.album-page .text-greeting,.shoso-page .element-text.text-title,.shoso-page .element-text.text-categoryTitle{font-family:Allura,cursive;text-shadow:0 2px 10px rgba(0,0,0,.2)}.album-page .text-subtitle,.album-page .text-categorySubtitle,.album-page .text-label,.album-page .text-body,.shoso-page .element-text.text-subtitle{font-family:Poppins,sans-serif}.album-page .text-studioName,.shoso-page .element-text.text-studioName{font-family:Poppins,sans-serif;font-weight:700}.album-page.photography-portfolio.charcoal,.shoso-page.photography-portfolio-v1.charcoal{background-color:#2d2d2d}.album-page.photography-portfolio.navy,.shoso-page.photography-portfolio-v1.navy{background-color:#1e3a5f}.album-page.photography-portfolio.forest,.shoso-page.photography-portfolio-v1.forest{background-color:#2d4a3e}.album-page.photography-portfolio.burgundy,.shoso-page.photography-portfolio-v1.burgundy{background-color:#722f37}.album-page.cover-hero .text-title,.shoso-page.cover-hero .text-title{font-size:96px}.album-page .text-label,.shoso-page .text-label{font-size:12px;font-weight:400;opacity:.85}.album-page.travel-journey{background-color:#fff}.album-page.travel-journey .photo-slot{z-index:1}.album-page.travel-journey .photo-slot img{display:block;width:100%;height:100%;object-fit:cover}.album-page.travel-journey .text-element{z-index:10}.album-page.travel-journey .text-title,.album-page.travel-journey .text-locationTitle{font-family:Playfair Display,Georgia,serif;font-style:italic;color:#398458}.album-page.travel-journey .text-body,.album-page.travel-journey .text-description{font-family:Lato,sans-serif;color:#545454}.album-page.travel-journey .text-quote{font-family:Playfair Display,Georgia,serif;font-style:italic;color:#545454}.album-page.travel-journey .decoration-overlay{z-index:5}.album-page.travel-journey.ocean .text-title,.album-page.travel-journey.ocean .text-locationTitle{color:#2e6b8a}.album-page.travel-journey.sunset .text-title,.album-page.travel-journey.sunset .text-locationTitle{color:#c4622d}.album-page.travel-journey.desert .text-title,.album-page.travel-journey.desert .text-locationTitle{color:#a67c52}.album-page.travel-journey.mountain .text-title,.album-page.travel-journey.mountain .text-locationTitle{color:#4a5568}.album-page.travel-journey.tropical .text-title,.album-page.travel-journey.tropical .text-locationTitle{color:#0d9488}@media print{.album-page.travel-journey{page-break-after:always}}.album-page.bar-mitzvah{font-family:Heebo,sans-serif;direction:rtl}.text-display{font-family:Frank Ruhl Libre,serif}.text-heading{font-family:Heebo,sans-serif}.text-decorative{font-family:Secular One,sans-serif}.album-page.wedding-prestige{background:#0d0d0d;font-family:Heebo,sans-serif;direction:rtl;width:100%;height:100%;position:relative;overflow:hidden;box-shadow:0 30px 100px #000c}.album-page.wedding-prestige *{box-sizing:border-box}.album-page.wedding-prestige h1{color:#c9a962;text-align:center;margin-bottom:8px;font-family:Frank Ruhl Libre,serif;font-weight:300;font-size:56px;letter-spacing:12px}.album-page.wedding-prestige .subtitle{color:#b8b0a0;text-align:center;margin-bottom:60px;font-size:14px;font-weight:200;letter-spacing:4px}.album-page.wedding-prestige.dark{background:#0d0d0d}.album-page.wedding-prestige.light{background:#fdfcfa}.album-page.wedding-prestige .photo{position:absolute;background:#2c2c2c;overflow:hidden}.album-page.wedding-prestige .photo img{width:100%;height:100%;object-fit:cover}.album-page.wedding-prestige .photo.editorial{box-shadow:0 20px 60px #0006}.album-page.wedding-prestige .photo.framed{border:2px solid #C9A962;box-shadow:0 15px 50px #0000004d}.album-page.wedding-prestige .photo.arch{border-radius:300px 300px 0 0;box-shadow:0 20px 60px #0000004d}.album-page.wedding-prestige .photo.circle{border-radius:50%;border:3px solid #C9A962;box-shadow:0 15px 50px #00000040}.album-page.wedding-prestige .photo.hexagon{clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}.album-page.wedding-prestige .overlay{position:absolute;inset:0;pointer-events:none;z-index:5}.album-page.wedding-prestige .gold-line{position:absolute;height:1px;background:linear-gradient(90deg,transparent,#C9A962,transparent);z-index:5}.album-page.wedding-prestige .vertical-line{position:absolute;width:1px;background:#c9a962;z-index:5}.album-page.wedding-prestige .film-strip{position:absolute;height:18px;background:repeating-linear-gradient(90deg,#1a1a1a,#1a1a1a 20px,#0d0d0d 20px 24px);z-index:6}.album-page.wedding-prestige .text-hebrew{font-family:Frank Ruhl Libre,serif}.album-page.wedding-prestige .text-display{font-family:Cormorant Garamond,serif}.album-page.wedding-prestige .text-accent{font-family:Cinzel,serif}.album-page.wedding-prestige .text-body{font-family:Heebo,sans-serif}.album-page.wedding-prestige .gold{color:#c9a962}.album-page.wedding-prestige .light{color:#fdfcfa}.album-page.wedding-prestige .secondary{color:#b8b0a0}.album-page.wedding-prestige .dark{color:#0d0d0d}.album-page.wedding-prestige .dark-secondary{color:#4a4540}.album-page.wedding-prestige .centered{text-align:center}.album-page.wedding-prestige .text-element{z-index:20}.album-page.wedding-prestige.cover .overlay{background:linear-gradient(to bottom,#0d0d0d4d,#0d0d0d1a 40%,#0d0d0dcc)}.album-page.wedding-prestige.cover .top-label{font-size:12px;font-weight:400;letter-spacing:6px}.album-page.wedding-prestige.cover .groom-name{font-size:56px;font-weight:300;letter-spacing:8px}.album-page.wedding-prestige.cover .ampersand{font-size:28px;font-weight:300}.album-page.wedding-prestige.cover .bride-name{font-size:56px;font-weight:300;letter-spacing:8px}.album-page.wedding-prestige.cover .date{font-size:13px;font-weight:200;letter-spacing:4px}.album-page.wedding-prestige.intro .chapter-num{font-size:100px;font-weight:400;opacity:.2}.album-page.wedding-prestige.intro .chapter-title{font-size:48px;font-weight:500}.album-page.wedding-prestige.intro .subtitle-text{font-size:16px;font-weight:300;line-height:1.8}.album-page.wedding-prestige.split .center-text{font-size:36px;font-weight:700;text-shadow:0 4px 30px rgba(0,0,0,.8)}.album-page.wedding-prestige.filmstrip .title{font-size:32px;font-weight:300;letter-spacing:12px}.album-page.wedding-prestige.filmstrip .subtitle-text{font-size:12px;font-weight:200;letter-spacing:3px}.album-page.wedding-prestige.hexagon-page .title{font-size:24px;font-weight:400}.album-page.wedding-prestige.asymmetric .quote{font-size:22px;font-weight:400;line-height:1.7;text-align:right}.album-page.wedding-prestige.asymmetric .attribution{font-size:11px;font-weight:200;letter-spacing:2px;text-align:right}.album-page.wedding-prestige.chuppah .overlay{background:linear-gradient(to top,rgba(13,13,13,.9) 0%,rgba(13,13,13,.2) 30%,transparent 60%)}.album-page.wedding-prestige.chuppah .title{font-size:44px;font-weight:500;letter-spacing:6px}.album-page.wedding-prestige.chuppah .blessing{font-size:14px;font-weight:200;line-height:1.6}.album-page.wedding-prestige.rings .title{font-size:28px;font-weight:500}.album-page.wedding-prestige.rings .subtitle-text{font-size:14px;font-weight:300}.album-page.wedding-prestige.timeline .time{font-size:14px;font-weight:400;letter-spacing:2px;text-align:center}.album-page.wedding-prestige.timeline .label{font-size:12px;font-weight:300;text-align:center}.album-page.wedding-prestige.timeline .title{font-size:28px;font-weight:300;letter-spacing:6px}.album-page.wedding-prestige.dance .overlay{background:radial-gradient(ellipse at center,transparent 0%,rgba(13,13,13,.7) 100%)}.album-page.wedding-prestige.dance .side-text{font-size:42px;font-weight:300;line-height:1.3;letter-spacing:4px;text-align:right}.album-page.wedding-prestige.arch-dramatic .left-text{font-size:24px;font-weight:400;letter-spacing:4px;line-height:1.8;text-align:center}.album-page.wedding-prestige.arch-dramatic .right-text{font-size:24px;font-weight:300;line-height:1.8;text-align:center}.album-page.wedding-prestige.quote-overlay .overlay{background:#0d0d0d99}.album-page.wedding-prestige.quote-overlay .quote{font-size:32px;font-weight:400;line-height:1.7}.album-page.wedding-prestige.quote-overlay .source{font-size:13px;font-weight:200;letter-spacing:3px}.album-page.wedding-prestige.parents .title{font-size:28px;font-weight:400}.album-page.wedding-prestige.parents .caption{font-size:13px;font-weight:400;text-align:center}.album-page.wedding-prestige.parents .dedication{font-size:14px;font-weight:300;font-style:italic}.album-page.wedding-prestige.closing .thanks{font-size:42px;font-weight:300;letter-spacing:8px}.album-page.wedding-prestige.closing .message{font-size:14px;font-weight:200;line-height:1.8}.album-page.wedding-prestige.closing .signature{font-size:20px;font-weight:500}.shoso-page.baby-first-year-hebrew-v1{background:linear-gradient(135deg,#e8b4b8,#a8d4d8);font-family:Heebo,sans-serif;direction:rtl}.shoso-page.baby-first-year-hebrew-v1 h1{color:#5d5a56;text-align:center;margin-bottom:8px;font-family:Rubik,sans-serif;font-weight:700;font-size:42px;line-height:1.2}.shoso-page.baby-first-year-hebrew-v1 .subtitle{color:#5d5a56;text-align:center;margin-bottom:50px;font-size:16px;font-weight:300;opacity:.8}.shoso-page.baby-first-year-hebrew-v1 .pages-container{display:flex;flex-direction:column;align-items:center;gap:50px}.shoso-page.baby-first-year-hebrew-v1 .page-wrapper{display:flex;flex-direction:column;align-items:center}.shoso-page.baby-first-year-hebrew-v1 .page-label{color:#5d5a56;font-size:13px;letter-spacing:2px;margin-bottom:14px;font-weight:500}.shoso-page.baby-first-year-hebrew-v1 .album-page{width:100%;height:100%;position:relative;overflow:hidden;direction:rtl}.shoso-page.baby-first-year-hebrew-v1 .photo{position:absolute;background:linear-gradient(135deg,#f5e6c8,#e8ddd4);display:flex;align-items:center;justify-content:center;overflow:hidden}.shoso-page.baby-first-year-hebrew-v1 .photo img{width:100%;height:100%;object-fit:cover}.shoso-page.baby-first-year-hebrew-v1 .photo.soft{border-radius:20px;box-shadow:0 4px 20px #5d5a5614}.shoso-page.baby-first-year-hebrew-v1 .photo.default{border-radius:12px;box-shadow:0 6px 25px #5d5a561a}.shoso-page.baby-first-year-hebrew-v1 .photo.circle{border-radius:50%;border:5px solid #FFFFFF;box-shadow:0 6px 25px #5d5a561f}.shoso-page.baby-first-year-hebrew-v1 .text-display{font-family:Rubik,sans-serif;color:#5d5a56}.shoso-page.baby-first-year-hebrew-v1 .text-heading{font-family:Heebo,sans-serif;color:#5d5a56}.shoso-page.baby-first-year-hebrew-v1 .text-body{font-family:Heebo,sans-serif;color:#7a7672}.shoso-page.baby-first-year-hebrew-v1 .text-playful{font-family:Varela Round,sans-serif;color:#e8b4b8}.shoso-page.baby-first-year-hebrew-v1 .text-accent{color:#e8b4b8}.shoso-page.baby-first-year-hebrew-v1 .text-light{color:#a09b95}.shoso-page.baby-first-year-hebrew-v1 .centered{text-align:center}.shoso-page.baby-first-year-hebrew-v1 .star{position:absolute;color:#f5e6c8;font-size:20px}.shoso-page.baby-first-year-hebrew-v1 .heart{position:absolute;color:#e8b4b8;font-size:16px}.shoso-page.baby-first-year-hebrew-v1 .cloud{position:absolute;color:#a8d4d8;font-size:30px;opacity:.3}.shoso-page.baby-first-year-hebrew-v1 .dot{position:absolute;width:12px;height:12px;border-radius:50%;background:#e8b4b8;opacity:.4}.shoso-page.baby-first-year-hebrew-v1 .theme-swatch{display:flex;flex-direction:column;align-items:center;gap:10px}.shoso-page.adventure-journal-v1{background:linear-gradient(135deg,#3d6b59,#2c3e2d);font-family:Heebo,sans-serif;direction:rtl}.shoso-page.adventure-journal-v1 h1{color:#f5f0e8;text-align:center;margin-bottom:8px;font-family:Bebas Neue,sans-serif;font-weight:400;font-size:56px;letter-spacing:8px}.shoso-page.adventure-journal-v1 .subtitle{color:#d4a03e;text-align:center;margin-bottom:50px;font-family:Caveat,cursive;font-size:24px}.shoso-page.adventure-journal-v1 .page-label{color:#d4a03e;font-size:12px;letter-spacing:2px;margin-bottom:14px;font-weight:500}.shoso-page.adventure-journal-v1.light{background:#f5f0e8}.shoso-page.adventure-journal-v1.dark{background:#2c3e2d}.shoso-page.adventure-journal-v1.alt{background:#e8e0d0}.shoso-page.adventure-journal-v1 .photo{position:absolute;background:#d4c4a8;overflow:hidden}.shoso-page.adventure-journal-v1 .photo img{width:100%;height:100%;object-fit:cover}.shoso-page.adventure-journal-v1 .photo.polaroid{background:#fff;padding:12px 12px 50px;box-shadow:0 10px 40px #2c3e2d33}.shoso-page.adventure-journal-v1 .photo.polaroid img{width:calc(100% - 24px);height:calc(100% - 62px);position:absolute;top:12px;left:12px}.shoso-page.adventure-journal-v1 .photo.stamp{border:3px dashed #C65D3B}.shoso-page.adventure-journal-v1 .photo.tilted{transform:rotate(-2deg);box-shadow:0 15px 40px #2c3e2d33}.shoso-page.adventure-journal-v1 .photo.default{border-radius:4px;box-shadow:0 8px 30px #2c3e2d26}.shoso-page.adventure-journal-v1 .text-display{font-family:Bebas Neue,sans-serif;color:#2c3e2d}.shoso-page.adventure-journal-v1 .text-handwritten{font-family:Caveat,cursive}.shoso-page.adventure-journal-v1 .text-hebrew{font-family:Heebo,sans-serif}.shoso-page.adventure-journal-v1 .text-mono{font-family:Space Mono,monospace}.shoso-page.adventure-journal-v1 .rust{color:#c65d3b}.shoso-page.adventure-journal-v1 .forest{color:#3d6b59}.shoso-page.adventure-journal-v1 .gold{color:#d4a03e}.shoso-page.adventure-journal-v1 .cream{color:#f5f0e8}.shoso-page.adventure-journal-v1 .dark{color:#2c3e2d}.shoso-page.adventure-journal-v1 .secondary{color:#5a6b5e}.shoso-page.adventure-journal-v1 .light-text{color:#8a9488}.shoso-page.adventure-journal-v1 .centered{text-align:center}.shoso-page.adventure-journal-v1 .dashed-line{position:absolute;border-top:2px dashed #C65D3B}.shoso-page.adventure-journal-v1 .stamp-decoration{position:absolute;width:60px;height:60px;border:3px solid #C65D3B;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Space Mono,monospace;font-size:8px;color:#c65d3b;text-align:center;line-height:1.2}.shoso-page.adventure-journal-v1 .compass{position:absolute;font-size:50px;color:#c65d3b;opacity:.3}.shoso-page.adventure-journal-v1 .map-pin{position:absolute;color:#3d6b59;font-size:24px}.shoso-page.adventure-journal-v1 .tape{position:absolute;width:60px;height:20px;background:#d4c4a8b3;transform:rotate(-10deg)}.adventure-journal-v1 .theme-swatch{display:flex;flex-direction:column;align-items:center;gap:10px}.album-page.bat-mitzvah-v1{background-color:#f9f4fb;box-sizing:border-box;font-family:Heebo,sans-serif;direction:rtl}.album-page.bat-mitzvah-v1 .text-element{z-index:10;pointer-events:auto}.album-page.bat-mitzvah-v1 .text-display{font-family:Gveret Levin AlefAlefAlef,Frank Ruhl Libre,serif;font-weight:400}.album-page.bat-mitzvah-v1 .text-heading{font-family:Frank Ruhl Libre,David Libre,serif}.album-page.bat-mitzvah-v1 .text-body,.album-page.bat-mitzvah-v1 .text-caption{font-family:Heebo,sans-serif}.album-page.bat-mitzvah-v1 .text-decorative{font-family:Secular One,sans-serif}.album-page.bat-mitzvah-v1 .photo-slot{box-shadow:0 4px 20px #9333ea1a;z-index:5}.album-page.bat-mitzvah-v1 .decoration{z-index:1}.album-page.bat-mitzvah-v1[data-page-type=cover],.album-page.bat-mitzvah-v1[data-page-type=closing]{background-color:#f9f4fb}.album-page.bat-mitzvah-v1[data-page-type=intro],.album-page.bat-mitzvah-v1[data-page-type=chapter]{background-color:#f3edf7}.album-page.birthday-v1{background-color:#fffbf0;box-sizing:border-box;font-family:Heebo,sans-serif;direction:rtl}.album-page.birthday-v1 .text-element{z-index:10;pointer-events:auto}.album-page.birthday-v1 .text-display{font-family:Fredoka,Varela Round,sans-serif;font-weight:600}.album-page.birthday-v1 .text-heading{font-family:Heebo,sans-serif;font-weight:700}.album-page.birthday-v1 .text-body,.album-page.birthday-v1 .text-caption{font-family:Heebo,sans-serif}.album-page.birthday-v1 .text-decorative{font-family:Secular One,sans-serif}.album-page.birthday-v1 .photo-slot{box-shadow:0 4px 20px #ff6b3526;z-index:5}.album-page.birthday-v1 .decoration{z-index:1}.album-page.birthday-v1[data-page-type=cover],.album-page.birthday-v1[data-page-type=closing]{background-color:#fffbf0}.album-page.birthday-v1[data-page-type=intro],.album-page.birthday-v1[data-page-type=chapter]{background-color:#fff5e0}.album-page.graduation-v1{background-color:#f0f4f8;box-sizing:border-box;font-family:Heebo,sans-serif;direction:rtl}.album-page.graduation-v1 .text-element{z-index:10;pointer-events:auto}.album-page.graduation-v1 .text-display{font-family:Frank Ruhl Libre,David Libre,serif;font-weight:700}.album-page.graduation-v1 .text-heading{font-family:Heebo,sans-serif;font-weight:700}.album-page.graduation-v1 .text-body,.album-page.graduation-v1 .text-caption{font-family:Heebo,sans-serif}.album-page.graduation-v1 .text-decorative{font-family:Secular One,sans-serif}.album-page.graduation-v1 .photo-slot{box-shadow:0 4px 20px #1b365d1f;z-index:5}.album-page.graduation-v1 .decoration{z-index:1}.album-page.graduation-v1[data-page-type=cover],.album-page.graduation-v1[data-page-type=closing]{background-color:#f0f4f8}.album-page.graduation-v1[data-page-type=intro],.album-page.graduation-v1[data-page-type=chapter]{background-color:#e8edf3}.album-page.army-enlistment-v1{background-color:#f5f2eb;box-sizing:border-box;font-family:Heebo,sans-serif;direction:rtl}.album-page.army-enlistment-v1 .text-element{z-index:10;pointer-events:auto}.album-page.army-enlistment-v1 .text-display{font-family:Secular One,Impact,sans-serif;font-weight:400}.album-page.army-enlistment-v1 .text-heading{font-family:Heebo,sans-serif;font-weight:700}.album-page.army-enlistment-v1 .text-body,.album-page.army-enlistment-v1 .text-caption{font-family:Heebo,sans-serif}.album-page.army-enlistment-v1 .text-decorative{font-family:Secular One,sans-serif}.album-page.army-enlistment-v1 .photo-slot{box-shadow:0 4px 20px #4a5e3a26;z-index:5}.album-page.army-enlistment-v1 .decoration{z-index:1}.album-page.army-enlistment-v1[data-page-type=cover],.album-page.army-enlistment-v1[data-page-type=closing]{background-color:#f5f2eb}.album-page.army-enlistment-v1[data-page-type=intro],.album-page.army-enlistment-v1[data-page-type=chapter]{background-color:#ece8dc}.album-page.engagement-v1{background-color:#fdf7f4;box-sizing:border-box;font-family:Montserrat,Open Sans,sans-serif;direction:rtl}.album-page.engagement-v1 .text-element{z-index:10;pointer-events:auto}.album-page.engagement-v1 .text-display,.album-page.engagement-v1 .text-script{font-family:Pinyon Script,Great Vibes,cursive;font-weight:400}.album-page.engagement-v1 .text-heading{font-family:Cormorant Garamond,Playfair Display,serif}.album-page.engagement-v1 .text-body,.album-page.engagement-v1 .text-caption{font-family:Montserrat,Open Sans,sans-serif}.album-page.engagement-v1 .text-decorative{font-family:Cormorant Garamond,serif;font-weight:600}.album-page.engagement-v1 .photo-slot{box-shadow:0 4px 20px #c4607e1a;z-index:5}.album-page.engagement-v1 .decoration{z-index:1}.album-page.engagement-v1[data-page-type=cover],.album-page.engagement-v1[data-page-type=closing]{background-color:#fdf7f4}.album-page.engagement-v1[data-page-type=intro],.album-page.engagement-v1[data-page-type=chapter]{background-color:#f9efe9}.shoso-page.wedding-prestige-preview-v1{background:linear-gradient(135deg,#faf6ee,#f3ecdb)!important}.shoso-page.wedding-prestige-preview-v1 .page-slot,.shoso-page.wedding-prestige-preview-v1 .layout-slot{border:2px solid #c9a96e;border-radius:1px;box-shadow:0 0 0 1px #e8d5b5,0 3px 15px #a0823c2e}.shoso-page.wedding-prestige-preview-v1 .text-element{font-family:Georgia,serif!important;color:#7a6530!important;font-style:italic}.shoso-page.wedding-prestige-preview-v1:before{content:"";position:absolute;inset:8px;border:1px solid rgba(201,169,110,.25);pointer-events:none;z-index:1}.shoso-page.bar-mitzvah-preview-v1{background:linear-gradient(180deg,#eef1fa,#e4e8f5)!important}.shoso-page.bar-mitzvah-preview-v1 .page-slot,.shoso-page.bar-mitzvah-preview-v1 .layout-slot{border:3px solid #6366f1;border-radius:6px;box-shadow:0 4px 16px #6366f126}.shoso-page.bar-mitzvah-preview-v1 .text-element{font-family:Assistant,Segoe UI,sans-serif!important;color:#3730a3!important;font-weight:700;letter-spacing:1.5px}.shoso-page.photography-portfolio-preview-v1{background:#111!important}.shoso-page.photography-portfolio-preview-v1 .page-slot,.shoso-page.photography-portfolio-preview-v1 .layout-slot{border:none;border-radius:0;box-shadow:none;outline:8px solid #111;outline-offset:-8px}.shoso-page.photography-portfolio-preview-v1 .text-element{font-family:Helvetica Neue,Arial,sans-serif!important;color:#888!important;font-size:9px;letter-spacing:3px;text-transform:uppercase;font-weight:300}.shoso-page.romantic-journey-preview-v1{background:linear-gradient(160deg,#fdf2f5,#fce4ec 40%,#f8e8ef)!important}.shoso-page.romantic-journey-preview-v1 .page-slot,.shoso-page.romantic-journey-preview-v1 .layout-slot{border:1.5px solid #f0a0bb;border-radius:14px;box-shadow:0 2px 20px #dc50821f,inset 0 0 30px #ffffff80}.shoso-page.romantic-journey-preview-v1 .text-element{font-family:Georgia,serif!important;color:#b03060!important;font-style:italic}.shoso-page.romantic-journey-preview-v1:before{content:"";position:absolute;inset:8px;border:1px solid rgba(220,100,140,.12);pointer-events:none;z-index:1}.shoso-page.travel-journey-preview-v1{background:linear-gradient(170deg,#f5f0e5,#ebe5d5,#e8e0cc)!important}.shoso-page.travel-journey-preview-v1 .page-slot,.shoso-page.travel-journey-preview-v1 .layout-slot{border:2px solid #a0926e;border-radius:2px;box-shadow:2px 2px #d4c9a8,4px 4px 12px #64502826}.shoso-page.travel-journey-preview-v1 .text-element{font-family:Courier New,monospace!important;color:#6b5b3e!important;font-size:10px;letter-spacing:2px;text-transform:uppercase;font-weight:600}.shoso-page.travel-journey-preview-v1:before{content:"";position:absolute;inset:8px;border:1px dashed rgba(140,120,80,.2);pointer-events:none;z-index:1}.shoso-page.baby-first-year-preview-v1{background:linear-gradient(135deg,#fef9ee,#fdf3e0,#fef6e8)!important}.shoso-page.baby-first-year-preview-v1 .page-slot,.shoso-page.baby-first-year-preview-v1 .layout-slot{border:2.5px solid #eab54c;border-radius:18px;box-shadow:0 3px 16px #dcaa3c26,inset 0 0 25px #ffffff80}.shoso-page.baby-first-year-preview-v1 .text-element{font-family:Assistant,Segoe UI,sans-serif!important;color:#9a6d1a!important;font-weight:600}.shoso-page.baby-first-year-preview-v1:before{content:"";position:absolute;inset:8px;border:1px solid rgba(200,160,50,.15);pointer-events:none;z-index:1}.shoso-page.family-roots-preview-v1{background:linear-gradient(135deg,#f7f2ec,#ede5d8)!important}.shoso-page.family-roots-preview-v1 .page-slot,.shoso-page.family-roots-preview-v1 .layout-slot{border:2px solid #9c8365;border-radius:3px;box-shadow:0 0 0 4px #f0e8da,0 0 0 5px #c4a882,0 4px 15px #785a3226}.shoso-page.family-roots-preview-v1 .text-element{font-family:Georgia,serif!important;color:#6b5332!important}.shoso-page.family-roots-preview-v1:before{content:"";position:absolute;inset:8px;border:1px solid rgba(140,110,70,.15);pointer-events:none;z-index:1}.book3d-cover-root{position:relative;transform-style:preserve-3d;perspective:2500px;margin:auto;cursor:grab}.book3d-cover-root:active{cursor:grabbing}.book3d-cover-stage{width:100%;height:100%;position:absolute;transform-style:preserve-3d;transition:transform .1s linear}.book3d-cover-face,.book3d-cover-spine,.book3d-cover-foreedge,.book3d-cover-bottom,.book3d-cover-back{position:absolute;backface-visibility:hidden;box-sizing:border-box}.book3d-cover-face{width:100%;height:100%;top:0;left:0;z-index:2;transform:translateZ(calc(var(--book-thickness) / 2));border-radius:2px 4px 4px 2px;transform-style:preserve-3d}.book3d-cover-face .face-outer{width:100%;height:100%;position:absolute;top:0;left:0;backface-visibility:hidden;background:#fff;border-radius:2px 4px 4px 2px;box-shadow:inset 4px 0 10px #0000001a,0 10px 30px #0000004d;overflow:hidden;z-index:2}.book3d-cover-face .face-inner{width:100%;height:100%;position:absolute;top:0;left:0;transform:rotateY(180deg);backface-visibility:hidden;background:#fdfbf7;display:flex;align-items:center;justify-content:center;box-shadow:inset 10px 0 20px #0000000d;border-radius:4px 2px 2px 4px;z-index:1}.book3d-cover-face .face-outer:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 50%,rgba(0,0,0,.1) 100%);pointer-events:none;z-index:10}.book3d-cover-spine{width:var(--book-thickness);height:100%;top:0;left:0;transform:rotateY(-90deg) translateZ(calc(var(--book-thickness) / 2));background:linear-gradient(90deg,#fff3,#fff0 20%,#0000001a,#fff0 80%,#fff3),var(--cover-color);box-shadow:inset 0 2px 4px #0003}.book3d-cover-foreedge{width:calc(var(--book-thickness) - 4px);height:calc(100% - 6px);top:3px;right:0;transform:rotateY(90deg) translateZ(calc(var(--book-thickness) / 2));background:#fdfbf7;background-image:repeating-linear-gradient(to right,#fdfbf7 0px 2px,#e2e8f0 3px);box-shadow:inset 2px 0 5px #0000000d}.book3d-cover-bottom{width:calc(100% - 6px);height:calc(var(--book-thickness) - 4px);bottom:3px;left:3px;transform:rotateX(-90deg) translateZ(calc(var(--book-thickness) / 2));background:#fdfbf7;background-image:repeating-linear-gradient(to bottom,#fdfbf7 0px 2px,#e2e8f0 3px)}.book3d-cover-back{width:100%;height:100%;top:0;left:0;transform:rotateY(180deg) translateZ(calc(var(--book-thickness) / 2));background:var(--cover-color);border-radius:4px 2px 2px 4px;box-shadow:inset -4px 0 10px #0000001a;display:flex;align-items:center;justify-content:center}.book3d{--book-thickness: 24px;position:relative;width:100%;height:100%;transform-style:preserve-3d;perspective:1200px}.book3d-stage{position:absolute;inset:0;transform-style:preserve-3d;transform:rotateX(3deg) rotateY(0)}.page-preview.is-book-spread .book3d-stage{transform:none}.book3d-body{position:absolute;inset:0;border-radius:10px;background:transparent;transform-style:preserve-3d}.book3d-spine,.book3d-foreedge,.book3d-bottom{position:absolute;pointer-events:none;border-radius:10px}.book3d-spine{left:8px;top:10px;bottom:10px;width:var(--book-thickness);background:linear-gradient(180deg,#1e293b59,#1e293b1a);box-shadow:0 10px 28px #00000029}.book3d-foreedge{right:8px;top:10px;bottom:10px;width:var(--book-thickness);background:linear-gradient(180deg,#ffffffe6,#eeeeeed9);border:1px solid rgba(0,0,0,.06);box-shadow:0 10px 28px #0000001f}.book3d-bottom{left:calc(var(--book-thickness) + 8px);right:calc(var(--book-thickness) + 8px);bottom:calc(var(--book-thickness) * -.28);height:var(--book-thickness);background:linear-gradient(90deg,#0000001a,#00000008 40%,#00000014);filter:blur(.2px);opacity:.65}.book3d-spread{position:absolute;top:10px;bottom:10px;left:calc(var(--book-thickness) + 8px);right:calc(var(--book-thickness) + 8px);display:flex;align-items:stretch;gap:0;border-radius:10px;overflow:hidden;background:linear-gradient(180deg,#ffffffa6,#ffffff59);box-shadow:0 18px 55px #00000038}.book3d-gutter{width:18px;background:linear-gradient(90deg,#00000026,#00000008,#00000026);box-shadow:inset 0 0 16px #00000040;flex:0 0 auto}.book3d-page{flex:1 1 0;position:relative;height:100%;display:block;overflow:hidden;background:#fff}.book3d-page .layout-grid{position:absolute;inset:0;padding:2rem;gap:var(--layout-gap, 16px);box-sizing:border-box;grid-auto-rows:1fr}.book3d-page .layout-slot{min-height:0}.book3d-page .page-caption{position:absolute;left:0;right:0;bottom:10px;text-align:center;font-style:italic;font-size:12px;pointer-events:none;z-index:6;padding:0 12px}.book3d-page.is-active{outline:3px solid rgba(44,62,80,.18);outline-offset:-3px}.book3d-page:not(.is-active){filter:saturate(.98) contrast(.98)}.book3d-page:not(.is-active) .layout-grid,.book3d-page:not(.is-active) .layout-slot,.book3d-page:not(.is-active) .edit-photo-btn{pointer-events:none}.book3d-page-activate{position:absolute;inset:0;z-index:5;background:transparent;border:none;cursor:pointer}.book3d-page.is-active .book3d-page-activate{display:none}.book3d-progress{position:absolute;left:50%;bottom:10px;transform:translate(-50%);padding:6px 10px;border-radius:999px;background:#ffffffd9;border:1px solid rgba(0,0,0,.08);color:#1e293bd9;font-size:12px;box-shadow:0 10px 18px #0000001a;z-index:6;-webkit-user-select:none;user-select:none;pointer-events:none}.book3d-flip-layer{position:absolute;inset:0;pointer-events:none;z-index:20;transform-style:preserve-3d}.book3d-sheet{position:absolute;top:0;bottom:0;width:calc((100% - 18px)/2);transform-style:preserve-3d;transition:transform .52s cubic-bezier(.2,.8,.2,1)}.book3d-sheet.is-next{left:calc((100% + 18px)/2);transform-origin:-9px center;transform:rotateY(0)}.book3d-sheet.is-prev{left:0;transform-origin:calc(100% + 9px) center;transform:rotateY(0)}.book3d-sheet.is-flipping{z-index:50}.book3d-sheet.is-next.is-flipping{transform:rotateY(-180deg)}.book3d-sheet.is-prev.is-flipping{transform:rotateY(180deg)}.book3d-sheet-face{position:absolute;inset:0;backface-visibility:hidden;overflow:hidden;border-radius:10px;box-shadow:0 18px 35px #0000002e}.book3d-sheet-face.back{transform:rotateY(180deg)}.book3d-sheet-face .layout-grid{pointer-events:none}:root{--mobile-touch-target: 44px;--mobile-toolbar-height: 54px;--mobile-nav-height: 64px;--mobile-timeline-height: 80px;--mobile-gap: 8px;--mobile-padding: 12px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px)}@media screen and (max-width:767px){*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html,body{overscroll-behavior:none;-webkit-overflow-scrolling:touch;touch-action:manipulation}body{position:fixed;width:100%;height:100%;overflow:hidden}.mobile-menu-toggle{display:inline-flex!important;width:44px;height:44px;min-width:44px;border-radius:10px;background:transparent;border:1px solid var(--border);color:var(--text-main);align-items:center;justify-content:center;font-size:1rem;cursor:pointer;flex-shrink:0}#app-container{display:flex!important;flex-direction:column!important;height:100vh;height:100dvh;width:100vw;overflow:hidden;grid-template-columns:unset!important;grid-template-rows:unset!important}.toolbar-top{height:var(--mobile-toolbar-height);min-height:var(--mobile-toolbar-height);max-height:var(--mobile-toolbar-height);padding:0 8px;padding-top:var(--safe-area-top);flex-wrap:nowrap;gap:5px;background:var(--bg-dark);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-shrink:0;z-index:50;position:relative!important;top:auto!important;left:auto!important;right:auto!important}.toolbar-top::-webkit-scrollbar{display:none}.toolbar-group{display:flex;align-items:center;gap:5px;flex-shrink:0}.toolbar-group.center{position:relative;left:auto;transform:none;flex-shrink:0}.btn-tool{width:44px!important;height:44px!important;min-width:44px!important;max-width:44px!important;margin:0!important;padding:0!important;border-radius:10px;font-size:0!important;display:inline-flex!important;align-items:center;justify-content:center;flex-shrink:0}.btn-tool i{font-size:1rem!important;margin:0!important}.btn-pill,.toolbar-group.center,#btn-new-project{display:none!important}#btn-share-project{width:44px!important;height:44px!important;padding:0!important;margin-right:0!important;gap:0!important;font-size:0!important}.toolbar-top .btn-primary,.toolbar-top .btn-secondary{padding:4px 10px;font-size:.6rem;min-height:36px;white-space:nowrap;flex-shrink:0;border-radius:8px;max-width:80px;overflow:hidden;text-overflow:ellipsis}#btn-preview{width:44px!important;height:44px!important;min-width:44px!important;font-size:0!important;padding:0!important}#btn-preview:before{content:none}#btn-preview i{font-size:1rem!important;display:inline-block!important}#btn-preview .btn-preview-text,.online-users-container{display:none!important}#sidebar-left{display:flex!important;position:fixed!important;inset:auto 0 0!important;height:var(--mobile-nav-height)!important;max-height:var(--mobile-nav-height)!important;width:100%!important;flex-direction:column!important;border-right:none!important;border-top:1px solid var(--border);z-index:100;padding-bottom:var(--safe-area-bottom);background-color:var(--bg-panel);overflow:visible;grid-column:unset!important;grid-row:unset!important;transition:height .3s ease,max-height .3s ease}#sidebar-left.expanded{height:55vh!important;max-height:65vh!important;box-shadow:0 -4px 30px #0006;z-index:500!important;isolation:isolate}#sidebar-left.expanded .sidebar-content{pointer-events:auto;position:relative;z-index:2}.mobile-sheet-handle{display:flex;justify-content:center;align-items:center;padding:10px 0 6px;cursor:grab;flex-shrink:0;touch-action:none;-webkit-user-select:none;user-select:none}.mobile-sheet-handle:active{cursor:grabbing}.mobile-sheet-handle .handle-bar{width:40px;height:5px;background:#ffffff59;border-radius:3px;transition:background .2s,width .2s}.mobile-sheet-handle:active .handle-bar{width:56px;background:#fff9}.sidebar-nav{width:100%;height:var(--mobile-nav-height);min-height:var(--mobile-nav-height);flex-direction:row;padding:4px;gap:2px;border-right:none;border-top:1px solid var(--border);border-bottom:none;justify-content:space-around;background:var(--bg-panel);order:2;flex-shrink:0;overflow-x:auto;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{flex:1;min-width:44px;height:52px;min-height:52px;border-radius:10px;font-size:1rem;flex-shrink:0;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:3px;padding:4px 2px}.nav-item:after{content:attr(data-label);font-size:9px;line-height:1;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;pointer-events:none;display:block!important;text-align:center}.nav-item.active:after{opacity:1}.sidebar-content{width:100%;height:0;order:1;overflow:hidden;transition:height .3s ease}#sidebar-left.expanded .sidebar-content{height:calc(100% - var(--mobile-nav-height));overflow-y:auto;-webkit-overflow-scrolling:touch}.tab-pane{height:100%;display:none;flex-direction:column}.tab-pane.active{display:flex!important}.panel-header{height:40px;padding:0 12px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.panel-header h3{font-size:.85rem}.asset-grid,.asset-list{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;padding:8px}.asset-item{min-width:72px;min-height:72px;border-radius:10px;cursor:pointer!important;position:relative}#sidebar-right{position:fixed!important;top:auto!important;right:0!important;left:0!important;bottom:-60vh!important;width:100%!important;max-width:100%!important;height:56vh;max-height:70vh;transform:none!important;transition:bottom .35s cubic-bezier(.4,0,.2,1);z-index:300;box-shadow:0 -6px 30px #00000080;border-radius:16px 16px 0 0;padding-top:0!important;visibility:hidden;grid-column:unset!important;grid-row:unset!important;background:var(--bg-panel);display:flex;flex-direction:column}#sidebar-right.open{bottom:calc(var(--mobile-nav-height) + var(--safe-area-bottom))!important;visibility:visible}#sidebar-right .properties-sheet-handle{display:flex;justify-content:center;align-items:center;padding:10px 0 4px;flex-shrink:0;touch-action:none;cursor:grab}#sidebar-right .properties-sheet-handle .handle-bar{width:40px;height:4px;background:#ffffff4d;border-radius:3px;transition:width .2s,background .2s}#sidebar-right .properties-sheet-handle:active .handle-bar{width:56px;background:#fff9}#sidebar-right .panel-header{padding:6px 16px 8px;border-bottom:1px solid var(--border);flex-shrink:0}.mobile-panel-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:16px;cursor:pointer}.mobile-panel-close:active{background:var(--bg-hover);color:#fff}#sidebar-right .panel-header:after{display:none}#properties-panel{padding:12px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}#workspace{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;position:relative!important;inset:auto!important;grid-column:unset!important;grid-row:unset!important;padding:0!important}#canvas-viewport{flex:1;padding:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;touch-action:pan-x pan-y pinch-zoom}#canvas-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;touch-action:manipulation}#canvas-viewport .shoso-page,#canvas-viewport .album-page{width:calc(100vw - 16px)!important;height:auto!important;aspect-ratio:4/3;max-height:calc(100% - 8px);transform-origin:center center}#timeline-bar{display:flex!important;flex-shrink:0;background:var(--bg-dark);border-top:1px solid var(--border);height:var(--mobile-timeline-height);min-height:var(--mobile-timeline-height);padding:4px 0;align-items:center;position:relative!important;bottom:auto!important;left:auto!important;right:auto!important;grid-column:unset!important;grid-row:unset!important;margin-bottom:calc(var(--mobile-nav-height) + var(--safe-area-bottom) + 2px)}#page-timeline{display:flex;gap:6px;padding:4px 8px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1}#page-timeline::-webkit-scrollbar{display:none}.timeline-page{width:72px;min-width:72px;aspect-ratio:4/3;scroll-snap-align:center;border-radius:6px;transition:transform .2s,border-color .2s}.timeline-page.active{border:3px solid #a855f7!important;transform:scale(1.06);box-shadow:0 0 0 1px #a855f766}.btn-add-page{min-width:60px;height:auto;padding:4px 8px;font-size:.7rem;flex-shrink:0}.timeline-controls{display:none}.modal-overlay,.modal{z-index:10000}.modal-content{width:95vw!important;max-width:95vw!important;max-height:85vh;margin:auto;border-radius:16px;overflow-y:auto;-webkit-overflow-scrolling:touch}#upload-options-modal .modal-content{max-width:95vw!important}#upload-options-modal .modal-body{flex-direction:column;gap:12px}#upload-options-modal .modal-body button{width:100%;height:56px}#magic-create-modal .modal-content{width:95vw!important;max-width:95vw!important}#magic-create-modal textarea{min-height:80px;font-size:16px}#auto-start-upload-modal .modal-content{width:92vw!important;max-width:92vw!important;padding:24px 16px!important}.mobile-fab{position:fixed;width:48px;height:48px;border-radius:50%;border:none;box-shadow:0 4px 15px #0000004d;z-index:98;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s}.mobile-fab:active{transform:scale(.95)}.mobile-fab-magic{display:flex!important;bottom:calc(var(--mobile-timeline-height) + var(--mobile-nav-height) + var(--safe-area-bottom) + 12px);right:12px;background:linear-gradient(135deg,var(--accent),#ec4899)}.mobile-fab-properties{bottom:calc(var(--mobile-timeline-height) + var(--mobile-nav-height) + var(--safe-area-bottom) + 68px);right:12px;background:var(--bg-hover);border:1px solid var(--border)}.prop-group input[type=text],.prop-group textarea,.prop-group select{min-height:42px;font-size:16px;padding:10px}.prop-group input[type=range]{height:36px;padding:8px 0}input[type=range]::-webkit-slider-thumb{width:22px;height:22px;margin-top:-9px}.layout-selector{grid-template-columns:repeat(3,1fr);gap:6px}.layout-btn{min-height:50px}#photo-library{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))!important;gap:6px!important;padding:8px!important}.photo-slot .btn-remove-slot-photo{opacity:1!important;width:28px!important;height:28px!important}.mobile-tap-selected{outline:3px solid var(--accent, #6366f1)!important;outline-offset:-3px;box-shadow:0 0 0 6px #6366f140!important;transform:scale(.95);transition:all .2s ease}.mobile-drop-highlight{outline:3px dashed var(--accent, #6366f1)!important;outline-offset:-3px;animation:mobile-pulse-border 1.2s ease-in-out infinite;position:relative}.mobile-drop-highlight:after{content:"+";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:700;color:var(--accent, #6366f1);text-shadow:0 2px 8px rgba(0,0,0,.5);pointer-events:none;z-index:10}.mobile-drop-highlight-replace{outline:2px dashed rgba(236,72,153,.6)!important;outline-offset:-2px;position:relative}.mobile-drop-highlight-replace:after{content:"↻";position:absolute;top:4px;right:4px;font-size:1.2rem;color:#ec4899cc;text-shadow:0 1px 4px rgba(0,0,0,.5);pointer-events:none;z-index:10}@keyframes mobile-pulse-border{0%,to{outline-color:var(--accent, #6366f1)}50%{outline-color:#6366f14d}}.mobile-placement-banner{position:fixed;top:calc(var(--mobile-toolbar-height) + var(--safe-area-top, 0px) + 56px);left:50%;transform:translate(-50%);background:linear-gradient(135deg,#6366f1f2,#8b5cf6f2);color:#fff;padding:10px 16px;border-radius:12px;font-size:.85rem;z-index:10001;box-shadow:0 4px 20px #6366f166;display:flex;align-items:center;gap:12px;max-width:92vw;direction:rtl;animation:mobile-banner-enter .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-placement-banner .banner-text{flex:1;font-weight:500}.mobile-placement-banner .banner-cancel{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 12px;border-radius:8px;font-size:.8rem;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:4px;transition:background .2s}.mobile-placement-banner .banner-cancel:active{background:#ffffff59}@keyframes mobile-banner-enter{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mobile-toast{position:fixed;top:calc(var(--mobile-toolbar-height) + var(--safe-area-top, 0px) + 56px);left:50%;transform:translate(-50%);background:#0f172af2;color:#fff;padding:10px 20px;border-radius:10px;font-size:.85rem;z-index:10002;box-shadow:0 4px 20px #0006;max-width:90vw;text-align:center;direction:rtl;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.mobile-toast.visible{opacity:1;visibility:visible}.mobile-zoom-indicator{position:fixed;top:70px;right:16px;background:#000000bf;color:#fff;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:10003;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;pointer-events:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 2px 12px #0000004d}.mobile-zoom-indicator.visible{opacity:1;visibility:visible}#canvas-container{transform-origin:center center;will-change:transform,opacity}#canvas-viewport{overflow:hidden;touch-action:pan-y pinch-zoom}.mobile-action-bar{position:fixed;bottom:calc(var(--mobile-timeline-height) + var(--mobile-nav-height) + var(--safe-area-bottom) + 8px);left:50%;transform:translate(-50%);background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;padding:6px 12px;display:flex;gap:8px;align-items:center;z-index:95;box-shadow:0 4px 20px #0006}.mobile-action-bar button{width:44px;height:44px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text-main);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.mobile-action-bar button:active{background:var(--bg-hover)}.hide-mobile{display:none!important}.show-mobile{display:block!important}.mobile-backdrop{position:fixed;inset:0;background:#00000080;z-index:99;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.mobile-backdrop.visible{opacity:1;visibility:visible}.mobile-sidebar-backdrop{position:fixed;inset:0;background:#00000080;z-index:99;opacity:0;visibility:hidden;transition:opacity .3s}.mobile-sidebar-backdrop.active{opacity:1;visibility:visible}.empty-state{padding:30px 16px;font-size:.85rem}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}#tab-ai textarea{min-height:60px;font-size:16px}#tab-ai button{min-height:44px}#covers-library{grid-template-columns:repeat(3,1fr)!important;gap:8px!important;padding:8px!important;max-height:none!important}#elements-library{grid-template-columns:repeat(3,1fr)!important;gap:6px!important;padding:8px!important}#template-library .asset-item,#design-library .asset-item{min-height:50px}#projects-modal .modal-content{width:95vw!important}#projects-list-container{max-height:50vh!important}#share-modal .modal-content{width:95vw!important}.photo-slot.empty-slot{cursor:pointer}.moveable-control{width:16px!important;height:16px!important}.moveable-line{width:2px!important}.asset-item:active{transform:scale(.95);opacity:.8}.photo-slot .btn-remove-slot-photo{display:flex!important}#mobile-overflow-menu{position:fixed!important;top:calc(var(--mobile-toolbar-height) + var(--safe-area-top));left:0;right:0;background:var(--bg-panel);border-bottom:1px solid var(--border);box-shadow:0 8px 24px #0006;z-index:400;padding:6px 8px 10px;display:flex;flex-direction:column;gap:2px;transform:translateY(-110%);transition:transform .25s cubic-bezier(.4,0,.2,1);visibility:hidden}#mobile-overflow-menu.open{transform:translateY(0);visibility:visible}.mob-menu-item{height:52px;display:flex!important;align-items:center;gap:14px;padding:0 16px;border-radius:10px;border:none;background:transparent;color:var(--text-main);font-size:.95rem;cursor:pointer;direction:rtl;text-align:right;transition:background .15s;width:100%}.mob-menu-item:active{background:var(--bg-hover)}.mob-menu-item i{width:20px;text-align:center;font-size:1rem;color:var(--text-muted);flex-shrink:0}.mob-menu-item--highlight{background:linear-gradient(90deg,#a855f726,#ec489926);border:1px solid rgba(168,85,247,.25)}.mob-menu-item--highlight i{color:#a855f7}.mob-menu-item--highlight:active{background:linear-gradient(90deg,#a855f74d,#ec48994d)}#mobile-magic-fab{position:fixed!important;top:calc(var(--mobile-toolbar-height) + var(--safe-area-top) + 10px);left:50%;transform:translate(-50%);background:linear-gradient(90deg,#a855f7,#ec4899);color:#fff;border:none;border-radius:22px;height:38px;padding:0 18px;font-size:.82rem;font-weight:600;display:flex!important;align-items:center;gap:8px;z-index:45;box-shadow:0 4px 16px #a855f773;cursor:pointer;white-space:nowrap;direction:rtl;transition:transform .15s,box-shadow .15s}#mobile-magic-fab:active{transform:translate(-50%) scale(.97);box-shadow:0 2px 8px #a855f759}#mobile-magic-fab i{font-size:.85rem}#mobile-edit-fab{position:fixed!important;bottom:calc(var(--mobile-nav-height) + var(--mobile-timeline-height) + 14px + var(--safe-area-bottom));left:16px;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border:none;font-size:1.1rem;box-shadow:0 4px 18px #a855f78c;z-index:92;cursor:pointer;align-items:center;justify-content:center;display:none!important;transition:transform .2s,opacity .2s,box-shadow .2s}#mobile-edit-fab.visible{display:flex!important;animation:editFabIn .3s cubic-bezier(.34,1.56,.64,1)}#mobile-edit-fab:active{transform:scale(.93);box-shadow:0 2px 8px #a855f766}@keyframes editFabIn{0%{transform:scale(0) rotate(-30deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}}@media screen and (min-width:768px)and (max-width:1024px){:root{--sidebar-width: 260px;--properties-width: 240px;--timeline-height: 120px}body{padding-top:var(--safe-area-top)}#app-container{grid-template-columns:var(--sidebar-width) 1fr var(--properties-width)}#sidebar-left{position:relative;height:auto;max-height:none;border-radius:0;box-shadow:none}.sidebar-nav{width:56px;flex-direction:column;border-right:1px solid var(--border);border-bottom:none;padding-top:16px}.nav-item{width:44px;height:44px;flex:unset;flex-direction:row;padding:0;gap:0}.nav-item:after{display:none}.sidebar-content{width:calc(var(--sidebar-width) - 56px)}#sidebar-right{position:relative;width:var(--properties-width);transform:none;box-shadow:none}#sidebar-right:before{display:none}.toolbar-group.center{position:relative;left:auto;transform:none}#canvas-container{width:90%;height:85%}#canvas-viewport .shoso-page,#canvas-viewport .album-page{width:auto!important;height:auto!important;max-width:100%;max-height:100%;aspect-ratio:4/3}#page-timeline{gap:10px}.timeline-page{width:100px}.modal-content{max-width:500px}.prop-group input[type=text],.prop-group textarea,.prop-group select{font-size:16px}}@media screen and (max-width:896px)and (max-height:500px)and (orientation:landscape){.toolbar-top{height:40px;min-height:40px;max-height:40px}#timeline-bar{height:60px;min-height:60px}.timeline-page{width:50px;min-width:50px}#sidebar-left{height:52px!important;max-height:52px!important}#sidebar-left.expanded{height:50vh!important;max-height:60vh!important}.sidebar-nav{height:52px;min-height:52px}.nav-item{min-width:40px;height:40px;min-height:40px;font-size:.8rem;flex-direction:row;gap:0;padding:0}.nav-item:after{display:none}#timeline-bar{margin-bottom:calc(52px + var(--safe-area-bottom))}.mobile-fab{width:44px;height:44px}#mobile-magic-fab{height:32px;padding:0 12px;font-size:.75rem}#mobile-edit-fab{width:46px;height:46px}}@media(hover:none)and (pointer:coarse){button,a,input,select,textarea,.nav-item,.asset-item,.timeline-page,.layout-btn{min-height:40px;min-width:40px}.btn-tool:hover,.btn-pill:hover,.nav-item:hover,.asset-item:hover,.timeline-page:hover{transform:none;background-color:inherit}.btn-tool:active,.btn-pill:active,.nav-item:active{transform:scale(.95);opacity:.8}.asset-item:active,.timeline-page:active{transform:scale(.97);opacity:.9}.asset-item,#canvas-viewport .shoso-page,#canvas-viewport .album-page{-webkit-user-select:none;user-select:none}.photo-slot .btn-remove-slot-photo{opacity:.7!important}.photo-slot:active .btn-remove-slot-photo{opacity:1!important}.moveable-control{width:14px!important;height:14px!important}}@media(prefers-color-scheme:dark){.mobile-fab{box-shadow:0 4px 20px #00000080}}@media(prefers-reduced-motion:reduce){#sidebar-left,#sidebar-right,.mobile-backdrop,.modal-content,.btn-tool,.btn-pill,.asset-item,.mobile-placement-banner,.mobile-toast{transition:none!important;animation:none!important}}@media(prefers-contrast:high){.nav-item.active{outline:2px solid white;outline-offset:2px}.btn-primary,.btn-pill,.mobile-fab{border:2px solid white}}@media print{body{display:none!important}}.album-page.romantic-journey{background-color:#f5f2ef;box-sizing:border-box}.album-page.romantic-journey .photo-slot{box-shadow:0 4px 20px #0000001a;transition:transform .2s ease;z-index:5}.album-page.romantic-journey .photo-slot img{display:block;width:100%;height:100%}.album-page.romantic-journey .text-element{z-index:10;pointer-events:auto}.album-page.romantic-journey .text-title,.album-page.romantic-journey .text-heading,.album-page.romantic-journey .text-script,.album-page.romantic-journey .text-chapter,.album-page.romantic-journey .text-quote{font-family:Pinyon Script,cursive;font-weight:400}.album-page.romantic-journey .text-body,.album-page.romantic-journey .text-subtitle,.album-page.romantic-journey .text-date{font-family:Cormorant Garamond,serif;font-weight:500}.album-page.romantic-journey .text-sans,.album-page.romantic-journey .text-bold{font-family:Montserrat,sans-serif}.album-page.romantic-journey .decoration{z-index:1}.album-page.romantic-journey .title-card{background-color:#c4956a;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;box-shadow:0 4px 12px #00000026;z-index:20}#google-photos-loader{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0a0a0ff2;z-index:10000;flex-direction:column;align-items:center;justify-content:center;font-family:Montserrat,sans-serif;color:#fff}#google-photos-loader.active{display:flex}.loader-animation-container{position:relative;width:400px;height:200px;display:flex;align-items:center;justify-content:space-between;margin-bottom:40px}.loader-icon{font-size:64px;z-index:2;background:#1e1e2f;padding:20px;border-radius:50%;box-shadow:0 4px 15px #0000004d;border:2px solid #333;display:flex;align-items:center;justify-content:center;width:100px;height:100px}.icon-google{color:#4285f4;border-color:#4285f4}.icon-book{color:#fff;border-color:#fff}.flying-photo{position:absolute;width:40px;height:40px;background-color:#fff;border-radius:4px;box-shadow:0 2px 5px #0003;opacity:0;left:80px;top:50%;transform:translateY(-50%);animation:flyToBook 1.5s infinite ease-in-out}.flying-photo:nth-child(1){background:#ea4335;animation-delay:0s}.flying-photo:nth-child(2){background:#fbbc05;animation-delay:.3s}.flying-photo:nth-child(3){background:#34a853;animation-delay:.6s}.flying-photo:nth-child(4){background:#4285f4;animation-delay:.9s}.flying-photo:nth-child(5){background:#f06292;animation-delay:1.2s}@keyframes flyToBook{0%{left:80px;opacity:0;transform:translateY(-50%) scale(.5) rotate(0)}15%{opacity:1;transform:translateY(-50%) scale(1) rotate(10deg)}85%{opacity:1;transform:translateY(-50%) scale(1) rotate(-10deg)}to{left:320px;opacity:0;transform:translateY(-50%) scale(.5) rotate(0)}}.loader-text{font-size:24px;font-weight:600;margin-bottom:10px;text-align:center}.loader-subtext{font-size:16px;color:#888;margin-bottom:30px;text-align:center}.loader-progress-track{width:400px;height:6px;background:#333;border-radius:3px;overflow:hidden;position:relative}.loader-progress-fill{height:100%;width:0%;background:linear-gradient(90deg,#4285f4,#34a853,#fbbc05,#ea4335);border-radius:3px;transition:width .3s ease-out;animation:gradientShift 2s linear infinite;background-size:200% 100%}@keyframes gradientShift{0%{background-position:100% 0}to{background-position:-100% 0}}
