:root{
  --soft:#FAF9F6;
  --blue:#5D6E8A;
  --gull:#7b8ea5; /* lighter bluish shade for birds */
}
*{box-sizing:border-box}
body{margin:0;background:var(--soft);font-family:'Inter',system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:#2a2f36;}

/* Hero with image and a light overlay; also add CSS fallback bg image */
.hero{position:relative;height:100vh;display:grid;place-items:center;overflow:hidden;
  background-image:url('./assets/hero.png');background-size:cover;background-position:center;}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(95%) brightness(98%);z-index:0;}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(250,249,246,.28)0%,rgba(250,249,246,.24)50%,rgba(250,249,246,.20)100%);z-index:1;}

/* Birds (3), behind content */
.birds{position:absolute;inset:0;pointer-events:none;z-index:2;}
.gull{position:absolute;width:220px;opacity:.55;filter:drop-shadow(0 2px 6px rgba(0,0,0,.18));}
.gull-shape{fill:var(--gull);stroke:var(--gull);stroke-width:1.1;}

@keyframes floatWideA{
  0%{transform:translate(-30vw, -2vh);opacity:0;}
  10%{opacity:.6;}
  40%{transform:translate(10vw, -1vh);}
  70%{transform:translate(60vw, 2vh);}
  100%{transform:translate(120vw, 0);opacity:0;}
}
@keyframes floatWideB{
  0%{transform:translate(120vw, 3vh) scaleX(-1);opacity:0;}
  10%{opacity:.6;}
  40%{transform:translate(60vw, 1vh) scaleX(-1);}
  70%{transform:translate(30vw, -1vh) scaleX(-1);}
  100%{transform:translate(-30vw, 1vh) scaleX(-1);opacity:0;}
}
@keyframes floatWideC{
  0%{transform:translate(-25vw, 0) scale(.9);opacity:0;}
  10%{opacity:.6;}
  40%{transform:translate(25vw, -2vh) scale(.9);}
  70%{transform:translate(70vw, 2vh) scale(.9);}
  100%{transform:translate(130vw, 1vh) scale(.9);opacity:0;}
}

.g1{top:22%;animation:floatWideA 24s linear infinite;}
.g2{top:48%;animation:floatWideB 28s linear infinite;}
.g3{top:34%;animation:floatWideC 26s linear infinite;}

.hero__content{
  position:relative;z-index:3;text-align:center;padding:2.2rem 2rem;background:rgba(250,249,246,0.55);
  border:1px solid rgba(93,110,138,0.18);border-radius:18px;box-shadow:0 10px 40px rgba(0,0,0,0.06);
}
.handwritten{font-family:'La Belle Aurore',cursive;font-weight:400;color:var(--blue);font-size:clamp(2.6rem,7.5vw,5.2rem);margin:0;}
/* Date/location line: 35% smaller, lighter color, letter-spaced */
.subhand{
  margin:.35rem 0 1.2rem;
  color:#8a9aaf;
  font-size:calc(clamp(1rem,2.3vw,1.25rem) * 0.65); /* 35% smaller */
  letter-spacing:.14em;
}

/* Actions with equal-width buttons (v4.18 style: ~190px, pill) */
.actions{
  display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;align-items:stretch;
  max-width:520px;margin-inline:auto;
}
.btn{
  appearance:none;padding:.78rem 1.2rem;border-radius:999px;text-decoration:none;
  cursor:pointer;border:1px solid transparent; background:transparent;
  font-weight:400; /* light/no bolding */
}
.btn--filled{background:var(--blue);color:var(--soft);}
.btn.equal{flex:1 1 190px; min-width:190px; text-align:center;}
.smallcaps{font-size:0.65rem; letter-spacing:.16em; text-transform:uppercase;}
.btn--filled:hover{filter:brightness(1.06);transform:translateY(-1px);}

/* Inline "Coming soon!" under DETAILS (lighter ivory-blue text) */
.details-wrap{ position:relative; display:flex; justify-content:center; align-items:center; flex:1 1 190px; min-width:190px; }
.details-wrap > .btn{ width:100%; text-align:center; }
.details-toast{
  position:absolute;
  top:100%;
  left:50%;
  transform:translate(-50%, 10px);
  color:#AEB7C5;
  background:transparent;
  font-weight:600;
  font-size:1rem;
  letter-spacing:.02em;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease, transform .35s ease;
  z-index:11;
}
.details-toast.show{ opacity:1; transform:translate(-50%, 2px); }

.section{padding:4rem 1rem;background:#fff}
.section:nth-of-type(even){background:#f4f3ef}
.container{max-width:980px;margin:0 auto}
h2{font-family:'La Belle Aurore',cursive;color:#5D6E8A;font-weight:400;font-size:clamp(1.7rem,3.4vw,2.3rem);margin:0 0 1rem 0;}

/* Toast (top) */
.toast{position:fixed;top:14px;left:50%;transform:translateX(-50%);background:#1b2a3b;color:#fff;padding:.7rem 1rem;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:10;font-weight:600;}
.toast.show{opacity:1;}

/* Modal */
.modal{border:none;border-radius:16px;padding:0;width:min(680px,92vw);background:#fff;box-shadow:0 25px 60px rgba(0,0,0,.2);}
.modal::backdrop{background:rgba(0,0,0,.3);}
.modal__card{padding:1.2rem 1.2rem 1rem 1.2rem;display:grid;gap:.9rem}
.modal__close{position:absolute;top:.4rem;right:.6rem;font-size:1.4rem;border:none;background:transparent;cursor:pointer}
label{display:grid;gap:.35rem;font-size:.95rem}
input,select{width:100%;padding:.7rem .8rem;border-radius:10px;border:1px solid #cfd6df;font:inherit;background:#fbfbfb}
.modal__actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:.5rem}
.hint{margin:0;font-size:.8rem;opacity:.7}
.hidden{display:none}
