/* ══════════════════════════════════════════
   TOKENS
══════════════════════════════════════════ */
:root {
    --ew: 430px;
    --eh: 286px;
    --ew2: 215px;
    --eh2: 143px;
    --sage: #6b9b7a;
    --sage-l: #9dc4ad;
    --sage-p: #d4e8de;
    --sage-d: #4a7a5a;
    --terra: #c8582a;
    --terra-l: #d4724c;
    --terra-p: #f0c8a8;
    --cream: #faf5ee;
    --cream-d: #ede0cc;
    --champ: #e8d5a8;
    --brown: #1e140c;
    --brown-m: #2a1f14;
    --txt: #2c2016;
    --txt-m: #5a4a38;
    --txt-l: #8b7a68;
}
@media (max-width: 520px) {
    :root {
        --ew: 300px;
        --eh: 200px;
        --ew2: 150px;
        --eh2: 100px;
    }
}

*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
html {
    scroll-behavior: smooth;
    overflow-x: hidden;
}
body {
    font-family: "Jost", sans-serif;
    background: var(--cream);
    color: var(--txt);
    overflow-x: hidden;
    cursor: none;
}
img {
    display: block;
    object-fit: cover;
}

/* ══ GRAIN OVERLAY ══ */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 9990;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
    opacity: 0.028;
    animation: grainShift 0.55s steps(2) infinite;
}
@keyframes grainShift {
    0% {
        transform: translate(0, 0);
    }
    25% {
        transform: translate(-2px, -1px);
    }
    50% {
        transform: translate(1px, 2px);
    }
    75% {
        transform: translate(-1px, 1px);
    }
    100% {
        transform: translate(2px, -2px);
    }
}

/* ══ CUSTOM CURSOR ══ */
#cur-dot {
    position: fixed;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--terra);
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%, -50%);
}
#cur-ring {
    position: fixed;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1.5px solid rgba(200, 88, 42, 0.5);
    pointer-events: none;
    z-index: 9998;
    transform: translate(-50%, -50%);
    transition:
        width 0.35s,
        height 0.35s,
        background 0.35s,
        border-color 0.35s;
}
.cg #cur-ring {
    width: 56px;
    height: 56px;
    background: rgba(200, 88, 42, 0.08);
    border-color: var(--terra);
}

/* ══ PROGRESS BAR ══ */
#pgbar {
    position: fixed;
    top: 0;
    left: 0;
    height: 2px;
    width: 0%;
    z-index: 800;
    pointer-events: none;
    background: linear-gradient(90deg, var(--terra), var(--terra-l), var(--champ));
}

/* ══ SCROLL SECTION COUNTER ══ */
#scroll-ctr {
    position: fixed;
    left: 28px;
    bottom: 36px;
    z-index: 300;
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 4px;
    color: var(--txt-l);
    display: flex;
    align-items: center;
    gap: 6px;
    transition: color 0.4s;
}
#scroll-ctr.light {
    color: rgba(250, 245, 238, 0.38);
}
#sc-cur {
    font-family: "Cormorant Garamond", serif;
    font-size: 1.5rem;
    font-weight: 300;
    color: var(--terra);
    line-height: 1;
    transition: color 0.4s;
}
#scroll-ctr.light #sc-cur {
    color: var(--champ);
}
.sc-divider {
    font-size: 0.7rem;
    opacity: 0.4;
}
.sc-tot {
    opacity: 0.4;
}

/* ══ AMBIENT PARTICLES ══ */
.amb-p {
    position: fixed;
    border-radius: 50%;
    pointer-events: none;
    z-index: 2;
    animation: ambFloat linear infinite;
    opacity: 0;
}
@keyframes ambFloat {
    0% {
        transform: translateY(110vh) rotate(0deg);
        opacity: 0;
    }
    5% {
        opacity: var(--op, 0.15);
    }
    95% {
        opacity: var(--op, 0.15);
    }
    100% {
        transform: translateY(-10vh) rotate(var(--rot, 360deg));
        opacity: 0;
    }
}

/* ══════════════════════════════════════════
   PASSWORD SCREEN
══════════════════════════════════════════ */
#pwd-screen {
    position: fixed;
    inset: 0;
    z-index: 2000;
    background: radial-gradient(ellipse at 40% 45%, #2a1f14 0%, #1e140c 55%, #0e0906 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 32px;
    transition:
        opacity 1.2s ease,
        transform 1.2s ease;
}
.pwd-logo {
    font-family: "Great Vibes", cursive;
    font-size: clamp(2.8rem, 5vw, 4rem);
    color: var(--champ);
    letter-spacing: 2px;
    text-shadow: 0 2px 30px rgba(232, 213, 168, 0.2);
    animation: fu 0.8s ease 0.1s both;
}
.pwd-sub {
    font-weight: 200;
    font-size: 0.62rem;
    letter-spacing: 7px;
    text-transform: uppercase;
    color: rgba(232, 213, 168, 0.45);
    animation: fu 0.8s ease 0.25s both;
}
.pwd-form {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    animation: fu 0.8s ease 0.4s both;
}
.pwd-input {
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 2px;
    padding: 16px 28px;
    text-align: center;
    letter-spacing: 10px;
    text-transform: uppercase;
    font-family: "Jost", sans-serif;
    font-weight: 300;
    font-size: 0.95rem;
    color: var(--cream);
    outline: none;
    width: 240px;
    cursor: text;
    transition:
        border-color 0.3s,
        background 0.3s;
}
.pwd-input::placeholder {
    letter-spacing: 4px;
    color: rgba(250, 245, 238, 0.25);
    text-transform: none;
}
.pwd-input:focus {
    border-color: rgba(232, 213, 168, 0.35);
    background: rgba(255, 255, 255, 0.12);
}
.pwd-btn {
    background: transparent;
    border: 1px solid rgba(200, 88, 42, 0.5);
    color: var(--terra-p);
    padding: 13px 44px;
    border-radius: 2px;
    font-family: "Jost", sans-serif;
    font-weight: 300;
    font-size: 0.64rem;
    letter-spacing: 6px;
    text-transform: uppercase;
    cursor: none;
    transition:
        background 0.3s,
        border-color 0.3s,
        color 0.3s;
}
.pwd-btn:hover {
    background: rgba(200, 88, 42, 0.15);
    border-color: var(--terra);
    color: var(--cream);
}
.pwd-err {
    font-weight: 300;
    font-size: 0.78rem;
    color: var(--terra-l);
    letter-spacing: 1px;
    opacity: 0;
    transition: opacity 0.3s;
}
.pwd-hint {
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 3px;
    color: rgba(232, 213, 168, 0.2);
    margin-top: 8px;
}

/* ══════════════════════════════════════════
   PRELOADER
══════════════════════════════════════════ */
#preloader {
    position: fixed;
    inset: 0;
    z-index: 1900;
    background: radial-gradient(ellipse at 35% 45%, #3d2d1a 0%, #1e140c 60%, #0e0906 100%);
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 28px;
}
.pre-monogram {
    font-family: "Great Vibes", cursive;
    font-size: var(--fs-accent, clamp(3rem, 6vw, 5rem));
    color: var(--champ);
    letter-spacing: 4px;
    opacity: 0;
}
.pre-bar-wrap {
    width: 160px;
    height: 1px;
    background: rgba(232, 213, 168, 0.15);
    overflow: hidden;
}
.pre-bar {
    height: 100%;
    width: 0%;
    background: var(--terra);
    transition: width 0.04s linear;
}
.pre-pct {
    font-weight: 200;
    font-size: 0.56rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: rgba(232, 213, 168, 0.3);
}

/* ══════════════════════════════════════════
   ENVELOPE SCREEN
══════════════════════════════════════════ */
#env-screen {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: none;
    background: radial-gradient(ellipse at 30% 40%, #3d2d1a 0%, #1e140c 60%, #100c06 100%);
    align-items: center;
    justify-content: center;
    transition:
        opacity 1.5s ease,
        transform 1.5s ease;
}
#env-screen::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
    opacity: 0.45;
}

/* Botanicals */
.bl {
    position: absolute;
    pointer-events: none;
    overflow: visible;
}
.bl-tl {
    top: -20px;
    left: -20px;
    width: 360px;
    opacity: 0.18;
    animation: bw 7s ease-in-out infinite;
}
.bl-br {
    bottom: -20px;
    right: -20px;
    width: 300px;
    opacity: 0.14;
    animation: bw 9s ease-in-out 1.5s infinite reverse;
}
.bl-tr {
    top: 6%;
    right: 4%;
    width: 165px;
    opacity: 0.09;
    animation: bw 8s ease-in-out 3s infinite;
}
.bl-bl {
    bottom: 8%;
    left: 4%;
    width: 125px;
    opacity: 0.07;
    animation: bw 6s ease-in-out 2s infinite reverse;
}
@keyframes bw {
    0%,
    100% {
        transform: rotate(0deg);
    }
    50% {
        transform: rotate(3.5deg);
    }
}

