:root{
  --ivory:#fff8ed;
  --paper:#f7ead7;
  --champagne:#ead4b8;
  --rose:#bd8a82;
  --rose-deep:#7d5954;
  --sage:#a6aa8a;
  --gold:#b88734;
  --gold-bright:#f4dd93;
  --ink:#49362e;
  --muted:#856f62;
  --soft-shadow:0 26px 80px rgba(73,54,46,.18);
  --script:"Great Vibes","Brush Script MT",cursive;
  --serif:"Cormorant Garamond",Georgia,serif;
  --display:"Playfair Display",Georgia,serif;
}

*{box-sizing:border-box}
html{background:#ead8c2;scroll-behavior:auto}
body{
  margin:0;
  min-height:100vh;
  color:var(--ink);
  font-family:var(--serif);
  background:
    radial-gradient(circle at 14% 8%,rgba(255,255,255,.78),transparent 25rem),
    radial-gradient(circle at 86% 12%,rgba(189,138,130,.22),transparent 21rem),
    linear-gradient(180deg,#fff8ed 0%,#f4e4ce 48%,#ead3b9 100%);
  overflow-x:hidden;
}
body.is-locked{overflow:hidden}
button,input,select,textarea{font:inherit}
a,button{-webkit-tap-highlight-color:transparent}
img{max-width:100%}

.ambient{
  position:fixed;
  width:34rem;
  height:34rem;
  border-radius:50%;
  pointer-events:none;
  filter:blur(24px);
  opacity:.18;
  z-index:0;
}
.ambient-one{left:-20rem;top:12vh;background:var(--rose)}
.ambient-two{right:-21rem;bottom:2vh;background:var(--sage)}

.cover{
  position:fixed;
  inset:0;
  z-index:40;
  display:grid;
  place-items:center;
  align-content:center;
  gap:22px;
  padding:24px;
  overflow:hidden;
  background:
    linear-gradient(130deg,rgba(255,255,255,.82),transparent 36%),
    radial-gradient(circle at 50% 12%,#fffaf0 0%,#f5dfc7 52%,#dfbfa5 100%);
}
.cover-grain{
  position:absolute;
  inset:0;
  opacity:.28;
  background-image:
    linear-gradient(90deg,rgba(255,255,255,.2) 1px,transparent 1px),
    linear-gradient(rgba(255,255,255,.16) 1px,transparent 1px);
  background-size:38px 38px;
  mask-image:radial-gradient(circle at center,#000,transparent 78%);
}
.cover-copy{
  position:relative;
  z-index:2;
  text-align:center;
  color:#67483f;
}
.cover-kicker,.eyebrow,.section-label{
  margin:0;
  font-family:var(--display);
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--muted);
}
.cover-name{
  margin:18px 0 0;
  padding:.16em .08em .28em;
  font-family:var(--script);
  font-size:clamp(4.1rem,16vw,6.6rem);
  line-height:.82;
  font-weight:400;
  color:#815d58;
  text-shadow:0 18px 44px rgba(125,89,84,.18);
}
.cover-name span{
  display:block;
  margin:.06em 0;
  font-size:.43em;
  color:var(--gold);
}
.envelope-shell{
  width:min(360px,88vw);
  height:250px;
  position:relative;
  z-index:2;
  border:0;
  background:transparent;
  cursor:pointer;
  perspective:1200px;
  filter:drop-shadow(0 34px 34px rgba(73,54,46,.25));
}
.envelope-shell::before{
  content:"";
  position:absolute;
  inset:auto 18px 4px;
  height:24px;
  border-radius:50%;
  background:rgba(73,54,46,.18);
  filter:blur(12px);
}
.letter-preview{
  position:absolute;
  left:12%;
  right:12%;
  bottom:58px;
  height:150px;
  display:grid;
  place-items:start center;
  padding-top:22px;
  background:linear-gradient(180deg,#fffaf2,#f1ddc5);
  border:1px solid rgba(184,135,52,.28);
  box-shadow:0 18px 44px rgba(73,54,46,.14);
  transform:translateY(55px) scale(.92);
  opacity:.18;
}
.letter-preview span{
  font-family:var(--script);
  font-size:2.2rem;
  color:#8e645e;
}
.envelope-back,.envelope-front,.flap{
  position:absolute;
  left:0;
  right:0;
}
.envelope-back{
  bottom:0;
  height:178px;
  border-radius:10px 10px 16px 16px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.72),transparent 38%),
    linear-gradient(180deg,#f0d3b4,#c99f78);
  box-shadow:inset 0 0 0 1px rgba(116,78,52,.18);
}
.flap{
  bottom:88px;
  height:118px;
  z-index:5;
  transform-origin:50% 100%;
  clip-path:polygon(0 100%,50% 0,100% 100%);
  background:linear-gradient(175deg,#f8e2c7,#c99e77);
  box-shadow:inset 0 -1px rgba(255,255,255,.7);
}
.envelope-front{
  bottom:0;
  height:178px;
  z-index:6;
  overflow:hidden;
  border-radius:10px 10px 16px 16px;
}
.envelope-front::before,.envelope-front::after{
  content:"";
  position:absolute;
  bottom:0;
  width:62%;
  height:100%;
  background:linear-gradient(145deg,#e6c09a,#f4dcc1);
  border-top:1px solid rgba(116,78,52,.14);
}
.envelope-front::before{left:0;clip-path:polygon(0 0,100% 100%,0 100%)}
.envelope-front::after{right:0;clip-path:polygon(100% 0,100% 100%,0 100%)}
.seal{
  position:absolute;
  left:50%;
  bottom:70px;
  z-index:8;
  width:70px;
  height:70px;
  display:grid;
  place-items:center;
  transform:translateX(-50%);
  border-radius:50%;
  color:#ffecc2;
  font-family:var(--script);
  font-size:1.55rem;
  background:
    radial-gradient(circle at 31% 25%,rgba(255,255,255,.4),transparent 20%),
    radial-gradient(circle,#bd7e83 0%,#7b3f49 72%);
  box-shadow:0 12px 28px rgba(98,47,55,.32), inset 0 0 0 2px rgba(255,255,255,.14);
}
.seal::after{
  content:"";
  position:absolute;
  inset:8px;
  border:1px solid rgba(255,236,194,.52);
  border-radius:50%;
}
.cover-hint{
  position:relative;
  z-index:2;
  margin:2px 0 0;
  font-family:var(--display);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#81665a;
}

.site{
  width:min(100%,480px);
  margin:0 auto;
  position:relative;
  z-index:1;
  min-height:100vh;
  background:
    linear-gradient(90deg,rgba(184,135,52,.08) 0 1px,transparent 1px calc(100% - 1px),rgba(184,135,52,.08) calc(100% - 1px)),
    linear-gradient(180deg,#fff8ed 0%,#f6e7d2 40%,#ecd4ba 100%);
  box-shadow:0 0 90px rgba(73,54,46,.16);
  opacity:0;
  transform:translateY(34px);
  filter:blur(14px);
}
.site.is-live{opacity:1;transform:none;filter:none}
.panel{
  position:relative;
  padding:clamp(58px,11vw,78px) 26px;
}
.panel + .panel{padding-top:36px}
.section-ornament{
  width:min(300px,84%);
  height:34px;
  margin:0 auto 28px;
  position:relative;
}
.section-ornament::before,.section-ornament::after{
  content:"";
  position:absolute;
  top:16px;
  width:42%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.section-ornament::before{left:0}
.section-ornament::after{right:0}
.section-ornament span{
  position:absolute;
  left:50%;
  top:50%;
  width:12px;
  height:12px;
  transform:translate(-50%,-50%) rotate(45deg);
  border:1px solid var(--gold);
  background:#fff8ed;
  box-shadow:0 0 24px rgba(184,135,52,.26);
}
.hero{text-align:center;padding-top:52px}
.hero-photo,.soft-photo{
  width:min(340px,100%);
  margin:0 auto 34px;
  padding:9px;
  background:rgba(255,252,246,.74);
  border:1px solid rgba(184,135,52,.30);
  box-shadow:var(--soft-shadow);
  position:relative;
}
.hero-photo::before,.hero-photo::after,.soft-photo::before{
  content:"";
  position:absolute;
  pointer-events:none;
  border:1px solid rgba(184,135,52,.24);
}
.hero-photo::before{inset:17px}
.hero-photo::after{inset:-9px}
.hero-photo img,.soft-photo img{
  display:block;
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  object-position:center;
}
.couple-name{
  margin:14px 0 22px;
  padding:.16em 0 .28em;
  font-family:var(--script);
  font-size:clamp(4.2rem,15vw,5.7rem);
  line-height:.84;
  font-weight:400;
  color:#67483f;
}
.couple-name span{
  display:block;
  margin:.06em 0;
  font-size:.42em;
  color:var(--gold);
}
.intro,.blessing,.final-copy{
  max-width:360px;
  margin:0 auto;
  font-size:1.22rem;
  line-height:1.78;
  color:#654d42;
}
.draw-title{margin:26px auto 0}
.draw-svg{
  width:100%;
  max-width:420px;
  height:auto;
  overflow:visible;
}
.draw-svg text{
  font-family:var(--script);
  font-size:62px;
  font-weight:400;
  stroke:var(--gold);
  stroke-width:1.15;
  stroke-linecap:round;
  stroke-linejoin:round;
  fill:url(#none);
  fill:rgba(184,135,52,0);
  paint-order:stroke fill;
}
.draw-svg.small text{font-size:58px}
.draw-svg.medium text{font-size:60px}
.draw-svg.is-filled text{
  fill:#b88734;
}
.date-line{
  margin:6px 0 0;
  font-family:var(--display);
  font-size:.86rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#71584b;
}

.countdown-section{text-align:center}
.countdown{
  width:min(390px,100%);
  margin:24px auto 0;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  padding:24px 14px;
  border-top:1px solid rgba(184,135,52,.26);
  border-bottom:1px solid rgba(184,135,52,.26);
}
.time-part{
  position:relative;
  min-width:0;
  padding:5px 2px;
}
.time-part + .time-part::before{
  content:"";
  position:absolute;
  left:-4px;
  top:16%;
  bottom:16%;
  width:1px;
  background:linear-gradient(180deg,transparent,rgba(184,135,52,.34),transparent);
}
.time-number{
  display:block;
  min-height:48px;
  font-family:var(--display);
  font-style:italic;
  font-size:clamp(2rem,10vw,3.1rem);
  line-height:1;
  color:#62453b;
  font-variant-numeric:tabular-nums;
}
.time-label{
  display:block;
  margin-top:8px;
  font-family:var(--display);
  font-size:.66rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
}

.music-card,.quote-card,.rsvp-card{
  position:relative;
  overflow:hidden;
  width:min(390px,100%);
  margin:0 auto;
  padding:28px;
  border:1px solid rgba(184,135,52,.28);
  background:linear-gradient(160deg,rgba(255,252,246,.76),rgba(238,214,188,.46));
  box-shadow:var(--soft-shadow);
  backdrop-filter:blur(12px);
}
.music-card::before,.quote-card::before,.rsvp-card::before,.family-block::before,.event-line::before{
  content:"";
  position:absolute;
  inset:9px;
  border:1px solid rgba(184,135,52,.15);
  pointer-events:none;
}
.music-copy h3{
  margin:8px 0 4px;
  font-family:var(--script);
  font-size:3.1rem;
  font-weight:400;
  line-height:1.05;
  color:#704e45;
}
.music-copy p:last-child{
  margin:0 0 20px;
  color:var(--muted);
}
.play-button{
  width:74px;
  height:74px;
  margin:0 auto 18px;
  position:relative;
  display:grid;
  place-items:center;
  border:0;
  border-radius:50%;
  cursor:pointer;
  color:#664438;
  background:radial-gradient(circle at 32% 28%,#fff7d8 0 18%,#ecc96f 42%,#a47227 100%);
  box-shadow:0 18px 34px rgba(164,114,39,.28), inset 0 0 0 1px rgba(255,255,255,.4);
}
.play-ring{
  position:absolute;
  inset:-8px;
  border:1px solid rgba(184,135,52,.32);
  border-radius:50%;
}
.play-button svg{
  width:28px;
  height:28px;
  fill:currentColor;
}
.sound-wave{
  height:42px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:6px;
}
.sound-wave span{
  width:3px;
  height:10px;
  border-radius:99px;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  transform-origin:center;
  opacity:.55;
}
.music-card.is-playing .sound-wave span{
  animation:wave 1.1s ease-in-out infinite;
}
.sound-wave span:nth-child(2){animation-delay:.1s;height:18px}
.sound-wave span:nth-child(3){animation-delay:.2s;height:30px}
.sound-wave span:nth-child(4){animation-delay:.3s;height:22px}
.sound-wave span:nth-child(5){animation-delay:.4s;height:34px}
.sound-wave span:nth-child(6){animation-delay:.5s;height:16px}
.sound-wave span:nth-child(7){animation-delay:.6s;height:24px}
@keyframes wave{0%,100%{transform:scaleY(.45)}50%{transform:scaleY(1.08);opacity:1}}

.events-section{padding-top:50px}
.event-line{
  position:relative;
  display:grid;
  grid-template-columns:84px 1fr;
  gap:20px;
  width:min(400px,100%);
  margin:0 auto 26px;
  padding:28px 22px 28px 18px;
  background:rgba(255,252,246,.46);
  border:1px solid rgba(184,135,52,.22);
  box-shadow:0 18px 48px rgba(73,54,46,.10);
  backdrop-filter:blur(10px);
}
.event-time{
  align-self:start;
  padding-top:12px;
  font-family:var(--display);
  font-style:italic;
  font-size:1.3rem;
  line-height:1.1;
  color:#704e45;
}
.event-body{min-width:0}
.place{
  margin:2px 0 8px;
  font-family:var(--display);
  font-size:.9rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.details{
  margin:0;
  font-size:1.08rem;
  line-height:1.58;
  color:#6b5448;
}
.action-link,.contact-button,.submit-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  margin-top:18px;
  padding:11px 20px;
  border:1px solid rgba(184,135,52,.36);
  color:#5f4339;
  text-decoration:none;
  background:rgba(255,252,246,.62);
  box-shadow:0 10px 24px rgba(73,54,46,.08);
  transition:transform .28s ease, box-shadow .28s ease, background .28s ease;
}
.action-link:hover,.contact-button:hover,.submit-button:hover{
  transform:translateY(-3px);
  background:#fffaf0;
  box-shadow:0 16px 34px rgba(73,54,46,.13);
}

.blessing-section{text-align:center}
.blessing{
  font-style:italic;
  font-size:1.48rem;
}
.quote-card{
  margin-top:30px;
  text-align:center;
}
.quote-card p{
  margin:0;
  font-family:var(--display);
  font-size:1.08rem;
  line-height:1.7;
}
.quote-card span{
  display:block;
  margin-top:14px;
  color:#8a645e;
  font-style:italic;
}
.soft-photo{
  margin-top:32px;
}
.soft-photo::before{inset:16px}

.family-section{
  display:grid;
  gap:18px;
}
.family-block{
  position:relative;
  width:min(390px,100%);
  margin:0 auto;
  padding:30px 26px;
  text-align:center;
  border-top:1px solid rgba(184,135,52,.25);
  border-bottom:1px solid rgba(184,135,52,.25);
  background:rgba(255,252,246,.34);
}
.family-block h3{
  margin:0 0 18px;
  font-family:var(--script);
  font-size:2.85rem;
  font-weight:400;
  color:#805953;
}
.family-block p{
  margin:7px 0;
  font-size:1.12rem;
}

.rsvp-card{text-align:center}
.rsvp-copy{
  max-width:340px;
  margin:0 auto 24px;
  font-size:1.1rem;
  line-height:1.65;
}
.contact-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:0 0 24px;
}
.contact-button{
  min-height:54px;
  margin:0;
  padding:10px;
  font-size:.94rem;
}
.rsvp-form{
  display:grid;
  gap:14px;
  text-align:left;
}
.rsvp-form label span{
  display:block;
  margin:0 0 6px;
  font-family:var(--display);
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}
.rsvp-form input,.rsvp-form select,.rsvp-form textarea{
  width:100%;
  border:1px solid rgba(184,135,52,.28);
  border-radius:0;
  padding:13px 14px;
  color:var(--ink);
  background:rgba(255,252,246,.72);
  outline:none;
  transition:border-color .22s ease, box-shadow .22s ease, background .22s ease;
}
.rsvp-form input:focus,.rsvp-form select:focus,.rsvp-form textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(184,135,52,.13);
  background:#fffaf0;
}
.submit-button{
  width:100%;
  margin-top:4px;
  border-color:transparent;
  font-family:var(--display);
  letter-spacing:.12em;
  text-transform:uppercase;
  background:linear-gradient(110deg,#9b6e25,#f4dd93 42%,#b88734 72%,#8e611f);
}
.form-status{
  min-height:22px;
  margin:0;
  text-align:center;
  color:#73544b;
}
.final-section{
  padding-bottom:86px;
  text-align:center;
}

.reveal{
  opacity:0;
  transform:translateY(34px);
  filter:blur(10px);
}
.char{
  display:inline-block;
  will-change:transform,opacity;
}

@media (max-width:380px){
  .panel{padding-left:19px;padding-right:19px}
  .countdown{gap:4px;padding-left:6px;padding-right:6px}
  .time-label{font-size:.58rem;letter-spacing:.11em}
  .event-line{grid-template-columns:1fr;gap:8px}
  .event-time{padding-top:0}
  .contact-row{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
  .reveal{opacity:1;transform:none;filter:none}
}
