  /* ============ RESET & BASE ============ */
  *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    font-family: 'Cormorant Garamond', 'Times New Roman', serif;
    font-weight: 300;
    background: #FFFFFF;
    color: #3a3a3a;
    line-height: 1.6;
    overflow-x: hidden;
  }
  img { max-width: 100%; height: auto; display: block; }
  a { color: inherit; text-decoration: none; }

  /* ============ COLOR & TYPE TOKENS ============ */
  :root {
    --cream: #FFFFFF;
    --cream-2: #FAF7F1;
    --gold: #B8956A;
    --gold-dark: #9A7C58;
    --gold-light: #D4B98E;
    --burgundy: #7A1F2D;
    --burgundy-dark: #5F1824;
    --burgundy-soft: #A85D68;
    --khaki: #59613F;
    --khaki-dark: #343B27;
    --champagne: #E7D5B4;
    --champagne-light: #F8EBD0;
    --ivory: #FFF9EF;
    --ink: #3a3a3a;
    --ink-soft: #5a5a5a;
    --slate: #2E3A47;
    --slate-deep: #232C36;
  }

  .display-serif { font-family: 'Cinzel', 'Cormorant Garamond', serif; }
  .body-serif    { font-family: 'Cormorant Garamond', serif; }
  .script        { font-family: 'Pinyon Script', cursive; }
  .label         { font-family: 'Montserrat', sans-serif; font-weight: 400; letter-spacing: 0.32em; text-transform: uppercase; font-size: 11px; }

  /* ============ TOP NAV ============ */
  .nav {
    position: fixed; top: 0; left: 0; right: 0;
    display: flex; justify-content: center; align-items: center; gap: 2.5rem;
    padding: 1.4rem 2rem;
    background: rgba(248,244,237,0.0);
    z-index: 50;
    transition: background .35s ease, box-shadow .35s ease;
  }
  .nav.scrolled {
    background: rgba(255,255,255,0.96);
    box-shadow: 0 1px 0 rgba(184,149,106,0.15);
  }
  .nav a {
    position: relative;
    font-family: 'Montserrat', sans-serif;
    font-weight: bold;
    font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
    color: #fff; text-shadow: 0 1px 8px rgba(0,0,0,0.45);
    transition: color .25s ease;
  }
  .nav a + a::before {
    content: "";
    position: absolute;
    left: -1.35rem;
    top: 50%;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.74;
    transform: translate(-50%, -50%);
  }
  .nav.scrolled a { color: var(--ink); text-shadow: none; }
  .nav a:hover { color: var(--burgundy); }
  .nav .lang {
    background: var(--gold); color: #fff !important;
    padding: 0.55rem 1rem; text-shadow: none !important;
    transition: background .25s ease;
  }
  .nav .lang:hover { background: var(--burgundy-dark); color: #fff !important; }

  /* ============ HERO ============ */
  .hero {
    position: relative;
    height: 100vh;
    min-height: 720px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #1a1a1a;
  }

  /* Slideshow / video container — replace the .slide divs with <img> or a <video> tag */
  .hero-media {
    position: absolute; inset: 0; z-index: 0;
  }
  .hero-media video,
  .hero-media .slide {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    background-size: cover; background-position: center;
  }
  .hero-media .slide {
    opacity: 0;
    transition: opacity 1.6s ease-in-out;
  }
  .hero-media .slide.active { opacity: 1; }

  .hero-content::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 760px;
    max-width: 80vw;
    height: 420px;
    max-height: 55vh;
    transform: translate(-50%, -50%);
    z-index: -1;
    pointer-events: none;
    border-radius: 999px;
    background: radial-gradient(
      circle at center,
      rgba(20, 25, 32, 0.42) 0%,
      rgba(20, 25, 32, 0.28) 42%,
      rgba(20, 25, 32, 0.12) 68%,
      rgba(20, 25, 32, 0) 100%
    );
    filter: blur(20px);
  }

  .hero-content * {
    text-shadow: 0 3px 18px rgba(0, 0, 0, 0.28);
  }

  .hero-media picture.slide,
  .hero-media picture.slide img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }

  .hero-media picture.slide img {
    object-fit: cover;
  }

  /* Placeholder slide gradients (replaced when real photos are added) */
  .slide-1 {
    background-image:
      linear-gradient(135deg, rgba(0,0,0,0.25), rgba(0,0,0,0.45)),
      linear-gradient(160deg, #6b8aa0 0%, #3f5b75 50%, #1f3349 100%);
  }
  .slide-2 {
    background-image:
      linear-gradient(180deg, rgba(0,0,0,0.20), rgba(0,0,0,0.50)),
      linear-gradient(135deg, #c9b393 0%, #8e7b5c 50%, #4a3f2d 100%);
  }
  .slide-3 {
    background-image:
      linear-gradient(180deg, rgba(0,0,0,0.20), rgba(0,0,0,0.45)),
      linear-gradient(135deg, #7e9c75 0%, #4a6650 50%, #1f2e23 100%);
  }
  .slide-4 {
    background-image:
      linear-gradient(180deg, rgba(0,0,0,0.20), rgba(0,0,0,0.45)),
      linear-gradient(135deg, #d9a6a0 0%, #a57d7f 50%, #4a3134 100%);
  }
  .slide-5 {
    background-image:
      linear-gradient(180deg, rgba(0,0,0,0.20), rgba(0,0,0,0.55)),
      linear-gradient(135deg, #d4b89a 0%, #8a6b48 50%, #3a2c1a 100%);
  }

  /* Slideshow indicators */
  .hero-indicators {
    position: absolute; bottom: 5.5rem; left: 50%;
    transform: translateX(-50%); z-index: 3;
    display: flex; gap: 10px;
  }
  .hero-indicators button {
    width: 22px; height: 2px; border: none;
    background: rgba(255,255,255,0.45); cursor: pointer;
    padding: 0; transition: background .3s ease;
  }
  .hero-indicators button.active { background: var(--ivory); }
  .hero-content {
    position: relative; z-index: 2;
    text-align: center; color: #fff;
    padding: 0 1.5rem;
  }
  .hero .overline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.7rem 1.05rem 0.7rem 1.38rem;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px; letter-spacing: 0.55em; text-transform: uppercase;
    color: #fff; opacity: 1; margin-bottom: 1.6rem;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.42);
    border-radius: 999px;
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(10px);
    text-shadow: 0 2px 14px rgba(0,0,0,0.85), 0 1px 3px rgba(0,0,0,0.7);
  }
  .hero .monogram {
    font-family: 'Cormorant Garamond', serif; font-weight: 300;
    font-size: clamp(80px, 13vw, 145px);
    line-height: 1; color: #fff;
    text-shadow:
      0 2px 30px rgba(0,0,0,0.9),
      0 4px 14px rgba(0,0,0,0.7),
      0 1px 3px rgba(0,0,0,0.6);
  }
  .hero .monogram .amp {
    font-family: 'Pinyon Script', cursive; font-weight: 400;
    font-size: clamp(70px, 11vw, 150px);
    color: var(--ivory);
    margin: 0 0.15em;
    vertical-align: 0.05em;
    text-shadow:
      0 2px 24px rgba(0,0,0,0.85),
      0 4px 12px rgba(0,0,0,0.6);
  }
  .hero .script-name {
    font-family: 'Pinyon Script', cursive;
    font-size: clamp(48px, 7vw, 96px);
    color: var(--ivory);
    line-height: 1.1;
    margin-top: 0.5rem;
    text-shadow:
      0 2px 22px rgba(0,0,0,0.85),
      0 4px 12px rgba(0,0,0,0.65),
      0 1px 3px rgba(0,0,0,0.5);
  }
  .hero .date {
    margin-top: 2.2rem;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px; letter-spacing: 0.6em; text-transform: uppercase;
    color: #fff; opacity: 1;
    text-shadow: 0 2px 14px rgba(0,0,0,0.85), 0 1px 3px rgba(0,0,0,0.7);
  }
  .hero .date-line {
    display: inline-flex; align-items: center; gap: 1.2rem;
    margin-top: 0.6rem;
  }
  .hero .date-line span {
    width: 60px; height: 1px; background: rgba(255,249,239,0.86);
  }
  .hero .scroll-cue {
    position: absolute; bottom: 1.6rem; left: 50%; transform: translateX(-50%);
    z-index: 3; color: var(--ivory);
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 0.4em; text-transform: uppercase;
    opacity: 0.95;
    text-shadow: 0 2px 10px rgba(0,0,0,0.7);
    animation: bob 2.4s ease-in-out infinite;
  }
  .hero .scroll-cue::after {
    content: ""; display: block; width: 1px; height: 32px;
    background: rgba(255,249,239,0.86); margin: 0.6rem auto 0;
  }
  @keyframes bob {
    0%, 100% { transform: translate(-50%, 0); }
    50%      { transform: translate(-50%, 6px); }
  }

  /* ============ SECTION RYTHM ============ */
  section { padding: 7rem 2rem; }
  .container { max-width: 1180px; margin: 0 auto; }
  .section-eyebrow {
    text-align: center;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px; font-weight: 500;
    letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--burgundy);
    margin-bottom: 1rem;
  }
  .section-title {
    text-align: center;
    font-family: 'Cinzel', 'Cormorant Garamond', serif;
    font-weight: 500;
    font-size: clamp(28px, 4vw, 44px);
    letter-spacing: 0.16em;
    color: var(--burgundy);
    text-transform: uppercase;
    line-height: 1.25;
  }
  .section-sub {
    text-align: center;
    font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-weight: 500;
    font-size: clamp(19px, 2.2vw, 24px);
    color: var(--ink);
    margin-top: 0.8rem;
  }
  .divider-line {
    display: flex; align-items: center; justify-content: center;
    margin: 1.8rem auto 0;
  }
  .divider-line::before, .divider-line::after {
    content: ""; width: 60px; height: 1px; background: var(--burgundy);
  }
  .divider-line span {
    width: 6px; height: 6px; border-radius: 50%; border: 1px solid var(--burgundy);
    margin: 0 14px;
  }

  /* Vertical line + notch (like chateaunainville right-aligned headings) */
  .v-mark {
    display: inline-block; position: relative;
    padding-left: 22px; text-align: left;
  }
  .v-mark::before {
    content: ""; position: absolute; left: 0; top: 0; bottom: 0;
    width: 1px; background: var(--burgundy);
  }
  .v-mark::after {
    content: ""; position: absolute; left: -3px; top: 50%; width: 7px; height: 7px;
    background: var(--cream); border: 1px solid var(--burgundy); transform: translateY(-50%);
  }

  /* ============ ORNAMENTAL CREST ============ */
  .crest {
    margin: 0 auto;
    width: 110px; height: 110px;
    color: var(--burgundy);
  }

  /* ============ COUNTDOWN ============ */
  .countdown-section {
    padding: 5rem 2rem 3rem;
    background: var(--cream);
    text-align: center;
  }
  .countdown {
    display: flex; justify-content: center; gap: clamp(1rem, 4vw, 4rem);
    flex-wrap: wrap;
    margin-top: 1.5rem;
  }
  .countdown .unit {
    min-width: 90px;
  }
  .countdown .num {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 300;
    font-size: clamp(40px, 5vw, 64px);
    color: var(--burgundy);
    line-height: 1;
  }
  .countdown .lbl {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px; font-weight: 500;
    letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--ink); margin-top: 0.7rem;
  }

  /* ============ SPLIT SECTION (image + text) ============ */
  .split {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 4rem; align-items: center;
  }
  .split.reverse { direction: rtl; }
  .split.reverse > * { direction: ltr; }
  .split-text { padding: 3rem 1rem; }
  .split-text h2 {
    font-family: 'Cinzel', serif; font-weight: 400;
    font-size: clamp(26px, 3vw, 38px); letter-spacing: 0.16em;
    color: var(--burgundy); text-transform: uppercase;
    line-height: 1.3;
  }
  .split-text .eyebrow {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px; font-weight: 500;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--ink); margin-top: 0.7rem;
  }
  .split-text p {
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px; color: var(--ink);
    margin-top: 1.6rem; line-height: 1.8;
    font-weight: 400;
  }

  /* Image collage with offset */
  .photo-collage {
    position: relative;
    height: 540px;
  }
  .photo-collage .ph {
    position: absolute;
    background-size: cover; background-position: bottom;
    overflow: hidden;
    box-shadow: 0 20px 46px rgba(95,24,36,0.16);
  }
  
  .photo-collage .ph::after {
    content: "";
    position: absolute;
    inset: 12px;
    /* border: 1px solid rgba(255,249,239,0.72); */
    border-radius: inherit;
    pointer-events: none;
  }
  
  .photo-collage .ph-1 {
    width: 62%; height: 78%; left: 0; top: 11%;
    border-radius: 48% 48% 14px 14px / 32% 32% 14px 14px;
  }
  .photo-collage .ph-2 {
    width: 56%; height: 72%; right: 0%; top: 0;
    border-radius: 56% 44% 52% 48% / 42% 58% 42% 58%;
  }

  /* Single image */
  .photo-single {
    position: relative;
    height: 540px;
    background-size: cover; background-position: center;
    box-shadow: 0 14px 36px rgba(46,58,71,0.15);
  }

  /* Photo placeholders use elegant layered SVG gradients */
  .ph-chateau {
    background:
      linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.25)),
      linear-gradient(180deg, #C8D6E0 0%, #A9BDCC 45%, #DDC8A8 100%);
  }
  .ph-couple {
      background-image: url("photos/3-_Tr6U-6.webp");
  }
  .ph-jardin {
    background:
      linear-gradient(180deg, rgba(0,0,0,0.0), rgba(0,0,0,0.18)),
      linear-gradient(180deg, #B5C9A7 0%, #7E9C75 50%, #4A6650 100%);
  }
  .ph-salon {
    background:
      linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.15)),
      linear-gradient(135deg, #F1E3CD 0%, #DBC195 70%, #B8956A 100%);
  }
  .ph-fleurs {
      background-image: url("photos/4-tSSboaT.webp");
  }
  .ph-banquet {
    background:
      linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.18)),
      linear-gradient(135deg, #ECE2D0 0%, #D6C9AE 60%, #98875F 100%);
  }

  /* ============ EXPLORE GRID ============ */
  .explore-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem;
    margin-top: 3rem;
  }
  .explore-card {
    position: relative; height: 380px; overflow: hidden;
    background-size: cover; background-position: center;
    box-shadow: 0 8px 22px rgba(0,0,0,0.12);
  }
  .explore-card::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.0) 40%, rgba(0,0,0,0.55) 100%);
  }
  .explore-card .caption {
    position: absolute; left: 0; right: 0; bottom: 1.2rem; z-index: 2;
    text-align: center;
    font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-size: 22px; color: #fff;
    text-shadow: 0 2px 10px rgba(0,0,0,0.5);
  }

  /* ============ PROGRAMME / TIMELINE ============ */
  .programme {
    background: var(--cream-2);
  }
  .programme-intro {
    max-width: 700px;
    margin: 1.8rem auto 0;
    text-align: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(19px, 2.2vw, 24px);
    font-style: italic;
    font-weight: 400;
    line-height: 1.75;
    color: var(--ink);
  }
  .programme-location {
    max-width: 720px;
    margin: 2rem auto 0;
    padding: 1.15rem 1.4rem;
    text-align: center;
    background: #fff;
    border: 1px solid rgba(122,31,45,0.16);
    box-shadow: 0 18px 45px rgba(46,58,71,0.08);
  }
  .programme-location .location-label {
    display: block;
    margin-bottom: 0.35rem;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--burgundy);
  }
  .programme-location p {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(18px, 2vw, 22px);
    font-weight: 500;
    line-height: 1.5;
    color: var(--ink);
  }
  .timeline {
    margin-top: 3.5rem;
    max-width: 820px; margin-left: auto; margin-right: auto;
    position: relative;
  }
  .ti-row .info .desc {
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    color: var(--ink-soft);
    line-height: 1.65;
    margin-top: 0.55rem;
  }
  .timeline::before {
    content: ""; position: absolute;
    left: 194px; top: 0; bottom: 0; width: 1px;
    background: rgba(122,31,45,0.34);
  }
  .ti-row {
    position: relative;
    display: grid; grid-template-columns: 170px 48px 1fr;
    gap: 1.2rem; align-items: start;
    padding: 1.6rem 0;
  }
  .ti-row .time {
    font-family: 'Cinzel', serif;
    font-size: clamp(18px, 2.2vw, 24px); letter-spacing: 0.08em;
    color: var(--burgundy); text-align: right;
    line-height: 1.35;
    padding-top: 0.15rem;
  }
  .ti-row.right .time { order: initial; text-align: right; }
  .ti-row .dot {
    width: 12px; height: 12px; border-radius: 50%;
    background: var(--cream); border: 1.5px solid var(--burgundy);
    justify-self: center; position: relative; z-index: 2;
    margin-top: 0.55rem;
  }
  .ti-row .info {
    text-align: left;
  }
  .ti-row.right .info { order: initial; text-align: left; }
  .ti-row .info h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 22px; font-weight: 500;
    color: var(--ink); letter-spacing: 0.04em;
  }
  .ti-row .info p {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px; font-weight: 400;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--ink); margin-top: 0.4rem;
  }

  /* ============ DRESS CODE ============ */
  .dress-code {
    position: relative;
    overflow: hidden;
    padding: 3.8rem 2rem;
    background:
      linear-gradient(90deg, rgba(89,97,63,0.07) 0 1px, transparent 1px 100%),
      linear-gradient(180deg, rgba(122,31,45,0.045) 0 1px, transparent 1px 100%),
      linear-gradient(135deg, #fffaf1 0%, #fbf4e8 48%, #f5ead8 100%);
    background-size: 48px 48px, 48px 48px, auto;
  }

  .dc-editorial {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.6rem;
    margin: 2rem auto 0;
    max-width: 980px;
  }
  .dc-copy-panel {
    position: relative;
    padding: clamp(1rem, 2vw, 1.45rem);
    background: rgba(255,255,255,0.72);
    border: 1px solid rgba(122,31,45,0.16);
    box-shadow: 0 24px 60px rgba(46,58,71,0.10);
    backdrop-filter: blur(4px);
  }
  .dc-copy-panel::before {
    content: "";
    position: absolute;
    inset: 12px;
    border: 1px solid rgba(184,149,106,0.25);
    pointer-events: none;
  }
  .dc-copy-panel > * {
    position: relative;
    z-index: 1;
  }
  .dc-seal-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.7rem;
  }
  .dc-seal {
    width: 68px;
    height: 68px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: var(--burgundy);
    color: #fff;
    font-family: 'Cinzel', serif;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.12em;
    line-height: 1.25;
    text-align: center;
    text-transform: uppercase;
    box-shadow: 0 14px 30px rgba(122,31,45,0.24);
  }
  .dc-seal-text {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--gold-dark);
  }
  .dc-copy-panel h3 {
    font-family: 'Cinzel', serif;
    font-size: clamp(24px, 3vw, 34px);
    font-weight: 500;
    letter-spacing: 0.12em;
    color: var(--khaki-dark);
    line-height: 1.25;
    text-transform: uppercase;
  }
  .dc-copy-panel p {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(17px, 1.6vw, 19px);
    font-weight: 400;
    line-height: 1.42;
    color: var(--ink);
    margin-top: 0;
  }
  .dc-rule-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 0.8rem;
  }
  .dc-rule {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 0.9rem;
    align-items: start;
    padding: 0.55rem 0;
    border-top: 1px solid rgba(122,31,45,0.12);
  }
  .dc-rule-mark {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    font-family: 'Cinzel', serif;
    font-size: 15px;
    font-weight: 700;
  }
  .dc-rule strong {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--burgundy);
    margin-bottom: 0.18rem;
  }
  .dc-rule span:last-child {
    font-family: 'Cormorant Garamond', serif;
    font-size: 15px;
    line-height: 1.35;
    color: var(--ink-soft);
  }
  .dc-rule.dc-yes .dc-rule-mark {
    background: rgba(89,97,63,0.12);
    color: var(--khaki);
  }
  .dc-rule.dc-no .dc-rule-mark {
    background: rgba(122,31,45,0.09);
    color: var(--burgundy);
  }
  .dc-palette-line {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 0.8rem;
    border: 1px solid rgba(122,31,45,0.16);
  }
  .dc-tone {
    min-height: 58px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 0.65rem 0.8rem;
    color: #fff;
  }
  .dc-tone h4 {
    font-family: 'Cinzel', serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.13em;
    text-transform: uppercase;
  }
  .dc-tone p {
    font-family: 'Montserrat', sans-serif;
    font-size: 8px;
    font-style: normal;
    font-weight: 500;
    letter-spacing: 0.18em;
    line-height: 1.4;
    text-transform: uppercase;
    margin-top: 0.35rem;
    color: currentColor;
  }
  .dc-tone.khaki { background: var(--khaki); }
  .dc-tone.burgundy { background: var(--burgundy); }
  .dc-tone.champagne {
    background: var(--champagne);
    color: var(--khaki-dark);
  }
  .dc-moodboard {
    display: grid;
    grid-template-columns: 1fr 0.78fr;
    grid-template-rows: 1fr 1fr;
    gap: 1rem;
    min-height: 560px;
  }
  .dc-frame {
    position: relative;
    overflow: hidden;
    min-height: 180px;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.15), rgba(0,0,0,0.24)),
      var(--photo, linear-gradient(135deg, #59613F 0%, #7A1F2D 54%, #E7D5B4 100%));
    background-size: cover;
    background-position: center;
    box-shadow: 0 22px 48px rgba(46,58,71,0.16);
  }
  .dc-frame::before {
    content: "";
    position: absolute;
    inset: 12px;
    border: 1px solid rgba(255,255,255,0.38);
    pointer-events: none;
    z-index: 2;
  }
  .dc-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 35%, rgba(33,35,28,0.56) 100%);
  }
  .dc-frame.large {
    grid-row: span 2;
    min-height: 100%;
    background:
      linear-gradient(180deg, rgba(46,58,71,0.10), rgba(46,58,71,0.40)),
      var(--photo, linear-gradient(145deg, #353b29 0%, #59613F 42%, #d9c4a0 42% 59%, #7A1F2D 59% 100%));
  }
  .dc-frame.detail {
    background:
      linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.35)),
      var(--photo, radial-gradient(circle at 72% 28%, #E7D5B4 0 14%, transparent 15%), linear-gradient(135deg, #7A1F2D 0%, #4f1520 100%));
  }
  .dc-frame.palette {
    background:
      linear-gradient(90deg, var(--khaki) 0 34%, var(--burgundy) 34% 67%, var(--champagne) 67% 100%);
  }
  .dc-frame-caption {
    position: absolute;
    left: 1.4rem;
    right: 1.4rem;
    bottom: 1.2rem;
    z-index: 3;
    color: #fff;
  }
  .dc-frame-caption span {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    opacity: 0.85;
  }
  .dc-frame-caption strong {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(24px, 3vw, 34px);
    font-style: italic;
    font-weight: 500;
    line-height: 1.05;
    margin-top: 0.35rem;
  }
  .dc-gallery-wrap {
    margin-top: 1.8rem;
  }
  .dc-gallery-head {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.8rem;
    align-items: start;
    margin-bottom: 1rem;
    text-align: center;
  }
  .dc-gallery-head h3 {
    font-family: 'Cinzel', serif;
    font-size: clamp(20px, 2.4vw, 26px);
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--burgundy);
  }
  .dc-gallery-head p {
    font-family: 'Cormorant Garamond', serif;
    font-size: 16px;
    font-style: italic;
    font-weight: 400;
    line-height: 1.55;
    color: var(--ink-soft);
  }
  .dc-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 1rem;
  }
  .dc-photo-card {
    position: relative;
    min-height: 190px;
    overflow: hidden;
    background:
      linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.48)),
      var(--photo, linear-gradient(135deg, rgba(89,97,63,0.88), rgba(122,31,45,0.86)));
    background-size: cover;
    background-position: center;
    color: #fff;
    box-shadow: 0 18px 42px rgba(46,58,71,0.13);
  }
  .dc-photo-card.tall {
    min-height: 350px;
    background-position: center top;
  }
  .dc-photo-card.wide {
    min-height: 190px;
  }
  .dc-photo-card.champagne {
    background:
      linear-gradient(180deg, rgba(70,58,36,0.02), rgba(70,58,36,0.36)),
      var(--photo, linear-gradient(135deg, #E7D5B4, #F8EBD0));
    color: var(--khaki-dark);
  }
  .dc-photo-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.18), transparent 32%),
      linear-gradient(180deg, transparent 45%, rgba(0,0,0,0.36) 100%);
  }
  .dc-photo-card.champagne::before {
    background: linear-gradient(180deg, transparent 42%, rgba(154,124,88,0.26) 100%);
  }
  .dc-photo-label {
    position: absolute;
    left: 1.25rem;
    right: 1.25rem;
    bottom: 1.15rem;
    z-index: 1;
  }
  .dc-photo-label span {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.26em;
    text-transform: uppercase;
    opacity: 0.86;
  }
  .dc-photo-label strong {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px;
    font-style: italic;
    font-weight: 500;
    line-height: 1.1;
    margin-top: 0.3rem;
  }
  .dress-note {
    max-width: 900px;
    margin: 1.4rem auto 0;
    padding: 0.85rem 1.2rem;
    border-top: 1px solid rgba(122,31,45,0.24);
    border-bottom: 1px solid rgba(122,31,45,0.24);
    text-align: center;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--khaki-dark);
    line-height: 1.9;
  }

  .full-width-image {
    background-size: contain !important;
  }

  /* ============ INFOS PRATIQUES ============ */
  .infos {
    background: var(--cream);
  }
  .infos-grid {
    display: grid; grid-template-columns: repeat(1, 1fr); gap: 2.5rem;
    margin-top: 3.5rem;
  }
  .info-card {
    text-align: center;
    padding: 2.5rem 1.5rem;
    background: #fff;
    border: 1px solid rgba(184,149,106,0.18);
  }
  .info-card .ic-ico {
    width: 46px; height: 46px; margin: 0 auto 1rem; color: var(--burgundy);
  }
  .info-card h3 {
    font-family: 'Cinzel', serif; font-weight: 500;
    font-size: 17px; letter-spacing: 0.16em; color: var(--burgundy);
    text-transform: uppercase;
  }
  .info-card p {
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px; color: var(--ink); margin-top: 1rem; line-height: 1.75;
  }

  /* ============ RSVP ============ */
  .rsvp {
    background: var(--cream-2);
    text-align: center;
  }
  .rsvp-note {
     max-width: 680px;
    margin: 1.1rem auto 0;
    padding: 1rem 1.25rem;
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(17px, 2vw, 20px);
    line-height: 1.6;
    color: var(--ink);
    background: rgba(122,31,45,0.08);
    border: 1px solid rgba(122,31,45,0.18);
    border-left: 4px solid var(--burgundy);
    box-shadow: 0 14px 35px rgba(46,58,71,0.06);
  }
  .rsvp-note strong {
    display: block;
    margin-bottom: 0.25rem;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-style: normal;
    font-weight: 500;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--burgundy);
  }
  .rsvp form {
    max-width: 640px; margin: 3rem auto 0;
    display: grid; gap: 1.2rem;
    text-align: left;
  }
  .rsvp .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
  .rsvp label {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px; font-weight: 500;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--ink); margin-bottom: 0.5rem; display: block;
  }
   .rsvp input[type="text"], .rsvp input[type="email"], .rsvp input[type="tel"], .rsvp select, .rsvp textarea {
    width: 100%;
    background: #fff;
    border: 1px solid rgba(184,149,106,0.45);
    border-radius: 2px;
    padding: 0.85rem 1rem;
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px; color: var(--ink);
    outline: none;
    transition: border-color .2s ease, box-shadow .2s ease;
  }
  .rsvp input::placeholder, .rsvp textarea::placeholder {
    color: #9a9a9a; font-style: italic;
  }
  .rsvp input:focus, .rsvp select:focus, .rsvp textarea:focus {
    border-color: var(--burgundy);
    box-shadow: 0 0 0 3px rgba(184,149,106,0.15);
  }
  .rsvp textarea { resize: vertical; min-height: 110px; }
  .rsvp .radio-group { display: grid; gap: 0.85rem; margin-top: 0.6rem; }
  .rsvp .radio-group label {
    font-family: 'Cormorant Garamond', serif; font-size: 19px; font-weight: 400;
    letter-spacing: 0; text-transform: none; color: var(--ink);
    display: inline-flex; align-items: center; gap: 0.6rem; cursor: pointer;
    margin-bottom: 0;
  }
  .rsvp .radio-group input[type="radio"] {
    appearance: none; width: 16px; height: 16px; border-radius: 50%;
    border: 1.5px solid var(--burgundy); cursor: pointer; position: relative;
  }
  .rsvp .radio-group input[type="radio"]:checked::after {
    content: ""; position: absolute; inset: 3px;
    background: var(--burgundy); border-radius: 50%;
  }

  /* ============ BUTTONS ============ */
  .btn {
    display: inline-block;
    background: var(--burgundy); color: #fff;
    padding: 0.95rem 2.3rem;
    font-family: 'Montserrat', sans-serif;
    font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
    border: none; cursor: pointer;
    text-align: center;
    transition: background .25s ease, transform .25s ease;
  }
  .btn:hover { background: var(--burgundy-dark); }
  .btn-ghost {
    background: transparent; color: var(--burgundy);
    border: 1px solid var(--burgundy);
  }
  .btn-ghost:hover { background: var(--burgundy); color: #fff; }
  .center { text-align: center; }
  .mt-3 { margin-top: 2rem; }

  /* ============ FOOTER ============ */
  footer {
    background: var(--khaki);
    color: white;
    padding: 5rem 2rem 2rem;
  }
  .footer-grid {
    max-width: 1100px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 3rem;
    align-items: start;
  }
  footer .crest-foot { color: var(--gold-light); width: 92px; height: 92px; }
  footer h5 {
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 18px; color: white;
    margin-bottom: 1rem;
  }
  footer .name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 24px;
    font-style: italic;
    letter-spacing: 0.18em;
  }
  footer p, footer a {
    font-family: 'Cormorant Garamond', serif;
    font-size: 16px; color: white; line-height: 1.7;
  }
  footer a:hover { color: var(--burgundy-soft); }
  footer .copy {
    margin-top: 4rem; padding-top: 1.5rem;
    border-top: 1px solid rgba(216,210,197,0.15);
    text-align: center;
    font-family: 'Montserrat', sans-serif;
    font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
    color: white;
  }

  /* ============ RESPONSIVE ============ */
  @media (max-width: 900px) {
    .nav { gap: 1rem; padding: 1rem; flex-wrap: wrap; }
    .nav a { font-size: 10px; letter-spacing: 0.2em; }
    .nav a + a::before {
      left: -0.55rem;
      width: 3px;
      height: 3px;
    }
    .split { grid-template-columns: 1fr; gap: 2rem; }
    .photo-collage { height: 250px; }
    .photo-collage .ph-1 { width: 62%; height: auto; aspect-ratio: 4 / 5; }
    .photo-collage .ph-2 { width: 56%; height: auto; aspect-ratio: 4 / 5; }
    .explore-grid, .infos-grid, .dc-editorial, .dc-gallery-head { grid-template-columns: 1fr; }
    .dc-moodboard { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
    .dc-frame.large { grid-column: 1 / -1; min-height: 360px; }
    .dc-frame { min-height: 210px; }
    .dc-gallery { grid-template-columns: minmax(0, 215px); justify-content: center; }
    .dc-photo-card, .dc-photo-card.wide, .dc-photo-card.tall {
      grid-column: auto;
      min-height: 280px;
    }
    .dc-gallery-head { align-items: start; }
    .footer-grid { grid-template-columns: 1fr; text-align: center; }
    .footer-grid > div { display: flex; flex-direction: column; align-items: center; }
    .timeline::before { left: 18px; }
    .ti-row {
      grid-template-columns: 18px 1fr;
      gap: 0.9rem 1.2rem;
      padding: 1.35rem 0;
    }
    .ti-row .dot {
      grid-column: 1;
      grid-row: 1 / span 2;
      margin-top: 0.45rem;
    }
    .ti-row .time {
      grid-column: 2;
      grid-row: 1;
      text-align: left !important;
      padding-top: 0;
    }
    .ti-row .info {
      grid-column: 2;
      grid-row: 2;
      text-align: left !important;
    }
    .rsvp .form-row { grid-template-columns: 1fr; }
    .hero .date-line span {
      width: 45px;
    }
    .hero-media .slide-2 {
      object-position: 10% bottom;
    }
    .hero-content {
      padding-bottom: 13rem;
    }
    .hero-media .slide-2 {
      object-position: 10% bottom;
    }
  }
  @media (max-width: 560px) {
    .dc-copy-panel { padding: 1.35rem; }
    .dc-seal {
      width: 72px;
      height: 72px;
      font-size: 10px;
      flex: 0 0 auto;
    }
    .dc-palette-line { grid-template-columns: 1fr; }
    .dc-rule-list { grid-template-columns: 1fr; }
    .dc-tone { min-height: 78px; }
    .dc-moodboard { grid-template-columns: 1fr; }
    .dc-frame.large, .dc-frame { min-height: 300px; }
    .dc-photo-card, .dc-photo-card.wide, .dc-photo-card.tall { min-height: 380px; background-position: center top !important; }
  }