.env-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    z-index: 2;
}
.env-title {
    font-family: "Great Vibes", cursive;
    font-size: clamp(2rem, 4.5vw, 3.5rem);
    color: var(--champ);
    letter-spacing: 2px;
    text-shadow: 0 2px 30px rgba(232, 213, 168, 0.25);
}

/* Envelope scene (relative container for letter) */
.env-scene {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Envelope ── */
.envelope {
    position: relative;
    width: var(--ew);
    height: var(--eh);
    cursor: none;
    transition:
        transform 0.3s,
        box-shadow 0.4s;
    z-index: 2;
    overflow: visible;
}
.env-back {
    box-shadow: 0 40px 90px rgba(0, 0, 0, 0.55);
}
.envelope:not(.opening):hover {
    transform: translateY(-6px);
}
.envelope:not(.opening):hover .env-back {
    box-shadow: 0 55px 110px rgba(0, 0, 0, 0.6);
}
.env-back {
    position: absolute;
    inset: 0;
    border-radius: 3px;
    background: linear-gradient(160deg, #fefcf8 0%, #ede0cc 100%);
}
.env-inner {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    text-align: center;
    z-index: 1;
    opacity: 0.28;
}
.env-inner p:first-child {
    font-family: "Great Vibes", cursive;
    color: var(--txt-l);
    font-size: 1.3rem;
}
.env-inner p:last-child {
    font-family: "Cormorant Garamond", serif;
    font-size: 0.68rem;
    letter-spacing: 3px;
    color: var(--txt-l);
    margin-top: 4px;
}
.env-fold-l,
.env-fold-r {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 50%;
    overflow: hidden;
    z-index: 1;
}
.env-fold-l {
    left: 0;
}
.env-fold-r {
    right: 0;
}
.env-fold-l::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: var(--eh2) solid transparent;
    border-bottom: var(--eh2) solid transparent;
    border-left: var(--ew2) solid rgba(200, 178, 148, 0.28);
}
.env-fold-r::before {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: var(--eh2) solid transparent;
    border-bottom: var(--eh2) solid transparent;
    border-right: var(--ew2) solid rgba(200, 178, 148, 0.18);
}
.env-fold-b {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    overflow: hidden;
    z-index: 1;
}
.env-fold-b::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: var(--ew2) solid transparent;
    border-right: var(--ew2) solid transparent;
    border-bottom: var(--eh2) solid rgba(210, 188, 158, 0.36);
}
.env-flap {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 3;
    height: calc(var(--eh2) + 2px);
    overflow: hidden;
    transform-origin: top center;
    transition: transform 1.6s cubic-bezier(0.25, 0, 0.1, 1);
}
.env-flap::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: calc(var(--ew2) + 3px) solid transparent;
    border-right: calc(var(--ew2) + 3px) solid transparent;
    border-top: calc(var(--eh2) + 2px) solid #ead8c0;
}
.env-flap::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: rgba(180, 155, 120, 0.4);
}
.envelope.opening .env-flap {
    transform: perspective(1400px) rotateX(-178deg);
}

/* ── Letter track (clip container above envelope) ── */
.env-letter-track {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 100%;
    height: 400px;
    overflow: hidden;
    z-index: 4;
    pointer-events: none;
}

/* ── Letter (emerges from envelope top) ── */
.env-letter {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%) translateY(100%);
    width: calc(100% - 50px);
    background: linear-gradient(165deg, #fefcf8 0%, #f5ecd8 100%);
    border: 1px solid rgba(200, 168, 125, 0.25);
    border-radius: 2px;
    padding: 28px 24px;
    text-align: center;
    opacity: 0;
    pointer-events: none;
    box-shadow: 0 14px 50px rgba(0, 0, 0, 0.25);
}
.letter-monogram {
    font-family: "Great Vibes", cursive;
    font-size: var(--fs-accent, 2.4rem);
    color: var(--terra);
    margin-bottom: 10px;
}
.letter-divider {
    width: 40px;
    height: 1px;
    background: var(--terra);
    margin: 0 auto 14px;
}
.letter-date-txt {
    font-weight: 200;
    font-size: 0.64rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--txt-l);
    margin-bottom: 8px;
}
.letter-venue-txt {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: 0.95rem;
    color: var(--txt-m);
    line-height: 1.6;
}

/* ══ WAX SEAL — Heart + Stethoscope ══ */
.env-seal {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -56%);
    width: 82px;
    height: 82px;
    border-radius: 50%;
    background: radial-gradient(circle at 35% 32%, #e06030 0%, var(--terra) 44%, #9c3515 100%);
    box-shadow:
        0 6px 28px rgba(200, 88, 42, 0.58),
        inset 0 1px 0 rgba(255, 255, 255, 0.18),
        inset 0 -2px 6px rgba(0, 0, 0, 0.22);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition:
        transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
        box-shadow 0.4s;
}
.env-seal::before {
    content: "";
    position: absolute;
    inset: 5px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.16);
}
.envelope:hover .env-seal {
    transform: translate(-50%, -56%) scale(1.12) rotate(10deg);
    box-shadow:
        0 10px 38px rgba(200, 88, 42, 0.68),
        inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.seal-svg {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
}
.env-rim {
    position: absolute;
    inset: 0;
    border-radius: 3px;
    border: 1.5px solid rgba(200, 168, 125, 0.22);
    pointer-events: none;
    z-index: 11;
}

.env-hint {
    font-weight: 200;
    font-size: 0.68rem;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: var(--champ);
    animation: breathe 3s ease-in-out infinite;
}
@keyframes breathe {
    0%,
    100% {
        opacity: 0.28;
        transform: translateY(0);
    }
    50% {
        opacity: 0.9;
        transform: translateY(-4px);
    }
}

/* Petals */
.petal {
    position: fixed;
    pointer-events: none;
    z-index: 999;
    opacity: 0;
    animation: pf linear forwards;
}
@keyframes pf {
    0% {
        opacity: 0.85;
        transform: translateY(0) rotate(0deg) scale(1);
    }
    100% {
        opacity: 0;
        transform: translateY(110vh) rotate(var(--pr, 540deg)) scale(0.6);
    }
}

/* ══════════════════════════════════════════
   MAIN SITE
══════════════════════════════════════════ */
/* Skip intro when session exists */
.has-site-session #pwd-screen,
.has-site-session #preloader,
.has-site-session #env-screen {
    display: none !important;
}
.has-site-session body {
    overflow-x: hidden !important;
}
.has-site-session #main-site {
    opacity: 1 !important;
}
.has-site-session #main-site .mob-toggle {
    opacity: 1 !important;
    pointer-events: auto !important;
}
/* Public site: hide only password screen */
.is-public-site #pwd-screen {
    display: none !important;
}

#main-site {
    opacity: 0;
    transition: opacity 1.3s ease 0.4s;
}
#main-site.visible {
    opacity: 1;
}
#main-site .mob-toggle {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.6s ease;
}
#main-site.visible .mob-toggle {
    opacity: 1;
    pointer-events: auto;
}

/* Nav dots */
.nav-dots {
    position: fixed;
    right: 22px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 11px;
    z-index: 300;
}
.nd {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--terra);
    opacity: 0.25;
    cursor: none;
    transition:
        opacity 0.3s,
        transform 0.3s;
    position: relative;
}
.nd::after {
    content: attr(data-l);
    position: absolute;
    right: 17px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.56rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--txt-m);
    white-space: nowrap;
    opacity: 0;
    background: rgba(250, 245, 238, 0.95);
    padding: 3px 10px;
    border-radius: 2px;
    pointer-events: none;
    transition: opacity 0.2s;
}
.nd:hover::after {
    opacity: 1;
}
.nd.on {
    opacity: 1;
    transform: scale(1.65);
}

/* Shared section */
section {
    min-height: 100vh;
    padding: 120px 40px;
    position: relative;
}
.wrap {
    max-width: 1100px;
    margin: 0 auto;
}
.eyebrow {
    display: block;
    font-weight: 200;
    font-size: var(--fs-label, 0.64rem);
    letter-spacing: 6px;
    text-transform: uppercase;
    color: var(--terra);
    margin-bottom: 14px;
}
h2 {
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: var(--fs-heading, clamp(2.8rem, 5vw, 4.8rem));
    line-height: 1.04;
    color: var(--txt);
}
h2 em {
    font-style: italic;
    color: var(--terra);
}
.bar {
    width: 44px;
    height: 1px;
    background: var(--terra);
    margin: 22px 0;
}
.bar.c {
    margin-left: auto;
    margin-right: auto;
}

