@import "https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:ital,wght@0,300;0,400;0,500;1,300&family=Playfair+Display:ital,wght@0,400;0,600;1,400;1,600&display=swap";:root{--cream:#faf6f0;--cream-2:#f0e8dc;--bark:#2a1f18;--bark-2:#1a130f;--amber:#c8874a;--amber-2:#e0a870;--sage:#7a9468;--sand:#d4b896;--text:#2a1f18;--text-soft:#6b5748;--text-on-dark:#faf6f0;--text-on-dark-soft:#faf6f0a6;--font-display:"Playfair Display", Georgia, serif;--font-body:"Be Vietnam Pro", "Segoe UI", sans-serif;--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--ease-in-out-smooth:cubic-bezier(.45, 0, .55, 1);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*,:before,:after{box-sizing:border-box}html{scroll-behavior:auto}body{font-family:var(--font-body);color:var(--text);background:var(--cream);-webkit-font-smoothing:antialiased;margin:0;font-weight:300;overflow-x:hidden}#root{overflow-x:hidden}h1,h2,h3,h4{font-family:var(--font-display);margin:0;font-weight:400;line-height:1.15}p{margin:0;line-height:1.75}img{max-width:100%;display:block}::selection{background:var(--amber-2);color:var(--bark)}.reveal-wrap{display:block;overflow:hidden}.section-num{font-family:var(--font-body);letter-spacing:.2em;text-transform:uppercase;color:var(--amber);font-size:.72rem}.section-label{font-family:var(--font-body);letter-spacing:.22em;text-transform:uppercase;color:var(--text-soft);font-size:.72rem;font-weight:400}.section-label--on-dark{color:var(--text-on-dark-soft)}.rule{border:none;border-top:1px solid #2a1f181f;margin:0}.rule--on-dark{border-top-color:#faf6f024}.hero{flex-direction:column;justify-content:flex-end;width:100%;height:100svh;min-height:600px;padding:0 clamp(1.5rem,5vw,5rem) clamp(3rem,6vh,5rem);display:flex;position:relative;overflow:hidden}.hero__bg{will-change:opacity;position:absolute;inset:0}.hero__bg-img{object-fit:cover;object-position:center;width:100%;height:100%}.hero__overlay{background:linear-gradient(#1a130f26 0%,#1a130f73 45%,#1a130fe0 100%);position:absolute;inset:0}.hero__content{z-index:1;flex-direction:column;gap:1.4rem;max-width:900px;display:flex;position:relative}.hero__date{margin:0}.hero__title{color:var(--text-on-dark);flex-direction:column;gap:.05em;font-size:clamp(3.6rem,9vw,8rem);font-weight:400;display:flex}.hero__title-line2{padding-left:clamp(2rem,8vw,8rem);font-style:italic}.hero__sub{color:var(--text-on-dark-soft);flex-direction:column;gap:.1em;font-size:clamp(1rem,1.8vw,1.3rem);font-weight:300;display:flex}.hero__sub-line{font-style:normal}.hero__rule-svg{z-index:1;width:clamp(80px,18vw,200px);height:2px;margin-top:.5rem;position:relative}.hero__scroll{z-index:1;flex-direction:column;align-items:center;gap:.6rem;display:flex;position:absolute;bottom:clamp(2rem,5vh,4rem);right:clamp(1.5rem,4vw,4rem)}.hero__scroll-line{transform-origin:top;background:#faf6f08c;width:1px;height:50px;display:block}.hero__scroll-text{letter-spacing:.22em;text-transform:uppercase;color:#faf6f099;font-size:.68rem}.about{background:var(--bark);grid-template-columns:1fr 1fr;min-height:100svh;display:grid;overflow:hidden}.about__text{z-index:1;flex-direction:column;justify-content:center;gap:2.2rem;padding:clamp(4rem,10vh,8rem) clamp(2rem,6vw,6rem);display:flex;position:relative}.about__heading{color:var(--text-on-dark);flex-direction:column;gap:.06em;font-size:clamp(2.2rem,4.5vw,3.8rem);font-weight:400;display:flex}.about__heading--italic span{font-style:italic}.about__body{color:var(--text-on-dark-soft);font-size:clamp(.95rem,1.35vw,1.05rem);line-height:1.95}.about__date{letter-spacing:.24em;text-transform:uppercase;color:var(--amber);font-size:.7rem}.about__photo-wrap{position:relative;overflow:hidden}.about__photo-inner{will-change:transform;position:absolute;inset:-8% 0}.about__photo{object-fit:cover;object-position:center center;width:100%;height:100%}.about__photo-fade{background:linear-gradient(to right, var(--bark) 0%, transparent 18%);pointer-events:none;position:absolute;inset:0}@media (width<=768px){.about{grid-template-rows:auto 70vw;grid-template-columns:1fr}.about__text{padding:clamp(3rem,8vh,5rem) 1.5rem 2rem}.about__photo-inner{height:100%;position:relative;inset:0}.about__photo-fade{background:linear-gradient(to bottom, var(--bark) 0%, transparent 20%)}}.timeline{background:var(--cream);padding:clamp(5rem,12vh,9rem) clamp(2rem,6vw,6rem) clamp(5rem,10vh,8rem)}.timeline__header{flex-direction:column;gap:1.2rem;margin-bottom:clamp(3.5rem,9vh,7rem);display:flex}.timeline__heading{flex-direction:column;gap:.02em;font-size:clamp(3.2rem,7.5vw,6rem);font-weight:400;line-height:1.08;display:flex}.timeline__heading--italic{padding-left:clamp(2.5rem,7vw,8rem);font-style:italic}.tl-rule{transform-origin:0;background:#2a1f1824;height:1px}.tl-item{padding:clamp(2.5rem,6vh,5rem) 0 0}.tl-item__inner{align-items:start;gap:clamp(1.5rem,3vw,3rem);margin-top:clamp(1.5rem,3vh,2.5rem);display:grid}.tl-item--left .tl-item__inner{grid-template-columns:clamp(3.5rem,5.5vw,5.5rem) 1fr}.tl-item--right .tl-item__inner{grid-template-columns:1fr clamp(3.5rem,5.5vw,5.5rem)}.tl-item--right .tl-item__num{text-align:right;order:2}.tl-item--right .tl-item__body{order:1}.tl-item__num{font-family:var(--font-display);color:var(--amber);opacity:.45;-webkit-user-select:none;user-select:none;padding-top:.1em;font-size:clamp(2.2rem,5vw,4.5rem);font-weight:400;line-height:1}.tl-item__body{flex-direction:column;gap:.9rem;padding-bottom:clamp(1rem,2vh,1.5rem);display:flex}.tl-item__date{margin:0}.tl-item__title{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:400;line-height:1.2}.tl-item__desc{color:var(--text-soft);max-width:54ch;font-size:clamp(.9rem,1.25vw,1rem);line-height:1.85}.tl-item--right .tl-item__desc{max-width:54ch}@media (width<=580px){.tl-item--left .tl-item__inner,.tl-item--right .tl-item__inner{grid-template-columns:2.8rem 1fr}.tl-item--right .tl-item__num{text-align:left;order:0}.tl-item--right .tl-item__body{order:1}.tl-item__num{font-size:2rem}.tl-item__title{font-size:1.4rem}}.memories{background:var(--bark);overflow:hidden}.memories__hero{flex-direction:column;gap:1.6rem;max-width:900px;padding:clamp(5rem,12vh,9rem) clamp(1.5rem,5vw,5rem) clamp(3rem,6vh,5rem);display:flex}.memories__heading{color:var(--text-on-dark);font-size:clamp(2.8rem,6.5vw,5.5rem);font-weight:400;line-height:1.12}.marquee{width:100%;padding:.5rem 0;overflow:hidden}.marquee__track{will-change:transform;gap:.9rem;width:max-content;display:flex}.memories__card{flex-shrink:0;width:clamp(220px,28vw,380px)}.memories__frame{aspect-ratio:4/5;border-radius:8px;position:relative;overflow:hidden}.memories__frame img{object-fit:cover;width:100%;height:100%}.memories__frame-label{color:#fff9;font-size:.8rem;font-family:var(--font-body);align-items:flex-end;padding:1rem;line-height:1.4;display:flex;position:absolute;inset:0}.memories__mid{justify-content:flex-end;padding:clamp(2.5rem,5vh,4rem) clamp(1.5rem,5vw,5rem);display:flex}.memories__mid-text{color:var(--text-on-dark-soft);font-size:.82rem}.memories__mid-text code{background:#faf6f01a;border-radius:3px;padding:.1em .4em;font-family:Courier New,monospace}.letter{background:var(--bark-2)}.letter__intro{flex-direction:column;gap:2rem;max-width:100%;padding:clamp(6rem,14vh,12rem) clamp(1.5rem,5vw,5rem) clamp(4rem,8vh,7rem);display:flex}.letter__intro-heading{color:var(--text-on-dark);will-change:transform, opacity;font-size:clamp(3rem,7vw,6.5rem);font-style:italic}.letter__body{background:var(--cream);flex-direction:column;gap:2.4rem;max-width:100%;padding:clamp(4rem,10vh,8rem) clamp(1.5rem,5vw,5rem) clamp(5rem,12vh,10rem);display:flex}.letter__p{max-width:72ch;color:var(--text);will-change:opacity, transform, filter;font-size:clamp(1.05rem,1.8vw,1.25rem);line-height:1.85}.letter__signature{font-family:var(--font-display);color:var(--amber);margin-top:1.5rem;font-size:clamp(1.2rem,2vw,1.6rem);font-style:italic}.footer{background:var(--cream);border-top:1px solid #2a1f181a;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:.5rem;padding:clamp(3rem,8vh,6rem) clamp(1.5rem,5vw,5rem);display:flex}.footer__tagline{font-family:var(--font-display);color:var(--text);font-size:clamp(1rem,1.8vw,1.3rem);font-style:italic}.footer__date{letter-spacing:.14em;text-transform:uppercase;color:var(--text-soft);font-size:.78rem}.music-toggle{z-index:9999;-webkit-backdrop-filter:blur(10px);color:#f5dc96b3;cursor:pointer;opacity:0;background:#140e0680;border:1px solid #ffcd6e33;border-radius:999px;align-items:center;gap:.4rem;padding:.5rem .75rem;transition:opacity .8s .5s,transform .8s .5s,color .2s,border-color .2s;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;transform:translateY(8px)}.music-toggle--visible{opacity:1;transform:translateY(0)}.music-toggle--muted{color:#f5dc9659;border-color:#ffcd6e1a}.music-toggle:hover{color:#f5dc96;border-color:#ffcd6e73}.music-bars{align-items:flex-end;gap:2px;height:12px;display:flex}.music-bars span{background:currentColor;border-radius:2px;width:2px;animation:1s ease-in-out infinite bar-bounce;display:block}.music-bars span:first-child{height:5px;animation-delay:0s}.music-bars span:nth-child(2){height:10px;animation-delay:.2s}.music-bars span:nth-child(3){height:7px;animation-delay:.4s}@keyframes bar-bounce{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}
