/* ============================================================
   Flourish & Godwin — "In Full Bloom"
   Bespoke stylesheet · ivory · emerald · antique gold
   ============================================================ */

:root{
  /* canvas */
  --ivory:#FBF7F0; --cream:#F4ECDF; --white:#FFFFFF; --blush:#FBEADE;
  /* green */
  --emerald:#1C3528; --emerald-2:#264433; --sage:#9CA995; --sage-tint:#E7ECE5;
  /* gold */
  --gold:#C7A24A; --gold-deep:#A07C2B; --gold-light:#E7CF95;
  --foil:linear-gradient(115deg,#E7CF95 0%,#C7A24A 38%,#9A7A2C 58%,#E7CF95 100%);
  /* warmth + metal */
  --peach:#F0CDB4; --peach-deep:#D99E78; --silver:#C6CACE;
  /* ink */
  --ink:#2A2620; --ink-soft:#6A6256; --on-dark:#F4ECDC; --on-dark-soft:#C9C2AE;
  /* type */
  --serif:"Cormorant Garamond",Georgia,serif;
  --script:"Pinyon Script",cursive;
  --sans:"Jost",system-ui,sans-serif;
  /* rhythm */
  --gut:clamp(1.5rem,5vw,3rem);
  --sec:clamp(4.5rem,11vw,9rem);
  --maxw:1180px;
  --shadow:0 26px 60px -28px rgba(28,53,40,.45);
  --radius:14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scrollbar-gutter:stable;overflow-x:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; background:var(--ivory); color:var(--ink);
  font-family:var(--sans); font-weight:300; font-size:clamp(1rem,1.05vw,1.0625rem);
  line-height:1.75; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.locked{overflow:hidden;height:100vh}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* paper grain — barely there */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.5;
  background-image:radial-gradient(rgba(42,38,32,.025) 1px,transparent 1px);
  background-size:3px 3px; mix-blend-mode:multiply;
}

/* ---------- typography helpers ---------- */
.display{
  font-family:var(--serif); font-weight:500; line-height:1.04;
  font-size:clamp(2.4rem,6.5vw,4.25rem); letter-spacing:.005em; margin:0;
}
.overline{
  font-family:var(--sans); font-weight:400; text-transform:uppercase;
  letter-spacing:.42em; font-size:.72rem; color:var(--gold-deep); margin:0 0 1.1rem;
  padding-left:.42em;
}
.overline--light{color:var(--gold-light)}
.script{font-family:var(--script);font-weight:400;line-height:1}
.wrap{width:min(100% - var(--gut)*2,var(--maxw));margin-inline:auto}

/* gold-foil text */
.foil,.couple__name,.foot__tag,.count__num{
  background:var(--foil); -webkit-background-clip:text; background-clip:text;
  color:transparent;
}

/* hairline rule with center diamond */
.rule{
  display:block; width:120px; height:1px; margin:1.4rem auto 0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent); position:relative;
}
.rule::after{
  content:""; position:absolute; left:50%; top:50%; width:7px; height:7px;
  transform:translate(-50%,-50%) rotate(45deg); background:var(--gold);
}
.sectionhead{text-align:center;margin-bottom:clamp(2.5rem,6vw,4rem)}
.section--emerald .overline{color:var(--gold-light)}

/* ---------- buttons ---------- */
.btn{
  --bx:1.9rem; display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--sans); font-weight:400; letter-spacing:.16em; text-transform:uppercase;
  font-size:.78rem; padding:.95em var(--bx); border-radius:999px; cursor:pointer;
  border:1px solid transparent; transition:transform .35s cubic-bezier(.2,.8,.2,1),
   box-shadow .35s ease, background .35s ease, color .35s ease; position:relative; overflow:hidden;
}
.btn--lg{font-size:.84rem;padding:1.15em 2.6rem}
.btn--mini{font-size:.68rem;padding:.7em 1.3rem}
.btn:active{transform:scale(.97)}
.btn--gold{
  background:var(--emerald); color:var(--gold-light);
  border:1px solid var(--gold); box-shadow:0 14px 30px -16px rgba(28,53,40,.6);
}
.btn--gold::before{ /* foil sheen sweep */
  content:""; position:absolute; top:0; left:-120%; width:60%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(231,207,149,.55),transparent);
  transform:skewX(-18deg); transition:left .7s ease;
}
.btn--gold:hover{background:var(--emerald-2);transform:translateY(-2px)}
.btn--gold:hover::before{left:140%}
.btn--ghost{background:transparent;border:1px solid currentColor;color:var(--on-dark)}
.btn--ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn--ghost-gold{color:var(--gold-light)}