/* GSAP initial states */
.g-up {
    opacity: 0;
    transform: translateY(54px);
    filter: blur(3px);
    will-change: transform, opacity, filter;
}
.g-left {
    opacity: 0;
    transform: translateX(-80px) perspective(1200px) rotateY(8deg);
    will-change: transform, opacity;
}
.g-right {
    opacity: 0;
    transform: translateX(80px) perspective(1200px) rotateY(-8deg);
    will-change: transform, opacity;
}
.g-clip {
    clip-path: inset(0 0 110% 0);
    will-change: clip-path;
}
.g-sc {
    opacity: 0;
    transform: scale(0.82);
    filter: blur(4px);
    will-change: transform, opacity, filter;
}

/* Word-by-word reveal wrappers */
.word-wrap {
    overflow: hidden;
    display: inline-block;
    vertical-align: top;
}
.word {
    display: inline-block;
    will-change: transform;
}

/* Split char animation — enhanced with 3D rotation */
.char {
    display: inline-block;
    opacity: 0;
    transform: translateY(24px) perspective(800px) rotateX(-90deg);
    will-change: transform, opacity;
}

/* Progress bar light mode for dark sections */
#pgbar {
    transition: background .4s ease;
}
.pgbar-light {
    background: rgba(232, 213, 168, .7) !important;
}

/* Decorative floating elements */
.deco-float {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    opacity: .15;
}

/* Bar grow-from-center initial state */
.bar {
    transform-origin: center center;
}

/* ══ S0a — BIENVENUE ══ */
#bienvenue {
    background: var(--cream);
    display: flex;
    align-items: center;
    text-align: center;
}
.bv-hero {
    width: 100%;
    max-width: 820px;
    height: 520px;
    border-radius: 2px;
    overflow: hidden;
    margin: 0 auto 48px;
    box-shadow: 0 30px 80px rgba(44, 32, 22, 0.14);
}
.bv-hero img {
    width: 100%;
    height: 100%;
}

/* ══ S0b — ALLIANCES ══ */
#alliances {
    background: var(--brown);
    color: var(--cream);
    display: flex;
    align-items: center;
    text-align: center;
}
#alliances::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 60% 30%, rgba(107, 155, 122, 0.1) 0%, transparent 55%);
    pointer-events: none;
}
#alliances .wrap {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.al-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    width: 100%;
    max-width: 820px;
    margin-bottom: 36px;
}
.al-photo {
    height: 400px;
    border-radius: 2px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
}
.al-photo img {
    width: 100%;
    height: 100%;
}

/* ══ S1 — HISTOIRE ══ */
#histoire {
    background: var(--cream);
    display: flex;
    align-items: center;
    padding-top: 0;
}
.hist-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    min-height: 100vh;
    padding: 120px 0;
}
.photo-stack {
    position: relative;
    height: 580px;
}
.ps-main {
    position: absolute;
    top: 0;
    left: 0;
    width: 72%;
    height: 88%;
    border-radius: 2px;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(44, 32, 22, 0.16);
}
.ps-main img {
    width: 100%;
    height: 100%;
}
.ps-accent {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 50%;
    height: 52%;
    border-radius: 2px;
    overflow: hidden;
    border: 6px solid var(--cream);
    box-shadow: 0 20px 55px rgba(44, 32, 22, 0.18);
}
.ps-accent img {
    width: 100%;
    height: 100%;
}
.ps-badge {
    position: absolute;
    top: 20px;
    right: 20px;
    background: var(--terra);
    color: var(--cream);
    font-size: 0.54rem;
    letter-spacing: 4px;
    text-transform: uppercase;
    font-weight: 300;
    padding: 8px 14px;
    z-index: 2;
}
.hist-text p {
    font-size: var(--fs-body, 1.05rem);
    line-height: 1.95;
    color: var(--txt-m);
    font-weight: 300;
    margin-bottom: 18px;
}
.sig-row {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-top: 10px;
}
.sig-dash {
    width: 44px;
    height: 1px;
    background: var(--terra);
}
.signature {
    font-family: "Great Vibes", cursive;
    font-size: var(--fs-accent, clamp(2rem, 4vw, 3rem));
    color: var(--terra);
}
.scroll-cue {
    position: absolute;
    bottom: 36px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    opacity: 0.38;
    animation: cf 2.5s ease-in-out infinite;
    pointer-events: none;
}
.scroll-cue span {
    font-weight: 200;
    font-size: 0.56rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--terra);
}
.sc-line {
    width: 1px;
    height: 42px;
    background: linear-gradient(var(--terra), transparent);
}
@keyframes cf {
    0%,
    100% {
        transform: translateX(-50%) translateY(0);
    }
    50% {
        transform: translateX(-50%) translateY(8px);
    }
}

/* ══ S2 — SAVE THE DATE ══ */
#save {
    background: linear-gradient(158deg, #1e140c 0%, #2a1f14 50%, #191209 100%);
    color: var(--cream);
    display: flex;
    align-items: center;
    text-align: center;
}
#save::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse at 68% 22%, rgba(107, 155, 122, 0.12) 0%, transparent 55%),
        radial-gradient(ellipse at 14% 82%, rgba(200, 88, 42, 0.08) 0%, transparent 50%);
}
#save .wrap {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
}
#save .eyebrow {
    color: var(--champ);
}
.std-pre {
    font-weight: 200;
    font-size: clamp(0.75rem, 1.8vw, 0.9rem);
    letter-spacing: 8px;
    text-transform: uppercase;
    color: var(--sage-l);
    margin-bottom: 6px;
}
.big-date {
    margin: 12px 0 4px;
}
.bd-day {
    display: block;
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(1rem, 2.5vw, 1.5rem);
    letter-spacing: 8px;
    text-transform: uppercase;
    color: var(--champ);
    margin-bottom: 4px;
}
.bd-num {
    display: block;
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(7rem, 18vw, 13rem);
    line-height: 0.82;
    color: var(--cream);
}
.bd-month {
    display: block;
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(1.6rem, 4vw, 3rem);
    letter-spacing: 6px;
    text-transform: uppercase;
    color: var(--champ);
    margin-top: 8px;
}

/* Countdown */
.countdown {
    display: flex;
    align-items: flex-start;
    gap: 28px;
    margin: 36px 0;
}
.cd-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.cd-num {
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(2.4rem, 4.5vw, 3.8rem);
    color: var(--cream);
    line-height: 1;
    min-width: 3ch;
    text-align: center;
    transition:
        transform 0.2s ease,
        color 0.3s;
}
.cd-num.tick {
    transform: scale(1.06) translateY(-3px);
    color: var(--champ);
}
.cd-lbl {
    font-weight: 200;
    font-size: 0.54rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: rgba(232, 213, 168, 0.45);
}
.cd-sep {
    font-family: "Cormorant Garamond", serif;
    font-size: 2rem;
    color: rgba(232, 213, 168, 0.22);
    margin-top: 6px;
}

.std-sep {
    width: 1px;
    height: 48px;
    background: rgba(232, 213, 168, 0.22);
    margin: 8px 0 28px;
}
.std-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    width: 100%;
    max-width: 780px;
}
.std-card {
    background: rgba(255, 255, 255, 0.045);
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 2px;
    padding: 28px 24px;
    text-align: left;
    transition:
        background 0.35s,
        border-color 0.35s,
        transform 0.35s;
}
.std-card:hover {
    background: rgba(255, 255, 255, 0.075);
    border-color: rgba(255, 255, 255, 0.15);
    transform: translateY(-4px);
}
.sc-label {
    display: block;
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--terra-l);
    margin-bottom: 12px;
}
.std-card h3 {
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(1.2rem, 2.2vw, 1.7rem);
    color: var(--cream);
    margin-bottom: 7px;
}
.std-card p {
    font-weight: 200;
    font-size: 0.86rem;
    color: rgba(250, 245, 238, 0.48);
    line-height: 1.75;
}
.time-pill {
    display: inline-block;
    margin-top: 14px;
    background: rgba(200, 88, 42, 0.2);
    border: 1px solid rgba(200, 88, 42, 0.36);
    border-radius: 2px;
    padding: 5px 13px;
    font-weight: 300;
    font-size: 0.66rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--terra-p);
}
.direction-link {
    display: flex;
    align-items: center;
    gap: 5px;
    width: fit-content;
    margin-top: 18px;
    font-size: 0.72rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--terra, #C8582A);
    text-decoration: none;
    font-weight: 400;
    transition: opacity .3s;
}
.direction-link:hover {
    opacity: .7;
}
.venue-strip {
    grid-column: 1/-1;
    height: 230px;
    border-radius: 2px;
    overflow: hidden;
    position: relative;
}
.venue-strip img {
    width: 100%;
    height: 100%;
    transition: transform 0.8s;
}
.venue-strip:hover img {
    transform: scale(1.04);
}
.venue-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(30, 20, 12, 0.72) 0%, transparent 55%);
    display: flex;
    align-items: center;
    padding: 0 32px;
}
.venue-txt span {
    display: block;
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: var(--champ);
    margin-bottom: 8px;
}
.venue-txt h4 {
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(1.3rem, 2.5vw, 2rem);
    color: var(--cream);
}

