:root{--primary: #ffd846;--primary-dark: #c76d1b;--primary-medium: #e5a620;--primary-light: #fdde6a;--primary-glow: rgba(255, 216, 70, .4);--primary-subtle: rgba(255, 216, 70, .08);--royal: #1a3a8f;--royal-dark: #0e2470;--royal-light: #2a4ea5;--royal-glow: rgba(26, 58, 143, .35);--royal-subtle: rgba(26, 58, 143, .12);--rose: #8b1a2b;--rose-glow: rgba(139, 26, 43, .35);--bg-darkest: #050510;--bg-dark: #0c0a1e;--bg-warm: #161235;--text-white: #ffffff;--text-cream: #f1ce81;--gold-primary: var(--primary);--gold-dark: var(--primary-dark);--gold-medium: var(--primary-medium);--gold-light: var(--primary-light);--gold-glow: var(--primary-glow);--gold-subtle: var(--primary-subtle);--teal: var(--royal);--teal-dark: var(--royal-dark);--teal-glow: var(--royal-glow);--teal-subtle: var(--royal-subtle);--rust: var(--rose);--rust-glow: var(--rose-glow)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Poppins,sans-serif;min-height:100vh;overflow-x:hidden;color:var(--text-white);background:var(--bg-darkest);background:radial-gradient(ellipse at 50% 0%,var(--bg-warm) 0%,var(--bg-dark) 45%,var(--bg-darkest) 100%);background-attachment:fixed}body:before{content:"";position:fixed;width:150%;height:150%;top:-25%;left:-25%;background:radial-gradient(circle at 30% 40%,rgba(26,58,143,.09) 0%,transparent 40%),radial-gradient(circle at 70% 60%,rgba(255,216,70,.06) 0%,transparent 45%),radial-gradient(circle at 50% 80%,rgba(139,26,43,.05) 0%,transparent 35%);animation:ambientLight 30s infinite linear;pointer-events:none;z-index:0}body:after{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at center,transparent 45%,rgba(0,0,0,.6) 100%);pointer-events:none;z-index:1}@keyframes ambientLight{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(360deg) scale(1)}}#root{position:relative;z-index:2}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.home{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px 30px;position:relative;overflow:hidden}.stars-layer{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.stars-small,.stars-medium,.stars-large{position:absolute;top:0;left:0;width:1px;height:1px;border-radius:50%}.stars-small{box-shadow:50vw 10vh #ffffff80,12vw 35vh #fff6,85vw 8vh #fff9,30vw 60vh #ffffff59,70vw 45vh #ffffff80,5vw 80vh #ffffff4d,92vw 25vh #ffffff73,45vw 90vh #fff6,20vw 15vh #ffffff80,75vw 70vh #ffffff59,60vw 5vh #ffffff8c,35vw 42vh #ffffff4d,88vw 55vh #fff6,15vw 50vh #ffffff73,55vw 30vh #ffffff80,8vw 22vh #ffffff59,42vw 75vh #fff6,95vw 88vh #ffffff4d,25vw 95vh #ffffff73,68vw 18vh #ffffff80,3vw 65vh #ffffff59,78vw 38vh #fff6,38vw 82vh #ffffff80,82vw 72vh #ffffff4d,18vw 3vh #ffffff8c;animation:twinkle1 4s ease-in-out infinite alternate}.stars-medium{box-shadow:22vw 20vh 0 .5px #fdde6a99,65vw 12vh 0 .5px #aab8ff80,40vw 55vh 0 .5px #fdde6a80,90vw 40vh 0 .5px #aab8ff99,10vw 70vh 0 .5px #fdde6a73,55vw 85vh 0 .5px #aab8ff80,80vw 15vh 0 .5px #fdde6a8c,28vw 48vh 0 .5px #ffb8c680,72vw 62vh 0 .5px #fdde6a80,48vw 8vh 0 .5px #aab8ff8c,15vw 88vh 0 .5px #fdde6a66,62vw 35vh 0 .5px #aab8ff80,35vw 28vh 0 .5px #ffb8c673;animation:twinkle2 5.5s ease-in-out infinite alternate}.stars-large{box-shadow:30vw 25vh 0 1px #ffffffb3,75vw 50vh 0 1px #fdde6aa6,50vw 75vh 0 1px #fff9,15vw 40vh 0 1px #aab8ff99,85vw 80vh 0 1px #fdde6a8c,60vw 15vh 0 1px #ffffffb3;animation:twinkle3 7s ease-in-out infinite alternate}@keyframes twinkle1{0%{opacity:.4}to{opacity:1}}@keyframes twinkle2{0%{opacity:.3}to{opacity:.9}}@keyframes twinkle3{0%{opacity:.2}to{opacity:1}}.particles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.particle{position:absolute;border-radius:50%;animation:particleFloat linear infinite;will-change:transform}@keyframes particleFloat{0%{transform:translateY(100vh);opacity:0}10%{opacity:var(--p-opacity, .3)}90%{opacity:var(--p-opacity, .3)}to{transform:translateY(-10vh);opacity:0}}.particle-gold{background:var(--primary);box-shadow:0 0 4px #ffd84666}.particle-blue{background:var(--royal-light);box-shadow:0 0 4px #1a3a8f66}.particle-rose{background:#b8344a;box-shadow:0 0 4px #8b1a2b59}.hero{text-align:center;margin-bottom:0;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:14px}.hero-title{font-family:Cinzel,serif;font-size:clamp(2.2rem,6vw,4.5rem);font-weight:700;color:var(--primary);letter-spacing:3px;line-height:1.2;text-shadow:0 0 20px rgba(255,216,70,.5),0 0 40px rgba(255,216,70,.2),0 2px 4px rgba(0,0,0,.5)}.shimmer{background:linear-gradient(110deg,var(--primary-dark) 0%,var(--primary) 20%,var(--primary-light) 40%,var(--primary) 60%,var(--primary-dark) 80%,var(--primary) 100%);background-size:250% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 4s ease-in-out infinite}@keyframes shimmer{0%{background-position:100% 50%}to{background-position:-100% 50%}}.hero-ornament{width:200px;height:2px;background:linear-gradient(90deg,transparent,var(--royal),var(--primary),var(--royal),transparent);border-radius:2px;box-shadow:0 0 10px #1a3a8f66}.hero-subtitle{font-family:Playfair Display,serif;font-style:italic;font-size:clamp(1rem,2.5vw,1.4rem);color:var(--text-cream);opacity:.9;margin-top:4px;letter-spacing:.5px}.hero-cta{display:inline-block;margin-top:8px;padding:12px 32px;background:transparent;border:1px solid var(--royal);border-radius:40px;color:var(--primary-light);font-family:Cinzel,serif;font-size:.85rem;letter-spacing:2px;text-decoration:none;text-transform:uppercase;cursor:pointer;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease,color .3s ease;box-shadow:0 0 16px #1a3a8f40}.hero-cta:hover{background:#1a3a8f33;border-color:var(--primary);color:var(--primary);box-shadow:0 0 24px #1a3a8f66,0 0 40px #ffd8461a}.hero-cta:active{transform:scale(.95);box-shadow:0 0 12px #1a3a8f4d}.hero-scroll-hint{margin-top:14px}.scroll-mouse{width:22px;height:36px;border:2px solid rgba(255,216,70,.3);border-radius:12px;display:flex;justify-content:center;padding-top:6px}.scroll-dot{width:3px;height:8px;background:var(--primary);border-radius:2px;animation:scrollBounce 1.8s ease-in-out infinite}@keyframes scrollBounce{0%,to{transform:translateY(0);opacity:.8}50%{transform:translateY(10px);opacity:.2}}.ornament-divider{position:relative;z-index:2;display:flex;justify-content:center;margin:12px 0;width:100%;max-width:360px;align-self:center}.ornament-svg{width:100%;height:auto;filter:drop-shadow(0 0 4px rgba(255,216,70,.2))}.photo-frame-wrapper{position:relative;margin:10px 0 20px;z-index:2}.photo-frame{position:relative;padding:6px;background:linear-gradient(145deg,var(--gold-dark),var(--gold-primary),var(--gold-light),var(--gold-primary),var(--gold-dark));border-radius:20px;box-shadow:0 10px 40px #00000080}.photo-frame:after{content:"";position:absolute;inset:-8px;border-radius:26px;background:radial-gradient(ellipse,rgba(255,216,70,.25),transparent 70%);z-index:-1;animation:frameGlow 3s ease-in-out infinite alternate}@keyframes frameGlow{0%{opacity:.5}to{opacity:1}}.photo-frame-inner{padding:8px;background:var(--bg-darkest);border-radius:16px}.photo-placeholder{width:340px;max-width:100%;aspect-ratio:4 / 5;border-radius:12px;background:linear-gradient(135deg,var(--bg-dark),var(--bg-warm));animation:placeholderPulse 1.5s ease-in-out infinite alternate}@keyframes placeholderPulse{0%{opacity:.5}to{opacity:.8}}.photo-frame-inner img{max-width:340px;width:100%;height:auto;border-radius:12px;display:block;transition:opacity .4s ease;filter:brightness(1.05) contrast(1.02);transition:transform .5s ease,filter .5s ease}.photo-frame:hover .photo-frame-inner img{transform:scale(1.03);filter:brightness(1.1) contrast(1.05)}.corner-decor{position:absolute;width:20px;height:20px;border-color:var(--gold-primary);border-style:solid;opacity:.7;transition:opacity .3s ease}.photo-frame:hover .corner-decor{opacity:1}.corner-decor.top-left{top:-8px;left:-8px;border-width:2px 0 0 2px;border-radius:4px 0 0}.corner-decor.top-right{top:-8px;right:-8px;border-width:2px 2px 0 0;border-radius:0 4px 0 0}.corner-decor.bottom-left{bottom:-8px;left:-8px;border-width:0 0 2px 2px;border-radius:0 0 0 4px}.corner-decor.bottom-right{bottom:-8px;right:-8px;border-width:0 2px 2px 0;border-radius:0 0 4px}@media(max-width:400px){.photo-frame-inner img{max-width:260px}}.enchanted-rose-wrapper{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;margin:10px 0;gap:16px}.rose-container{position:relative;width:200px;height:280px}.glass-dome{position:absolute;bottom:30px;left:50%;transform:translate(-50%);width:150px;height:220px;border-radius:75px 75px 0 0;background:#ffffff08;border:1px solid rgba(255,255,255,.07);box-shadow:inset 0 0 40px #8b1a2b0f,0 0 30px #8b1a2b0a;overflow:hidden}.glass-shine{position:absolute;top:20px;left:20px;width:18px;height:80px;background:#ffffff14;border-radius:12px;transform:rotate(-8deg)}.dome-base{position:absolute;bottom:16px;left:50%;transform:translate(-50%);width:170px;height:18px;background:linear-gradient(180deg,#3a2a14,#2a1c0c);border-radius:3px;box-shadow:0 4px 12px #00000080}.dome-base:after{content:"";position:absolute;bottom:-7px;left:6px;right:6px;height:7px;background:linear-gradient(180deg,#2a1c0c,#1a100a);border-radius:0 0 4px 4px}.rose{position:absolute;bottom:115px;left:50%;transform:translate(-50%);width:50px;height:50px}.rose-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:radial-gradient(circle,#e8456b,#c94060);z-index:6;box-shadow:0 0 10px #e8456b99}.rose-petal{position:absolute;top:50%;left:50%;width:22px;height:28px;border-radius:50% 0;background:linear-gradient(135deg,#e8456b,#8b1a2b);box-shadow:0 0 8px #8b1a2b66}.p1{transform:translate(-50%,-50%) rotate(0) translateY(-10px);z-index:5}.p2{transform:translate(-50%,-50%) rotate(72deg) translateY(-10px);z-index:4}.p3{transform:translate(-50%,-50%) rotate(144deg) translateY(-10px);z-index:3}.p4{transform:translate(-50%,-50%) rotate(216deg) translateY(-10px);z-index:2}.p5{transform:translate(-50%,-50%) rotate(288deg) translateY(-10px);z-index:1;background:linear-gradient(135deg,#c94060,#5d0200)}.rose-stem{position:absolute;bottom:-65px;left:50%;transform:translate(-50%);width:3px;height:70px;background:linear-gradient(180deg,#2d6b30,#1a4d1e);border-radius:2px}.rose-leaf{position:absolute;width:20px;height:12px;background:linear-gradient(135deg,#3a8b3e,#1a4d1e);border-radius:0 50%}.rose-leaf.left{bottom:-35px;left:calc(50% - 22px);transform:rotate(-30deg)}.rose-leaf.right{bottom:-50px;left:calc(50% + 4px);transform:rotate(30deg) scaleX(-1)}.rose-glow{position:absolute;bottom:95px;left:50%;transform:translate(-50%);width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(232,69,107,.3),transparent 70%);animation:roseGlow 3s ease-in-out infinite alternate}@keyframes roseGlow{0%{opacity:.5;transform:translate(-50%) scale(1)}to{opacity:1;transform:translate(-50%) scale(1.4)}}.dome-petal{position:absolute;width:6px;height:5px;border-radius:50% 0;background:linear-gradient(135deg,#e8456b,#8b1a2b);animation:domePetalFall linear infinite;opacity:0}.dp1{left:calc(50% - 10px);bottom:140px;animation-duration:6s;animation-delay:0s}.dp2{left:calc(50% + 8px);bottom:150px;animation-duration:7s;animation-delay:2s}.dp3{left:calc(50% - 2px);bottom:130px;animation-duration:8s;animation-delay:4s}@keyframes domePetalFall{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:.7}50%{transform:translateY(60px) rotate(180deg) translate(10px);opacity:.5}90%{opacity:.3}to{transform:translateY(100px) rotate(360deg) translate(-5px);opacity:0}}.fallen-petal{position:absolute;width:9px;height:7px;border-radius:50% 0;background:linear-gradient(135deg,#c94060,#8b1a2b);opacity:.5}.fp1{bottom:36px;left:calc(50% - 18px);transform:rotate(45deg)}.fp2{bottom:34px;left:calc(50% + 12px);transform:rotate(-20deg)}.rose-caption{font-family:Playfair Display,serif;font-style:italic;font-size:.9rem;color:var(--text-cream);opacity:.6;letter-spacing:.5px;text-align:center}@media(max-width:400px){.rose-container{transform:scale(.8)}}.countdown{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;z-index:2;position:relative}.countdown-block{min-width:95px;padding:20px 16px 14px;background:linear-gradient(160deg,#1a3a8f1f,#8b1a2b0f);border-radius:16px;border:1px solid rgba(26,58,143,.22);box-shadow:0 0 16px #1a3a8f14;text-align:center;transition:box-shadow .3s ease,border-color .3s ease,transform .3s ease}.countdown-block:hover{border-color:#ffd8464d;transform:translateY(-2px);box-shadow:0 0 24px #1a3a8f26,0 0 12px #ffd84614}.countdown-number-wrapper{height:52px;display:flex;align-items:center;justify-content:center}.countdown-number{display:block;font-family:Cinzel,serif;font-size:2.6rem;font-weight:700;color:var(--primary);line-height:1;text-shadow:0 0 12px rgba(255,216,70,.4)}.countdown-label{display:block;font-size:.8rem;color:var(--text-cream);opacity:.75;margin-top:6px;letter-spacing:1.5px;text-transform:uppercase;font-weight:300}@media(max-width:480px){.countdown{gap:10px}.countdown-block{min-width:72px;padding:14px 10px 10px}.countdown-number{font-size:2rem}.countdown-number-wrapper{height:40px}.countdown-label{font-size:.7rem}}.gallery-section{width:100%;max-width:900px;margin-top:64px;padding:0 16px;position:relative;z-index:2}.gallery-header{display:flex;align-items:center;gap:20px;justify-content:center;margin-bottom:36px}.gallery-title{font-family:Cinzel,serif;font-size:clamp(1.4rem,4vw,2rem);font-weight:600;color:var(--primary);letter-spacing:4px;text-transform:uppercase;text-shadow:0 0 16px rgba(255,216,70,.3);white-space:nowrap}.gallery-ornament{flex:1;height:1px;max-width:120px;background:linear-gradient(90deg,transparent,var(--royal),var(--primary-medium),transparent)}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:560px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}}.gallery-card{aspect-ratio:1 / 1;border-radius:12px;overflow:hidden;position:relative;cursor:pointer;border:1px solid rgba(26,58,143,.25);background:#1a3a8f12;transition:border-color .3s ease,box-shadow .3s ease}.gallery-card:hover{border-color:#ffd8464d;box-shadow:0 0 24px #1a3a8f40,0 0 40px #ffd84614}.gallery-card--placeholder{cursor:default}.gallery-card--placeholder:hover{border-color:#1a3a8f40;box-shadow:none}.gallery-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.gallery-card:hover .gallery-img{transform:scale(1.06)}.gallery-overlay{position:absolute;inset:0;background:#05051080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.gallery-card:hover .gallery-overlay{opacity:1}.gallery-overlay-icon{font-size:1.8rem;color:var(--primary);text-shadow:0 0 12px rgba(255,216,70,.6)}.gallery-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:radial-gradient(ellipse at center,rgba(26,58,143,.12) 0%,transparent 70%)}.gallery-placeholder-letter{font-family:Great Vibes,cursive;font-size:3rem;color:var(--royal-light);opacity:.4;line-height:1}.gallery-placeholder-text{font-family:Poppins,sans-serif;font-size:.65rem;color:var(--text-cream);opacity:.35;letter-spacing:1.5px;text-transform:uppercase}.lightbox{position:fixed;inset:0;background:#050510f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;border-radius:12px;overflow:hidden;border:1px solid rgba(255,216,70,.2);box-shadow:0 0 60px #1a3a8f4d}.lightbox-img{display:block;max-width:90vw;max-height:85vh;object-fit:contain}.lightbox-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#050510b3;border:1px solid rgba(255,216,70,.3);color:var(--primary-light);font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease}.lightbox-close:hover{background:#1a3a8f59;border-color:var(--primary)}.lightbox-close:active{transform:scale(.9)}@media(max-width:480px){.lightbox-close{width:44px;height:44px;font-size:1.1rem;top:8px;right:8px}}.footer{margin-top:20px;padding-bottom:20px;text-align:center;z-index:2;position:relative;display:flex;flex-direction:column;align-items:center;gap:10px}.footer-rose{font-size:1.6rem;animation:roseFloat 3s ease-in-out infinite alternate}@keyframes roseFloat{0%{transform:translateY(0) rotate(-5deg)}to{transform:translateY(-6px) rotate(5deg)}}.footer-line{width:100px;height:1px;background:linear-gradient(90deg,transparent,var(--royal),var(--primary),var(--royal),transparent);margin-bottom:2px}.footer-date{font-family:Cinzel,serif;font-size:1.1rem;color:var(--primary);letter-spacing:2px;text-shadow:0 0 10px rgba(255,216,70,.3)}.footer-tagline{font-family:Playfair Display,serif;font-style:italic;font-size:.95rem;color:var(--text-cream);opacity:.7;letter-spacing:.5px}.footer-credit{font-family:Poppins,sans-serif;font-size:.7rem;color:var(--royal-light);opacity:.4;letter-spacing:1px;margin-top:4px}.inv-page{min-height:100vh;display:grid;place-items:center;padding:40px 20px;position:relative;overflow:hidden}.inv-page>.env-scene,.inv-page>.inv-letter{grid-area:1 / 1}.env-scene{display:flex;flex-direction:column;align-items:center;gap:36px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.env-wrap{position:relative;width:340px;height:210px;perspective:1000px}.env-inner{position:relative;width:100%;height:100%;display:grid;transform-style:preserve-3d;transition:transform 1s ease-in-out}.env-inner--open{transform:rotateY(180deg)}.env-front,.env-back{grid-area:1 / 1;width:100%;height:100%;border-radius:6px;backface-visibility:hidden;-webkit-backface-visibility:hidden;perspective:1000px}.env-front{background:linear-gradient(160deg,#2a4590,#1a3380,#122868);border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0009,0 0 40px #1a3a8f33,inset 0 1px #ffffff14;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;overflow:visible;position:relative}.env-fold-left{position:absolute;top:0;left:0;width:0;height:0;border-style:solid;border-width:105px 0 105px 170px;border-color:transparent transparent transparent rgba(0,0,0,.14);pointer-events:none}.env-fold-right{position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:105px 170px 105px 0;border-color:transparent rgba(0,0,0,.14) transparent transparent;pointer-events:none}.env-fold-bottom{position:absolute;bottom:0;left:0;right:0;height:120px;background:#0000001f;clip-path:polygon(0 100%,50% 0,100% 100%);pointer-events:none}.env-back .env-fold-left,.env-back .env-fold-right,.env-back .env-fold-bottom{z-index:3}.env-back .env-fold-left{border-color:transparent transparent transparent #1a3380}.env-back .env-fold-right{border-color:transparent #1a3380 transparent transparent}.env-back .env-fold-bottom{background:#122868}.env-seal{position:absolute;top:calc(55% - 26px);left:calc(50% - 26px);z-index:15;width:52px;height:52px;border-radius:50%;background:radial-gradient(circle at 38% 32%,#b8344a,#8b1a2b 55%,#5d0200);border:2px solid rgba(253,222,106,.65);display:flex;align-items:center;justify-content:center;font-family:Great Vibes,cursive;font-size:1.6rem;color:#fdde6a;text-shadow:0 1px 3px rgba(0,0,0,.6);box-shadow:0 3px 14px #8b1a2b8c,inset 0 1px #ffffff26}.env-address{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:2px}.env-address-label{font-family:Cinzel,serif;font-size:.6rem;letter-spacing:4px;color:var(--primary-light);opacity:.7;text-transform:uppercase}.env-address-name{font-family:Great Vibes,cursive;font-size:2.4rem;color:var(--primary);line-height:1;text-shadow:0 0 20px rgba(255,216,70,.35),0 2px 4px rgba(0,0,0,.4)}.env-back{transform:rotateY(180deg);background:linear-gradient(160deg,#2a4590,#1a3380,#122868);border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0009,inset 0 1px #ffffff14;overflow:visible;position:relative;perspective:600px}.env-flap{position:absolute;inset:-120px 0 0;background:linear-gradient(160deg,#3a5aac,#2a4590 45%,#1a3380);clip-path:polygon(0% 36%,50% 72%,100% 36%);z-index:10;pointer-events:none}.env-flap--open{animation:env-flap-open 1.1s cubic-bezier(.4,0,.4,1) 1s both}@keyframes env-flap-open{0%{z-index:10;clip-path:polygon(0% 36%,50% 72%,100% 36%);filter:brightness(1)}40%{z-index:1;clip-path:polygon(0% 36%,50% 36%,100% 36%);filter:brightness(1.2)}to{z-index:1;clip-path:polygon(0% 36%,50% 3%,100% 36%);filter:brightness(.95)}}.env-letter{position:absolute;bottom:5px;left:calc(50% - 100px);width:200px;height:140px;background:linear-gradient(160deg,#fef6e0,#f5d98a);border-radius:4px;border:1px solid rgba(255,216,70,.55);display:flex;align-items:center;justify-content:center;box-shadow:0 -4px 16px #00000040;z-index:2;transition:transform .8s ease-in-out 2s}.env-letter--out{transform:translateY(-190px)}.env-letter--hidden{opacity:0!important;transition:opacity .15s ease-out!important}.env-letter-s{font-family:Great Vibes,cursive;font-size:3.5rem;color:var(--royal-dark);opacity:.35;line-height:1}.inv-letter{perspective:1000px;z-index:25;opacity:0;pointer-events:none}.inv-letter--visible{opacity:1;transform:translate(var(--handoff-x, 0px),var(--handoff-y, 0px));transition:opacity .01s}.inv-letter--expanded{opacity:1;pointer-events:auto;transform:translateY(0) scale(2.3);transition:transform 1.2s ease-in-out}.inv-letter--stretched{opacity:1;pointer-events:auto;transform:translateY(0) scale(2.3);transition:transform .8s ease-in-out}.inv-letter--stretched .inv-letter-inner{transform:rotateY(180deg);height:240px;transition:height .8s ease-in-out,transform 1.2s ease-in-out}.inv-letter-inner{width:200px;height:140px;position:relative;display:grid;transform-style:preserve-3d;transition:transform 1.2s ease-in-out}.inv-letter--expanded .inv-letter-inner{transform:rotateY(180deg)}.inv-letter-front,.inv-letter-back{grid-area:1 / 1;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:6px;overflow:hidden}.inv-letter-front{background:linear-gradient(160deg,#fef6e0,#f5d98a);border:1px solid rgba(255,216,70,.55);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #00000040}.inv-letter-s{font-family:Great Vibes,cursive;font-size:3.5rem;color:var(--royal-dark);opacity:.35;line-height:1}.inv-letter-back{transform:rotateY(180deg);padding:4px 6px 3px;background:linear-gradient(160deg,#12102a,#0c0a1e);border:1px solid rgba(26,58,143,.3);border-radius:10px;box-shadow:0 0 30px #1a3a8f26,inset 0 1px #ffd84614;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:1px}.env-scene--dimmed{transition:opacity .8s ease;opacity:.15}.env-hint{font-family:Playfair Display,serif;font-style:italic;font-size:.95rem;color:var(--primary-light);letter-spacing:.5px;text-align:center;pointer-events:none;animation:hintPulse 2.5s ease-in-out infinite}@keyframes hintPulse{0%,to{opacity:.5}50%{opacity:1}}.inv-deco-top{display:flex;align-items:center;gap:12px;width:100%}.inv-deco-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--royal),transparent)}.inv-deco-diamond{font-size:.5rem;color:var(--royal-light);opacity:.7}.inv-eyebrow{font-family:Cinzel,serif;font-size:.7rem;letter-spacing:5px;color:var(--royal-light);text-transform:uppercase;opacity:.85}.inv-name{font-family:Great Vibes,cursive;font-size:clamp(3.2rem,10vw,4.5rem);color:var(--primary);line-height:1.1;text-shadow:0 0 24px rgba(255,216,70,.4),0 2px 6px rgba(0,0,0,.4);margin:-4px 0}.inv-sparkles-row{display:flex;align-items:center;gap:10px;margin:-6px 0}.inv-sparkle{font-size:.75rem;display:inline-block}.inv-sparkle--0{color:var(--primary)}.inv-sparkle--1{color:var(--royal-light);font-size:.85rem}.inv-sparkle--2{color:var(--rose)}.inv-verse{font-family:Playfair Display,serif;font-size:.9rem;color:var(--text-cream);line-height:1.7;opacity:.85}.inv-divider{color:var(--primary-dark);font-size:.7rem;opacity:.6}.inv-details{display:flex;flex-direction:column;gap:14px;width:100%}.inv-detail{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#1a3a8f1a;border:1px solid rgba(26,58,143,.2);border-radius:10px}.inv-detail-icon{font-size:1rem;color:var(--royal-light);flex-shrink:0;width:20px;text-align:center}.inv-detail div{display:flex;flex-direction:column;text-align:left;gap:1px}.inv-detail strong{font-family:Cinzel,serif;font-size:.8rem;color:var(--primary);letter-spacing:1px;font-weight:600}.inv-detail span{font-size:.78rem;color:var(--text-cream);opacity:.7}.inv-back{margin-top:4px;font-family:Poppins,sans-serif;font-size:.8rem;color:var(--royal-light);text-decoration:none;letter-spacing:.5px;opacity:.75;transition:opacity .2s ease,color .2s ease}.inv-back:hover{opacity:1;color:var(--primary-light)}.inv-back:active{transform:scale(.95)}.inv-letter-back .inv-deco-top{gap:3px}.inv-letter-back .inv-deco-line{height:.4px}.inv-letter-back .inv-deco-diamond{font-size:.22rem}.inv-letter-back .inv-eyebrow{font-size:.32rem;letter-spacing:1.2px;margin-top:-1px}.inv-letter-back .inv-name{font-size:1.2rem;margin:-1px 0;line-height:1}.inv-letter-back .inv-sparkles-row{display:none}.inv-letter-back .inv-verse{font-size:.38rem;line-height:1.4}.inv-letter-back .inv-divider{font-size:.25rem}.inv-letter-back .inv-details{gap:3px}.inv-letter-back .inv-detail{padding:3px 6px;gap:5px;border-radius:4px}.inv-letter-back .inv-detail-icon{font-size:.4rem;width:10px}.inv-letter-back .inv-detail strong{font-size:.38rem;letter-spacing:.3px}.inv-letter-back .inv-detail span{font-size:.34rem}.inv-letter-back .inv-back{font-size:.36rem;margin-top:2px}@media(max-width:420px){.env-wrap{width:290px;height:180px}.env-fold-left{border-width:90px 0 90px 145px}.env-fold-right{border-width:90px 145px 90px 0}.env-letter{left:calc(50% - 85px);width:170px;height:120px}.inv-letter-inner{width:170px;height:120px}.inv-letter--expanded{transform:translateY(0) scale(2)}.env-flap{clip-path:polygon(0% 40%,50% 73%,100% 40%)}@keyframes env-flap-open{0%{z-index:10;clip-path:polygon(0% 40%,50% 73%,100% 40%);filter:brightness(1)}40%{z-index:1;clip-path:polygon(0% 40%,50% 40%,100% 40%);filter:brightness(1.2)}to{z-index:1;clip-path:polygon(0% 40%,50% 7%,100% 40%);filter:brightness(.95)}}}.music-btn{position:fixed;bottom:20px;right:20px;z-index:50;width:40px;height:40px;display:flex;align-items:center;justify-content:center;padding:0;background:#0c0a1ecc;border:1px solid rgba(26,58,143,.3);border-radius:50%;font-size:1rem;cursor:pointer;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease,border-color .3s ease,background .3s ease;pointer-events:none;line-height:1}.music-btn--visible{opacity:.7;transform:translateY(0);pointer-events:auto}.music-btn:hover{opacity:1;border-color:var(--primary);background:#1a3a8f33}.music-btn:active{transform:scale(.9)}.music-btn--playing{border-color:#ffd8464d}@media(max-width:480px){.music-btn{bottom:14px;right:14px;width:36px;height:36px;font-size:.85rem}}