/* ════════ 0 · THE SEAL ════════ */
.seal{
  position:fixed; inset:0; z-index:90; display:grid; place-items:center;
  background:var(--ivory); text-align:center; overflow:clip;
  transition:opacity 1s ease, visibility 1s;
}
.seal__paper{position:absolute;inset:0;background:
  radial-gradient(120% 90% at 50% 30%,rgba(240,205,180,.18),transparent 60%),
  radial-gradient(90% 80% at 50% 110%,rgba(156,169,149,.14),transparent 55%);}
.seal__inner{position:relative;padding:var(--gut)}
.seal__mandala{
  position:absolute; left:50%; top:46%; width:min(78vw,440px);
  transform:translate(-50%,-50%); opacity:.16; pointer-events:none;
  animation:spin 90s linear infinite;
}
.seal__overline{font-family:var(--sans);text-transform:uppercase;letter-spacing:.4em;
  font-size:.7rem;color:var(--gold-deep);margin:0 0 1.6rem}
.seal__medallion{
  display:block; margin:0 auto; width:min(46vw,190px); aspect-ratio:1; background:none;
  border:none; cursor:pointer; padding:0; position:relative;
  transition:transform .5s cubic-bezier(.2,.8,.2,1), filter .5s ease;
  animation:breathe 4.5s ease-in-out infinite;
}
.seal__medallion img{width:100%}
.seal__logo{width:100%;height:auto;display:block;overflow:visible}
.seal__logo path{fill:#241f17;fill-opacity:1}
/* draw-on / assemble: lines write themselves, then fill blooms in */
.seal__logo.draw path{
  fill-opacity:0; stroke:#2c2418; stroke-width:.32;
  stroke-dasharray:620; stroke-dashoffset:620;
  animation:logodraw 2.4s cubic-bezier(.55,.12,.3,1) forwards;
  animation-delay:calc(var(--i,0) * 52ms);
}
@keyframes logodraw{
  0%{stroke-dashoffset:620;fill-opacity:0}
  58%{stroke-dashoffset:0;fill-opacity:0}
  100%{stroke-dashoffset:0;fill-opacity:1;stroke-width:0}
}
.seal__medallion:hover{transform:scale(1.04)}
.seal__tag{margin:1.5rem 0 0;font-family:var(--sans);font-weight:500;
  font-size:clamp(.84rem,1.7vw,1rem);letter-spacing:.2em;color:var(--gold-deep);
  opacity:0;animation:fadeUp 1s ease forwards 2.4s}
.seal__hint{margin:.9rem 0 0;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-soft);opacity:0;animation:fadeUp 1s ease forwards 3s,fade 2.6s ease-in-out infinite 4s}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.seal.is-open{opacity:0;visibility:hidden}
.seal.is-open .seal__medallion{transform:scale(1.35);filter:opacity(0)}

@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.035)}}
@keyframes fade{0%,100%{opacity:.4}50%{opacity:1}}

/* ════════ NAV ════════ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:70; display:flex; align-items:center;
  justify-content:space-between; gap:1rem; padding:.7rem var(--gut);
  transition:background .4s ease, box-shadow .4s ease, padding .4s ease, transform .5s ease;
}
.nav.hidden{transform:translateY(-115%)}
.nav.solid{background:rgba(251,247,240,.9);backdrop-filter:blur(10px);
  box-shadow:0 1px 0 rgba(199,162,74,.25);padding:.45rem var(--gut)}
.nav__brand img{height:46px;transition:height .4s ease,filter .4s ease}
.nav.solid .nav__brand img{height:38px}
/* over the dark hero (transparent nav) → light logo; on solid light nav → dark logo */
.nav:not(.solid) .nav__brand img{filter:brightness(0) invert(1) drop-shadow(0 1px 3px rgba(0,0,0,.4))}
.nav__links{display:none;gap:2rem}
.nav__links a{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);
  position:relative;padding-bottom:3px;transition:color .4s ease}
