@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;700&family=Playfair+Display:wght@400;700&family=Caveat&family=Lobster&family=Pacifico&family=Montserrat:wght@400;700&family=Merriweather:wght@400;700&family=Dancing+Script:wght@400;700&family=Bebas+Neue&family=Amatic+SC:wght@400;700&family=Shadows+Into+Light&display=swap";*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;background-color:#fff;color:#213547;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}a{font-weight:500;color:#646cff;text-decoration:none}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:#fff;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.welcome-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background-color:#fcefee;position:relative;overflow:hidden;font-family:Helvetica Neue,Arial,sans-serif}.welcome-layout{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;width:100%;max-width:1200px;padding:2rem}.photo-strip.static{display:none}.scrolling-background{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;justify-content:space-evenly;pointer-events:none}.film-strip-row{display:flex;width:100%;height:200px;position:relative}.film-strip-row:before,.film-strip-row:after{content:"";position:absolute;left:0;right:0;height:15px;background-image:repeating-linear-gradient(90deg,#1a1a1a,#1a1a1a 10px,transparent 10px,transparent 20px);background-size:20px 100%}.film-strip-row:before{top:0}.film-strip-row:after{bottom:0}.film-strip-content{display:flex;flex-shrink:0;min-width:200%}.film-frame{background-color:#1a1a1a;padding:20px 10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.film-frame img{height:160px;width:auto;display:block;background-color:#fff}.scroll-left{animation:scroll-left-anim linear infinite}.scroll-right{animation:scroll-right-anim linear infinite}@keyframes scroll-left-anim{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes scroll-right-anim{0%{transform:translate(-50%)}to{transform:translate(0)}}.welcome-content{background-color:#fffffff2;padding:3rem 4rem;border-radius:12px;text-align:center;max-width:600px;box-shadow:0 10px 30px #0000001a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.5);z-index:2}.logo-container img{height:150px}.est-year{display:flex;justify-content:space-between;font-size:.8rem;color:#888;margin-bottom:1.5rem}.welcome-content h1{font-size:2rem;font-weight:300;color:#333}.welcome-content h1 span{display:block;font-size:2.5rem;font-weight:700;color:#111}.welcome-content p{font-size:1rem;color:#555;margin:1rem 0 2rem}.start-button{background-color:#ff5879;color:#fff;border:none;padding:1rem 3rem;border-radius:50px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.start-button:hover{transform:translateY(-3px);box-shadow:0 8px 15px #ff587966}.plus-icon{font-size:1.5rem}.packages-page{background-color:#fff;min-height:100vh;padding:2rem;color:#000;font-family:Helvetica Neue,Arial,sans-serif}.packages-header{text-align:center;margin-bottom:3rem}.header-logo{height:150px}.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1300px;margin:0 auto}.package-card{background-color:#fff;border-radius:12px;overflow:hidden;border:1px solid #ddd;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease;color:#000}.package-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #ff587933;border-color:#ff5879}.card-image-container{position:relative}.card-image-container img{width:100%;aspect-ratio:1080 / 1351;object-fit:cover;display:block}.price-tag{position:absolute;bottom:1rem;left:1rem;background:#0009;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:.5rem 1rem;border-radius:8px;color:#fff;text-align:left}.price-tag .price-amount{font-size:2rem;font-weight:700}.price-tag .price-amount sup{font-size:1rem;font-weight:400;margin-right:2px}.price-tag .price-per{font-size:.9rem;opacity:.8}.card-content{padding:1.5rem;text-align:left;flex-grow:1;display:flex;flex-direction:column}.card-content h3{margin:0 0 .25rem;font-size:1.5rem;color:#000}.card-price-sub{color:#555;margin:0 0 1rem;font-size:.9rem}.card-details{color:#444;font-size:.9rem;margin-bottom:1.5rem;flex-grow:1}.card-details p{margin:.25rem 0}.select-button{background-color:#ff5879;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:background-color .3s ease;width:100%}.select-button:hover{background-color:#e64a69}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;color:#333;padding:2rem;border-radius:12px;width:90%;max-width:450px;position:relative;text-align:center}.close-button{position:absolute;top:10px;right:15px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#888}.modal-content h4{font-size:.9rem;color:#888;margin:0;font-weight:400;text-transform:uppercase;letter-spacing:1px}.modal-content h2{font-size:2.5rem;margin:.5rem 0 1.5rem;color:#111}.modal-details,.addons-section{text-align:left;margin-bottom:1.5rem;border-top:1px solid #eee;padding-top:1.5rem}.modal-details p{margin:0;font-weight:700}.pax-control{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}.pax-buttons{display:flex;align-items:center;border:1px solid #ddd;border-radius:8px}.pax-buttons button{background:none;border:none;font-size:1.2rem;width:40px;height:40px;cursor:pointer;color:#000}.pax-buttons button:hover{background-color:#f0f0f0;border-radius:6px}.pax-buttons span{width:40px;text-align:center;font-weight:700}.addons-section h5{margin:0 0 1rem;font-size:1rem}.addons-section label{display:block;margin-bottom:.75rem;font-size:.9rem;cursor:pointer}.addons-section input{margin-right:.5rem}.pay-button{background-color:#ff5879;color:#fff;border:none;padding:1rem;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:background-color .3s ease;width:100%}.pay-button:hover{background-color:#e64a69}:root{--bg-color: #121212;--surface-color: #1e1e1e;--primary-color: #FFC107;--text-color: #E0E0E0;--text-secondary-color: #A0A0A0;--border-color: #333333;--shadow-color: rgba(0, 0, 0, .5)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-color);font-family:Poppins,sans-serif}.photo-session-page{display:flex;width:100vw;height:100vh;overflow:hidden}.camera-view{flex:1;display:flex;flex-direction:column;height:100%;background-color:var(--bg-color)}.controls-sidebar{width:340px;height:100%;background-color:#1e1e1ecc;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-left:1px solid var(--border-color);padding:2rem;display:flex;flex-direction:column;gap:2rem;overflow-y:auto}.session-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;flex-shrink:0;border-bottom:1px solid var(--border-color)}.logo-image{height:30px}.header-title{font-weight:600;font-size:1rem;letter-spacing:1px}.camera-main-area{flex-grow:1;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:hidden}.camera-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.video-wrapper{position:relative;background-color:#000;border-radius:16px;overflow:hidden;transition:all .4s cubic-bezier(.25,.8,.25,1);box-shadow:0 10px 40px var(--shadow-color);width:100%;height:100%;display:flex;justify-content:center;align-items:center}.camera-feed{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transition:filter .3s ease,transform .4s ease-in-out}.maximize-button{position:absolute;top:1rem;right:1rem;background:#0000004d;color:#fff;border:none;border-radius:50%;width:40px;height:40px;display:flex;justify-content:center;align-items:center;cursor:pointer;z-index:10;transition:background-color .2s}.maximize-button:hover{background:#0009}.photo-session-page.camera-is-maximized .video-wrapper{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:2000;border-radius:0}.photo-session-page.camera-is-maximized .controls-sidebar,.photo-session-page.camera-is-maximized .session-header,.photo-session-page.camera-is-maximized .thumbnail-panel{display:none}.thumbnail-panel{flex-shrink:0;padding:1rem 1.5rem;background-color:#12121280;border-top:1px solid var(--border-color)}.thumbnail-gallery{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin;scrollbar-color:var(--primary-color) var(--surface-color)}.thumbnail-gallery::-webkit-scrollbar{height:6px}.thumbnail-gallery::-webkit-scrollbar-thumb{background-color:var(--primary-color);border-radius:3px}.thumbnail-gallery::-webkit-scrollbar-track{background:var(--surface-color)}.thumbnail{width:120px;height:90px;object-fit:cover;border-radius:8px;cursor:pointer;border:2px solid transparent;transition:all .2s ease}.thumbnail:hover{transform:scale(1.05);border-color:var(--primary-color)}.control-group{display:flex;flex-direction:column;gap:1rem}.main-actions{align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:2rem}.capture-btn{width:90px;height:90px;border-radius:50%;background:linear-gradient(145deg,#ffca28,#ffac00);border:4px solid var(--surface-color);color:var(--bg-color);display:flex;justify-content:center;align-items:center;cursor:pointer;transition:all .2s cubic-bezier(.25,.8,.25,1);box-shadow:0 5px 20px #ffc1074d}.capture-btn:hover{transform:scale(1.05)}.capture-btn:active{transform:scale(.95);box-shadow:0 2px 10px #ffc10733}.capture-btn:disabled{background:#555;cursor:not-allowed;box-shadow:none}.capture-label{font-weight:600;font-size:1.1rem;margin-top:.5rem;color:var(--primary-color)}.secondary-actions{gap:.75rem}.sidebar-button{width:100%;padding:.8rem 1rem;background-color:var(--surface-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:8px;font-weight:500;font-size:.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:background-color .2s,border-color .2s}.sidebar-button:hover{background-color:#2a2a2a;border-color:#555}.sidebar-button.primary{background-color:var(--primary-color);color:var(--bg-color);border-color:var(--primary-color);font-weight:700}.sidebar-button.primary:hover{background-color:#ffcd38}.control-title{font-size:1rem;font-weight:600;color:var(--text-secondary-color);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.button-group{display:flex;gap:.75rem}.control-button{flex:1;height:48px;background-color:var(--surface-color);color:var(--text-secondary-color);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .2s;gap:.5rem}.control-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.control-button.active{background-color:var(--primary-color);color:var(--bg-color);border-color:var(--primary-color)}.control-button span{font-size:.9rem;font-weight:600}.filters-container{display:flex;flex-wrap:wrap;gap:.5rem}.filter-button{padding:.5rem 1rem;background-color:var(--surface-color);color:var(--text-secondary-color);border:1px solid var(--border-color);border-radius:20px;cursor:pointer;font-weight:500;font-size:.9rem;transition:all .2s}.filter-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.filter-button.active{background-color:var(--primary-color);color:var(--bg-color);border-color:var(--primary-color)}.filter-button.mirror-button{flex:1;border-radius:8px;height:48px;display:flex;justify-content:center;align-items:center}.loading-screen{width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;font-size:1.5rem}.flash-overlay{position:absolute;inset:0;background-color:#fff;z-index:50;animation:flash-anim .2s ease-out;pointer-events:none}@keyframes flash-anim{0%{opacity:.8}to{opacity:0}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:3000}.modal-content{background-color:var(--surface-color);padding:2.5rem;border-radius:12px;width:90%;max-width:400px;text-align:center;position:relative;border:1px solid var(--border-color)}.modal-content h2{margin-bottom:.5rem;color:var(--primary-color)}.modal-content p{margin-bottom:1.5rem;color:var(--text-secondary-color)}.modal-content input{width:100%;padding:.8rem;margin-bottom:1rem;border-radius:8px;border:1px solid var(--border-color);background-color:var(--bg-color);color:var(--text-color);font-size:1rem}.modal-submit-button{width:100%;padding:.8rem;font-size:1rem;background-color:var(--primary-color);color:var(--bg-color);border:none;border-radius:8px;font-weight:700;cursor:pointer}.modal-close-button{position:absolute;top:10px;right:15px;font-size:24px;color:var(--text-secondary-color);background:none;border:none;cursor:pointer}.error-message{color:#ff8a80;margin-top:-1rem;margin-bottom:1rem!important}@media (max-width: 1024px){.photo-session-page{flex-direction:column-reverse;height:auto;min-height:100vh}.controls-sidebar{width:100%;height:auto;flex-shrink:0;border-left:none;border-top:1px solid var(--border-color);flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:flex-start;padding:1rem}.main-actions{padding-bottom:0;border-bottom:none}.camera-view{height:auto;flex:1;min-height:50vh}.control-group{flex-basis:300px}}@media (max-width: 768px){.controls-sidebar{flex-direction:column;align-items:center}.control-group{width:100%;max-width:400px}}.gallery-container{display:flex;flex-direction:column;align-items:center;padding:40px 20px;background-color:#f4f4f9;min-height:100vh;box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;text-align:center}.gallery-container h1{font-size:2.5rem;color:#333;margin-bottom:8px;font-weight:700}.gallery-container p{font-size:1.1rem;color:#666;margin-top:0;margin-bottom:40px}.slider-container{display:flex;align-items:center;justify-content:center;width:100%;max-width:900px;margin-top:2rem;gap:20px}.photo-display-area{display:flex;justify-content:center;gap:24px;min-width:650px;min-height:450px;align-items:center}.photo-item{width:300px;flex-shrink:0;cursor:pointer;background-color:#fff;border-radius:12px;box-shadow:0 6px 12px #00000014;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.photo-item:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0000001f}.photo-item img{width:100%;height:100%;display:block;aspect-ratio:4 / 5;object-fit:cover}.slider-nav-button{background-color:#ffffffb3;border:1px solid #ddd;border-radius:50%;width:50px;height:50px;font-size:24px;color:#333;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .3s ease;flex-shrink:0;box-shadow:0 2px 5px #0000001a}.slider-nav-button:hover:not(:disabled){background-color:#fff;transform:scale(1.1)}.slider-nav-button:disabled{opacity:.3;cursor:not-allowed;transform:scale(1)}.gallery-actions{margin-top:50px}.print-button{padding:15px 60px;font-size:1.2rem;font-weight:700;color:#fff;background:linear-gradient(45deg,#4c68d7,#6a82fb);border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 10px #4c68d766;transition:all .3s ease;text-decoration:none;display:inline-block}.print-button:hover{transform:scale(1.05);box-shadow:0 6px 15px #4c68d780}@media (max-width: 768px){.gallery-container h1{font-size:2rem}.photo-display-area{min-width:280px;width:280px}.slider-nav-button{width:40px;height:40px;font-size:20px}.print-button{width:90%;padding:15px 30px}}.photo-item{position:relative;cursor:pointer}.gallery-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background-color:#00000080;border-radius:50%;pointer-events:none;opacity:.9;transition:opacity .2s}.photo-item:hover .gallery-play-icon{opacity:1}.empty-gallery{text-align:center;padding:4rem}:root{--primary-color: #d17a8b;--primary-hover: #b96476;--background-color: #fdf6f8;--text-primary: #333;--text-secondary: #888;--card-bg: #ffffff;--card-border-selected: #e91e63;--disabled-color: #ccc}*,*:before,*:after{box-sizing:border-box}.layout-chooser-page{display:flex;flex-direction:column;align-items:center;min-height:100vh;background-color:var(--background-color);color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;padding:2rem 1rem;overflow-x:hidden}.layout-chooser-page h1{color:var(--primary-color);font-weight:700;font-size:2.5rem;margin-top:1rem;margin-bottom:.5rem;text-align:center}.layout-chooser-page .subtitle{color:var(--text-secondary);margin-bottom:2rem;text-align:center;max-width:600px;padding:0 1rem}.layout-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.5rem;width:100%;max-width:1200px;padding:0 1rem;margin-bottom:1rem}.layout-card{background-color:var(--card-bg);border:3px solid transparent;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s ease,border-color .2s ease,opacity .3s ease,box-shadow .3s ease;box-shadow:0 4px 15px #0000000d;text-align:center;display:flex;flex-direction:column}.layout-card:hover:not(.disabled){transform:translateY(-5px);box-shadow:0 8px 20px #0000001a}.layout-card.selected{border-color:var(--card-border-selected);transform:scale(1.05)}.layout-card.disabled{opacity:.4;cursor:not-allowed}.layout-image{width:100%;height:auto;display:block;background-color:#f0f0f0}.layout-info{padding:1rem;margin-top:auto}.layout-info h3{margin:0;font-size:1rem}.selection-info{font-size:1.2rem;color:#555;margin-bottom:1.5rem;font-weight:700;text-align:center;width:100%}.action-buttons-container{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:1.5rem;margin-top:1rem;margin-bottom:2rem}.next-button{padding:1rem 2.5rem;font-size:1.2rem;font-weight:700;color:#666;background-color:#e0e0e0;border:none;border-radius:50px;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.next-button:hover:not(:disabled){background-color:#d1d1d1;transform:translateY(-2px)}.next-button:disabled{background-color:#f5f5f5;color:#b0b0b0;cursor:not-allowed;transform:none}.custom-frame-button,.gift-button{background:linear-gradient(45deg,#ff6b6b,#feca57);color:#fff;font-weight:700;font-size:1.2rem;border:none;padding:1rem 2.5rem;border-radius:50px;cursor:pointer;transition:transform .2s,box-shadow .2s,opacity .2s;box-shadow:0 4px 15px #0000001a}.custom-frame-button:hover:not(:disabled),.gift-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 20px #feca5766}.gift-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 1024px){.layout-chooser-page h1{font-size:2rem}.layout-chooser-page .subtitle{font-size:.95rem;margin-bottom:1.5rem}.layout-grid{grid-template-columns:repeat(3,1fr);gap:1rem}.selection-info{font-size:1.1rem}.next-button,.custom-frame-button,.gift-button{padding:.8rem 2rem;font-size:1.1rem}}@media (max-width: 768px){.layout-chooser-page{padding:1rem .5rem}.layout-chooser-page h1{font-size:1.8rem}.layout-chooser-page .subtitle{font-size:.9rem;margin-bottom:1rem}.layout-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;padding:0 1rem}.next-button,.custom-frame-button,.gift-button{width:90%;max-width:350px;border-radius:50px}.action-buttons-container{flex-direction:column;gap:1rem;width:100%;align-items:center}}.admin-trigger-button{position:absolute;top:1rem;right:1rem;background:#fff;border:1px solid #ccc;border-radius:50%;width:40px;height:40px;font-size:1.5rem;cursor:pointer;z-index:100;box-shadow:0 2px 5px #0000001a}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:8px;width:90%;max-width:400px;box-shadow:0 5px 15px #0000004d;display:flex;flex-direction:column;gap:1rem}.modal-content.large{max-width:600px;max-height:80vh;overflow-y:auto}.modal-content h2{margin-top:0;text-align:center}.modal-input{width:100%;padding:.8rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.modal-button-primary,.modal-button-secondary{padding:.7rem 1.5rem;border-radius:5px;border:none;font-weight:700;cursor:pointer}.modal-button-primary{background-color:var(--primary-color);color:#fff}.modal-button-secondary{background-color:#f0f0f0;color:#333}.modal-button-primary.full-width{width:100%;margin-top:1rem}.image-preview{max-width:150px;margin-top:1rem;border:1px solid #ddd;padding:4px;border-radius:4px}.upload-form-section,.uploaded-list-section{border-top:1px solid #eee;padding-top:1rem;margin-top:1rem}.uploaded-frames-list{list-style:none;padding:0;margin:0}.uploaded-frame-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem;border-bottom:1px solid #f0f0f0}.uploaded-frame-item:last-child{border-bottom:none}.delete-frame-btn{background-color:#e74c3c;color:#fff;border:none;border-radius:4px;padding:.4rem .8rem;cursor:pointer}.back-button{padding:1rem 2.5rem;font-size:1.2rem;font-weight:700;color:#666;background-color:#e0e0e0;border:none;border-radius:50px;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.back-button:hover{background-color:#d1d1d1;transform:translateY(-2px)}.editor-page-v2{display:flex;height:100vh;overflow:hidden;background-color:#f8f9fa;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.photo-source-column-v2{flex-basis:300px;flex-shrink:0;background-color:#fff;padding:1.5rem;display:flex;flex-direction:column;box-shadow:4px 0 15px #0000000d;z-index:10}.photo-source-column-v2 h3{text-align:center;margin:.5rem 0 1.5rem;color:#333;font-size:1.2rem}.source-photo-grid-v2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;overflow-y:auto;padding-right:5px}.source-photo-item{position:relative;aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;cursor:grab;touch-action:none;border:1px solid #eee}.source-photo-item:active{cursor:grabbing}.source-photo-item img{width:100%;height:100%;object-fit:cover}.editor-canvas-column{flex-grow:1;display:flex;flex-direction:column;align-items:center;padding:2rem;overflow-y:auto}.canvas-header{text-align:center;margin-bottom:2rem}.canvas-header h1{font-size:2.2rem;color:#2c3e50;margin:0}.canvas-header p{color:#7f8c8d;margin-top:.5rem;font-size:1.1rem}.paper-4x6-container{background-color:#fff;box-shadow:0 5px 25px #0000001a;padding:15px;display:flex;width:500px;max-width:100%;aspect-ratio:4 / 6}.paper-4x6-container.single_4r{justify-content:center;align-items:center}.paper-4x6-container.dual_strip{justify-content:space-between;gap:15px}.frame-wrapper{height:100%;display:flex}.paper-4x6-container.dual_strip .frame-wrapper{width:calc(50% - 7.5px)}.paper-4x6-container.single_4r .frame-wrapper{width:100%}.frame-content-v2{width:100%;height:100%;border:1px dashed #ccc;display:grid;gap:8px;padding:8px;background-color:#fdfdfd}.layout-1-full{grid-template-rows:1fr}.layout-3-vertical{grid-template-rows:repeat(3,1fr)}.layout-4-vertical{grid-template-rows:repeat(4,1fr)}.layout-2-landscape{grid-template-rows:repeat(2,1fr)}.layout-4-vertical-small{grid-template-rows:repeat(4,1fr)}.layout-4-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.layout-2-vertical-wide{grid-template-rows:repeat(2,1fr)}.drop-slot{    background-color: #e9ecef;    border-radius: 4px;    transition: background-color .2s ease,border .2s ease;width:100%;height:100%;border:2px dashed #dcdcdc}.drop-slot.over{    background-color: #cdeacb;    border: 2px dashed #4caf50}.drop-slot.filled{    padding: 0;    background-color: transparent;    border: none}.slot-image-bg{width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;border-radius:4px}.slot-video{width:100%;height:100%;object-fit:cover;border-radius:4px}.editor-footer-v2{margin-top:2.5rem}.edit-frame-button{padding:15px 50px;font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(45deg,#28a745,#218838);border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 10px #28a74566}.edit-frame-button:hover{transform:scale(1.05);box-shadow:0 6px 15px #28a74580}.gallery-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{position:relative;display:flex;align-items:center;justify-content:center;width:90%;height:90%}.modal-image{max-width:100%;max-height:100%;border-radius:8px;object-fit:contain}.modal-close-button{position:absolute;top:15px;right:35px;font-size:40px;color:#fff;background:none;border:none;cursor:pointer}.modal-nav-button{position:absolute;top:50%;transform:translateY(-50%);background-color:#00000080;color:#fff;border:none;border-radius:50%;width:50px;height:50px;font-size:24px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:background-color .3s ease}.modal-nav-button:hover{background-color:#000c}.modal-nav-button.prev{left:20px}.modal-nav-button.next{right:20px}.editor-play-icon{position:absolute;bottom:8px;right:8px;width:24px;height:24px;background-color:#0009;border-radius:50%;pointer-events:none;opacity:.9;padding:4px;box-sizing:border-box}.layout-custom-frame{position:relative;background-size:contain;background-position:center;background-repeat:no-repeat;display:block;width:100%;height:100%}.layout-custom-frame .frame-content-v2{display:block;position:relative;border:none;padding:0;background-color:transparent}.layout-custom-frame .drop-slot{position:absolute;background-color:#fff3;border:2px dashed #aaa;overflow:hidden}.layout-custom-frame .drop-slot.filled{border:none;background-color:transparent}body{margin:0;font-family:Poppins,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.customize-page{display:flex;height:100vh;background-color:#f8f9fa;font-family:Poppins,sans-serif}.preview-column{flex:2;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background-color:#e9ecef}.final-frame-canvas{width:100%;max-width:450px;aspect-ratio:4 / 6;background-color:#f0f0f0;box-shadow:0 10px 30px #0000001a;position:relative;padding:20px;box-sizing:border-box}.paper-content{display:flex;width:100%;height:100%;box-sizing:border-box}.paper-content.single_4r{justify-content:center;align-items:center}.paper-content.dual_strip{justify-content:space-between;gap:10px;padding:10px}.frame-wrapper-final{height:100%;display:flex;flex-direction:column;border:3px solid transparent;transition:border-color .3s ease;cursor:pointer;position:relative;box-sizing:border-box;padding:15px}.frame-border{display:flex;flex-direction:column;height:100%;width:100%;background-size:cover;background-position:center}.frame-wrapper-final.active{border-color:#007bff}.paper-content.dual_strip .frame-wrapper-final{width:calc(50% - 5px)}.paper-content.single_4r .frame-wrapper-final{width:100%}.frame-content-final{width:100%;flex-grow:1;display:grid;gap:8px;overflow:hidden;margin-bottom:35px}.photo-slot-final{width:100%;height:100%;overflow:hidden}.photo-slot-final img{width:100%;height:100%;object-fit:cover}.photo-slot-final.shape-normal{border-radius:0}.photo-slot-final.shape-square{border-radius:10px}.photo-slot-final.shape-circle{border-radius:50%}.photo-slot-final.shape-heart{clip-path:polygon(50% 100%,0 45%,0 0,100% 0,100% 45%)}.caption-area{position:absolute;bottom:5px;left:5px;right:5px;min-height:30px;text-align:center;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:5px;box-sizing:border-box}.caption-display{width:100%;height:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:inherit}.preview-actions{margin-top:2rem;display:flex;gap:1rem}.print-button-v2,.share-button-v2{padding:10px 20px;background-color:#000;color:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;text-transform:capitalize;transition:all .2s ease-in-out}.print-button-v2:hover,.share-button-v2:hover{background-color:#fff;color:#000;border-color:#000;transform:none;box-shadow:none}.print-button-v2:disabled,.share-button-v2:disabled{opacity:.5;cursor:not-allowed;background-color:#ccc;border-color:#ccc;color:#666;transform:none;box-shadow:none}.controls-column{flex:1;padding:2rem;background-color:#fff;overflow-y:auto}.controls-column h2{margin-top:0}.control-group{margin-bottom:2rem}.control-group h3{margin-bottom:1rem;padding-bottom:.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee}.info-text{font-size:.8rem;color:#999;font-weight:400}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(35px,1fr));gap:10px}.color-swatch{width:35px;height:35px;border-radius:50%;cursor:pointer;border:2px solid #eee;background-size:cover}.shape-picker{display:flex;gap:1rem}.shape-picker button{padding:10px 20px;background-color:#000;color:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease-in-out}.shape-picker button:hover,.shape-picker button.active{background-color:#fff;color:#000;border-color:#000}.text-control-item{border:1px solid #eee;border-radius:8px;padding:1rem}.text-control-item input{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;margin-bottom:10px;box-sizing:border-box}.text-style-controls{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.text-style-controls select,.text-style-controls input{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.text-style-controls input[type=number]{width:60px}.text-style-controls input[type=color]{padding:2px;height:34px}.boomerang-button-v2{padding:10px 20px;background-color:#000;color:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;text-transform:capitalize;transition:all .2s ease-in-out;box-shadow:none}.boomerang-button-v2:hover{background-color:#fff;color:#000;border-color:#000;transform:none;box-shadow:none}.boomerang-button-v2:disabled{opacity:.5;cursor:not-allowed;background-color:#ccc;border-color:#ccc;color:#666;transform:none;box-shadow:none}.boomerang-modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;justify-content:center;align-items:center;z-index:1000}.boomerang-modal-content{background-color:#fff;padding:2rem;border-radius:12px;width:90%;max-width:1000px;box-shadow:0 10px 30px #0003;position:relative;color:#333}.boomerang-modal-content h3{text-align:center;margin-top:0;margin-bottom:1.5rem;font-size:24px}.close-button{position:absolute;top:15px;right:15px;background:none;border:none;font-size:28px;cursor:pointer;color:#aaa;line-height:1}.close-button:hover{color:#333}.boomerang-main-area{display:flex;gap:2rem}.boomerang-preview{flex:2;background-color:#eee;border-radius:8px;overflow:hidden;position:relative;min-height:480px;display:flex;align-items:center;justify-content:center}.webcam-view{transform:scaleX(-1);object-fit:cover;height:100%;width:100%}.recording-indicator{position:absolute;top:10px;left:10px;background-color:#f00c;color:#fff;padding:5px 10px;border-radius:5px;font-weight:700;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.boomerang-controls{flex:1;display:flex;flex-direction:column;gap:1.5rem}.boomerang-controls h4{margin:0 0 .5rem;border-bottom:1px solid #eee;padding-bottom:.5rem}.filter-picker,.duration-picker{display:flex;flex-wrap:wrap;gap:10px}.filter-picker button,.duration-picker button{padding:8px 12px;border:1px solid #ddd;background-color:#f9f9f9;border-radius:5px;cursor:pointer;transition:all .2s ease}.filter-picker button.active,.duration-picker button.active{background-color:#007bff;color:#fff;border-color:#007bff}.filter-grayscale{filter:grayscale(100%)}.filter-sepia{filter:sepia(100%)}.filter-saturate{filter:saturate(200%)}.filter-contrast{filter:contrast(150%)}.control-button{width:100%;padding:15px;font-size:18px;font-weight:700;border-radius:8px;border:none;cursor:pointer;margin-top:auto}.control-button.record{background-color:#dc3545;color:#fff}.control-button.record:disabled{background-color:#a06268}.result-actions{display:flex;gap:10px;margin-top:auto}.control-button.record-again{background-color:#6c757d;color:#fff}.control-button.download-final{background-color:#28a745;color:#fff}@media (max-width: 768px){.boomerang-main-area{flex-direction:column}.boomerang-modal-content{padding:1.5rem;height:90vh;overflow-y:auto}}.video-inframe-button-v2{padding:10px 20px;background-color:#000;color:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;text-transform:capitalize;transition:all .2s ease-in-out;box-shadow:none}.video-inframe-button-v2:hover{background-color:#fff;color:#000;border-color:#000;transform:none;box-shadow:none}.video-inframe-button-v2:disabled{opacity:.5;cursor:not-allowed;background-color:#ccc;border-color:#ccc;color:#666;transform:none;box-shadow:none}.video-inframe-modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.video-inframe-modal-content{background-color:#f0f2f5;border-radius:12px;width:100%;max-width:1150px;height:95vh;box-shadow:none;position:relative;display:flex;overflow:hidden}.inframe-layout{display:flex;width:100%;height:100%;gap:2rem;padding:1.5rem;align-items:center;justify-content:center}.inframe-preview-column{flex-shrink:0;position:relative;background-size:cover;background-position:center;background-repeat:no-repeat;border-radius:8px;display:flex;justify-content:center;align-items:center;box-shadow:none;max-width:580px;aspect-ratio:1080 / 1920}.inframe-controls-column{width:450px;flex-shrink:0;background-color:#fff;padding:2rem;border-radius:8px;overflow-y:auto;display:flex;flex-direction:column;height:95%;max-height:850px;border-left:1px solid #e0e0e0}.inframe-controls-column h2{text-align:center;color:#333;margin-top:0}.video-grid-container{display:grid;width:540px;gap:30px;padding:30px 0;grid-template-columns:repeat(2,250px);justify-content:center;align-content:center;background-color:#fff0;border-radius:6px}.video-cell{background-color:#333;border-radius:4px;overflow:hidden;position:relative;width:250px;height:250px;border:2px solid transparent;transition:border-color .3s ease;box-shadow:none}.video-cell.active{border-color:#0f8;box-shadow:0 0 15px #0f8}.video-cell .webcam-view,.video-cell .video-result{width:100%;height:100%;object-fit:cover}.video-cell-overlay{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;background-color:#00000080;opacity:0;transition:opacity .3s ease}.video-cell.active .video-cell-overlay{opacity:1}.finished-checkmark,.countdown-text{font-size:48px;font-weight:700;color:#fff;text-shadow:0 0 10px black}.finished-checkmark{color:#0f8}.recording-indicator-cell{position:absolute;top:5px;left:5px;background-color:#f00c;color:#fff;padding:2px 6px;border-radius:5px;font-size:10px;font-weight:700;animation:pulse 1.5s infinite}.inframe-caption-display{position:absolute;bottom:30px;left:50%;transform:translate(-50%);width:100%;text-align:center;font-weight:700;text-shadow:1px 1px 3px rgba(0,0,0,.6);pointer-events:none;z-index:10}.inframe-main-actions{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:20px}.main-action-button{width:100%;padding:16px 20px;font-size:17px;font-weight:600;border-radius:10px;border:none;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.8px;box-shadow:0 4px 15px #0000001a}.main-action-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.main-action-button.reset{background-color:#ff8c00;color:#fff;border:1px solid #e07b00}.main-action-button.reset:hover{background-color:#e07b00}.main-action-button.download{background-color:#4caf50;color:#fff;border:1px solid #388E3C}.main-action-button.download:hover{background-color:#388e3c}.main-action-button.start{background-color:#000;color:#fff;border:2px solid #000000}.main-action-button.start:hover{background-color:#fff;color:#000;border-color:#000}.main-action-button.recording{background-color:#6c757d;color:#fff;cursor:not-allowed;opacity:.8}.main-action-button.recording:hover{background-color:#6c757d;transform:translateY(0);box-shadow:none}@media (max-width: 1200px){.customize-page{flex-direction:column;height:auto}.preview-column,.controls-column{flex:none;width:100%;padding:1rem}.final-frame-canvas{max-width:90%;margin:0 auto}.preview-actions{flex-wrap:wrap;justify-content:center}.video-inframe-modal-content{max-width:95%;height:90vh;overflow-y:auto}.inframe-layout{flex-direction:column;gap:1rem;padding:1rem}.inframe-preview-column{max-width:100%;aspect-ratio:1080 / 1920;height:auto}.inframe-controls-column{width:100%;max-height:none}.video-grid-container{width:100%;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;padding:15px 0}.video-cell{width:auto;height:auto;aspect-ratio:1 / 1}}@media (max-width: 768px){.preview-column{padding:1rem .5rem}.final-frame-canvas,.frame-wrapper-final{padding:10px}.frame-content-final{gap:5px}.caption-area{bottom:2px;left:2px;right:2px;padding:2px}.print-button-v2,.share-button-v2,.boomerang-button-v2,.video-inframe-button-v2{padding:10px 15px;font-size:.9rem}.controls-column{padding:1rem}.control-group h3{font-size:1.1rem}.picker-grid{gap:5px}.color-swatch{width:30px;height:30px}.shape-picker button{padding:8px 10px;font-size:.9rem}.text-control-item{padding:.8rem}.text-style-controls{grid-template-columns:1fr}.main-action-button{padding:12px 15px;font-size:16px}}.main-action-button.proceed-upload{background-color:#007bff;color:#fff;margin-top:10px}.main-action-button.proceed-upload:hover{background-color:#0056b3}.frame-wrapper-final,.inframe-preview-column{position:relative;overflow:hidden}.applied-sticker{position:absolute;pointer-events:none;z-index:10}.sticker-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:10px;max-height:220px;overflow-y:auto;padding:10px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.sticker-swatch{width:100%;aspect-ratio:1 / 1;border-radius:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;align-items:center;justify-content:center;background-color:#fff;border:1px solid #ddd;padding:5px;box-sizing:border-box}.sticker-swatch:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000001a;z-index:2}.sticker-swatch img{max-width:100%;max-height:100%;object-fit:contain}.undo-sticker-button{margin-left:10px;padding:3px 10px;font-size:12px;font-weight:500;border-radius:5px;border:1px solid #ccc;background-color:#f0f0f0;color:#333;cursor:pointer}.undo-sticker-button:hover{background-color:#e0e0e0;border-color:#bbb}.slot-media{width:100%;height:100%;object-fit:cover}.download-button-v2{background:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:5px;font-weight:700;cursor:pointer;transition:background-color .2s}.download-button-v2:hover{background:#2980b9}.download-button-v2:disabled{background:#bdc3c7;cursor:not-allowed}.modal-content.share-modal{max-width:450px;text-align:center}.share-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:1rem}.qr-code-container{padding:1rem;background-color:#fff;border-radius:8px;border:1px solid #eee}.qr-code-container p{font-size:.9rem;color:#555;margin-top:.8rem;margin-bottom:0}.share-buttons-container{display:flex;flex-direction:column;gap:1rem;width:100%}.share-button{padding:12px 20px;border-radius:8px;text-decoration:none;font-weight:700;color:#fff;text-align:center;transition:transform .2s}.share-button:hover{transform:scale(1.05)}.share-button.whatsapp{background-color:#25d366}.share-button.email{background-color:#7f8c8d}@keyframes ellipsis{0%{content:"."}33%{content:".."}66%{content:"..."}to{content:"."}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-container p:after{content:".";animation:ellipsis 1.5s infinite;display:inline-block;width:20px;text-align:left}.share-success-content{animation:fadeIn .5s ease-out}.error-container p{color:#e74c3c;font-weight:700}.gif-button-v2{background:linear-gradient(45deg,#6a82fb,#fc5c7d);color:#fff;border:none;padding:10px 20px;border-radius:5px;font-weight:700;cursor:pointer;transition:transform .2s}.gif-button-v2:hover{transform:scale(1.05)}.modal-overlay.show{display:flex}.gif-creator-modal{max-width:600px;width:90%}.photo-selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin:1rem 0;max-height:300px;overflow-y:auto;padding:5px;border:1px solid #eee;border-radius:8px}.photo-selection-grid .photo-item{aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;cursor:pointer;border:3px solid transparent;transition:border-color .2s,transform .2s}.photo-selection-grid .photo-item:hover{transform:scale(1.05)}.photo-selection-grid .photo-item.selected{border-color:#fc5c7d}.photo-selection-grid .photo-item img{width:100%;height:100%;object-fit:cover}.gif-controls{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:1.5rem}.gif-controls select{padding:8px;border-radius:4px;border:1px solid #ccc}.gif-result-container{text-align:center}.gif-result-container img{max-width:100%;border:1px solid #eee;border-radius:8px;margin-bottom:1rem}.download-gif-button{display:inline-block;background-color:#28a745;color:#fff;padding:10px 20px;text-decoration:none;border-radius:5px;margin-right:10px}.upload-page-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:20px;background-color:#f0f2f5;min-height:100vh;box-sizing:border-box;font-family:Poppins,sans-serif;color:#333}.upload-header{width:100%;max-width:1200px;display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:10px 0}.upload-header h2{color:#333;margin:0;font-size:2em}.back-button{padding:10px 18px;background-color:#6c757d;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:16px;transition:background-color .3s ease;display:flex;align-items:center;gap:5px}.back-button:hover{background-color:#5a6268}.upload-status-notification{background-color:#e0f7fa;color:#007bff;border:1px solid #007bff;padding:10px 20px;border-radius:5px;margin-bottom:20px;width:100%;max-width:1200px;text-align:center;font-weight:700}.content-area{display:flex;flex-direction:row;gap:30px;align-items:flex-start;width:100%;max-width:1200px;justify-content:center}.inframe-result-display{width:580px;height:960px;position:relative;overflow:hidden;border:2px solid #ccc;border-radius:8px;box-shadow:0 4px 12px #00000026;background-color:transparent;flex-shrink:0;background-size:cover;background-position:center;background-repeat:no-repeat}.video-grid-container-final{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr);padding:200px 60px 100px;gap:20px;width:100%;height:100%;box-sizing:border-box;position:absolute;top:0;left:0}.video-cell-final{background-color:#000;display:flex;justify-content:center;align-items:center;overflow:hidden}.video-result-final{width:100%;height:100%;object-fit:cover}.placeholder-video{color:#fff;font-size:14px;text-align:center;padding:10px}.inframe-caption-display-final{width:100%;text-align:center;position:absolute;bottom:80px;left:0;padding:0 60px;box-sizing:border-box;white-space:pre-wrap;word-break:break-word}.upload-actions{width:350px;background-color:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:15px;box-sizing:border-box;flex-shrink:0;align-self:flex-start}.upload-actions h3,.upload-actions h4{margin-top:0;color:#333;border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:15px}.action-button{padding:12px 20px;border:none;border-radius:5px;cursor:pointer;font-size:16px;font-weight:700;color:#fff;transition:background-color .3s ease;width:100%;box-sizing:border-box}.download-image-strip{background-color:#007bff}.download-image-strip:hover{background-color:#0056b3}.download-all-clips{background-color:#28a745}.download-all-clips:hover{background-color:#218838}.social-media-uploads{margin-top:20px;border-top:1px solid #eee;padding-top:15px;display:flex;flex-direction:column;gap:10px}.social-media-uploads h4{width:100%;margin-top:0;margin-bottom:5px;color:#555;border:none;padding-bottom:0}.social-button{padding:12px 20px;border:none;border-radius:5px;cursor:pointer;font-size:16px;font-weight:700;color:#fff;transition:opacity .3s ease;width:100%;box-sizing:border-box;text-align:center}.social-button.instagram{background:radial-gradient(circle at 30% 107%,#fdf497 0% 5%,#fd5949 45%,#d6249f 60%,#285aeb 90%)}.social-button.instagram:hover{opacity:.9}.social-button.tiktok{background-color:#000}.social-button.tiktok:hover{background-color:#333}.social-button.facebook{background-color:#3b5998}.social-button.facebook:hover{background-color:#2d4373}.social-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.social-modal-content{background-color:#fff;padding:30px;border-radius:10px;box-shadow:0 5px 15px #0000004d;width:90%;max-width:550px;position:relative;display:flex;flex-direction:column;gap:15px}.social-modal-content .close-button{position:absolute;top:15px;right:15px;background:none;border:none;font-size:28px;cursor:pointer;color:#666;line-height:1}.social-modal-content .close-button:hover{color:#333}.social-modal-content h3{margin-top:0;color:#333;text-align:center;font-size:1.8em;border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:20px}.modal-description{font-size:.95em;color:#666;line-height:1.5;text-align:center;margin-bottom:15px}.auth-button{padding:12px 20px;background-color:#007bff;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1.1em;font-weight:700;transition:background-color .3s ease;width:100%;text-align:center}.auth-button:hover{background-color:#0056b3}.modal-separator{border:0;border-top:1px dashed #ccc;margin:20px 0}.video-selection-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;max-height:200px;overflow-y:auto;padding:5px;border:1px solid #eee;border-radius:5px;background-color:#f9f9f9}.video-selection-item{cursor:pointer;border:2px solid transparent;border-radius:5px;overflow:hidden;position:relative;padding:5px;background-color:#fff;box-shadow:0 2px 5px #0000000d}.video-selection-item.selected{border-color:#007bff;box-shadow:0 0 0 3px #007bff}.video-selection-item img,.video-selection-item .placeholder-thumb{width:100%;height:100px;object-fit:cover;display:block;border-radius:3px;background-color:#ccc}.video-selection-item .placeholder-thumb{display:flex;align-items:center;justify-content:center;color:#555;font-size:.9em;text-align:center}.video-selection-item .clip-label{position:absolute;bottom:0;left:0;right:0;background-color:#0009;color:#fff;font-size:.75em;text-align:center;padding:3px 0}.no-videos-message{font-style:italic;color:#999;text-align:center;grid-column:span 3}.form-group label{font-weight:700;margin-bottom:5px;display:block}.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-family:Poppins,sans-serif}.upload-confirm-button{padding:12px 25px;background-color:#28a745;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1.1em;font-weight:700;transition:background-color .3s ease;align-self:center;width:auto;min-width:200px}.upload-confirm-button:hover:not(:disabled){background-color:#218838}.upload-confirm-button:disabled{background-color:#ccc;cursor:not-allowed}.upload-status-message{text-align:center;font-size:.9em;color:#dc3545;font-weight:700}@media (max-width: 1024px){.content-area{flex-direction:column;align-items:center}.upload-actions{width:100%;max-width:580px;align-self:center}.social-media-uploads{flex-direction:row;flex-wrap:wrap;justify-content:center}.social-button{flex:1 1 calc(50% - 10px);min-width:unset}.social-modal-content{max-width:90%}}@media (max-width: 768px){.upload-page-container{padding:10px}.upload-header{padding:5px 0}.upload-header h2{font-size:1.6em}.back-button{font-size:13px;padding:7px 12px}.upload-status-notification{font-size:.9em;padding:8px 15px}.inframe-result-display{width:100%;height:auto;max-width:350px;aspect-ratio:580 / 960}.video-grid-container-final{padding:18% 10% 12%;gap:12px}.inframe-caption-display-final{bottom:8%;padding:0 10%;font-size:.9em!important}.upload-actions{padding:15px;gap:10px}.action-button{padding:10px 15px;font-size:14px}.social-button{font-size:13px;padding:10px 15px;flex:1 1 100%}.social-modal-content{padding:20px;gap:10px;max-width:95%}.social-modal-content h3{font-size:1.4em}.modal-description,.modal-instructions,.modal-note{font-size:.9em}.video-selection-grid{grid-template-columns:repeat(2,1fr)}.social-modal-content .modal-download-button,.social-modal-content .auth-button,.social-modal-content .upload-confirm-button{padding:10px 15px;font-size:1em;min-width:unset}}.gift-creator-page{display:flex;height:100vh;background-color:#fdf6f8;font-family:Segoe UI,sans-serif;color:#333;overflow:hidden}.photo-source-column{width:300px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;padding:1.5rem;overflow-y:auto}.photo-source-column h3{margin:0 0 .5rem;color:#d17a8b}.source-photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.photo-item{position:relative;cursor:pointer;border-radius:8px;overflow:hidden;border:3px solid transparent;transition:transform .2s ease,border-color .2s ease}.photo-item:hover{transform:scale(1.05)}.photo-item img{width:100%;height:100%;object-fit:cover;display:block}.photo-item.selected{border-color:#e91e63;transform:scale(1.03)}.selection-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#e91e6399;display:flex;justify-content:center;align-items:center}.checkmark-icon{width:40px;height:40px}.canvas-column{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem;overflow-y:auto}.canvas-header{text-align:center;margin-bottom:1.5rem}.canvas-header h1{color:#d17a8b;font-size:2.2rem;margin:0}.canvas-header p{color:#888;margin-top:.5rem}.controls-section{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center}.orientation-selector{display:flex}.orientation-selector button{padding:12px 24px;border:2px solid #d17a8b;background-color:transparent;color:#d17a8b;cursor:pointer;font-weight:700;transition:all .2s ease}.orientation-selector button:first-child{border-top-left-radius:50px;border-bottom-left-radius:50px}.orientation-selector button:last-child{border-top-right-radius:50px;border-bottom-right-radius:50px;border-left:none}.orientation-selector button.active{background-color:#d17a8b;color:#fff;border-color:#d17a8b}.generate-button{padding:14px 28px;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(45deg,#ff6b6b,#feca57);border:none;border-radius:50px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #0000001a}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #feca5766}.generate-button:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#e74c3c;font-weight:700;margin-bottom:1rem}.gif-preview-container{background-color:#fff;border:2px dashed #ccc;border-radius:12px;display:flex;justify-content:center;align-items:center;position:relative;box-shadow:0 5px 20px #00000014;transition:all .3s ease}.gif-preview-container.portrait{width:320px;height:480px}.gif-preview-container.landscape{width:480px;height:320px}.generated-gif{max-width:100%;max-height:100%;border-radius:10px}.placeholder-preview{text-align:center;color:#aaa}.placeholder-preview p{margin:0;font-size:1.2rem}.placeholder-preview small{font-size:.9rem}.output-section{width:100%;max-width:650px;margin-top:2rem;padding:1.5rem;background-color:#fff;border-radius:12px;box-shadow:0 5px 20px #0000000d}.output-section h2{text-align:center;margin-top:0;margin-bottom:1.5rem;color:#d17a8b}.share-grid{display:flex;justify-content:space-around;gap:2rem;flex-wrap:wrap}.share-option{text-align:center}.share-option strong{display:block;margin-bottom:1rem;font-size:1.1rem}.qr-wrapper{padding:10px;background-color:#fff;border-radius:8px;box-shadow:0 2px 5px #0000001a;display:inline-block}.action-buttons{display:flex;flex-direction:column;gap:1rem;width:220px}.action-btn{padding:12px;border-radius:8px;border:none;font-weight:700;cursor:pointer;transition:opacity .2s ease;text-decoration:none;color:#fff;display:block}.action-btn:hover{opacity:.85}.action-btn.download{background-color:#3498db}.action-btn.whatsapp{background-color:#25d366}.action-btn.email{background-color:#8e44ad}.back-button-gift{margin-top:2rem;padding:10px 20px;background-color:#e0e0e0;color:#333;border:none;border-radius:20px;font-weight:700;cursor:pointer;transition:background-color .2s ease}.back-button-gift:hover{background-color:#d1d1d1}.loading-spinner{border:5px solid #f3f3f3;border-top:5px solid #d17a8b;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#root{width:100vw;height:100%;margin:0;padding:0;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
