/* ══════════════════════════════════════════════════════════════
   ANANYA & KAMAL · ENGAGEMENT
   A gold-arch invitation — blush · ivory · peach · sage · gold
   Signature: the gold welcome arch (from their real decor)
   ══════════════════════════════════════════════════════════════ */

:root{
    /* ---- palette ---- */
    --ivory:        #FBF6EE;
    --ivory-deep:   #F4EADC;
    --paper:        #FFFDF8;
    --blush:        #E3AEB1;
    --blush-soft:   #F3D9D8;
    --rose:         #D89FA0;
    --rose-deep:    #C98789;
    --peach:        #EFD0BD;
    --sage:         #94A684;
    --sage-soft:    #C3CEB6;
    --sage-deep:    #7E9070;
    --gold:         #BD9A52;
    --gold-deep:    #97712F;
    --gold-light:   #E6CD8A;
    --ink:          #4A332E;
    --ink-soft:     #8C736A;
    --on-dark:      #FFF8F0;

    /* ---- gold foil ---- */
    --foil: linear-gradient(135deg,#EFD89B 0%,#C9A45C 30%,#9A7430 52%,#D9BC73 74%,#A47E38 100%);
    --foil-line: linear-gradient(90deg,transparent,var(--gold) 18%,var(--gold-light) 50%,var(--gold) 82%,transparent);

    /* ---- depth ---- */
    --shadow-card: 0 26px 60px -32px rgba(74,51,46,.45), 0 8px 22px -16px rgba(74,51,46,.22);
    --shadow-gold: 0 16px 36px -18px rgba(151,113,47,.5);
    --shadow-soft: 0 14px 40px -28px rgba(74,51,46,.4);

    /* ---- rhythm ---- */
    --pad-y: clamp(64px, 11vh, 116px);
    --pad-x: clamp(22px, 6vw, 44px);
    --maxw: 660px;
}

*{margin:0;padding:0;box-sizing:border-box}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

body{
    font-family:'Poppins',sans-serif;
    background:var(--ivory);
    color:var(--ink);
    overflow-x:hidden;
    -webkit-tap-highlight-color:transparent;
    text-rendering:optimizeLegibility;
    -webkit-font-smoothing:antialiased;
}

img{max-width:100%;display:block}
.blend{mix-blend-mode:multiply}

/* ── shared atoms ────────────────────────────────────── */
.eyebrow{
    font-family:'Poppins',sans-serif;
    font-size:.7rem;
    font-weight:500;
    letter-spacing:.42em;
    text-transform:uppercase;
    color:var(--gold-deep);
    margin-bottom:1.1rem;
    padding-left:.42em;
}
.eyebrow::before{content:"\2767";display:block;font-size:1.1rem;letter-spacing:0;
    color:var(--gold);margin:0 0 .55rem;opacity:.85}

.section-title{
    font-family:'Bodoni Moda',serif;
    font-weight:500;
    font-size:clamp(2.1rem,7vw,3.3rem);
    line-height:1.04;
    letter-spacing:.01em;
    color:var(--ink);
    margin-bottom:.4em;
}

.gold-foil{
    background:var(--foil);
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
}

/* floral garland used as a section rule */
.floral-rule{
    width:min(280px,72%);height:auto;margin:1.6rem auto 0;
    opacity:.92;
}

/* a button system */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:.5em;
    font-family:'Poppins',sans-serif;font-size:.8rem;font-weight:500;
    letter-spacing:.16em;text-transform:uppercase;
    padding:.95em 1.9em;border-radius:100px;border:0;cursor:pointer;
    text-decoration:none;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s,filter .35s;
    will-change:transform;
}
.btn-fill{background:var(--foil);color:var(--ink);box-shadow:var(--shadow-gold);
    text-shadow:0 1px 0 rgba(255,255,255,.25)}
.btn-fill:hover{transform:translateY(-3px);filter:brightness(1.06)}
.btn-line{background:transparent;color:var(--gold-deep);box-shadow:inset 0 0 0 1px var(--gold)}
.btn-line:hover{transform:translateY(-3px);background:rgba(189,154,82,.08)}
.link-btn{background:none;border:0;cursor:pointer;font-family:'Poppins',sans-serif;
    font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);
    margin-top:1.3rem;padding:.4em;border-bottom:1px solid currentColor;border-radius:0}