.nav:not(.solid) .nav__links a{color:rgba(255,248,236,.9);text-shadow:0 1px 3px rgba(0,0,0,.4)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--gold);transition:width .35s ease}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{width:100%}
.nav__cta{--bx:1.4rem;font-size:.7rem}
.nav:not(.solid) .nav__cta{background:rgba(255,255,255,.12);border-color:rgba(231,207,149,.7);
  color:#fff;backdrop-filter:blur(6px)}
@media(min-width:860px){.nav.solid .nav__links{display:flex}}

/* ════════ 1 · HERO ════════ */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;
  text-align:center;color:#fff;overflow:hidden;isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:50% 28%;
  animation:kenburns 22s ease-in-out infinite alternate}
.hero__veil{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(68% 52% at 50% 50%,rgba(13,21,16,.66),rgba(13,21,16,.3) 72%,transparent),
  linear-gradient(180deg,rgba(13,21,16,.6),rgba(13,21,16,.4) 42%,rgba(13,21,16,.8))}
.hero__content{padding:5rem var(--gut);position:relative;z-index:2}
.couple{font-family:var(--serif);font-weight:500;margin:.2em 0 .35em;line-height:.92}
.couple__name{display:block;font-size:clamp(3.4rem,15vw,8.5rem);letter-spacing:.01em;
  background:linear-gradient(100deg,#D7B463 0%,#E3C275 14%,#F4E2AE 30%,#FBF2D8 46%,#E9D193 54%,#D8BB6C 66%,#EEDCA6 82%,#D7B463 100%);
  background-size:230% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  filter:drop-shadow(0 1px 0 rgba(120,92,34,.38)) drop-shadow(0 3px 7px rgba(0,0,0,.32));
  animation:shimmer 6.5s linear infinite}
@keyframes shimmer{to{background-position:230% center}}
.couple__amp{display:block;font-family:var(--script);font-weight:400;
  font-size:clamp(2.2rem,7vw,3.6rem);color:var(--gold-light);margin:-.18em 0;line-height:1}
.hero__meta{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.85rem;
  font-size:.76rem;letter-spacing:.28em;text-transform:uppercase;color:#f4ecdc;margin:.4rem 0 2rem}
.hero__meta .dot{width:4px;height:4px;border-radius:50%;background:var(--gold-light);display:inline-block}
.hero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero__tag{margin-top:1.7rem;font-family:var(--sans);font-weight:500;
  font-size:clamp(.82rem,1.5vw,.98rem);letter-spacing:.16em;color:var(--gold-light);
  text-shadow:0 1px 4px rgba(0,0,0,.45)}
.scrolldown{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);
  width:26px;height:42px;border:1px solid rgba(244,236,220,.5);border-radius:14px;z-index:2}
.scrolldown span{position:absolute;left:50%;top:8px;width:3px;height:7px;border-radius:2px;
  background:var(--gold-light);transform:translateX(-50%);animation:scroll 1.8s ease-in-out infinite}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.12)}}
@keyframes scroll{0%{opacity:0;top:8px}40%{opacity:1}100%{opacity:0;top:24px}}

/* ════════ sections shared ════════ */
section{position:relative;padding-block:var(--sec)}
.section--emerald{background:var(--emerald);color:var(--on-dark);overflow:clip}
.section--emerald .display{color:var(--gold-light)}
.section--emerald p{color:var(--on-dark-soft)}

/* decorative leaves & roses */
.leaf{position:absolute;width:clamp(90px,14vw,180px);opacity:.85;pointer-events:none;z-index:1}
.leaf--tl{top:2rem;left:-1.5rem;transform:rotate(8deg)}
.leaf--tr{top:2rem;right:-1.5rem;transform:scaleX(-1) rotate(8deg)}
.rose{position:absolute;width:clamp(120px,18vw,230px);pointer-events:none;z-index:1;
  opacity:0;transform-origin:center bottom;
  transform:rotate(calc(var(--rot,0deg) + var(--br,-10deg))) scaleX(var(--flip,1)) scale(var(--s,.12));
  transition:transform 1.7s cubic-bezier(.2,1.18,.32,1),opacity 1s ease .1s;
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.25))}
.rose.bloom{opacity:var(--o,.96);--s:1;--br:0deg}
.rose--br{--rot:-6deg;right:-2.5rem;bottom:-2.5rem}
@media(prefers-reduced-motion:no-preference){
  .leaf{animation:float 7s ease-in-out infinite}
  .leaf--tr{animation-delay:-3s}
  .rose.bloom{animation:float 8s ease-in-out infinite 1.4s}
}
@keyframes float{0%,100%{translate:0 0}50%{translate:0 -10px}}