/* ══ S3 — PROGRAMME ══ */
#programme {
    background: var(--cream-d);
}
.prog-head {
    text-align: center;
    margin-bottom: 80px;
}
.programme-tabs {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 48px;
    flex-wrap: wrap;
}
.programme-tab {
    padding: 10px 24px;
    border: 1.5px solid var(--champ, #E8D5A8);
    border-radius: 100px;
    background: transparent;
    color: var(--txt, #3A2A1C);
    font-family: var(--f-body, 'Jost', sans-serif);
    font-size: 0.82rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all .3s ease;
}
.programme-tab:hover {
    background: rgba(200,88,42,0.06);
    border-color: var(--terra, #C8582A);
}
.programme-tab.active {
    background: var(--terra, #C8582A);
    color: var(--cream, #EDE0CC);
    border-color: var(--terra, #C8582A);
}
.timeline {
    position: relative;
    max-width: 700px;
    margin: 0 auto;
}
.tl-spine {
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 1px;
    transform: translateX(-50%) scaleY(0);
    transform-origin: top;
    background: linear-gradient(transparent, var(--champ) 8%, var(--terra-p) 50%, var(--champ) 92%, transparent);
}
.tl-row {
    display: grid;
    grid-template-columns: 1fr 60px 1fr;
    align-items: flex-start;
    margin-bottom: 54px;
}
.tl-l {
    text-align: right;
    padding-right: 18px;
    padding-top: 4px;
}
.tl-c {
    display: flex;
    justify-content: center;
    padding-top: 5px;
}
.tl-r {
    text-align: left;
    padding-left: 18px;
    padding-top: 4px;
}
.tl-row:nth-child(even) .tl-l {
    order: 3;
    text-align: left;
    padding-left: 18px;
    padding-right: 0;
}
.tl-row:nth-child(even) .tl-c {
    order: 2;
}
.tl-row:nth-child(even) .tl-r {
    order: 1;
    text-align: right;
    padding-right: 18px;
    padding-left: 0;
}
.tl-node {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--terra);
    flex-shrink: 0;
    transform: scale(0);
    box-shadow:
        0 0 0 4px var(--cream-d),
        0 0 0 6.5px rgba(200, 88, 42, 0.28);
}
.tl-time {
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(1.6rem, 2.8vw, 2.2rem);
    color: var(--terra);
    line-height: 1;
}
.tl-label {
    font-family: "Cormorant Garamond", serif;
    font-weight: 500;
    font-size: var(--fs-subheading, 1.15rem);
    color: var(--txt);
    margin-bottom: 4px;
}
.tl-desc {
    font-weight: 300;
    font-size: 0.86rem;
    color: var(--txt-l);
    line-height: 1.65;
}

/* Calendar buttons */
.cal-row {
    display: flex;
    gap: 12px;
    justify-content: center;
    margin-top: 48px;
    flex-wrap: wrap;
}
.btn-cal {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(200, 88, 42, 0.4);
    color: var(--terra);
    background: transparent;
    border-radius: 2px;
    padding: 12px 22px;
    font-family: "Jost", sans-serif;
    font-weight: 300;
    font-size: 0.64rem;
    letter-spacing: 4px;
    text-transform: uppercase;
    cursor: none;
    transition:
        background 0.3s,
        color 0.3s,
        border-color 0.3s;
}
.btn-cal:hover {
    background: var(--terra);
    color: var(--cream);
    border-color: var(--terra);
}
.btn-cal svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

/* ══ S4 — RSVP ══ */
#rsvp {
    background: var(--sage-d);
    color: var(--cream);
    display: flex;
    align-items: center;
    text-align: center;
}
.rsvp-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}
.rsvp-bg img {
    width: 100%;
    height: 120%;
    opacity: 0.14;
}
#rsvp::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: radial-gradient(ellipse at 80% 20%, rgba(107, 155, 122, 0.28) 0%, transparent 60%);
}
#rsvp .wrap {
    position: relative;
    z-index: 2;
}
#rsvp .eyebrow {
    color: var(--champ);
}
#rsvp h2 {
    color: var(--cream);
}
.rsvp-sub {
    font-weight: 300;
    font-size: 0.98rem;
    opacity: 0.82;
    max-width: 470px;
    margin: 14px auto 48px;
    line-height: 1.9;
}
.rsvp-sub strong {
    font-weight: 500;
    color: var(--champ);
}
.rsvp-form {
    max-width: 600px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.row2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
.fg {
    display: flex;
    flex-direction: column;
    text-align: left;
}
.fg label {
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 4.5px;
    text-transform: uppercase;
    color: var(--champ);
    margin-bottom: 8px;
}
span.required { color: var(--terra, #C8582A); font-weight: 400; }
.fg input,
.fg select,
.fg textarea {
    background: rgba(255, 255, 255, 0.11);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 2px;
    padding: 14px 18px;
    color: var(--cream);
    font-family: "Jost", sans-serif;
    font-weight: 300;
    font-size: 0.95rem;
    outline: none;
    transition:
        border-color 0.3s,
        background 0.3s;
    -webkit-appearance: none;
    cursor: text;
}
.fg input::placeholder,
.fg textarea::placeholder {
    color: rgba(250, 245, 238, 0.3);
}
.fg input:focus,
.fg select:focus,
.fg textarea:focus {
    border-color: var(--champ);
    background: rgba(255, 255, 255, 0.18);
}
.fg select option {
    background: var(--sage-d);
    color: var(--cream);
}
.fg textarea {
    resize: vertical;
    min-height: 90px;
    cursor: text;
}
.btn-rsvp {
    background: var(--terra);
    color: var(--cream);
    border: none;
    padding: 18px 58px;
    border-radius: 2px;
    font-family: "Jost", sans-serif;
    font-weight: 300;
    font-size: 0.68rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    cursor: none;
    box-shadow: 0 6px 26px rgba(200, 88, 42, 0.32);
    transition:
        background 0.3s,
        box-shadow 0.3s,
        transform 0.15s;
    align-self: center;
    margin-top: 8px;
    position: relative;
}
.btn-rsvp:hover {
    background: var(--terra-l);
    box-shadow: 0 10px 38px rgba(200, 88, 42, 0.48);
}
.btn-rsvp:active {
    transform: scale(0.96);
}

/* Dynamic RSVP sections */
.rsvp-dynamic-section {
    margin-top: 12px;
    margin-bottom: 12px;
}
.rsvp-dynamic-section label {
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 4.5px;
    text-transform: uppercase;
    color: var(--champ);
    display: block;
    margin-bottom: 10px;
}
/* Dietary preset chips on RSVP form */
.dietary-presets {
    display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px;
}
.dietary-chip {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 12px; border-radius: 16px;
    border: 1px solid rgba(232,213,168,0.2);
    font-size: .75rem; color: var(--cream-l, #d4c9a8);
    cursor: pointer; transition: all .2s;
}
.dietary-chip:hover { border-color: rgba(232,213,168,0.4); }
.dietary-chip:has(input:checked) {
    background: rgba(232,213,168,0.12); border-color: var(--champ, #d4af37); color: var(--champ, #d4af37);
}
.dietary-chip input { display: none; }

.rsvp-checks {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.rsvp-checks label {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.7rem;
    letter-spacing: 1px;
    text-transform: none;
    cursor: pointer;
    padding: 10px 14px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(232,213,168,0.12);
    border-radius: 6px;
    transition: all .2s;
}
.rsvp-checks label:hover {
    border-color: rgba(232,213,168,0.3);
}
.rsvp-checks input[type="checkbox"] {
    width: 16px; height: 16px;
    accent-color: var(--champ);
}
.rsvp-question-field {
    margin-bottom: 14px;
}
.rsvp-question-field label {
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--champ);
    display: block;
    margin-bottom: 8px;
}
.rsvp-question-field input,
.rsvp-question-field select,
.rsvp-question-field textarea {
    width: 100%;
}
.rsvp-question-field .rsvp-toggle {
    display: flex;
    gap: 12px;
}
.rsvp-question-field .rsvp-toggle label {
    font-size: .68rem;
    letter-spacing: 1px;
    cursor: pointer;
    padding: 8px 20px;
    border: 1px solid rgba(232,213,168,0.2);
    border-radius: 4px;
    text-align: center;
    transition: all .2s;
}
.rsvp-question-field .rsvp-toggle input:checked + label,
.rsvp-question-field .rsvp-toggle label.active {
    background: rgba(232,213,168,0.15);
    border-color: var(--champ);
}
.rsvp-question-field .rsvp-toggle input { display: none; }
.rsvp-summary {
    margin-top: 24px;
    padding: 20px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(232,213,168,0.12);
    border-radius: 8px;
    text-align: left;
}
.rsvp-summary p {
    margin: 6px 0;
    font-size: 0.68rem;
    letter-spacing: 1px;
}
.rsvp-summary .sum-label {
    color: var(--champ);
    font-weight: 500;
    text-transform: uppercase;
    font-size: 0.55rem;
    letter-spacing: 3px;
}

/* Guests section */
.guests-section {
    margin-top: 4px;
}
.guests-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}
.guests-header label {
    font-weight: 200;
    font-size: 0.58rem;
    letter-spacing: 4.5px;
    text-transform: uppercase;
    color: var(--champ);
}
.btn-add-guest {
    background: transparent;
    border: 1px solid rgba(232, 213, 168, 0.3);
    color: var(--champ);
    padding: 8px 18px;
    border-radius: 2px;
    font-family: "Jost", sans-serif;
    font-weight: 300;
    font-size: 0.68rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    cursor: pointer;
    transition:
        background 0.3s,
        border-color 0.3s;
}
.btn-add-guest:hover {
    background: rgba(232, 213, 168, 0.12);
    border-color: var(--champ);
}

/* Guest sub-cards */
.guest-card {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 2px;
    padding: 18px;
    margin-bottom: 14px;
    overflow: hidden;
}
.gc-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}
.guest-card .gc-title {
    font-family: "Cormorant Garamond", serif;
    font-weight: 400;
    font-size: 1rem;
    color: var(--champ);
    letter-spacing: 1px;
}
.gc-remove {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: transparent;
    color: rgba(250, 245, 238, 0.5);
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
    line-height: 1;
}
.gc-remove:hover {
    background: rgba(192, 57, 43, 0.3);
    border-color: var(--red);
    color: var(--cream);
}
.guest-card .row2 {
    margin-bottom: 8px;
}

/* RSVP Thank you screen */
#rsvp-thanks {
    display: none;
    text-align: center;
    padding: 40px 20px;
    max-width: 500px;
    margin: 0 auto;
}
.thanks-heart {
    font-size: 3rem;
    margin-bottom: 24px;
    animation: thanksPulse 2s ease-in-out infinite;
}
@keyframes thanksPulse {
    0%,
    100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.12);
    }
}
.thanks-title {
    font-family: "Great Vibes", cursive;
    font-size: clamp(2.5rem, 5vw, 4rem);
    color: var(--cream);
    margin-bottom: 16px;
}
.thanks-msg {
    font-weight: 300;
    font-size: 1rem;
    color: rgba(250, 245, 238, 0.75);
    line-height: 1.9;
    max-width: 380px;
    margin: 0 auto;
}
.thanks-sig {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: 1.3rem;
    color: var(--champ);
    margin-top: 24px;
    opacity: 0.8;
}

