:root{
    --blush:#f8b7c8;
    --blush-soft:#fff0f5;
    --blush-pale:#fff8fb;
    --blush-deep:#bd5877;
    --rose:#8d4058;
    --champagne:#fff4ec;
    --cream:#fffaf7;
    --sage:#809c7c;
    --sage-soft:#edf7eb;
    --ink:#46313a;
    --muted:#876775;
    --shadow:0 24px 70px rgba(180,85,115,.17);
    --soft-shadow:0 12px 34px rgba(180,85,115,.10);
    --radius:30px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;min-height:100%}
body{
    margin:0;
    font-family:Georgia,"Times New Roman",serif;
    color:var(--ink);
    background:#fff7fa;
    overflow-x:hidden;
    min-height:100%;
}
body::before{
    content:"";
    position:fixed;
    inset:0;
    z-index:-3;
    background:
        radial-gradient(circle at 10% 8%, rgba(248,183,200,.20), transparent 24%),
        radial-gradient(circle at 90% 12%, rgba(255,226,234,.50), transparent 30%),
        radial-gradient(circle at 50% 100%, rgba(255,244,236,.95), transparent 45%),
        linear-gradient(135deg,#fffafb,#fff3f7 48%,#fffaf7);
}
body::after{
    content:"";
    position:fixed;
    inset:0;
    z-index:-2;
    opacity:.34;
    pointer-events:none;
    background-image:url('../img/blush-floral-pattern.svg');
    background-size:min(500px,95vw);
    background-position:center;
}
a{color:inherit}
.muted{color:var(--muted)}

/* HEADER */
.site-header{
    position:fixed;
    top:14px;
    left:50%;
    transform:translateX(-50%);
    width:min(1120px,calc(100% - 24px));
    z-index:1000;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    padding:10px 14px;
    border:1px solid rgba(255,255,255,.78);
    border-radius:999px;
    background:rgba(255,255,255,.76);
    backdrop-filter:blur(18px);
    box-shadow:0 18px 45px rgba(160,70,95,.12);
    transition:.35s ease;
}
body.landing-active .site-header{
    opacity:0;
    visibility:hidden;
    transform:translateX(-50%) translateY(-15px);
    pointer-events:none;
}
.nav{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    flex-wrap:wrap;
}
.nav a,
.music-button{
    border:0;
    background:transparent;
    text-decoration:none;
    cursor:pointer;
    color:var(--rose);
    font:800 12px/1 Arial,sans-serif;
    letter-spacing:.08em;
    text-transform:uppercase;
    padding:10px 12px;
    border-radius:999px;
}
.nav a:hover,
.music-button:hover{background:var(--blush-soft);color:var(--blush-deep)}
.nav-toggle{display:none}
.mobile-nav-toggle{display:none}

/* MUSIC BUTTON DESKTOP */
.music-button{
    position:fixed;
    top:14px;
    right:14px;
    width:52px;
    height:52px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    z-index:1002;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(14px);
    box-shadow:0 10px 25px rgba(180,85,115,.22);
    padding:0;
    margin:0;
    font-size:0;
}
.music-button::before{
    content:'♫';
    font-size:24px;
    color:var(--blush-deep);
    line-height:1;
}
body.landing-active .music-button{opacity:0;visibility:hidden;pointer-events:none}

/* LANDING */
.landing{
    position:fixed;
    inset:0;
    z-index:9999;
    display:grid;
    place-items:center;
    padding:22px;
    background:
        radial-gradient(circle at 50% 38%, rgba(255,255,255,.96), rgba(255,243,247,.92) 42%, rgba(255,250,247,.98)),
        linear-gradient(135deg,#fffafd,#fff2f6 58%,#fff8ef);
    transition:1s ease;
    overflow:hidden;
}
.landing.hide{opacity:0;visibility:hidden;pointer-events:none}
.landing-florals::before,
.landing-florals::after{
    content:"";
    position:absolute;
    width:min(520px,72vw);
    height:min(520px,72vw);
    background:url('../img/blush-corner.svg') center/contain no-repeat;
    animation:flowerGrow 1.7s cubic-bezier(.2,.8,.2,1) both;
    opacity:.92;
}
.landing-florals::before{left:-92px;top:-96px}
.landing-florals::after{right:-92px;bottom:-96px;transform:rotate(180deg);animation-delay:.2s}
@keyframes flowerGrow{
    from{opacity:0;transform:scale(.55) rotate(-8deg)}
    to{opacity:1;transform:scale(1) rotate(0)}
}
.envelope-wrap{
    position:relative;
    z-index:2;
    display:grid;
    place-items:center;
    width:100%;
    min-height:100svh;
}
.wedding-envelope{
    position:relative;
    width:min(620px,88vw);
    height:min(390px,58vh);
    min-height:290px;
    cursor:pointer;
    perspective:1200px;
    filter:drop-shadow(0 30px 55px rgba(170,75,105,.22));
}
.env-back,.env-front,.env-left,.env-right,.env-flap{position:absolute;inset:0}
.env-back{border-radius:24px;background:linear-gradient(135deg,#fff,#ffe5ec);border:2px solid rgba(200,95,126,.14)}
.env-front{top:46%;height:54%;border-radius:0 0 24px 24px;background:linear-gradient(135deg,#ffe9ef,#fff8fa);clip-path:polygon(0 0,50% 58%,100% 0,100% 100%,0 100%);z-index:5;border-bottom:2px solid rgba(200,95,126,.12)}
.env-left{background:linear-gradient(135deg,#fff1f5,#ffe1ea);clip-path:polygon(0 0,50% 50%,0 100%);z-index:4;border-radius:24px}
.env-right{background:linear-gradient(225deg,#fff1f5,#ffe1ea);clip-path:polygon(100% 0,50% 50%,100% 100%);z-index:4;border-radius:24px}
.env-flap{height:56%;transform-origin:top center;background:linear-gradient(180deg,#fff7fa,#ffdce6);clip-path:polygon(0 0,100% 0,50% 100%);z-index:7;transition:1s cubic-bezier(.2,.8,.2,1);border-radius:24px 24px 0 0}
.env-letter{
    position:absolute;
    left:8%;right:8%;top:12%;height:58%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:10px;
    text-align:center;
    border-radius:22px;
    background:rgba(255,255,255,.91);
    border:1px solid rgba(247,169,189,.32);
    z-index:2;
    transition:1.1s ease;
    padding:18px;
}
.env-letter small{font:800 12px/1.4 Arial,sans-serif;letter-spacing:.22em;text-transform:uppercase;color:var(--sage)}
.env-letter strong{font-size:clamp(36px,7vw,70px);color:var(--blush-deep);line-height:1}
.env-letter span{color:var(--rose);font-weight:700}
.open-envelope{position:absolute;left:50%;bottom:32px;transform:translateX(-50%);z-index:9;border:0;border-radius:999px;padding:15px 48px;background:linear-gradient(135deg,var(--blush-deep),var(--blush));color:#fff;font:900 14px/1 Arial,sans-serif;letter-spacing:.28em;box-shadow:0 18px 38px rgba(200,95,126,.28);cursor:pointer}
.wedding-envelope.open .env-flap{transform:rotateX(178deg);z-index:1}
.wedding-envelope.open .env-letter{transform:translateY(-92px);z-index:6}

/* THREE LINE NAMES */
.three-line-couple,
.three-line-title{
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    text-align:center!important;
    line-height:.92!important;
    gap:2px!important;
    width:100%!important;
}
.three-line-couple span,
.three-line-title span{display:block!important;width:100%!important}
.three-line-couple em,
.three-line-title em{display:block!important;font-style:normal!important;font-size:.55em!important;line-height:1!important;opacity:.9}

/* GENERAL SECTIONS */
main{position:relative}
.section{position:relative;padding:96px 20px 70px;display:block}
.hero{min-height:calc(100svh - 30px);display:grid;place-items:center;padding-top:118px}
.hero-card,
.couple-side,
.detail-card,
.timeline article,
.gallery-card,
.entourage article,
.gifts>p,
.rsvp-dialog{
    background:rgba(255,255,255,.78);
    border:1px solid rgba(255,255,255,.84);
    box-shadow:var(--shadow);
    border-radius:var(--radius);
    backdrop-filter:blur(16px);
}
.hero-card{
    width:min(900px,100%);
    text-align:center;
    padding:clamp(38px,7vh,70px) clamp(20px,5vw,46px);
    position:relative;
    overflow:visible;
}
.hero-card::before,
.hero-card::after{
    content:"";
    position:absolute;
    width:210px;
    height:210px;
    background:url('../img/blush-spray.svg') center/contain no-repeat;
    opacity:.62;
    pointer-events:none;
}
.hero-card::before{left:-64px;top:-64px}
.hero-card::after{right:-64px;bottom:-64px;transform:rotate(180deg)}
.eyebrow,
.section-title span{font:900 12px/1.4 Arial,sans-serif;letter-spacing:.25em;text-transform:uppercase;color:var(--sage)}
.hero h1{font-size:clamp(48px,9vw,108px);line-height:.94;margin:18px 0 12px;color:var(--blush-deep);font-weight:400}
.floral-divider{font-size:28px;color:var(--blush);margin:8px auto 18px}
.intro{font-size:clamp(16px,2.2vw,23px);line-height:1.65;max-width:720px;margin:0 auto;color:#6d4d59}
.date-card{margin:28px auto 14px;width:min(450px,100%);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;padding:18px;border-radius:26px;background:#fff6f8;border:1px solid #ffd9e3}
.date-card span{font:900 12px/1.3 Arial,sans-serif;text-transform:uppercase;letter-spacing:.15em;color:var(--rose)}
.date-card strong{font-size:clamp(52px,8vw,72px);color:var(--blush-deep);line-height:1}
.time{font-weight:900;color:var(--rose);letter-spacing:.1em;text-transform:uppercase}
.venue strong{display:block;font-size:clamp(22px,3vw,28px);color:var(--ink)}
.venue span{display:block;color:var(--muted);margin-top:8px}
.venue-map-link{color:inherit;text-decoration:none;font:inherit}
.venue-map-link:hover{text-decoration:underline;text-underline-offset:5px}
.button{display:inline-flex;align-items:center;justify-content:center;margin-top:22px;padding:15px 38px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--blush-deep),var(--blush));color:#fff;text-decoration:none;font:900 12px/1 Arial,sans-serif;letter-spacing:.18em;text-transform:uppercase;box-shadow:0 18px 36px rgba(200,95,126,.25);cursor:pointer}
.section-title{text-align:center;margin-bottom:clamp(24px,5vh,48px)}
.section-title h2{font-weight:400;font-size:clamp(40px,6vw,72px);line-height:1;margin:10px 0 0;color:var(--blush-deep)}

/* COUNTDOWN */
.countdown{width:min(900px,100%);margin:26px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.hero-card>.countdown{margin-top:28px}
.countdown div,
.quick-links a{background:rgba(255,255,255,.74);border:1px solid #ffe0e8;border-radius:24px;padding:18px;text-align:center;box-shadow:var(--soft-shadow)}
.countdown strong{display:block;font-size:30px;color:var(--blush-deep)}
.countdown span{font:900 11px Arial;text-transform:uppercase;color:var(--muted);letter-spacing:.13em}

/* COUPLE */
.couple-photo-wrap{width:min(1050px,100%);margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center}
.couple-side{text-align:center;padding:24px}
.portrait{width:min(240px,70vw);height:min(310px,46vh);margin:auto;border-radius:170px 170px 32px 32px;background:#fff0f4 center/cover no-repeat;border:8px solid #fff;box-shadow:0 18px 42px rgba(180,85,115,.18)}
.couple-side h3{font-size:clamp(30px,5vw,40px);color:var(--rose);margin:18px 0 8px}
.couple-side p{color:var(--muted);font-size:16px;line-height:1.6}
.heart{width:66px;height:66px;display:grid;place-items:center;border-radius:50%;background:#fff0f4;color:var(--blush-deep);box-shadow:var(--shadow);font-size:30px}

/* QUICK LINKS */
.quick-links{width:min(1120px,calc(100% - 40px));margin:30px auto 70px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.quick-links a{text-decoration:none;min-height:180px;display:flex;flex-direction:column;justify-content:center}
.quick-links strong{display:block;color:var(--rose);font-size:24px}
.quick-links small{color:var(--muted);margin-top:8px}

/* JOURNEY */
.timeline{width:min(900px,100%);margin:0 auto;display:grid;gap:18px;padding:4px}
.timeline article{padding:25px}
.timeline time{color:var(--blush-deep);font-weight:900}
.timeline h3,
.detail-card h3,
.gallery-card h3,
.entourage h3{color:var(--rose);font-size:clamp(24px,4vw,30px);margin:8px 0}
.timeline p,
.detail-card p,
.gallery-card p,
.entourage p,
.gifts p{color:var(--muted);line-height:1.6;font-size:16px}

/* DETAILS */
.details-grid{width:min(1120px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:4px}
.detail-card{padding:22px;overflow:hidden}
.detail-card img{width:100%;height:180px;object-fit:cover;border-radius:22px;margin-bottom:14px}
.attire-reminder{background:#fff0f4;color:var(--blush-deep)!important;padding:13px;border-radius:18px;font-weight:900}
.attire-palette{display:flex;gap:9px;flex-wrap:wrap}
.attire-palette span{display:inline-flex;gap:8px;align-items:center;background:#fff7f9;border:1px solid #ffdbe5;border-radius:999px;padding:9px 12px;color:var(--rose);font:900 12px Arial}
.attire-palette i{width:19px;height:19px;border-radius:50%;display:block;border:1px solid rgba(0,0,0,.12)}

/* ENTOURAGE */
.entourage,
.entourage .section-title,
.entourage-grid,
.entourage-grid article,
.entourage-grid h3,
.entourage-grid p,
.principal-grid,
.principal-item{text-align:center}
.entourage-grid{width:min(1120px,100%);margin:0 auto;display:grid;gap:18px;padding:4px}
.program-group{display:grid;gap:16px}
.program-group.two{grid-template-columns:repeat(2,1fr)}
.program-group.three{grid-template-columns:repeat(3,1fr)}
.entourage article{padding:22px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.entourage-grid article h3{display:flex;align-items:center;justify-content:center;gap:8px}
.entourage-grid article h3::before{content:"♡";color:#c96f91;font-size:18px;line-height:1}
.program-heading{display:flex;align-items:center;justify-content:center;gap:10px;text-align:center;width:100%;margin:24px 0 4px!important}
.program-heading::before,
.program-heading::after{content:"✿";color:#d88aa7;font-size:20px;line-height:1}
.principal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;justify-items:center}
.principal-item{display:flex;gap:8px;align-items:center;justify-content:center;background:rgba(255,255,255,.74);border:1px solid #ffe0e8;border-radius:18px;padding:14px;width:100%}
.principal-item span{color:#c96f91;font-weight:900}
.principal-item p::before{content:"❀ ";color:#d88aa7}
.flower-girl-group{display:grid!important;grid-template-columns:minmax(260px,520px)!important;justify-content:center!important}
.flower-girl-card{text-align:center!important;position:relative!important}
.flower-girl-card::before{content:"❀";display:block;font-size:30px;margin-bottom:6px;color:#c96f91}

/* GALLERY */
.gallery-grid{width:min(1120px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:4px}
.gallery-card{overflow:hidden}
.gallery-card img,
.gallery-art{width:100%;height:200px;object-fit:cover;display:block;background:#fff0f4}
.gallery-card div{padding:20px}

/* GIFTS */
.gifts{text-align:center}
.gifts>p{width:min(760px,100%);margin:0 auto;padding:34px;font-size:clamp(18px,3vw,22px)!important}

/* RSVP */
.rsvp-modal{position:fixed;inset:0;z-index:2000;background:rgba(70,40,50,.50);display:none;place-items:center;padding:18px;overflow:auto}
.rsvp-modal:target{display:grid}
.rsvp-dialog{width:min(760px,100%);padding:28px;max-height:none;overflow:visible}
.modal-close{float:right;text-decoration:none;font-size:36px;color:var(--rose);line-height:1}
.rsvp-form{display:grid;grid-template-columns:1fr 1fr;gap:15px;overflow:visible}
.rsvp-form label{font:900 12px Arial;color:var(--rose);text-transform:uppercase;letter-spacing:.1em}
.field-note{display:block;margin-top:6px;color:var(--muted);font:700 11px/1.3 Arial;text-transform:none;letter-spacing:0}
.rsvp-form input,
.rsvp-form select,
.rsvp-form textarea{width:100%;margin-top:8px;border:1px solid #ffd7e1;border-radius:16px;padding:14px;background:#fff;color:var(--ink);font:16px Arial}
.wide{grid-column:1/-1}
.guest-fields{overflow:visible}
.rsvp-form .button,
.rsvp-form button[type="submit"]{display:flex;margin:18px auto 0;align-items:center;justify-content:center;text-align:center;width:min(260px,100%)}
.form-status{font-weight:900;color:var(--blush-deep)}

/* FOOTER */
footer{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:70px 20px;background:rgba(255,255,255,.46);color:var(--muted)}
footer blockquote{font-size:clamp(24px,4vw,34px);color:var(--rose);margin:0 0 8px}
.reveal{opacity:0;transform:translateY(24px);transition:.8s ease}
.reveal.visible{opacity:1;transform:none}

/* TABLET */
@media(max-width:900px){
    .section{padding:92px 16px 48px}
    .hero{min-height:100svh;padding:92px 14px 30px}
    .hero-card{padding:42px 20px}
    .hero-card::before,.hero-card::after{width:150px;height:150px}
    .date-card{grid-template-columns:1fr;gap:8px}
    .couple-photo-wrap,
    .details-grid,
    .gallery-grid,
    .program-group.two,
    .program-group.three,
    .principal-grid,
    .quick-links{grid-template-columns:1fr;max-height:none;overflow:visible}
    .heart{margin:auto}
    .countdown{grid-template-columns:repeat(2,1fr)}
    .rsvp-form{grid-template-columns:1fr}
    .quick-links{min-height:auto;padding:45px 0}
    .quick-links a{min-height:130px}
    .portrait{height:320px}
    .details-grid,.gallery-grid,.entourage-grid,.timeline{padding:0}
}

/* MOBILE FLOATING NAV - BOTTOM, ONE LINE, SCROLLABLE */
@media(max-width:768px){
    body:not(.landing-active){
        padding-bottom:118px;
    }

    body.landing-active .site-header,
    body.landing-active .mobile-nav-toggle,
    body.landing-active .music-button{
        opacity:0!important;
        visibility:hidden!important;
        pointer-events:none!important;
    }

    .site-header{
        position:fixed!important;
        top:auto!important;
        bottom:16px!important;
        left:12px!important;
        right:118px!important;
        transform:none!important;

        width:auto!important;
        max-width:none!important;
        min-height:auto!important;

        padding:0!important;
        margin:0!important;

        border:0!important;
        border-radius:0!important;

        background:transparent!important;
        box-shadow:none!important;
        backdrop-filter:none!important;

        display:block!important;

        z-index:10000!important;

        pointer-events:none!important;
    }

    .site-header .nav{
        pointer-events:auto!important;

        display:flex!important;
        flex-direction:row!important;
        align-items:center!important;
        justify-content:flex-start!important;
        flex-wrap:nowrap!important;

        width:100%!important;
        max-width:100%!important;

        gap:8px!important;

        padding:10px!important;

        overflow-x:auto!important;
        overflow-y:hidden!important;

        white-space:nowrap!important;

        border-radius:999px!important;

        background:rgba(255,247,249,.95)!important;
        border:1px solid rgba(216,138,167,.34)!important;
        box-shadow:0 18px 44px rgba(154,71,103,.22)!important;
        backdrop-filter:blur(18px)!important;

        scrollbar-width:none!important;
        -webkit-overflow-scrolling:touch!important;

        opacity:1!important;
        visibility:visible!important;

        transform:translateY(0)!important;
        transition:.28s ease!important;
    }

    .site-header .nav::-webkit-scrollbar{
        display:none!important;
    }

    .site-header .nav a{
        flex:0 0 48px!important;

        width:48px!important;
        height:48px!important;
        min-width:48px!important;

        padding:0!important;
        margin:0!important;

        display:grid!important;
        place-items:center!important;

        border-radius:50%!important;

        font-size:0!important;
        line-height:1!important;

        background:rgba(255,255,255,.72)!important;
        color:#9b4f68!important;

        border:1px solid rgba(216,138,167,.18)!important;
        box-shadow:0 8px 16px rgba(154,71,103,.10)!important;

        text-decoration:none!important;
    }

    .site-header .nav a::before{
        content:attr(data-icon);
        font-size:21px!important;
        line-height:1!important;
        font-family:Georgia,'Times New Roman',serif!important;
    }

    .site-header .nav a:active,
    .site-header .nav a:hover{
        transform:translateY(-2px)!important;
        background:#fff!important;
        color:#c96f91!important;
    }

    .mobile-nav-toggle{
        display:grid!important;
        place-items:center!important;

        position:fixed!important;
        right:16px!important;
        bottom:22px!important;

        width:48px!important;
        height:48px!important;

        padding:0!important;
        margin:0!important;

        border:0!important;
        border-radius:50%!important;

        background:linear-gradient(135deg,#c96f91,#e3a3b8)!important;
        color:#fff!important;

        font-size:24px!important;
        line-height:1!important;

        box-shadow:0 14px 30px rgba(154,71,103,.30)!important;

        z-index:10002!important;

        pointer-events:auto!important;
    }

    .music-button{
        position:fixed!important;

        right:16px!important;
        bottom:78px!important;

        top:auto!important;
        left:auto!important;

        transform:none!important;

        width:48px!important;
        height:48px!important;
        min-width:48px!important;

        padding:0!important;
        margin:0!important;

        display:grid!important;
        place-items:center!important;

        border:0!important;
        border-radius:50%!important;

        background:rgba(255,247,249,.96)!important;
        color:#9b4f68!important;

        box-shadow:0 14px 30px rgba(154,71,103,.18)!important;
        backdrop-filter:blur(14px)!important;

        font-size:0!important;

        z-index:10002!important;

        pointer-events:auto!important;
    }

    .music-button::before{
        content:"♪";
        font-size:23px!important;
        line-height:1!important;
        color:#bd5877!important;
    }

    body.mobile-nav-hidden .site-header .nav{
        transform:translateY(24px)!important;
        opacity:0!important;
        visibility:hidden!important;
        pointer-events:none!important;
    }

    body.mobile-nav-hidden .mobile-nav-toggle{
        background:linear-gradient(135deg,#9b4f68,#c96f91)!important;
        font-size:0!important;
    }

    body.mobile-nav-hidden .mobile-nav-toggle::before{
        content:"☰";
        font-size:22px!important;
        line-height:1!important;
    }

    .three-line-title{
        font-size:clamp(46px,16vw,76px)!important;
    }

    .three-line-couple{
        font-size:clamp(24px,9vw,42px)!important;
    }

    .wedding-envelope{
        width:92vw;
        height:300px;
        min-height:260px;
    }

    .env-letter strong{
        font-size:40px;
        line-height:1.1;
        text-align:center;
    }

    .open-envelope{
        bottom:26px;
        padding:14px 36px;
    }

    .landing-florals::before{
        left:-150px;
        top:-130px;
    }

    .landing-florals::after{
        right:-150px;
        bottom:-130px;
    }

    .rsvp-modal{
        padding:16px 12px;
    }

    .rsvp-dialog{
        padding:22px 16px;
    }
}

/* SMALL PHONE */
@media(max-width:480px){
    .hero h1{
        font-size:44px;
    }

    .section-title h2{
        font-size:38px;
    }

    .date-card strong{
        font-size:48px;
    }

    .countdown div{
        padding:14px;
    }

    .wedding-envelope{
        height:270px;
    }

    .env-letter small{
        font-size:10px;
    }

    .env-letter span{
        font-size:13px;
    }

    .open-envelope{
        font-size:12px;
        letter-spacing:.22em;
    }

    .gallery-card img,
    .gallery-art{
        height:170px;
    }

    .site-header{
        left:10px!important;
        right:108px!important;
        bottom:14px!important;
    }

    .site-header .nav{
        display:flex!important;
        flex-wrap:nowrap!important;
        gap:7px!important;
        padding:9px!important;
        border-radius:999px!important;
        overflow-x:auto!important;
        overflow-y:hidden!important;
        white-space:nowrap!important;
    }

    .site-header .nav a{
        flex:0 0 44px!important;
        width:44px!important;
        height:44px!important;
        min-width:44px!important;
        border-radius:50%!important;
    }

    .site-header .nav a::before{
        font-size:19px!important;
    }

    .mobile-nav-toggle{
        right:12px!important;
        bottom:20px!important;
        width:46px!important;
        height:46px!important;
    }

    .music-button{
        right:12px!important;
        bottom:72px!important;
        width:46px!important;
        height:46px!important;
        min-width:46px!important;
    }
}