/* ════════ 2 · STORY ════════ */
.story__grid{display:grid;gap:clamp(1.8rem,5vw,3.5rem);align-items:center}
.story__photo{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.story__photo img{width:100%;aspect-ratio:4/5;object-fit:cover}
.story__text .lede{font-family:var(--serif);font-style:italic;font-size:1.5rem;line-height:1.4;
  color:var(--gold-light);margin:0 0 1.2rem}
.story__text p{margin:0 0 1.1rem}
.signature{font-family:var(--script)!important;font-size:1.9rem;color:var(--gold-light)!important;margin-top:1.4rem}
.story__strip{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.6rem,2vw,1.2rem);
  margin-top:clamp(2rem,5vw,3.2rem)}
.story__strip figure{margin:0;border-radius:10px;overflow:hidden}
.story__strip img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .8s ease}
.story__strip figure:hover img{transform:scale(1.06)}
@media(min-width:820px){.story__grid{grid-template-columns:0.9fr 1.1fr}}

/* ════════ 3 · COUPLE mosaic ════════ */
.mosaic{display:grid;gap:clamp(.7rem,2vw,1.3rem);grid-template-columns:1fr 1fr}
.mosaic figure{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.mosaic img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;transition:transform .8s ease}
.mosaic figure:hover img{transform:scale(1.04)}

/* ════════ 3b · QUOTE ════════ */
.quote{min-height:62vh;display:grid;place-items:center;text-align:center;color:#fff;
  overflow:hidden;isolation:isolate;padding-block:clamp(4rem,10vw,7rem)}
.quote__media{position:absolute;inset:0;z-index:-2}
.quote__media img{width:100%;height:100%;object-fit:cover;object-position:50% 35%}
.quote__veil{position:absolute;inset:0;z-index:-1;background:rgba(20,30,24,.5)}
.quote blockquote{margin:0;padding:0 var(--gut)}
.quote .script{font-size:clamp(2.6rem,9vw,4.5rem);color:var(--gold-light)}
.quote .display{font-style:italic;font-weight:400;margin-top:-.2em}

/* ════════ 4 · COUNTDOWN ════════ */
.count{text-align:center;background:var(--cream)}
.count__grid{display:flex;justify-content:center;gap:clamp(.8rem,4vw,3rem);flex-wrap:wrap;margin-top:.5rem}
.count__cell{min-width:72px}
.count__num{font-family:var(--serif);font-weight:600;font-size:clamp(2.6rem,8vw,4.5rem);line-height:1;display:block}
.count__lbl{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft);margin-top:.5rem;display:block}
.count__date{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--gold-deep);margin-top:2rem}

/* ════════ 5 · DETAILS ════════ */
.cards{display:grid;gap:clamp(1.6rem,4vw,2.5rem);align-items:center}
.card{background:rgba(255,255,255,.04);border:1px solid rgba(231,207,149,.28);
  border-radius:var(--radius);padding:clamp(1.8rem,4vw,2.6rem);text-align:center}
.card__kicker{font-family:var(--sans);text-transform:uppercase;letter-spacing:.32em;
  font-size:.7rem;color:var(--gold-light)!important;margin:0 0 1rem}
.card__time{font-family:var(--serif);font-size:clamp(2rem,5vw,2.8rem);color:var(--on-dark)!important;margin:0}
.card__place{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold-light)!important;margin:.6rem 0 .4rem}
.card__addr{font-size:.92rem;margin:0 0 1.6rem}
.cards__div{display:grid;place-items:center}
.cards__div img{width:80px;opacity:.7}
@media(min-width:820px){.cards{grid-template-columns:1fr auto 1fr}}
.colour{text-align:center;margin-top:clamp(2.5rem,6vw,4rem)}
.colour__title{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold-light)!important;margin:0 0 1.4rem}
.colour__swatches{display:flex;justify-content:center;gap:clamp(1.2rem,4vw,2.6rem);flex-wrap:wrap}
.sw{display:flex;flex-direction:column;align-items:center;gap:.6rem;font-size:.72rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--on-dark-soft)}
.sw i{width:44px;height:44px;border-radius:50%;box-shadow:0 0 0 1px rgba(231,207,149,.4),0 8px 18px -8px rgba(0,0,0,.5)}