/* ══ S5 — CADEAUX ══ */
#cadeaux {
    background: var(--cream);
    display: flex;
    align-items: center;
}
.cad-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 88px;
    align-items: center;
}
.cad-text p {
    font-size: 1.03rem;
    line-height: 1.95;
    color: var(--txt-m);
    font-weight: 300;
    margin-bottom: 16px;
}
.cad-aside {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: 1.15rem;
    color: var(--txt-l);
    margin-top: 10px;
}
.qr-scene {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}
.qr-card {
    background: #fff;
    border-radius: 4px;
    padding: 20px;
    box-shadow:
        0 16px 60px rgba(44, 32, 22, 0.1),
        0 2px 8px rgba(44, 32, 22, 0.05);
    transition:
        transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1),
        box-shadow 0.5s;
}
.qr-card:hover {
    transform: translateY(-8px) rotate(-1.5deg);
    box-shadow: 0 28px 80px rgba(44, 32, 22, 0.16);
}
.qr-note {
    font-weight: 200;
    font-size: 0.62rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--txt-l);
    text-align: center;
    max-width: 200px;
    line-height: 1.65;
}

/* ══ S6 — GALERIE ══ */
#galerie {
    background: var(--brown);
    color: var(--cream);
    padding: 120px 40px 100px;
    overflow: hidden;
}
#galerie .eyebrow {
    color: var(--champ);
}
#galerie h2 {
    color: var(--cream);
}
.gal-head {
    margin-bottom: 56px;
    text-align: center;
}
.gal-divider {
    text-align: center;
    margin-bottom: 56px;
    position: relative;
}
.gal-divider::before,
.gal-divider::after {
    content: "";
    position: absolute;
    top: 50%;
    height: 1px;
    width: calc(50% - 60px);
    background: linear-gradient(to right, transparent, rgba(232, 213, 168, 0.18));
}
.gal-divider::before {
    left: 0;
}
.gal-divider::after {
    right: 0;
    background: linear-gradient(to left, transparent, rgba(232, 213, 168, 0.18));
}

/* Masonry grid */
.gal-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: 58px;
    gap: 12px;
    max-width: 1200px;
    margin: 0 auto;
}
.gal-card {
    position: relative;
    overflow: hidden;
    border-radius: 2px;
    cursor: none;
    opacity: 0;
    transform: translateY(55px) scale(0.95);
    will-change: transform, opacity;
}
.gal-card:nth-child(1) {
    grid-column: 1/6;
    grid-row: span 7;
}
.gal-card:nth-child(2) {
    grid-column: 6/10;
    grid-row: span 5;
}
.gal-card:nth-child(3) {
    grid-column: 10/13;
    grid-row: span 4;
}
.gal-card:nth-child(4) {
    grid-column: 6/10;
    grid-row: span 5;
}
.gal-card:nth-child(5) {
    grid-column: 10/13;
    grid-row: span 6;
}
.gal-card:nth-child(6) {
    grid-column: 1/5;
    grid-row: span 5;
}
.gal-card:nth-child(7) {
    grid-column: 5/9;
    grid-row: span 6;
}
.gal-card:nth-child(8) {
    grid-column: 9/13;
    grid-row: span 5;
}
.gal-card img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.1);
    transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.gal-card:hover img {
    transform: scale(1.15);
}
.gal-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(18, 10, 4, 0.78) 0%, rgba(18, 10, 4, 0.12) 45%, transparent 100%);
    display: flex;
    align-items: flex-end;
    padding: 18px;
    opacity: 0;
    transition: opacity 0.45s;
}
.gal-card:hover .gal-overlay {
    opacity: 1;
}
.gal-label {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: 1.05rem;
    color: var(--cream);
    font-weight: 300;
    transform: translateY(10px);
    transition: transform 0.45s;
}
.gal-card:hover .gal-label {
    transform: translateY(0);
}
.gal-num {
    position: absolute;
    top: 13px;
    right: 14px;
    font-weight: 200;
    font-size: 0.52rem;
    letter-spacing: 3px;
    color: rgba(250, 245, 238, 0.42);
}
/* Click cursor on gallery */
.gal-card {
    cursor: none;
}

/* ══ S6b — GUEST PHOTOS ══ */
.guest-photos-grid {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    padding: 0 20px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.guest-photos-grid::-webkit-scrollbar { display: none; }
.guest-photo-item {
    flex: 0 0 220px;
    aspect-ratio: 3/4;
    border-radius: 6px;
    overflow: hidden;
    position: relative;
    scroll-snap-align: start;
    cursor: pointer;
}
.guest-photo-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s;
}
.guest-photo-item:hover img {
    transform: scale(1.05);
}
.guest-photo-item .gp-overlay {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 10px 12px;
    background: linear-gradient(transparent, rgba(0,0,0,0.6));
    color: var(--cream);
}
.guest-photo-item .gp-name {
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.05em;
}
.guest-photo-item .gp-caption {
    font-size: 0.62rem;
    font-weight: 200;
    opacity: 0.7;
    font-style: italic;
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.btn-guest-photos {
    display: inline-block;
    padding: 12px 32px;
    font-family: "Jost", sans-serif;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--cream);
    border: 1px solid var(--champ);
    text-decoration: none;
    transition: all 0.3s;
}
.btn-guest-photos:hover {
    background: var(--champ);
    color: var(--brown);
}
.guest-photos-empty {
    text-align: center;
    padding: 30px 20px;
    color: rgba(250,245,238,0.4);
    font-size: 0.82rem;
    font-weight: 200;
}
@media (max-width: 520px) {
    .guest-photo-item { flex: 0 0 160px; }
}

