*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#2a2018;--color-bg-warm:#332a1f;--color-bg-card:#ffebcd0a;--color-bg-card-hover:#ffebcd14;--color-text:#fdf6ee;--color-text-secondary:#fdf6ee8c;--color-accent:#d4a853;--color-accent-light:#e8c06a;--color-accent-soft:#d4a8531f;--color-divider:#d4a8531f;--font-display:"Cormorant Garamond", Georgia, serif;--font-body:"Montserrat", system-ui, sans-serif}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}#root{min-height:100dvh}.invitation{flex-direction:column;align-items:center;width:100%;display:flex}.hero{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100dvh;padding:2rem 1.5rem;display:flex;position:relative;overflow:hidden}.hero-bg{z-index:0;position:absolute;inset:0}.hero-bg img{object-fit:cover;object-position:center 30%;filter:brightness(.55)saturate(1.1);width:100%;height:100%}.hero-bg:after{content:"";background:linear-gradient(#2a201826 0%,#2a201800 30%,#2a201866 75%,#2a2018 100%);position:absolute;inset:0}.hero>:not(.hero-bg){z-index:1;position:relative}.particles{z-index:1;pointer-events:none;position:absolute;inset:0;overflow:hidden}.particle{background:radial-gradient(circle, var(--color-accent) 0%, transparent 70%);border-radius:50%;position:absolute;box-shadow:0 0 6px 2px #d4a8534d}.hero-ornament{color:var(--color-accent);opacity:.6;letter-spacing:1rem;margin-bottom:1.5rem;font-size:clamp(1.5rem,4vw,2.5rem)}.hero-names{font-family:var(--font-display);color:var(--color-text);text-shadow:0 4px 30px #00000080;margin-bottom:1rem;font-size:clamp(3rem,10vw,7rem);font-style:italic;font-weight:300;line-height:1.1}.hero-names .ampersand{color:var(--color-accent);margin:.2em 0;font-size:.5em;display:block}.hero-date{font-family:var(--font-body);letter-spacing:.4em;text-transform:uppercase;color:var(--color-text-secondary);margin-top:1.5rem;font-size:clamp(.85rem,2.2vw,1.2rem);font-weight:300}.scroll-hint{z-index:2;color:var(--color-text-secondary);letter-spacing:.2em;text-transform:uppercase;text-shadow:0 1px 8px #000c;flex-direction:column;align-items:center;gap:.5rem;font-size:.7rem;display:flex;position:absolute;bottom:2rem}.scroll-arrow{background:linear-gradient(to bottom, var(--color-accent), transparent);width:1px;height:40px;animation:2s ease-in-out infinite scrollPulse}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}.section{text-align:center;width:100%;max-width:800px;padding:5rem 1.5rem}.section-title{font-family:var(--font-display);color:var(--color-text);margin-bottom:.5rem;font-size:clamp(2rem,5vw,3.5rem);font-weight:400}.section-divider{background:var(--color-accent);width:60px;height:1px;margin:1.5rem auto}.section-text{color:var(--color-text-secondary);max-width:600px;margin:0 auto;font-size:clamp(.95rem,2vw,1.1rem);font-weight:300;line-height:1.8}.greeting{text-align:center;padding:4rem 1.5rem}.greeting-text{font-family:var(--font-display);color:var(--color-accent);font-size:clamp(1.5rem,4vw,2.5rem);font-style:italic;font-weight:300}.greeting-children{font-family:var(--font-display);color:var(--color-accent-light);opacity:.85;margin-top:.75rem;font-size:clamp(1.1rem,3vw,1.6rem);font-style:italic;font-weight:300}.greeting-sub{color:var(--color-text-secondary);max-width:550px;margin-top:1.5rem;margin-left:auto;margin-right:auto;font-size:clamp(.95rem,2vw,1.1rem);font-weight:300;line-height:1.8}.gallery{grid-template-rows:auto auto;grid-template-columns:repeat(2,1fr);gap:1rem;width:100%;max-width:900px;padding:0 1.5rem 5rem;display:grid}.gallery-item{aspect-ratio:4/3;border-radius:16px;position:relative;overflow:hidden}.gallery-item:first-child{aspect-ratio:16/9;grid-column:1/-1}.gallery-img-wrap{width:100%;height:100%;overflow:hidden}.gallery-img-wrap img,.gallery-item>img{object-fit:cover;object-position:center center;width:100%;height:120%;transition:transform .6s}.gallery-item:first-child .gallery-img-wrap img,.gallery-item:first-child>img{object-position:center 10%}.gallery-item:hover img{transform:scale(1.05)}.gallery-item:after{content:"";pointer-events:none;background:linear-gradient(#0000 60%,#1a151166 100%);position:absolute;inset:0}@media (width<=480px){.gallery{grid-template-columns:1fr}.gallery-item:first-child{aspect-ratio:4/3}}.photo-break{width:100%;height:85vh;position:relative;overflow:hidden}.photo-break img{object-fit:cover;object-position:center 35%;width:100%;height:100%}.photo-break:before,.photo-break:after{content:"";z-index:1;pointer-events:none;height:80px;position:absolute;left:0;right:0}.photo-break:before{background:linear-gradient(#2a2018,#0000);top:0}.photo-break:after{background:linear-gradient(#0000,#2a2018);bottom:0}.details-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;width:100%;max-width:800px;padding:0 1.5rem 5rem;display:grid}.detail-card{background:var(--color-bg-card);border:1px solid var(--color-divider);text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:2.5rem 2rem;transition:background .3s,border-color .3s}.detail-card:hover{background:var(--color-bg-card-hover);border-color:#d4a85340;box-shadow:0 0 30px #d4a85314,0 8px 32px #0003}.detail-icon{margin-bottom:1rem;font-size:2rem}.detail-label{letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent);margin-bottom:.75rem;font-size:.75rem;font-weight:500}.detail-value{font-family:var(--font-display);color:var(--color-text);font-size:1.4rem;font-weight:400;line-height:1.4}.detail-extra{color:var(--color-text-secondary);margin-top:.5rem;font-size:.85rem}.detail-link{letter-spacing:.1em;color:var(--color-accent);border:1px solid #d4a8534d;border-radius:100px;margin-top:.75rem;padding:.4rem 1rem;font-size:.8rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-block}.detail-link:visited,.detail-link:active{color:var(--color-accent)}.detail-link:hover{background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent)}.transfer-question{text-align:center;margin-top:2rem}.transfer-text{font-family:var(--font-display);color:var(--color-text);margin-bottom:1rem;font-size:1.2rem}.transfer-confirmed{font-family:var(--font-display);color:var(--color-accent-light);margin-top:1.5rem;font-size:1.1rem;font-style:italic}.rsvp-btn--small{padding:.7rem 1.8rem;font-size:.8rem}.timeline-v2{flex-direction:column;align-items:center;gap:0;width:100%;max-width:500px;padding:0 1.5rem 5rem;display:flex}.tl-card{background:var(--color-bg-card);border:1px solid var(--color-divider);text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:default;border-radius:20px;width:100%;padding:2rem 2rem 1.5rem;transition:background .3s,border-color .3s,box-shadow .3s;position:relative}.tl-card:hover{background:var(--color-bg-card-hover);border-color:#d4a85340;box-shadow:0 0 40px #d4a8531a,0 12px 40px #00000040}.tl-icon{margin-bottom:.75rem;font-size:2.2rem;display:inline-block}.tl-time{letter-spacing:.25em;text-transform:uppercase;color:var(--color-accent);margin-bottom:.4rem;font-size:.75rem;font-weight:600}.tl-event{font-family:var(--font-display);color:var(--color-text);margin-bottom:.3rem;font-size:1.5rem;font-weight:400}.tl-desc{color:var(--color-text-secondary);font-size:.85rem;font-weight:300}.tl-arrow{transform-origin:top;justify-content:center;padding:.75rem 0;display:flex}.tl-arrow svg{opacity:.4;filter:drop-shadow(0 0 4px #d4a8534d)}.countdown{justify-content:center;gap:clamp(1rem,4vw,2.5rem);margin-top:2rem;display:flex}.countdown-item{perspective:200px;flex-direction:column;align-items:center;display:flex}.countdown-number{font-family:var(--font-display);color:var(--color-accent);font-size:clamp(2.5rem,7vw,4.5rem);font-weight:300;line-height:1}.countdown-label{letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-secondary);margin-top:.5rem;font-size:.7rem;font-weight:500}.rsvp-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:2rem;display:flex}.rsvp-btn{font-family:var(--font-body);letter-spacing:.15em;text-transform:uppercase;cursor:pointer;border:none;border-radius:100px;padding:1rem 2.5rem;font-size:.85rem;font-weight:500;transition:all .3s}.rsvp-btn--accept{background:var(--color-accent);color:var(--color-bg)}.rsvp-btn--accept:hover{background:var(--color-accent-light);transform:translateY(-2px);box-shadow:0 8px 24px #d4a8534d}.rsvp-btn--decline{color:var(--color-text-secondary);border:1px solid var(--color-divider);background:0 0}.rsvp-btn--decline:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.rsvp-confirmed{background:var(--color-accent-soft);color:var(--color-accent);font-family:var(--font-display);border:1px solid #d4a85333;border-radius:12px;margin-top:2rem;padding:1.5rem 2.5rem;font-size:1.3rem;font-style:italic}.footer{text-align:center;border-top:1px solid var(--color-divider);width:100%;color:var(--color-text-secondary);padding:3rem 1.5rem;font-size:.85rem}.footer-hearts{color:var(--color-accent);margin-bottom:.5rem;font-size:1.5rem}.not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:2rem;display:flex}.not-found h1{font-family:var(--font-display);color:var(--color-text);margin-bottom:1rem;font-size:clamp(2rem,5vw,3rem);font-weight:300}.not-found p{color:var(--color-text-secondary);font-weight:300}
