@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600&family=Great+Vibes&display=swap";:root{--color-ivory:#faf8f5;--color-champagne:#f5e6d3;--color-blush:#f2d7d5;--color-rose:#d4a5a5;--color-dusty-rose:#c9929b;--color-gold:#c5a55a;--color-gold-light:#d4b96a;--color-gold-dark:#a8893c;--color-sage:#9caf88;--color-deep-green:#2d4a3e;--color-charcoal:#2c2c2c;--color-warm-gray:#6b6560;--color-light-gray:#e8e4e0;--color-white:#fff;--color-overlay:#2c2c2cd9;--gradient-hero:linear-gradient(135deg, #2d4a3e 0%, #1a2e26 40%, #2c2c2c 100%);--gradient-gold:linear-gradient(135deg, var(--color-gold-dark), var(--color-gold), var(--color-gold-light));--gradient-blush:linear-gradient(135deg, var(--color-ivory), var(--color-blush), var(--color-champagne));--gradient-card:linear-gradient(145deg, #ffffffe6, #faf8f5b3);--glass-bg:#ffffff26;--glass-border:#ffffff40;--glass-shadow:0 8px 32px #0000001a;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 20px #00000014;--shadow-lg:0 8px 40px #0000001f;--shadow-xl:0 16px 60px #00000029;--shadow-gold:0 4px 20px #c5a55a4d;--font-display:"Playfair Display", Georgia, serif;--font-body:"Inter", -apple-system, sans-serif;--font-script:"Great Vibes", cursive;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--space-4xl:6rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.3s cubic-bezier(.4, 0, .2, 1);--transition-slow:.5s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background-color:var(--color-ivory);color:var(--color-charcoal);line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-ivory)}::-webkit-scrollbar-thumb{background:var(--color-rose);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-dusty-rose)}::selection{background:var(--color-blush);color:var(--color-charcoal)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes heartbeat{0%,to{transform:scale(1)}25%{transform:scale(1.1)}50%{transform:scale(1)}75%{transform:scale(1.05)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)rotate(0)}50%{opacity:1;transform:scale(1)rotate(180deg)}}@keyframes drawLine{0%{width:0}to{width:80px}}.animate-fade-in-up{animation:fadeInUp .8s var(--transition-base) forwards;opacity:0}.animate-fade-in{animation:fadeIn .6s var(--transition-base) forwards;opacity:0}.animate-scale-in{animation:scaleIn .5s var(--transition-spring) forwards;opacity:0}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}.delay-4{animation-delay:.4s}.delay-5{animation-delay:.5s}.delay-6{animation-delay:.6s}.delay-7{animation-delay:.7s}.delay-8{animation-delay:.8s}#root{text-align:left;max-width:none;margin:0;padding:0}a{color:var(--color-gold);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-gold-dark)}img{max-width:100%;display:block}button{cursor:pointer;font-family:var(--font-body)}input,textarea{font-family:var(--font-body)}.hero{background:var(--gradient-hero);min-height:100vh;padding:var(--space-2xl);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero-particles{pointer-events:none;position:absolute;inset:0;overflow:hidden}.particle{background:var(--color-gold);opacity:0;border-radius:50%;width:3px;height:3px;animation:4s ease-in-out infinite sparkle;position:absolute}.botanical-corner{pointer-events:none;z-index:1;width:140px;height:140px;position:absolute}.botanical-corner.top-left{top:20px;left:20px}.botanical-corner.top-right{top:20px;right:20px;transform:scaleX(-1)}.botanical-corner.bottom-left{bottom:90px;left:20px;transform:scaleY(-1)}.botanical-corner.bottom-right{bottom:90px;right:20px;transform:scale(-1)}.hero-top-border{background:var(--gradient-gold);justify-content:center;align-items:flex-start;height:4px;display:flex;position:absolute;top:0;left:0;right:0}.border-ornament{background:var(--color-deep-green);color:var(--color-gold);width:50px;height:50px;font-size:1.4rem;font-family:var(--font-script);border:2px solid var(--color-gold);z-index:10;border-radius:50%;justify-content:center;align-items:center;margin-top:-20px;transition:transform .3s;display:flex;box-shadow:0 4px 15px #0000004d}.border-ornament:hover{transform:scale(1.1)}.hero-content{text-align:center;z-index:2;width:100%;max-width:700px}.hero-monogram{margin-bottom:var(--space-lg);justify-content:center;display:flex}.av-monogram{filter:drop-shadow(0 4px 24px #c5a55a40);border-radius:50%;width:320px;height:320px}.hero-tagline{font-family:var(--font-display);color:#faf8f5a6;letter-spacing:.05em;margin-bottom:var(--space-md);font-size:1rem;font-style:italic;font-weight:400}.hero-title{margin-bottom:var(--space-lg)}.hero-names{font-family:var(--font-script);color:var(--color-ivory);background:linear-gradient(135deg, var(--color-ivory), var(--color-champagne), var(--color-gold-light), var(--color-ivory));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(3rem,8vw,5.5rem);font-weight:400;line-height:1.2;display:block}.hero-date-wrapper{justify-content:center;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl);display:flex}.hero-line{background:linear-gradient(90deg, transparent, var(--color-gold));width:60px;height:1px;animation:1s ease-out .8s forwards drawLine}.hero-line:last-child{background:linear-gradient(90deg, var(--color-gold), transparent)}.hero-date-badge{align-items:center;gap:var(--space-sm);display:flex}.hero-date-month{font-family:var(--font-display);color:var(--color-gold);letter-spacing:.2em;text-transform:uppercase;font-size:.85rem;font-weight:500}.hero-date-day{font-family:var(--font-display);color:var(--color-champagne);border-left:1px solid var(--color-gold);border-right:1px solid var(--color-gold);padding:0 var(--space-sm);font-size:2rem;font-weight:700;line-height:1}.hero-date-year{font-family:var(--font-display);color:var(--color-gold);letter-spacing:.2em;font-size:.85rem;font-weight:500}.hero-subtitle{color:#faf8f5b3;margin-bottom:var(--space-2xl);padding:0 var(--space-sm);font-size:1.05rem;font-weight:300;line-height:1.8}.hero-cta-group{gap:var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.hero-cta{align-items:center;gap:var(--space-sm);border-radius:var(--radius-full);transition:all var(--transition-base);letter-spacing:.02em;border:none;padding:14px 32px;font-size:.95rem;font-weight:500;display:inline-flex}.hero-cta.primary{background:var(--gradient-gold);color:var(--color-white);box-shadow:var(--shadow-gold)}.hero-cta.primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #c5a55a80}.hero-cta.secondary{background:var(--glass-bg);color:var(--color-ivory);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-cta.secondary:hover{background:#ffffff40;transform:translateY(-2px)}.hero-scroll-indicator{color:#faf8f580;letter-spacing:.15em;text-transform:uppercase;transition:color var(--transition-fast);z-index:2;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;font-size:.75rem;display:flex;position:absolute;bottom:80px}.hero-scroll-indicator:hover{color:var(--color-gold)}.bounce{animation:2s ease-in-out infinite float}.hero-wave{z-index:1;position:absolute;bottom:-1px;left:0;right:0}.hero-wave svg{width:100%;height:80px;display:block}@media (width<=768px){.hero{padding:var(--space-xl) var(--space-md);min-height:100svh;padding-bottom:calc(var(--space-xl) + env(safe-area-inset-bottom,0px))}.hero-subtitle br{display:none}.av-monogram{width:220px;height:220px}.hero-tagline{padding:0 var(--space-sm);font-size:.9rem}.hero-subtitle{margin-bottom:var(--space-xl)}.hero-cta-group{flex-direction:column;width:100%;max-width:280px;margin:0 auto}.hero-cta{justify-content:center;width:100%}.hero-scroll-indicator{margin-top:var(--space-lg);position:static}.botanical-corner{width:90px;height:90px}.botanical-corner.bottom-left,.botanical-corner.bottom-right{display:none}.hero-date-wrapper{gap:var(--space-md)}.hero-line{width:40px}.hero-wave svg{height:64px}}.photo-upload{max-width:640px;margin:0 auto}.upload-success{justify-content:center;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--color-sage);color:var(--color-deep-green);background:#2d4a3e1a;padding:14px 20px;font-size:.9rem;font-weight:500;display:flex}.upload-error{margin-bottom:var(--space-lg);border-radius:var(--radius-lg);color:#8b2020;background:#c8323214;border:1px solid #c832324d;justify-content:center;align-items:center;padding:14px 20px;font-size:.9rem;font-weight:500;display:flex}.upload-progress-card{margin-bottom:var(--space-lg);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);background:linear-gradient(#c5a55a1f,#ffffffeb);border:1px solid #c5a55a47;padding:18px 20px}.upload-progress-header{justify-content:space-between;align-items:center;gap:var(--space-md);color:var(--color-charcoal);margin-bottom:10px;font-size:.95rem;font-weight:600;display:flex}.upload-progress-bar{border-radius:var(--radius-full);background:#2c2c2c14;height:12px;overflow:hidden}.upload-progress-fill{border-radius:inherit;background:var(--gradient-gold);height:100%;transition:width .2s;display:block}.upload-progress-copy{color:var(--color-warm-gray);margin-top:10px;font-size:.9rem}.uploaded-list{margin-top:var(--space-md);gap:10px;display:grid}.uploaded-item{border-radius:var(--radius-lg);color:var(--color-deep-green);background:#ffffffbf;border:1px solid #2d4a3e1a;align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;text-decoration:none;display:flex}.uploaded-item span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.upload-name-field{margin-bottom:var(--space-lg)}.name-input-wrapper{align-items:center;gap:var(--space-sm);background:var(--color-ivory);border:2px solid var(--color-light-gray);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:14px 20px;display:flex}.name-input-wrapper:focus-within{border-color:var(--color-gold);background:var(--color-white);box-shadow:0 0 0 4px #c5a55a1a}.name-icon{color:var(--color-rose);flex-shrink:0}.name-input{color:var(--color-charcoal);background:0 0;border:none;outline:none;flex:1;font-size:1rem}.name-input::placeholder{color:var(--color-warm-gray);opacity:.7}.drop-zone{border:2px dashed var(--color-light-gray);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--color-ivory);position:relative;overflow:hidden}.drop-zone.has-files{margin-bottom:var(--space-sm)}.drop-zone:before{content:"";background:var(--gradient-blush);opacity:0;transition:opacity var(--transition-base);position:absolute;inset:0}.drop-zone:hover{border-color:var(--color-rose);box-shadow:var(--shadow-md);transform:translateY(-2px)}.drop-zone:hover:before{opacity:.3}.drop-zone.dragging{border-color:var(--color-gold);box-shadow:var(--shadow-lg), var(--shadow-gold);background:#c5a55a0d;border-style:solid;transform:scale(1.02)}.drop-zone.dragging:before{opacity:.5}.file-input{display:none}.drop-zone-content{z-index:1;position:relative}.drop-zone-icon-wrapper{margin-bottom:var(--space-lg)}.drop-zone-icon{background:var(--gradient-blush);width:72px;height:72px;color:var(--color-dusty-rose);transition:all var(--transition-base);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.drop-zone:hover .drop-zone-icon{color:var(--color-gold);transform:scale(1.1)}.drop-zone.dragging .drop-zone-icon{background:var(--gradient-gold);color:#fff;animation:1s ease-in-out infinite float}.drop-zone-title{font-family:var(--font-display);color:var(--color-charcoal);margin-bottom:var(--space-xs);font-size:1.25rem;font-weight:600}.drop-zone-hint{color:var(--color-warm-gray);margin-bottom:var(--space-sm);font-size:.9rem}.drop-zone-formats{color:var(--color-warm-gray);background:var(--color-light-gray);border-radius:var(--radius-full);letter-spacing:.05em;padding:4px 12px;font-size:.75rem;display:inline-block}.previews-section{margin-top:var(--space-xl)}.previews-header{margin-bottom:var(--space-md);justify-content:center;align-items:center;display:flex}.previews-count{color:var(--color-gold);align-items:center;gap:6px;font-size:.85rem;font-weight:500;display:flex}.previews-grid{gap:var(--space-sm);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.preview-item{aspect-ratio:1;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast);position:relative;overflow:hidden}.preview-item:hover{transform:scale(1.05)}.preview-image{object-fit:cover;width:100%;height:100%}.preview-remove{color:#fff;opacity:0;width:24px;height:24px;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#2c2c2cb3;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:4px;right:4px}.preview-item:hover .preview-remove{opacity:1}.preview-remove:hover{background:#c83232e6;transform:scale(1.1)}.preview-remove:disabled{opacity:.45;cursor:not-allowed}.upload-submit{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-lg);background:var(--gradient-gold);color:#fff;letter-spacing:.02em;width:100%;transition:all var(--transition-base);box-shadow:var(--shadow-gold);border:none;padding:16px;font-size:1rem;font-weight:600;display:flex}.upload-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #c5a55a80}.upload-submit:active:not(:disabled){transform:translateY(0)}.upload-submit:disabled{opacity:.6;cursor:not-allowed}.upload-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.drop-zone{padding:var(--space-2xl) var(--space-md)}.previews-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}.gallery-empty{text-align:center;padding:var(--space-4xl) var(--space-xl)}.empty-icon-wrapper{background:var(--gradient-blush);width:100px;height:100px;color:var(--color-dusty-rose);margin-bottom:var(--space-xl);border-radius:50%;justify-content:center;align-items:center;animation:3s ease-in-out infinite float;display:inline-flex}.empty-title{font-family:var(--font-display);color:var(--color-charcoal);margin-bottom:var(--space-sm);font-size:1.5rem;font-weight:600}.empty-message{color:var(--color-warm-gray);max-width:400px;margin:0 auto;font-size:1rem}.gallery-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.gallery-item{border-radius:var(--radius-lg);cursor:pointer;aspect-ratio:4/3;background:var(--color-light-gray);box-shadow:var(--shadow-sm);transition:all var(--transition-base);position:relative;overflow:hidden}.gallery-item:hover{box-shadow:var(--shadow-xl);transform:translateY(-6px)}.gallery-image{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.gallery-item:hover .gallery-image{transform:scale(1.08)}.gallery-overlay{padding:var(--space-lg);opacity:0;transition:opacity var(--transition-base);background:linear-gradient(#0000 40%,#2c2c2ccc 100%);align-items:flex-end;display:flex;position:absolute;inset:0}.gallery-item:hover .gallery-overlay{opacity:1}.gallery-info{flex-direction:column;gap:2px;display:flex}.gallery-guest{color:var(--color-white);font-size:.95rem;font-weight:600}.gallery-time{color:#ffffffb3;font-size:.75rem}.gallery-shine{pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff26,#0000);width:50%;height:100%;transition:left .6s;position:absolute;top:0;left:-100%}.gallery-item:hover .gallery-shine{left:150%}@media (width<=768px){.gallery-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.gallery-item{border-radius:var(--radius-md)}.gallery-overlay{opacity:1;padding:var(--space-sm)}.gallery-guest{font-size:.8rem}}@media (width<=480px){.gallery-grid{gap:var(--space-xs);grid-template-columns:repeat(2,1fr)}}.lightbox{z-index:1000;background:var(--color-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-xl);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lb-close{top:var(--space-lg);right:var(--space-lg);color:#fff;width:44px;height:44px;transition:all var(--transition-fast);z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.lb-close:hover{background:#fff3;transform:rotate(90deg)scale(1.1)}.lb-nav{color:#fff;width:48px;height:48px;transition:all var(--transition-fast);z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lb-nav:hover{background:#ffffff40;transform:translateY(-50%)scale(1.1)}.lb-prev{left:var(--space-lg)}.lb-next{right:var(--space-lg)}.lb-image-wrapper{justify-content:center;align-items:center;max-width:90vw;max-height:80vh;display:flex}.lb-image{object-fit:contain;border-radius:var(--radius-md);max-width:100%;max-height:80vh;box-shadow:var(--shadow-xl)}.lb-info{padding:var(--space-lg) var(--space-2xl);background:linear-gradient(#0000,#0009);justify-content:space-between;align-items:center;display:flex;position:absolute;bottom:0;left:0;right:0}.lb-info-left{align-items:center;gap:var(--space-lg);display:flex}.lb-info-right{align-items:center;gap:var(--space-md);display:flex}.lb-meta{color:#ffffffd9;align-items:center;gap:6px;font-size:.85rem;display:flex}.lb-counter{color:#fff9;font-size:.85rem;font-weight:500}.lb-delete{color:#ffffffb3;width:36px;height:36px;transition:all var(--transition-fast);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.lb-delete:hover{color:#fff;background:#dc3232cc;transform:scale(1.1)}@media (width<=768px){.lightbox{padding:var(--space-sm)}.lb-close{top:var(--space-sm);right:var(--space-sm)}.lb-nav{width:40px;height:40px}.lb-prev{left:var(--space-xs)}.lb-next{right:var(--space-xs)}.lb-info{gap:var(--space-sm);padding:var(--space-md);flex-direction:column}.lb-info-left{gap:var(--space-xs);flex-direction:column}}.footer{background:var(--gradient-hero);padding:var(--space-3xl) var(--space-xl);text-align:center;position:relative}.footer:before{content:"";background:linear-gradient(90deg, transparent, var(--color-gold), transparent);height:1px;position:absolute;top:0;left:0;right:0}.footer-content{max-width:600px;margin:0 auto}.footer-ornament{color:var(--color-gold);margin-bottom:var(--space-lg);font-size:.9rem}.footer-text{color:#faf8f5b3;margin-bottom:var(--space-md);justify-content:center;align-items:center;gap:4px;font-size:.9rem;display:flex}.footer-heart{animation:2s ease-in-out infinite heartbeat}.footer-brand{font-family:var(--font-script);color:var(--color-gold);margin-bottom:var(--space-xs);font-size:2rem}.footer-tagline{font-family:var(--font-display);color:#faf8f580;letter-spacing:.15em;margin-bottom:var(--space-md);font-size:.85rem}.footer-year{color:#faf8f559;font-size:.75rem}.install-banner{z-index:100;background:var(--gradient-hero);border-top:2px solid var(--color-gold);justify-content:space-between;align-items:center;gap:var(--space-md);padding:16px 20px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 30px #0003}.install-banner-content{align-items:center;gap:var(--space-md);flex:1;min-width:0;display:flex}.install-banner-icon{border-radius:var(--radius-md);background:var(--gradient-gold);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.install-banner-text{flex-direction:column;gap:2px;min-width:0;display:flex}.install-banner-text strong{color:var(--color-ivory);font-size:.95rem}.install-banner-text span{color:#faf8f599;font-size:.8rem}.install-banner-actions{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.install-btn{border-radius:var(--radius-full);background:var(--gradient-gold);color:#fff;transition:all var(--transition-fast);box-shadow:var(--shadow-gold);border:none;padding:10px 24px;font-size:.9rem;font-weight:600}.install-btn:hover{transform:scale(1.05)}.install-dismiss{color:#fff9;width:36px;height:36px;transition:all var(--transition-fast);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.install-dismiss:hover{color:#fff;background:#fff3}.ios-popup-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-md);background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.ios-popup{background:var(--color-white);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:420px;padding:var(--space-2xl) var(--space-xl) var(--space-xl);box-shadow:var(--shadow-xl);position:relative}.ios-popup-close{top:var(--space-md);right:var(--space-md);background:var(--color-light-gray);width:32px;height:32px;color:var(--color-warm-gray);transition:all var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.ios-popup-close:hover{background:var(--color-rose);color:#fff}.ios-popup-header{text-align:center;margin-bottom:var(--space-xl)}.ios-popup-icon{border-radius:var(--radius-lg);background:var(--gradient-gold);color:#fff;width:56px;height:56px;margin-bottom:var(--space-md);justify-content:center;align-items:center;display:inline-flex}.ios-popup-header h3{font-family:var(--font-display);color:var(--color-charcoal);margin-bottom:var(--space-xs);font-size:1.25rem;font-weight:600}.ios-popup-header p{color:var(--color-warm-gray);font-size:.9rem}.ios-popup-steps{gap:var(--space-md);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.ios-step{align-items:center;gap:var(--space-md);border-radius:var(--radius-md);background:var(--color-ivory);padding:14px 16px;display:flex}.ios-step-number{background:var(--gradient-gold);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.ios-step-content{color:var(--color-charcoal);flex-wrap:wrap;align-items:center;gap:4px;font-size:.9rem;display:flex}.ios-step-icon{color:var(--color-gold)}.ios-popup-ok{border-radius:var(--radius-lg);background:var(--gradient-gold);color:#fff;width:100%;transition:all var(--transition-base);box-shadow:var(--shadow-gold);border:none;padding:14px;font-size:1rem;font-weight:600}.ios-popup-ok:hover{transform:translateY(-2px);box-shadow:0 8px 30px #c5a55a80}@media (width>=769px){.ios-popup-overlay{align-items:center}.ios-popup{border-radius:var(--radius-xl)}}.app{flex-direction:column;min-height:100vh;display:flex}main{flex:1}.section{padding:var(--space-4xl) var(--space-xl);position:relative}.section-container{max-width:1200px;margin:0 auto}.section-header{text-align:center;margin-bottom:var(--space-3xl)}.section-label{font-family:var(--font-script);color:var(--color-gold);margin-bottom:var(--space-sm);font-size:1.4rem;display:block}.section-title{font-family:var(--font-display);color:var(--color-charcoal);margin-bottom:var(--space-md);letter-spacing:-.02em;font-size:clamp(2rem,4vw,2.8rem);font-weight:600}.section-subtitle{color:var(--color-warm-gray);max-width:560px;margin:0 auto;font-size:1.05rem;line-height:1.7}.section-divider{margin-top:var(--space-lg);justify-content:center;align-items:center;gap:var(--space-md);display:flex}.section-divider:before,.section-divider:after{content:"";background:linear-gradient(90deg, transparent, var(--color-gold), transparent);width:60px;height:1px}.divider-ornament{color:var(--color-gold);font-size:.75rem}.upload-section{background:var(--color-white);position:relative}.upload-section:before{content:"";background:linear-gradient(90deg, transparent, var(--color-champagne), var(--color-blush), var(--color-champagne), transparent);height:1px;position:absolute;top:0;left:0;right:0}.gallery-section{background:var(--color-ivory);padding-bottom:var(--space-4xl)}.scroll-top-btn{background:var(--gradient-gold);color:#fff;width:48px;height:48px;box-shadow:var(--shadow-lg), var(--shadow-gold);opacity:0;visibility:hidden;transition:all var(--transition-base);z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;bottom:2rem;right:2rem;transform:translateY(20px)}.scroll-top-btn.visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-top-btn:hover{box-shadow:var(--shadow-xl), var(--shadow-gold);transform:translateY(-3px)scale(1.1)}.scroll-top-btn:active{transform:translateY(0)scale(.95)}@media (width<=768px){.section{padding:var(--space-3xl) var(--space-md)}.section-header{margin-bottom:var(--space-2xl)}.section-subtitle{font-size:.95rem}.scroll-top-btn{width:42px;height:42px;bottom:5rem;right:1rem}}