/* ══ S7 — HÉBERGEMENT ══ */
#hebergement {
    background: linear-gradient(160deg, #2a1f14 0%, #18100a 100%);
    color: var(--cream);
    display: flex;
    align-items: center;
}
#hebergement::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 22% 55%, rgba(107, 155, 122, 0.1) 0%, transparent 55%);
}
#hebergement .wrap {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}
#hebergement .eyebrow {
    color: var(--champ);
}
#hebergement h2 {
    color: var(--cream);
}
.bnb-sub {
    font-weight: 300;
    font-size: 0.97rem;
    opacity: 0.68;
    max-width: 510px;
    margin: 14px auto 46px;
    line-height: 1.9;
}
.bnb-card {
    max-width: 520px;
    width: 100%;
    background: rgba(255, 255, 255, 0.055);
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 4px;
    overflow: hidden;
    text-align: left;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.3);
    transition:
        transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1),
        box-shadow 0.5s;
}
.bnb-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 36px 90px rgba(0, 0, 0, 0.4);
}
.bnb-img {
    height: 220px;
    overflow: hidden;
}
.bnb-img img {
    display: block;
    width: 100%;
    height: 100%;
    transition: transform 0.8s;
}
.bnb-card:hover .bnb-img img {
    transform: scale(1.05);
}
.bnb-body {
    padding: 28px 30px;
}
.bnb-body h3 {
    font-family: "Cormorant Garamond", serif;
    font-weight: 400;
    font-size: 1.6rem;
    color: var(--cream);
    margin-bottom: 8px;
}
.bnb-body p {
    font-weight: 300;
    font-size: 0.88rem;
    color: rgba(250, 245, 238, 0.52);
    line-height: 1.78;
    margin-bottom: 22px;
}
.btn-bnb {
    display: inline-block;
    text-decoration: none;
    background: var(--terra);
    color: var(--cream);
    border-radius: 2px;
    padding: 13px 34px;
    font-weight: 300;
    font-size: 0.66rem;
    letter-spacing: 4px;
    text-transform: uppercase;
    transition:
        background 0.3s,
        transform 0.3s,
        box-shadow 0.3s;
    box-shadow: 0 4px 20px rgba(200, 88, 42, 0.3);
}
.btn-bnb:hover {
    background: var(--terra-l);
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(200, 88, 42, 0.44);
}

/* ══ S8 — MESSAGE ══ */
#message {
    background: var(--cream);
    display: flex;
    align-items: center;
    text-align: center;
}
.msg-wrap {
    max-width: 680px;
    margin: 0 auto;
}
.msg-photo {
    width: 100%;
    height: 420px;
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 60px;
    box-shadow: 0 24px 70px rgba(44, 32, 22, 0.13);
}
.msg-photo img {
    width: 100%;
    height: 100%;
}
.msg-quote {
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    font-size: clamp(1.25rem, 2.8vw, 1.8rem);
    font-weight: 300;
    line-height: 1.9;
    color: var(--txt-m);
    margin-bottom: 38px;
    position: relative;
}
.msg-quote::before {
    content: "\201C";
    position: absolute;
    top: -28px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 6rem;
    color: rgba(200, 88, 42, 0.1);
    line-height: 1;
    pointer-events: none;
}
.msg-sig {
    font-family: "Great Vibes", cursive;
    font-size: clamp(3rem, 5.5vw, 4.8rem);
    color: var(--terra);
    margin-bottom: 12px;
}
.msg-dt {
    font-weight: 200;
    font-size: 0.66rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--txt-l);
}

/* Footer */
footer {
    background: var(--brown);
    padding: 38px 24px;
    text-align: center;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}
footer p {
    font-weight: 200;
    font-size: 0.63rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(232, 213, 168, 0.22);
}

/* ══ SCROLL TO TOP ══ */
.scroll-top {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 500;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid rgba(200, 88, 42, 0.35);
    background: rgba(250, 245, 238, 0.92);
    backdrop-filter: blur(10px);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(44, 32, 22, 0.1);
    opacity: 0;
    pointer-events: none;
    transform: translateY(10px);
    transition:
        opacity 0.4s ease,
        transform 0.4s ease,
        background 0.3s,
        border-color 0.3s;
}
.scroll-top.show {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}
.scroll-top:hover {
    background: var(--terra);
    border-color: var(--terra);
}
.scroll-top:hover svg {
    stroke: var(--cream);
}
.scroll-top svg {
    width: 18px;
    height: 18px;
    stroke: var(--terra);
    transition: stroke 0.3s;
}

/* ══ MOBILE NAV ══ */
.mob-toggle {
    display: none;
    position: fixed;
    top: 18px;
    right: 18px;
    z-index: 600;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid rgba(200, 88, 42, 0.4);
    background: rgba(250, 245, 238, 0.92);
    backdrop-filter: blur(10px);
    cursor: pointer;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    box-shadow: 0 4px 16px rgba(44, 32, 22, 0.1);
    transition:
        background 0.3s,
        border-color 0.3s;
}
.mob-toggle span {
    display: block;
    width: 18px;
    height: 1.5px;
    background: var(--terra);
    transition:
        transform 0.3s,
        opacity 0.3s;
}
.mob-toggle.active span:nth-child(1) {
    transform: translateY(6.5px) rotate(45deg);
}
.mob-toggle.active span:nth-child(2) {
    opacity: 0;
}
.mob-toggle.active span:nth-child(3) {
    transform: translateY(-6.5px) rotate(-45deg);
}
.mob-toggle.dark {
    background: rgba(30, 20, 12, 0.82);
    border-color: rgba(232, 213, 168, 0.3);
}
.mob-toggle.dark span {
    background: var(--champ);
}

.mob-drawer {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 590;
    background: rgba(30, 20, 12, 0.92);
    backdrop-filter: blur(18px);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
}
.mob-drawer.open {
    opacity: 1;
    pointer-events: auto;
}
.mob-drawer a {
    display: block;
    text-decoration: none;
    color: var(--cream);
    font-family: "Cormorant Garamond", serif;
    font-weight: 300;
    font-size: clamp(1.3rem, 4vw, 1.8rem);
    letter-spacing: 2px;
    padding: 12px 0;
    opacity: 0.7;
    transition:
        opacity 0.3s,
        color 0.3s;
}
.mob-drawer a:hover,
.mob-drawer a:active {
    opacity: 1;
    color: var(--champ);
}
.mob-drawer a.active {
    opacity: 1;
    color: var(--champ);
    position: relative;
}
.mob-drawer a.active::before {
    content: "";
    position: absolute;
    left: -16px;
    top: 50%;
    transform: translateY(-50%);
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--terra);
}

@media (max-width: 900px) {
    .mob-toggle {
        display: flex;
    }
    .mob-drawer {
        display: flex;
    }
}

/* Toast */
#toast {
    position: fixed;
    bottom: 34px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: var(--sage-d);
    color: var(--cream);
    padding: 16px 44px;
    border-radius: 2px;
    font-weight: 300;
    font-size: 0.88rem;
    opacity: 0;
    pointer-events: none;
    z-index: 900;
    transition:
        opacity 0.4s,
        transform 0.4s;
    box-shadow: 0 10px 36px rgba(0, 0, 0, 0.2);
}
#toast.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* ══════════════════════════════════════════
   LIGHTBOX
══════════════════════════════════════════ */
#lightbox {
    position: fixed;
    inset: 0;
    z-index: 5000;
    background: rgba(14, 9, 6, 0.97);
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.45s ease;
}
#lightbox.open {
    opacity: 1;
}
#lb-close {
    position: absolute;
    top: 24px;
    right: 28px;
    background: none;
    border: none;
    color: rgba(250, 245, 238, 0.5);
    font-size: 1.8rem;
    cursor: none;
    z-index: 10;
    transition:
        color 0.25s,
        transform 0.25s;
    line-height: 1;
    padding: 8px;
}
#lb-close:hover {
    color: var(--cream);
    transform: rotate(90deg);
}
#lb-counter {
    position: absolute;
    top: 28px;
    left: 50%;
    transform: translateX(-50%);
    font-weight: 200;
    font-size: 0.6rem;
    letter-spacing: 5px;
    color: rgba(250, 245, 238, 0.35);
}
.lb-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(200, 88, 42, 0.12);
    border: 1px solid rgba(200, 88, 42, 0.3);
    color: var(--cream);
    font-size: 1.8rem;
    padding: 14px 18px;
    cursor: none;
    transition:
        background 0.3s,
        border-color 0.3s;
    z-index: 10;
    line-height: 1;
}
.lb-nav:hover {
    background: rgba(200, 88, 42, 0.3);
    border-color: var(--terra);
}
#lb-prev {
    left: 20px;
}
#lb-next {
    right: 20px;
}
#lb-img-wrap {
    width: 100%;
    height: calc(100vh - 150px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 90px;
}
#lb-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: 2px;
    transition: opacity 0.35s ease;
    display: block;
}
/* Film strip */
#lb-strip {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 88px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    background: linear-gradient(transparent, rgba(10, 6, 3, 0.8));
    overflow-x: auto;
    scrollbar-width: none;
}
#lb-strip::-webkit-scrollbar {
    display: none;
}
.lb-thumb {
    width: 64px;
    height: 64px;
    flex-shrink: 0;
    border-radius: 2px;
    overflow: hidden;
    cursor: none;
    opacity: 0.45;
    border: 2px solid transparent;
    transition:
        opacity 0.3s,
        border-color 0.3s,
        transform 0.3s;
}
.lb-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.lb-thumb.active {
    opacity: 1;
    border-color: var(--terra);
    transform: scale(1.08);
}
.lb-thumb:hover {
    opacity: 0.8;
}