/* tinted section variants — kept light enough for blend:multiply assets */
.tint-blush{background:linear-gradient(178deg,var(--ivory) 0%,#F7E7E4 60%,#F3DEDB 100%)}
.tint-rose{background:linear-gradient(165deg,#E7BEBF 0%,#D89FA0 55%,#C98C8D 100%)}
.tint-sage{background:linear-gradient(165deg,#AFBDA2 0%,#92A382 55%,#80916F 100%)}
.on-rose,.on-sage{color:var(--on-dark)}
.on-rose.eyebrow,.on-sage.eyebrow{color:rgba(255,248,240,.85)}
.on-rose.eyebrow::before,.on-sage.eyebrow::before{color:var(--gold-light);opacity:1}

/* ── page frame + progress ───────────────────────────── */
.page-frame{
    position:fixed;inset:clamp(9px,2.4vw,18px);
    border:1px solid rgba(189,154,82,.55);
    border-radius:5px;pointer-events:none;z-index:40;
    box-shadow:inset 0 0 0 3px rgba(255,253,248,.4),inset 0 0 0 4px rgba(189,154,82,.22);
}
.scroll-progress{
    position:fixed;top:0;left:0;height:3px;width:0;z-index:70;
    background:var(--foil);box-shadow:0 0 12px rgba(189,154,82,.6);
}

/* ── falling petals ──────────────────────────────────── */
.petals-overlay{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:30}
.petal{position:absolute;top:-6%;border-radius:54% 0 55% 50%;
    opacity:0;will-change:transform;animation:petal-fall linear infinite}
@keyframes petal-fall{
    0%{transform:translate3d(0,-10vh,0) rotate(0deg);opacity:0}
    8%{opacity:.9}
    92%{opacity:.55}
    100%{transform:translate3d(var(--drift,40px),112vh,0) rotate(540deg);opacity:0}
}

/* ════════════════ ENVELOPE / OPENING ════════════════ */
.envelope-screen{
    position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
    background:
      radial-gradient(46% 15% at 50% 100%, rgba(255,247,236,.55) 0%, rgba(255,247,236,0) 72%),
      radial-gradient(54% 44% at 50% 44%, rgba(255,245,228,.34) 0%, rgba(255,245,228,0) 72%),
      radial-gradient(84% 54% at 50% 2%, rgba(243,221,165,.5) 0%, rgba(243,221,165,0) 58%),
      radial-gradient(128% 104% at 50% 40%, #FBEAE4 0%, #EFCDC9 42%, #D7A1A2 100%);
    transition:opacity 1s ease .15s,visibility 1s ease .15s;overflow:hidden;
}
.envelope-screen.opened{opacity:0;visibility:hidden;pointer-events:none}

/* the temple mandap — a grand watercolour backdrop rising behind the couple */
.env-temple{
    position:absolute;left:50%;bottom:0;transform:translateX(-50%);
    height:min(98vh,1000px);width:auto;max-width:none;z-index:1;pointer-events:none;opacity:.65;
    filter:saturate(.97) brightness(1.04) drop-shadow(0 12px 30px rgba(150,92,72,.22));
    -webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 9%,#000 90%,transparent 100%);
            mask-image:linear-gradient(to bottom,transparent 0,#000 9%,#000 90%,transparent 100%);
    animation:temple-rise 1.9s cubic-bezier(.22,1,.36,1) both;
}
@keyframes temple-rise{
    from{opacity:0;transform:translateX(-50%) translateY(20px) scale(1.035)}
    to{opacity:.65;transform:translateX(-50%) translateY(0) scale(1)}
}

/* the couple — full-opacity watercolour the envelope floats in front of */
.env-couple{
    position:absolute;left:50%;bottom:0;transform:translateX(-50%);
    width:min(96vw,50vh);height:auto;z-index:2;pointer-events:none;opacity:.97;
    filter:saturate(1.04) drop-shadow(0 16px 32px rgba(120,66,68,.34));
    -webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 80%,transparent 99%);
            mask-image:linear-gradient(to bottom,#000 0%,#000 80%,transparent 99%);
    animation:couple-rise 1.5s cubic-bezier(.22,1,.36,1) both;
}
@keyframes couple-rise{
    from{opacity:0;transform:translateX(-50%) translateY(26px) scale(1.045)}
    to{opacity:.97;transform:translateX(-50%) translateY(0) scale(1)}
}

.env-petals{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:4}
.env-vignette{position:absolute;inset:0;pointer-events:none;z-index:3;
    background:radial-gradient(72% 58% at 50% 45%,transparent 38%,rgba(118,62,64,.40) 100%)}

.env-stage{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;align-items:center;
    justify-content:space-between;padding:clamp(34px,7vh,68px) 24px clamp(26px,5vh,52px)}
/* soft ivory halo that lifts the envelope off the couple behind it */
.env-stage::before{content:"";position:absolute;left:50%;top:57%;transform:translate(-50%,-50%);
    width:min(90vw,432px);aspect-ratio:1;border-radius:50%;z-index:-1;pointer-events:none;
    background:radial-gradient(circle,rgba(255,250,242,.62) 0%,rgba(255,249,238,.26) 40%,transparent 70%)}
.env-overline{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(1.15rem,4.5vw,1.32rem);
    color:#7c4f50;letter-spacing:.05em;margin-bottom:.2rem;opacity:.94;position:relative}

.envelope{
    position:relative;width:min(78vw,330px);aspect-ratio:7/5;
    --env-shift:clamp(42px,9vh,86px);   /* float lower, so faces + garlands clear the card */
    transform:translateY(var(--env-shift));   /* base anchor — holds for reduced-motion too */
    background:none;border:0;padding:0;cursor:pointer;
    perspective:1000px;animation:env-float 4s ease-in-out infinite;
    /* ---- royal gold-foil system (shared by every face) ---- */
    --g-hi:#FBEFC2;--g-lt:#ECD188;--g-md:#CDA552;--g-dk:#9C7530;--g-sh:#6E4E1E;
    --foil-body:linear-gradient(150deg,#F4E1A4 0%,#D3A95A 15%,#AE7C34 30%,#EAD08A 46%,#B68B40 58%,#DCBF74 72%,#9A722E 88%,#C7A258 100%);
    --foil-flap:linear-gradient(154deg,#F9E9B2 0%,#DDB868 17%,#BB8E42 34%,#F1D896 50%,#C29748 64%,#E4C77D 80%,#A87E36 100%);
    --foil-trim:linear-gradient(150deg,#FCEFC6 0%,#E9CD86 42%,#D0AA60 72%,#EAD193 100%);
    --foil-edge:linear-gradient(160deg,#7A5A24 0%,#5C4019 55%,#46300F 100%);
    --sheen:radial-gradient(130% 82% at 26% 8%,rgba(255,250,224,.6) 0%,rgba(255,250,224,0) 46%);
    --streak:linear-gradient(150deg,transparent 40%,rgba(255,252,238,.5) 47.5%,rgba(255,255,250,.72) 50.5%,rgba(255,250,232,.38) 54%,transparent 61%);
    --striae:repeating-linear-gradient(94deg,rgba(255,247,214,.05) 0 2px,rgba(108,78,30,.06) 2px 4px);
    --emboss:
      repeating-linear-gradient(45deg,rgba(84,57,21,.11) 0 1px,transparent 1px 16px),
      repeating-linear-gradient(45deg,rgba(255,244,208,.16) 1px 2px,transparent 2px 17px),
      repeating-linear-gradient(135deg,rgba(84,57,21,.11) 0 1px,transparent 1px 16px),
      repeating-linear-gradient(135deg,rgba(255,244,208,.16) 1px 2px,transparent 2px 17px);
}
@keyframes env-float{0%,100%{transform:translateY(var(--env-shift))}
    50%{transform:translateY(calc(var(--env-shift) - 13px))}}

.env-shadow{position:absolute;left:50%;bottom:-9%;width:74%;height:18px;transform:translateX(-50%);
    background:radial-gradient(closest-side,rgba(120,70,72,.4),transparent 75%);
    filter:blur(4px);z-index:0;animation:env-shadow 4s ease-in-out infinite}
@keyframes env-shadow{0%,100%{transform:translateX(-50%) scale(1);opacity:.6}
    50%{transform:translateX(-50%) scale(.82);opacity:.4}}

/* outer rim — a deep antique-gold edge that gives the card real thickness */
.env-back{position:absolute;inset:0;border-radius:12px;z-index:1;
    background:var(--foil-edge);
    box-shadow:0 32px 62px -24px rgba(70,46,14,.7),0 12px 28px -16px rgba(70,46,14,.5)}

/* the inner card that rises out (kept fully behind the front until opened) */
.env-card{position:absolute;left:7%;right:7%;top:9%;bottom:9%;z-index:2;border-radius:7px;
    background:linear-gradient(165deg,var(--paper),#F4E8D6);overflow:hidden;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    box-shadow:0 8px 22px -8px rgba(120,80,30,.5),inset 0 0 0 1px rgba(189,154,82,.42);
    transform:translateY(0);transition:transform 1.05s cubic-bezier(.62,0,.2,1)}
.env-card-mandala{position:absolute;width:170%;left:-35%;top:50%;transform:translateY(-50%);opacity:.16}
.env-card-script{font-family:'Italianno',cursive;font-size:2.4rem;color:var(--rose-deep);
    position:relative;line-height:1}
.env-card-names{font-family:'Bodoni Moda',serif;font-size:.74rem;letter-spacing:.34em;
    text-transform:uppercase;color:var(--gold-deep);margin-top:.5rem;position:relative}

/* solid front face — richly foiled, embossed, fully hides the card while closed */
.env-pocket{position:absolute;inset:0;z-index:4;border-radius:11px;overflow:hidden;
    background:var(--streak),var(--sheen),var(--emboss),var(--striae),var(--foil-body);
    box-shadow:inset 0 2px 5px rgba(255,248,224,.5),inset 0 -20px 44px rgba(120,84,28,.3),
        inset 0 0 0 1px rgba(255,246,214,.28),0 0 0 1px rgba(74,50,18,.5)}
.env-pocket::before,.env-pocket::after{content:"";position:absolute;inset:0}
.env-pocket::before{ /* the two front seams — beveled gold creases rising to centre */
    background:
      linear-gradient(to top right,transparent calc(50% - 1.4px),rgba(86,58,22,.5) 50%,rgba(255,245,210,.5) calc(50% + 1px),transparent calc(50% + 2.6px)) left/50% 100% no-repeat,
      linear-gradient(to top left,transparent calc(50% - 1.4px),rgba(86,58,22,.5) 50%,rgba(255,245,210,.5) calc(50% + 1px),transparent calc(50% + 2.6px)) right/50% 100% no-repeat}
.env-pocket::after{ /* bottom flap plane — a touch deeper than the body */
    clip-path:polygon(0 100%,50% 46%,100% 100%);
    background:linear-gradient(158deg,#CBA75E,#B5903C);opacity:.5}

/* top flap — bright foil with a fine piped gold trim around its edges */
.env-flap{position:absolute;top:0;left:0;width:100%;height:58%;z-index:6;transform-origin:top center;
    background:var(--foil-trim);
    clip-path:polygon(0 0,100% 0,50% 100%);
    box-shadow:0 4px 12px rgba(140,100,34,.35);
    transition:transform .9s cubic-bezier(.6,0,.25,1),z-index 0s .25s}
.env-flap::before{ /* inset body panel — leaves the parent foil showing as piping */
    content:"";position:absolute;inset:clamp(2px,.8vw,3.5px);clip-path:polygon(0 0,100% 0,50% 100%);
    background:var(--streak),var(--emboss),var(--striae),var(--foil-flap)}
.env-flap::after{ /* specular sheen along the top edge */
    content:"";position:absolute;inset:0;clip-path:polygon(0 0,100% 0,50% 100%);pointer-events:none;
    background:radial-gradient(64% 86% at 50% 0,rgba(255,252,236,.5),transparent 60%)}

/* ornate wax seal — a domed rose-wax medallion in a reeded gold ring */
.wax-seal{position:absolute;left:50%;top:42%;width:27%;aspect-ratio:1;transform:translate(-50%,-50%);
    z-index:7;border-radius:50%;display:flex;align-items:center;justify-content:center;
    background:radial-gradient(circle at 38% 30%,#DC8F94 0%,#C2727A 28%,#A4555E 58%,#863F49 100%);
    box-shadow:0 5px 14px rgba(108,44,54,.5),inset 0 2px 5px rgba(255,228,228,.5),inset 0 -7px 14px rgba(92,32,42,.5);
    transition:transform .5s ease,opacity .4s ease}
.wax-seal::before{ /* reeded gold ring radiating around the wax */
    content:"";position:absolute;inset:-26%;border-radius:50%;z-index:-1;
    background:repeating-conic-gradient(from 0deg,#6E4E1E 0 4deg,#EAD08A 4deg 8deg);
    -webkit-mask:radial-gradient(circle,transparent 56%,#000 59%,#000 84%,transparent 88%);
            mask:radial-gradient(circle,transparent 56%,#000 59%,#000 84%,transparent 88%);
    filter:drop-shadow(0 3px 6px rgba(110,70,20,.4))}
.wax-seal::after{ /* ivory keyline hugging the wax — a pearl inlay between wax & ring */
    content:"";position:absolute;inset:-4%;border-radius:50%;pointer-events:none;
    box-shadow:inset 0 0 0 1.5px rgba(255,248,234,.85),inset 0 0 7px rgba(110,45,55,.35)}
.wax-monogram{font-family:'Bodoni Moda',serif;font-weight:600;font-size:clamp(.82rem,3vw,1.05rem);
    color:#F8EAD0;letter-spacing:.02em;position:relative;z-index:1;display:flex;align-items:baseline;gap:.02em;
    text-shadow:0 1px 1px rgba(100,38,48,.6),0 -1px 1px rgba(255,225,225,.25)}
.wax-monogram i{font-size:.6em;font-style:italic;opacity:.85}

/* an inset engraved frame — double gold keyline, beaded rule & corner studs */
.env-frame{position:absolute;inset:6.5%;z-index:6;border-radius:7px;pointer-events:none;
    box-shadow:
      inset 0 0 0 1px rgba(255,248,220,.6),
      inset 0 0 0 2px rgba(96,68,26,.32),
      inset 0 0 0 3.5px rgba(255,246,214,.22);
    transition:opacity .45s ease}
.env-frame::before{ /* beaded inner rule */
    content:"";position:absolute;inset:5px;border-radius:4px;
    background:
      radial-gradient(circle,rgba(120,86,30,.85) .6px,transparent 1.2px) 0 0/6px 2.5px repeat-x,
      radial-gradient(circle,rgba(120,86,30,.85) .6px,transparent 1.2px) 0 100%/6px 2.5px repeat-x,
      radial-gradient(circle,rgba(120,86,30,.85) .6px,transparent 1.2px) 0 0/2.5px 6px repeat-y,
      radial-gradient(circle,rgba(120,86,30,.85) .6px,transparent 1.2px) 100% 0/2.5px 6px repeat-y}
.env-frame::after{ /* gold corner studs */
    content:"";position:absolute;inset:0;border-radius:7px;pointer-events:none;background-repeat:no-repeat;
    background:
      radial-gradient(circle at 7px 7px,#F0D78F 0 2px,#7a5a22 2px 2.8px,transparent 3.2px),
      radial-gradient(circle at calc(100% - 7px) 7px,#F0D78F 0 2px,#7a5a22 2px 2.8px,transparent 3.2px),
      radial-gradient(circle at 7px calc(100% - 7px),#F0D78F 0 2px,#7a5a22 2px 2.8px,transparent 3.2px),
      radial-gradient(circle at calc(100% - 7px) calc(100% - 7px),#F0D78F 0 2px,#7a5a22 2px 2.8px,transparent 3.2px)}

/* opened: flap tips back behind, seal drops, frame fades, card glides up & out */
.envelope.is-open{animation:none;cursor:default;transform:translateY(var(--env-shift))}
.envelope.is-open .env-flap{transform:rotateX(164deg);z-index:1}
.envelope.is-open .env-frame{opacity:0}
.envelope.is-open .wax-seal{opacity:0;transform:translate(-50%,-50%) scale(1.4)}
.envelope.is-open .env-card{transform:translateY(-84%)}

.env-hint{margin-top:2.3rem;font-family:'Poppins',sans-serif;font-size:.74rem;
    letter-spacing:.28em;text-transform:uppercase;color:#7c4f50;display:flex;align-items:center;gap:.6em;
    animation:hint-pulse 2.4s ease-in-out infinite}
.env-hint-dot{width:6px;height:6px;border-radius:50%;background:var(--gold-deep);
    box-shadow:0 0 0 0 rgba(151,113,47,.5);animation:hint-ring 2.4s ease-out infinite}
.envelope.is-open ~ .env-hint{opacity:0;transition:opacity .3s}
@keyframes hint-pulse{0%,100%{opacity:.65}50%{opacity:1}}
@keyframes hint-ring{0%{box-shadow:0 0 0 0 rgba(151,113,47,.45)}70%{box-shadow:0 0 0 10px rgba(151,113,47,0)}100%{box-shadow:0 0 0 0 rgba(151,113,47,0)}}

.confetti-canvas{position:absolute;inset:0;pointer-events:none;z-index:8}

/* ════════════════ MAIN ════════════════ */
.main-content{position:relative;opacity:0;transition:opacity 1.1s ease .35s}
.main-content.visible{opacity:1}

section{position:relative;padding:var(--pad-y) var(--pad-x);text-align:center;overflow:hidden}
.section-title{position:relative;z-index:2}

/* hidden-until-revealed (GSAP drives these) */
[data-animate]{opacity:0}

/* ════════════════ HERO — THE GOLD ARCH ════════════════ */
.hero{
    min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding-top:clamp(70px,12vh,120px);padding-bottom:clamp(54px,9vh,90px);
    background:linear-gradient(178deg,var(--ivory) 0%,#FBEFE9 55%,#F6E3DD 100%);
}
.hero-aura{position:absolute;width:min(120vw,760px);aspect-ratio:1;top:46%;left:50%;
    transform:translate(-50%,-50%);z-index:0;pointer-events:none;
    background:radial-gradient(circle,rgba(231,200,160,.4) 0%,rgba(231,200,160,0) 62%)}
.hero-mandala{position:absolute;width:min(135vw,720px);top:50%;left:50%;
    transform:translate(-50%,-50%);opacity:.10;z-index:0;pointer-events:none}

.arch{
    position:relative;z-index:2;width:min(86vw,440px);
    padding:clamp(7px,1.7vw,11px);
    background:var(--foil);
    border-radius:49% 49% 12px 12px / 33% 33% 3% 3%;
    box-shadow:var(--shadow-gold),0 2px 5px rgba(255,255,255,.4) inset;
}
.arch-inner{
    position:relative;border-radius:47% 47% 7px 7px / 31% 31% 2% 2%;
    background:linear-gradient(176deg,var(--paper) 0%,#FBF1E6 70%,#F7E9DA 100%);
    box-shadow:inset 0 0 0 1px rgba(151,113,47,.35);
    padding:clamp(40px,9vw,64px) clamp(24px,6vw,42px) clamp(34px,7vw,50px);
    overflow:hidden;
}
.arch-rose{position:absolute;z-index:3;width:42%;top:-4%;opacity:.96;pointer-events:none}
.arch-rose-l{left:-9%}
.arch-rose-r{right:-9%;transform:scaleX(-1)}

.hero-ganesha{width:clamp(58px,15vw,82px);margin:0 auto .7rem;opacity:.95}
.hero .eyebrow{margin-bottom:.85rem}
.hero .eyebrow::before{content:none}

.names{display:flex;flex-direction:column;align-items:center;line-height:.8;margin:.1rem 0 .2rem}
.name{font-family:'Italianno',cursive;font-size:clamp(4.2rem,17vw,6.6rem);color:var(--rose-deep);
    letter-spacing:.01em;text-shadow:0 3px 14px rgba(201,135,137,.22)}
.amp{font-family:'Bodoni Moda',serif;font-style:italic;font-weight:500;
    font-size:clamp(1.5rem,5vw,2rem);color:var(--gold-deep);margin:-.18em 0}

.rule{display:flex;align-items:center;justify-content:center;gap:.8rem;margin:1.1rem auto 1.3rem;width:78%}
.rule span{height:1px;flex:1;background:var(--foil-line)}
.rule i{color:var(--gold);font-size:.85rem;font-style:normal}

.hero-kicker{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05rem;
    color:var(--ink-soft);margin-bottom:.5rem;max-width:24em;margin-inline:auto;line-height:1.5}
.hero-occasion{font-family:'Bodoni Moda',serif;font-weight:600;
    font-size:clamp(1.45rem,5.6vw,2.1rem);letter-spacing:.02em;line-height:1.1;margin-bottom:1.2rem}

.hero-when{display:flex;flex-direction:column;gap:.18rem;align-items:center}
.when-day{font-family:'Poppins',sans-serif;font-size:.66rem;letter-spacing:.36em;
    text-transform:uppercase;color:var(--gold-deep);font-weight:500}
.when-date{font-family:'Bodoni Moda',serif;font-size:clamp(1.2rem,4.6vw,1.55rem);font-weight:500;color:var(--ink)}
.when-time{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:var(--ink-soft)}

.scroll-cue{position:relative;z-index:2;margin-top:clamp(30px,6vh,54px);display:flex;flex-direction:column;
    align-items:center;gap:.7rem;text-decoration:none;color:var(--ink-soft)}
.scroll-cue span{font-family:'Poppins',sans-serif;font-size:.6rem;letter-spacing:.4em;text-transform:uppercase}
.scroll-line{width:1px;height:42px;background:linear-gradient(180deg,var(--gold),transparent);
    position:relative;overflow:hidden}
.scroll-line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;
    background:var(--gold-deep);animation:scroll-run 1.9s ease-in-out infinite}
@keyframes scroll-run{0%{top:-55%}60%,100%{top:120%}}

/* ════════════════ INVITATION ════════════════ */
.invite{background:var(--ivory);display:flex;justify-content:center}
.invite-watermark{position:absolute;width:min(130vw,640px);top:50%;left:50%;
    transform:translate(-50%,-50%);opacity:.08;z-index:0;pointer-events:none}
.invite-body{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto}
.invite-greeting{font-family:'Italianno',cursive;font-size:clamp(2.8rem,11vw,4rem);
    color:var(--rose-deep);line-height:1;margin-bottom:1.1rem}
.invite-text{font-family:'Cormorant Garamond',serif;font-size:clamp(1.22rem,3.6vw,1.5rem);
    line-height:1.85;color:var(--ink);max-width:30em;margin:0 auto;font-weight:500}
.invite-text + .invite-text{margin-top:1.1rem}
.invite-text::first-letter{font-family:'Bodoni Moda',serif;font-size:1.15em;color:var(--gold-deep)}
.invite-sign{font-family:'Bodoni Moda',serif;font-style:italic;font-size:1.05rem;
    color:var(--ink-soft);margin-top:1.5rem;letter-spacing:.02em}
.invite-signoff{font-family:'Italianno',cursive;font-size:clamp(2.3rem,9vw,3.1rem);
    color:var(--rose-deep);line-height:1;margin-top:.1rem}

/* ════════════════ COUPLE ════════════════ */
.couple-grid{display:flex;flex-direction:column;align-items:center;gap:clamp(18px,4vw,26px);
    max-width:760px;margin:2.4rem auto 0;position:relative;z-index:2}
.vow-card{
    position:relative;width:min(86vw,330px);background:linear-gradient(176deg,var(--paper),#FAF1E6);
    border-radius:150px 150px 18px 18px;padding:clamp(34px,6vw,46px) 28px clamp(28px,5vw,38px);
    box-shadow:var(--shadow-card);overflow:hidden;
    transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s}
.vow-card::before{content:"";position:absolute;inset:7px 7px auto 7px;height:62%;
    border:1px solid rgba(189,154,82,.4);border-bottom:0;border-radius:140px 140px 0 0;pointer-events:none}
.vow-card:hover{transform:translateY(-7px);box-shadow:0 36px 70px -34px rgba(74,51,46,.5)}
.vow-card-top{display:block;width:34px;height:34px;margin:0 auto 1.1rem;
    background:var(--foil);border-radius:50%;position:relative;box-shadow:var(--shadow-gold)}
.vow-card-top::after{content:"\2767";position:absolute;inset:0;display:flex;align-items:center;
    justify-content:center;color:var(--paper);font-size:1rem}
.vow-role{font-family:'Poppins',sans-serif;font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;
    color:var(--gold-deep)}
.vow-name{font-family:'Italianno',cursive;font-size:clamp(3.2rem,11vw,4.2rem);color:var(--rose-deep);
    line-height:.95;margin:.2rem 0 .5rem}
.vow-rel{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:var(--ink-soft);
    margin-bottom:.35rem}
.vow-parents{font-family:'Bodoni Moda',serif;font-size:1.1rem;font-weight:500;line-height:1.5;color:var(--ink)}

.couple-knot{position:relative;width:74px;height:60px;display:flex;align-items:center;justify-content:center}
.knot-ring{position:absolute;width:38px;height:38px;border-radius:50%;
    border:2.5px solid var(--gold);left:11px;box-shadow:var(--shadow-gold)}
.knot-ring-2{left:auto;right:11px;border-color:var(--gold-light)}
.knot-amp{position:relative;z-index:2;font-family:'Bodoni Moda',serif;font-style:italic;
    font-size:1.5rem;color:var(--gold-deep);text-shadow:0 1px 0 var(--paper)}

/* ════════════════ SAVE THE DATE ════════════════ */
.save{position:relative}
.save-peacock{position:absolute;width:min(96vw,460px);top:50%;left:50%;
    transform:translate(-50%,-50%);opacity:.2;z-index:0;pointer-events:none}
.save-hint{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.1rem;
    color:rgba(255,248,240,.92);margin-bottom:1.7rem;position:relative;z-index:2}
.scratch-wrap{position:relative;width:min(82vw,330px);aspect-ratio:11/9;margin:0 auto;
    border-radius:18px;overflow:hidden;z-index:2;
    box-shadow:0 30px 60px -28px rgba(90,40,42,.6),0 0 0 1px rgba(255,255,255,.35),inset 0 0 0 1px rgba(189,154,82,.4)}
.scratch-reveal{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
    justify-content:center;color:var(--ink);
    background:linear-gradient(165deg,#FFFDF8,#F6E8D4);padding:18px}
.sr-day{font-family:'Poppins',sans-serif;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;
    color:var(--gold-deep);font-weight:500}
.sr-num{font-family:'Bodoni Moda',serif;font-weight:700;font-size:clamp(4.4rem,20vw,6rem);line-height:.86;
    color:var(--rose-deep);margin:.12rem 0}
.sr-my{font-family:'Bodoni Moda',serif;font-size:1.25rem;font-weight:500;letter-spacing:.02em}
.sr-div{color:var(--gold);font-size:.7rem;margin:.5rem 0}
.sr-time{font-family:'Poppins',sans-serif;font-size:.78rem;letter-spacing:.06em}
.sr-venue{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05rem;color:var(--ink-soft);margin-top:.1rem}
.scratch-canvas{position:absolute;inset:0;width:100%;height:100%;cursor:grab;touch-action:none}
.scratch-canvas:active{cursor:grabbing}

/* ════════════════ COUNTDOWN ════════════════ */
.countdown{background:linear-gradient(178deg,var(--ivory-deep),var(--ivory))}
.count-mandala{position:absolute;width:min(120vw,600px);top:50%;left:50%;
    transform:translate(-50%,-50%);opacity:.07;z-index:0;pointer-events:none}
.count-grid{display:flex;justify-content:center;gap:clamp(8px,2.4vw,16px);margin-top:2.2rem;
    position:relative;z-index:2;flex-wrap:nowrap}
.count-cell{position:relative;flex:1 1 0;max-width:108px;min-width:0;
    background:linear-gradient(176deg,var(--paper),#FBF2E6);
    border-radius:14px;padding:clamp(14px,3.4vw,22px) 4px clamp(10px,2.4vw,15px);
    box-shadow:var(--shadow-soft);overflow:hidden}
.count-cell::before{content:"";position:absolute;inset:5px;border:1px solid rgba(189,154,82,.3);
    border-radius:9px;pointer-events:none}
.count-cell::after{content:"";position:absolute;left:0;right:0;top:50%;height:1px;
    background:rgba(151,113,47,.14)}
.count-num{font-family:'Bodoni Moda',serif;font-weight:600;font-size:clamp(1.9rem,8vw,3rem);
    line-height:1;color:var(--rose-deep);display:block;position:relative;font-variant-numeric:tabular-nums}
.count-tag{font-family:'Poppins',sans-serif;font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;
    color:var(--ink-soft);margin-top:.7rem;display:block;position:relative}
.count-done{font-family:'Italianno',cursive;font-size:clamp(2.6rem,9vw,3.6rem);color:var(--rose-deep);
    margin-top:1.6rem;position:relative;z-index:2}

/* ════════════════ SCHEDULE ════════════════ */
.timeline{list-style:none;max-width:430px;margin:2.4rem auto 0;position:relative;z-index:2;
    text-align:left;display:flex;flex-direction:column;gap:18px}
.tl-item{display:grid;grid-template-columns:64px 26px 1fr;align-items:center;gap:14px;position:relative;
    background:rgba(255,250,244,.16);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);
    border:1px solid rgba(255,248,240,.32);border-radius:16px;padding:16px 18px;
    transition:transform .4s,background .4s}
.tl-item:hover{transform:translateX(6px);background:rgba(255,250,244,.24)}
.tl-item:not(:last-child)::after{content:"";position:absolute;left:90px;
    top:100%;width:1px;height:18px;background:linear-gradient(var(--gold-light),transparent)}
.tl-time{font-family:'Bodoni Moda',serif;font-weight:600;font-size:1.5rem;color:var(--on-dark);
    line-height:1;white-space:nowrap;text-align:right;min-width:60px}
.tl-time i{font-style:normal;font-family:'Poppins',sans-serif;font-size:.55rem;letter-spacing:.12em;
    text-transform:uppercase;display:block;opacity:.8;margin-top:.2rem}
.tl-marker{width:13px;height:13px;border-radius:50%;background:var(--foil);justify-self:center;
    box-shadow:0 0 0 4px rgba(255,248,240,.28)}
.tl-title{font-family:'Bodoni Moda',serif;font-size:1.18rem;font-weight:500;color:var(--on-dark);display:block}
.tl-note{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;
    color:rgba(255,248,240,.82);display:block;margin-top:.1rem}

/* ════════════════ VENUE ════════════════ */
.venue{background:linear-gradient(178deg,var(--ivory),var(--ivory-deep))}
.venue-card{position:relative;z-index:2;max-width:430px;margin:2.4rem auto 0;
    background:linear-gradient(176deg,var(--paper),#FAF1E6);border-radius:140px 140px 22px 22px;
    padding:clamp(34px,6vw,46px) clamp(22px,5vw,32px) clamp(26px,5vw,34px);
    box-shadow:var(--shadow-card);overflow:hidden}
.venue-card::before{content:"";position:absolute;inset:7px 7px auto 7px;height:120px;
    border:1px solid rgba(189,154,82,.38);border-bottom:0;border-radius:130px 130px 0 0;pointer-events:none}
.venue-card-top{display:block;width:30px;height:1px;background:var(--foil-line);margin:0 auto 1rem}
.venue-kicker{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:var(--ink-soft)}
.venue-name{font-family:'Bodoni Moda',serif;font-weight:600;font-size:clamp(1.7rem,6vw,2.3rem);
    color:var(--ink);line-height:1.05;margin:.15rem 0 .35rem}
.venue-addr{font-family:'Poppins',sans-serif;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
    color:var(--gold-deep);margin-bottom:1.4rem}
.venue-map{border-radius:14px;overflow:hidden;border:1px solid rgba(189,154,82,.3);margin-bottom:1.4rem;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.4)}
.venue-map iframe{width:100%;height:200px;border:0;display:block;filter:saturate(.92)}

/* ════════════════ DRESS ════════════════ */
.dress-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.12rem;color:var(--ink-soft);
    margin-bottom:2.2rem;position:relative;z-index:2}
.dress-grid{display:flex;flex-direction:column;gap:clamp(16px,3vw,22px);max-width:680px;
    margin:0 auto;position:relative;z-index:2}
.dress-card{background:linear-gradient(176deg,var(--paper),#FAF1E6);border-radius:20px;
    padding:clamp(28px,5vw,38px) 26px;box-shadow:var(--shadow-card);
    transition:transform .45s cubic-bezier(.22,1,.36,1)}
.dress-card:hover{transform:translateY(-6px)}
.dress-for{font-family:'Poppins',sans-serif;font-size:.64rem;letter-spacing:.32em;text-transform:uppercase;
    color:var(--gold-deep);margin-bottom:1.2rem}
.swatches{display:flex;justify-content:center;margin-bottom:1.1rem}
.swatch{width:46px;height:46px;border-radius:50%;background:var(--c);margin:0 -8px;
    box-shadow:0 6px 16px -8px rgba(74,51,46,.5),inset 0 0 0 2px rgba(255,255,255,.7);
    position:relative}
.swatch-gold{background:var(--foil)}
.dress-names{font-family:'Bodoni Moda',serif;font-weight:500;font-size:1.5rem;color:var(--ink);
    margin-bottom:.3rem}
.dress-note{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.08rem;color:var(--ink-soft)}

/* ════════════════ CLOSING ════════════════ */
.closing{background:linear-gradient(178deg,var(--ivory) 0%,#F7E7E3 55%,#F1D9D6 100%);
    padding-bottom:calc(var(--pad-y) + 30px)}
.closing-mandala{position:absolute;width:min(130vw,680px);top:50%;left:50%;
    transform:translate(-50%,-50%);opacity:.09;z-index:0;pointer-events:none}
.closing-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto}
.closing-ganesha{width:clamp(70px,18vw,96px);margin:0 auto 1.4rem;opacity:.95}
.closing-quote{font-family:'Bodoni Moda',serif;font-style:italic;font-weight:500;
    font-size:clamp(1.4rem,5.2vw,2rem);line-height:1.42;color:var(--ink);
    max-width:18em;margin:0 auto 2rem}
.closing-cta{display:flex;flex-direction:column;align-items:center;gap:.9rem;margin-bottom:.4rem}
.closing-names{font-family:'Italianno',cursive;font-size:clamp(3.8rem,15vw,5.6rem);
    color:var(--rose-deep);line-height:1;margin-top:.5rem}
.closing-date{font-family:'Bodoni Moda',serif;font-size:1.1rem;letter-spacing:.5em;
    color:var(--gold-deep);font-weight:500;margin:.4rem 0 1.1rem;padding-left:.5em}
.closing-thanks{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.15rem;
    color:var(--ink-soft)}

/* ════════════════ MUSIC ════════════════ */
.music-toggle{position:fixed;bottom:clamp(18px,4vw,28px);right:clamp(18px,4vw,28px);z-index:60;
    width:50px;height:50px;border-radius:50%;border:1px solid var(--gold);cursor:pointer;
    background:linear-gradient(176deg,var(--paper),#F6E8D4);box-shadow:var(--shadow-gold);
    display:flex;align-items:center;justify-content:center;transition:transform .35s}
.music-toggle:hover{transform:scale(1.08)}
.music-bars{display:flex;align-items:flex-end;gap:2.5px;height:17px}
.music-bars i{width:2.5px;height:40%;background:var(--gold-deep);border-radius:2px}
.music-toggle.playing .music-bars i{animation:eq .9s ease-in-out infinite}
.music-toggle.playing .music-bars i:nth-child(2){animation-delay:.18s}
.music-toggle.playing .music-bars i:nth-child(3){animation-delay:.36s}
.music-toggle.playing .music-bars i:nth-child(4){animation-delay:.12s}
@keyframes eq{0%,100%{height:30%}50%{height:100%}}

/* ════════════════ RESPONSIVE ════════════════ */
@media(min-width:720px){
    .couple-grid{flex-direction:row;justify-content:center;align-items:stretch}
    .vow-card{flex:1 1 0;max-width:320px}
    .couple-knot{align-self:center;flex:0 0 auto}
    .dress-grid{flex-direction:row}
    .dress-card{flex:1 1 0}
    .count-cell{max-width:124px}
}
@media(min-width:1024px){
    :root{--maxw:720px}
    .arch{width:min(44vw,416px)}
    .hero{padding-top:clamp(58px,8vh,92px)}
    .hero-occasion{font-size:2.1rem}
    .name{font-size:6rem}
}

/* ════════════════ MOTION SAFETY ════════════════ */
@media(prefers-reduced-motion:reduce){
    *{animation-duration:.001ms!important;animation-iteration-count:1!important;
        transition-duration:.001ms!important;scroll-behavior:auto!important}
    .petals-overlay,.env-petals,.petal{display:none!important}
    [data-animate]{opacity:1!important;transform:none!important}
    .main-content{opacity:1}
}