/* ════════ 6 · GALLERY ════════ */
.gallery{background:var(--blush)}
.gallery__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.6rem,2vw,1rem)}
.gallery__grid figure{margin:0;border-radius:10px;overflow:hidden}
.gallery__grid img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .8s ease,filter .8s ease}
.gallery__grid figure:hover img{transform:scale(1.05)}
.gallery__grid img{transition:transform .8s ease}
.gallery__wide{grid-column:1 / -1}
.gallery__wide img{aspect-ratio:16/10}
.gallery__cta{text-align:center;margin-top:clamp(2rem,5vw,3rem)}
@media(min-width:680px){
  .gallery__grid{grid-template-columns:repeat(3,1fr)}
  .gallery__wide{grid-column:span 2}
}

/* ════════ 7 · RSVP ════════ */
.rsvp{background:
  radial-gradient(70% 60% at 50% 0%,var(--blush),transparent 60%),var(--ivory)}
.rsvp__card{position:relative;max-width:640px;margin-inline:auto;text-align:center;
  background:var(--white);border:1px solid rgba(199,162,74,.4);border-radius:24px;
  padding:clamp(2.6rem,7vw,4rem) clamp(1.6rem,5vw,3.4rem);box-shadow:var(--shadow);overflow:clip}
.rsvp__rose{position:absolute;top:-30px;right:-30px;width:140px;opacity:.9;pointer-events:none}
.rsvp__copy{max-width:42ch;margin:.5rem auto 2rem;color:var(--ink-soft)}
.rsvp__by{margin-top:1.4rem;font-size:.82rem;letter-spacing:.06em;color:var(--ink-soft)}
.rsvp .display{color:var(--gold-deep)}

/* ════════ 8 · AFTER ════════ */
.after{text-align:center;background:var(--cream)}
.after .display{color:var(--gold-deep)}
.after__copy{color:var(--ink-soft);margin:.6rem 0 1.8rem}
.after__cta{margin-bottom:1.4rem}
.after__soon{display:inline-block;font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-deep);border:1px solid var(--gold);border-radius:999px;padding:.6em 1.4em}

/* ════════ FOOTER ════════ */
.foot{position:relative;text-align:center;overflow:clip}
.foot__inner{position:relative;z-index:2;padding-inline:var(--gut)}
.foot__mark{height:96px;margin:0 auto 1rem;filter:brightness(0) invert(1) sepia(.3) saturate(3) hue-rotate(5deg);opacity:.95}
.foot__tag{font-family:var(--sans);font-weight:500;font-size:clamp(.92rem,2vw,1.08rem);
  letter-spacing:.18em;margin:.4rem 0 1.4rem}
.foot__thanks{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--gold-light)!important;line-height:1.5}
.foot .btn{margin:1.6rem 0 .4rem}
.foot__meta{font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--on-dark-soft)!important;margin:1.6rem 0 .3rem}
.foot__credit{font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--on-dark-soft)!important;margin:0}
.rose--fl{--rot:12deg;--o:.5;left:-3rem;bottom:-3rem}
.rose--fr{--rot:12deg;--flip:-1;--o:.5;right:-3rem;top:-3rem}

/* ════════ mobile flora — smaller, tucked into corners, never covering text ════════ */
@media(max-width:680px){
  .rose{width:clamp(72px,19vw,104px)}
  .rose--br{right:0;bottom:-.8rem}
  .rose--fl{left:0;bottom:-.8rem}
  .rose--fr{right:0;top:-.8rem}
  .leaf{width:clamp(54px,13vw,84px)}
  .leaf--tl{left:0}
  .leaf--tr{right:0}
  .rsvp__rose{width:76px;top:-10px;right:-8px;opacity:.85}
}

/* ════════ reveal-on-scroll ════════ */
[data-reveal]{opacity:0;transform:translateY(26px);
  transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .seal__mandala,.seal__medallion,.hero__media img,.leaf,.scrolldown span,.couple__name{animation:none!important}
  .rose{opacity:var(--o,.96);--s:1;transition:none;animation:none!important}
  .seal__logo.draw path{fill-opacity:1;stroke:none;stroke-dashoffset:0;animation:none!important}
}