/* ══════════════════════════════════════════
   TOUCH DEVICES — disable custom cursor
══════════════════════════════════════════ */
@media (hover: none), (pointer: coarse) {
    body {
        cursor: auto !important;
    }
    #cur-dot,
    #cur-ring {
        display: none !important;
    }
    button,
    a,
    [onclick] {
        cursor: pointer !important;
    }
    .pwd-input,
    .fg input,
    .fg select,
    .fg textarea {
        cursor: text !important;
    }
    .envelope,
    .mob-toggle,
    .mob-drawer a {
        cursor: pointer !important;
    }
}

/* ══════════════════════════════════════════
   RESPONSIVE — TABLET  ≤900px
══════════════════════════════════════════ */
@media (max-width: 900px) {
    /* Global */
    section {
        padding: 80px 28px;
        min-height: auto;
    }
    .nav-dots,
    #scroll-ctr {
        display: none;
    }
    .wrap {
        padding: 0;
    }

    /* ── Bienvenue ── */
    .bv-hero {
        height: 400px;
        margin-bottom: 36px;
    }

    /* ── Alliances ── */
    .al-grid {
        grid-template-columns: 1fr;
    }
    .al-photo {
        height: 340px;
    }
    .al-photo:last-child {
        display: none;
    }

    /* ── Histoire ── */
    #histoire {
        padding-top: 0;
    }
    .hist-grid {
        grid-template-columns: 1fr;
        gap: 48px;
        padding: 80px 0;
        min-height: auto;
        align-items: start;
    }
    .photo-stack {
        height: 380px;
    }
    .ps-accent {
        display: none;
    }
    .ps-main {
        width: 100%;
        height: 100%;
        position: relative;
        top: auto;
        left: auto;
    }
    .ps-badge {
        top: 14px;
        right: 14px;
    }

    /* ── Save the Date ── */
    .std-cards {
        grid-template-columns: 1fr;
        max-width: 100%;
    }
    .venue-strip {
        grid-column: 1;
        height: 200px;
    }
    .countdown {
        gap: 16px;
        margin: 28px 0;
    }
    .cd-sep {
        font-size: 1.5rem;
        margin-top: 4px;
    }

    /* ── Programme / Timeline — show ALL content on mobile ── */
    .prog-head {
        margin-bottom: 56px;
    }
    .tl-spine {
        left: 20px;
        transform: translateX(0) scaleY(0);
    }
    .tl-row {
        grid-template-columns: 40px 1fr;
        grid-template-rows: auto auto;
        gap: 0;
        margin-bottom: 40px;
    }
    .tl-c {
        grid-column: 1;
        grid-row: 1/-1;
        order: unset !important;
        justify-content: flex-start;
        padding-top: 2px;
    }
    .tl-l,
    .tl-r,
    .tl-row:nth-child(even) .tl-l,
    .tl-row:nth-child(even) .tl-r {
        grid-column: 2;
        display: block !important;
        text-align: left !important;
        padding: 0 0 4px 16px !important;
    }
    /* Odd rows: time (.tl-l) first, content (.tl-r) second */
    .tl-row:nth-child(odd) .tl-l {
        order: 1;
    }
    .tl-row:nth-child(odd) .tl-r {
        order: 2;
    }
    /* Even rows: time (.tl-r) first, content (.tl-l) second */
    .tl-row:nth-child(even) .tl-r {
        order: 1;
    }
    .tl-row:nth-child(even) .tl-l {
        order: 2;
    }
    .tl-node {
        width: 12px;
        height: 12px;
        box-shadow:
            0 0 0 3px var(--cream-d),
            0 0 0 5px rgba(200, 88, 42, 0.28);
    }
    .cal-row {
        gap: 10px;
        margin-top: 36px;
    }

    /* ── RSVP ── */
    .row2 {
        grid-template-columns: 1fr;
    }
    .rsvp-form {
        padding: 0;
    }
    #rsvp {
        padding: 80px 28px;
    }

    /* ── Cadeaux ── */
    .cad-grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }
    .qr-scene {
        align-items: center;
    }

    /* ── Galerie ── */
    #galerie {
        padding: 80px 24px 60px;
    }
    .gal-grid {
        grid-template-columns: 1fr 1fr;
        grid-auto-rows: 220px;
        gap: 10px;
    }
    .gal-card {
        grid-column: unset !important;
        grid-row: unset !important;
    }
    .gal-card:nth-child(1) {
        grid-column: 1/-1 !important;
    }

    /* ── Hébergement ── */
    .bnb-card {
        max-width: 100%;
        width: 100%;
    }
    .bnb-img {
        height: 220px;
    }

    /* ── Message ── */
    .msg-wrap {
        max-width: 100%;
    }
    .msg-photo {
        height: 360px;
    }

    /* ── Lightbox ── */
    .lb-nav {
        display: none;
    }
    #lb-img-wrap {
        padding: 0 16px;
        height: calc(100vh - 130px);
    }
    .lb-thumb {
        width: 52px;
        height: 52px;
    }
}

/* ══════════════════════════════════════════
   RESPONSIVE — MOBILE  ≤600px
══════════════════════════════════════════ */
@media (max-width: 600px) {
    /* Global */
    section {
        padding: 64px 20px;
    }
    h2 {
        font-size: var(--fs-heading, clamp(2rem, 9vw, 3rem)) !important;
    }
    .eyebrow {
        font-size: var(--fs-label, 0.56rem);
        letter-spacing: 4px;
    }
    .wrap {
        padding: 0;
    }

    /* ── Password screen ── */
    .pwd-logo {
        font-size: 2.2rem;
    }
    .pwd-sub {
        font-size: 0.52rem;
        letter-spacing: 5px;
    }
    .pwd-input {
        width: 100%;
        max-width: 260px;
        padding: 14px 18px;
        letter-spacing: 6px;
    }
    .pwd-btn {
        padding: 13px 36px;
        font-size: 0.58rem;
    }
    .pwd-hint {
        font-size: 0.5rem;
    }

    /* ── Preloader ── */
    .pre-monogram {
        font-size: 3rem;
    }
    .pre-bar-wrap {
        width: 120px;
    }

    /* ── Envelope screen ── */
    #env-screen {
        padding: 20px;
    }
    .env-title {
        font-size: 1.7rem;
    }
    .env-wrap {
        gap: 16px;
    }
    .env-letter {
        padding: 18px 14px;
        width: calc(100% - 40px);
    }
    .letter-monogram {
        font-size: 1.7rem;
    }
    .letter-date-txt {
        font-size: 0.56rem;
    }
    .letter-venue-txt {
        font-size: 0.88rem;
    }
    .env-hint {
        font-size: 0.56rem;
        letter-spacing: 4px;
    }
    .bl-tl {
        width: 200px;
    }
    .bl-br {
        width: 170px;
    }
    .bl-tr,
    .bl-bl {
        display: none;
    }

    /* ── Bienvenue ── */
    #bienvenue {
        padding: 64px 20px;
    }
    .bv-hero {
        height: 260px;
        margin-bottom: 28px;
    }
    #bienvenue p {
        font-size: 0.96rem !important;
    }
    #bienvenue .msg-quote,
    #bienvenue em {
        font-size: 1.1rem !important;
    }

    /* ── Alliances ── */
    #alliances {
        padding: 64px 20px;
    }
    .al-grid {
        gap: 12px;
    }
    .al-photo {
        height: 280px;
    }
    #alliances p {
        font-size: 0.95rem !important;
    }

    /* ── Histoire ── */
    #histoire {
        padding: 0 20px;
    }
    .hist-grid {
        padding: 64px 0;
        gap: 36px;
    }
    .photo-stack {
        height: 260px;
    }
    .ps-badge {
        font-size: 0.48rem;
        padding: 6px 10px;
    }
    .hist-text p {
        font-size: 0.93rem;
        line-height: 1.85;
    }
    .sig-row {
        margin-top: 8px;
    }
    .sig-row .signature {
        font-size: var(--fs-accent, 2rem);
    }
    .scroll-cue {
        bottom: 20px;
    }

    /* ── Save the Date ── */
    #save {
        padding: 64px 20px;
    }
    .std-pre {
        font-size: 0.68rem;
        letter-spacing: 5px;
    }
    .big-date {
        margin: 8px 0 4px;
    }
    .bd-day {
        letter-spacing: 5px;
        font-size: 0.95rem;
    }
    .bd-month {
        letter-spacing: 4px;
    }
    .countdown {
        gap: 6px;
        margin: 24px auto;
        width: 100%;
        justify-content: center;
        flex-wrap: nowrap;
    }
    .cd-block {
        gap: 4px;
    }
    .cd-num {
        font-size: clamp(1.8rem, 8vw, 2.8rem);
        min-width: 2.2ch;
    }
    .cd-lbl {
        font-size: 0.42rem;
        letter-spacing: 3px;
    }
    .cd-sep {
        font-size: 1rem;
        margin-top: 4px;
        align-self: flex-start;
        padding-top: 6px;
    }
    .std-sep {
        height: 32px;
        margin: 4px 0 20px;
    }
    .std-cards {
        gap: 12px;
    }
    .std-card {
        padding: 18px 14px;
    }
    .std-card h3 {
        font-size: 1.15rem;
    }
    .std-card p {
        font-size: 0.8rem;
    }
    .time-pill {
        font-size: 0.58rem;
        padding: 4px 10px;
    }
    .venue-strip {
        height: 150px;
    }
    .venue-overlay {
        padding: 0 20px;
    }
    .venue-txt h4 {
        font-size: 1.2rem;
    }

    /* ── Programme ── */
    #programme {
        padding: 64px 20px;
    }
    .prog-head {
        margin-bottom: 44px;
    }
    .tl-row {
        margin-bottom: 32px;
        grid-template-columns: 36px 1fr;
    }
    .tl-time {
        font-size: 1.3rem;
    }
    .tl-label {
        font-size: var(--fs-subheading, 0.96rem);
        margin-bottom: 3px;
    }
    .tl-desc {
        font-size: 0.78rem;
        line-height: 1.6;
    }
    .cal-row {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
        margin-top: 32px;
    }
    .btn-cal {
        width: 100%;
        justify-content: center;
        padding: 13px 20px;
        font-size: 0.6rem;
    }

    /* ── RSVP ── */
    #rsvp {
        padding: 64px 20px;
    }
    .rsvp-sub {
        font-size: 0.88rem;
        margin: 12px auto 28px;
        max-width: 100%;
    }
    .rsvp-form {
        gap: 14px;
    }
    .fg label {
        font-size: 0.52rem;
        letter-spacing: 3px;
    }
    .fg input,
    .fg select,
    .fg textarea {
        font-size: 1rem; /* prevent iOS zoom */
        padding: 13px 14px;
    }
    .fg textarea {
        min-height: 80px;
    }
    .btn-rsvp {
        width: 100%;
        padding: 16px 20px;
        font-size: 0.6rem;
        letter-spacing: 4px;
        align-self: stretch;
        margin-top: 4px;
    }
    #rsvp-thanks {
        padding: 32px 12px;
    }
    .thanks-heart {
        font-size: 2.4rem;
        margin-bottom: 16px;
    }
    .thanks-title {
        font-size: 2rem;
    }
    .thanks-msg {
        font-size: 0.88rem;
    }
    .thanks-sig {
        font-size: 1.1rem;
    }

    /* ── Cadeaux ── */
    #cadeaux {
        padding: 64px 20px;
    }
    .cad-text p {
        font-size: 0.92rem;
        line-height: 1.85;
    }
    .cad-aside {
        font-size: 1rem;
    }
    .qr-card {
        padding: 14px;
    }
    .qr-scene svg {
        width: 140px !important;
        height: 140px !important;
    }
    .qr-note {
        font-size: 0.56rem;
        max-width: 160px;
    }

    /* ── Galerie ── */
    #galerie {
        padding: 64px 16px 48px;
    }
    .gal-head {
        margin-bottom: 28px;
    }
    .gal-grid {
        grid-template-columns: 1fr;
        grid-auto-rows: 250px;
        gap: 8px;
    }
    .gal-card {
        grid-column: 1/-1 !important;
        grid-row: unset !important;
    }
    .gal-num {
        font-size: 0.48rem;
    }

    /* ── Hébergement ── */
    #hebergement {
        padding: 64px 20px;
    }
    .bnb-sub {
        font-size: 0.9rem;
        margin: 10px auto 32px;
    }
    .bnb-card {
        max-width: 100%;
    }
    .bnb-img {
        height: 180px;
    }
    .bnb-body {
        padding: 20px 18px;
    }
    .bnb-body h3 {
        font-size: 1.25rem;
    }
    .bnb-body p {
        font-size: 0.82rem;
        margin-bottom: 16px;
    }
    .btn-bnb {
        display: block;
        text-align: center;
        padding: 12px 24px;
        font-size: 0.6rem;
    }

    /* ── Message final ── */
    #message {
        padding: 64px 20px;
    }
    .msg-wrap {
        max-width: 100%;
    }
    .msg-photo {
        height: 240px;
        margin-bottom: 40px;
    }
    .msg-quote {
        font-size: 1rem;
        line-height: 1.85;
    }
    .msg-quote::before {
        font-size: 4rem;
        top: -18px;
    }
    .msg-sig {
        font-size: 2.4rem;
    }
    .msg-dt {
        font-size: 0.58rem;
        letter-spacing: 4px;
    }

    /* ── Footer ── */
    footer {
        padding: 24px 16px;
    }
    footer p {
        font-size: 0.52rem;
        letter-spacing: 1.5px;
    }

    /* ── Lightbox ── */
    #lightbox {
        padding: 0;
    }
    #lb-close {
        font-size: 1.4rem;
        top: 14px;
        right: 14px;
        padding: 6px;
    }
    #lb-counter {
        font-size: 0.52rem;
        top: 16px;
        letter-spacing: 4px;
    }
    #lb-img-wrap {
        height: calc(100vh - 100px);
        padding: 0 12px;
    }
    #lb-strip {
        height: 66px;
        padding: 10px 14px;
        gap: 6px;
    }
    .lb-thumb {
        width: 44px;
        height: 44px;
    }
}

/* ══════════════════════════════════════════
   RESPONSIVE — SMALL MOBILE  ≤400px
══════════════════════════════════════════ */
@media (max-width: 400px) {
    section {
        padding: 56px 16px;
    }

    /* Countdown stays in one row */
    .countdown {
        gap: 2px;
    }
    .cd-num {
        font-size: 1.7rem;
        min-width: 2ch;
    }
    .cd-lbl {
        font-size: 0.38rem;
        letter-spacing: 2px;
    }
    .cd-sep {
        font-size: 0.85rem;
    }

    /* Photos smaller */
    .bv-hero {
        height: 210px;
    }
    .al-photo {
        height: 220px;
    }
    .photo-stack {
        height: 220px;
    }
    .msg-photo {
        height: 200px;
    }
    .bnb-img {
        height: 150px;
    }
    .venue-strip {
        height: 130px;
    }

    /* Password */
    .pwd-logo {
        font-size: 1.9rem;
    }
    .pwd-input {
        padding: 12px 14px;
    }

    /* RSVP sub */
    .rsvp-sub {
        font-size: 0.82rem;
    }
    .fg input,
    .fg select,
    .fg textarea {
        padding: 12px 12px;
    }

    /* Envelope letter clips on 400px */
    .env-letter {
        width: calc(100% - 20px);
    }
    .letter-monogram {
        font-size: 1.5rem;
    }
}

/* ══════════════════════════════════════════
   PRINT STYLESHEET — Programme only
══════════════════════════════════════════ */
@media print {
    #pwd-screen,
    #preloader,
    #env-screen,
    #main-site > *:not(#programme),
    .nav-dots,
    #scroll-ctr,
    #pgbar,
    #cur-dot,
    #cur-ring,
    footer,
    #lightbox,
    #toast,
    .scroll-cue,
    .cal-row {
        display: none !important;
    }
    body {
        cursor: auto !important;
        background: #fff !important;
        color: #000 !important;
    }
    #programme {
        display: block !important;
        padding: 20mm;
        min-height: auto;
    }
    .prog-head h2 {
        font-size: 28pt;
        color: #2a1f14;
    }
    .tl-time {
        color: #c8582a;
    }
    .tl-node {
        box-shadow: none;
        border: 2px solid #c8582a;
        transform: scale(1) !important;
    }
    .tl-spine {
        display: none;
    }
    .tl-desc,
    .tl-label {
        color: #333;
    }
    .g-up,
    .g-clip,
    .g-left,
    .g-right,
    .g-sc,
    .char {
        opacity: 1 !important;
        transform: none !important;
        clip-path: none !important;
    }
}


/* ═══ REDUCED MOTION — respect user accessibility preference ═══ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}