/* ============================================================
   MAPDRINKS — Cave Vivante design system
   Dark editorial: bleu nuit + doré + ivoire
   Cardo (serif) + Space Grotesk (sans)
   TODO: swap display serif to 'Amorah' once licensed font files
   are provided. Cormorant Garamond is loaded as a transitional
   display fallback, closer to Amorah's editorial voice than Cardo.
   Do not fake Amorah.
   ============================================================ */

:root {
    --md-nuit: #05102C;
    --md-nuit-2: #1A2545;
    --md-nuit-3: #22305A;
    --md-dore: #CEB37C;
    --md-dore-soft: #DBC59C;
    --md-dore-d: #8B6E30;
    --md-ivoire: #F5EFE2;
    --md-ivoire-deep: #E8DDC4;
    --md-ivoire-2: #E8DDC4;
    --md-ink: #F5EFE2;
    --md-ink-dim: rgba(245, 239, 226, 0.55);
    --md-ink-faint: rgba(245, 239, 226, 0.25);
    --md-hair: rgba(206, 179, 124, 0.30);
    --md-hair-faint: rgba(206, 179, 124, 0.12);
    --md-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* ===== Baseline override for the public site ===== */
html.md-html { background: var(--md-nuit); scroll-behavior: smooth; }
body.md-body {
    background: var(--md-nuit) !important;
    color: var(--md-ink);
    font-family: 'Space Grotesk', sans-serif;
    font-weight: 300;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    margin: 0;
}
body.md-body * { box-sizing: border-box; }
body.md-body ::selection { background: rgba(201,162,83,0.28); color: var(--md-ivoire); }

/* While gate is open: blur the page behind the gate */
body.md-body.gate-open { overflow: hidden; height: 100vh; }
body.md-body.gate-open .page-wrap { filter: blur(14px) brightness(0.55); transform: scale(1.03); }
.page-wrap { transition: filter 700ms ease, transform 900ms ease; }

/* Native cursor everywhere — custom cursor disabled */
.md-cursor, .md-cursor-dot { display: none !important; }

/* ===== Age Gate ===== */
.md-gate {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(8, 14, 26, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center;
    padding: 24px;
    animation: gateFade 700ms ease;
}
@keyframes gateFade { from { opacity: 0; } to { opacity: 1; } }
.md-gate.is-leaving { opacity: 0; transition: opacity 600ms ease; pointer-events: none; }
.md-gate-card {
    position: relative; z-index: 2;
    width: min(480px, 94vw);
    background: linear-gradient(155deg, var(--md-nuit-2) 0%, var(--md-nuit) 70%, var(--md-nuit-3) 100%);
    border: 1px solid var(--md-hair);
    padding: 52px 44px 36px;
    text-align: center;
    box-shadow: 0 40px 100px rgba(0,0,0,0.6), 0 0 0 1px rgba(201,162,83,0.08) inset;
    animation: gateIn 1000ms var(--md-ease) both;
    overflow: hidden;
}
.md-gate-card::before {
    content: ""; position: absolute; inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(201,162,83,0.12), transparent 60%);
    pointer-events: none;
}
.md-gate-card::after {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
}
@keyframes gateIn {
    0% { opacity: 0; transform: translateY(20px) scale(0.96); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}
.md-gate-logo {
    display: flex; align-items: center; justify-content: center;
    width: 154px; height: 56px;
    margin: 0 auto 28px;
    overflow: hidden;
    position: relative; z-index: 2;
}
.md-gate-logo__image {
    display: block;
    width: 154px; height: 56px;
    object-fit: cover;
    object-position: center 50%;
}
.md-stem {
    width: 2px; height: 30px;
    background: linear-gradient(180deg, var(--md-dore), var(--md-dore-d));
    position: relative;
}
.md-stem::before {
    content: ""; position: absolute;
    left: 50%; top: -12px; width: 13px; height: 13px;
    transform: translateX(-50%);
    border: 1.3px solid var(--md-dore);
    border-top-left-radius: 50%; border-top-right-radius: 50%;
    border-bottom: none;
}
.md-stem::after {
    content: ""; position: absolute;
    left: 50%; top: -2px; width: 9px; height: 1.3px;
    transform: translateX(-50%); background: var(--md-dore);
}
.md-gate-word {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: 30px; color: var(--md-dore); line-height: 1;
}
.md-gate-word em { font-style: italic; font-weight: 400; }
.md-gate-rule { width: 40px; height: 1px; background: var(--md-dore); opacity: 0.5; margin: 0 auto 24px; position: relative; z-index: 2; }
.md-gate-kicker {
    font-size: 10px; letter-spacing: 0.32em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 18px; position: relative; z-index: 2;
}
.md-gate-title {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: 38px; line-height: 1.2;
    color: var(--md-ivoire); letter-spacing: -0.01em;
    margin-bottom: 14px; position: relative; z-index: 2;
}
.md-gate-title em { font-style: italic; color: var(--md-dore); font-weight: 400; }
.md-gate-sub {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 15px; color: var(--md-ink-dim);
    line-height: 1.5; margin-bottom: 32px;
    position: relative; z-index: 2;
}
.md-gate-actions {
    display: flex; flex-direction: column; gap: 10px;
    position: relative; z-index: 2; margin-bottom: 28px;
}
.md-gate-btn {
    font-size: 11.5px; letter-spacing: 0.22em;
    text-transform: uppercase;
    padding: 15px 22px;
    border: 1px solid transparent;
    transition: all 350ms var(--md-ease);
    font-weight: 500; text-decoration: none; text-align: center;
    display: inline-block;
    background: transparent;
}
.md-gate-btn.primary { background: var(--md-dore); color: var(--md-nuit); border-color: var(--md-dore); }
.md-gate-btn.primary:hover { background: var(--md-ivoire); border-color: var(--md-ivoire); }
.md-gate-btn.ghost { background: transparent; color: var(--md-ink-dim); border-color: var(--md-hair-faint); }
.md-gate-btn.ghost:hover { color: var(--md-ivoire); border-color: var(--md-hair); }
.md-gate-legal {
    font-size: 9.5px; letter-spacing: 0.22em;
    color: var(--md-ink-faint); text-transform: uppercase;
    line-height: 1.8; position: relative; z-index: 2;
    padding-top: 22px; border-top: 1px solid var(--md-hair-faint);
}

/* ===== Page entrance orchestration ===== */
.page-wrap.md-page { opacity: 0; transition: opacity 1200ms var(--md-ease); position: relative; }
.page-wrap.md-page.revealed { opacity: 1; }

.enter-item { opacity: 0; }
.page-wrap.md-page.revealed .enter-item {
    opacity: 1;
    transition: opacity 700ms var(--md-ease), transform 900ms var(--md-ease), letter-spacing 1000ms var(--md-ease);
}

.md-page.first-entry .enter-header { opacity: 0; transform: translateY(-8px); transition-delay: 200ms; }
.md-page.first-entry.revealed .enter-header { opacity: 1; transform: translateY(0); }
.md-page.first-entry .enter-kicker { opacity: 0; letter-spacing: 0.5em; transition-delay: 450ms; }
.md-page.first-entry.revealed .enter-kicker { opacity: 1; letter-spacing: 0.22em; }
.md-page.first-entry .word-mask { overflow: hidden; display: inline-block; vertical-align: top; }
.md-page.first-entry .word-mask .w { display: inline-block; transform: translateY(110%); transition: transform 1200ms var(--md-ease); }
.md-page.first-entry.revealed .word-mask .w { transform: translateY(0); }
.md-page.first-entry .enter-banner { opacity: 0; transform: scale(1.04); transition: opacity 900ms var(--md-ease) 400ms, transform 1100ms var(--md-ease) 400ms; }
.md-page.first-entry.revealed .enter-banner { opacity: 1; transform: scale(1); }

.md-page.short-entry .enter-header,
.md-page.short-entry .enter-kicker,
.md-page.short-entry .enter-banner { opacity: 0; transition: opacity 500ms var(--md-ease); }
.md-page.short-entry.revealed .enter-header,
.md-page.short-entry.revealed .enter-kicker,
.md-page.short-entry.revealed .enter-banner { opacity: 1; }
.md-page.short-entry .word-mask .w { transform: translateY(0); }

/* Ambient hero */
@keyframes md-banner-breathe { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.012); } }
.md-banner-media { animation: md-banner-breathe 20s ease-in-out infinite; }
@keyframes md-bar-pulse { 0%, 100% { width: 24px; opacity: 0.5; } 50% { width: 40px; opacity: 1; } }
.md-bar-live { display: inline-block; width: 24px; height: 1px; background: var(--md-dore); animation: md-bar-pulse 4s ease-in-out infinite; }

/* Reveal on scroll */
.md-reveal { opacity: 0; transform: translateY(16px); transition: opacity 520ms var(--md-ease), transform 620ms var(--md-ease); }
.md-reveal.in { opacity: 1; transform: translateY(0); }

/* ===== Header ===== */
.md-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 50;
    padding: 14px 40px;
    display: grid; grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 28px;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    transition:
        background 500ms ease,
        padding 500ms ease,
        border-color 500ms ease,
        opacity 360ms var(--md-ease),
        transform 420ms var(--md-ease);
    border-bottom: 1px solid transparent;
}
.md-header.md-header--hidden {
    opacity: 0;
    transform: translateY(-110%);
    pointer-events: none;
}
body.md-menu-open .md-header {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
.md-header.scrolled {
    background: rgba(8, 16, 28, 0.85);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    padding: 10px 40px;
    border-bottom-color: var(--md-hair-faint);
}
.md-nav {
    display: flex; gap: clamp(18px, 2vw, 28px); align-items: center;
    font-size: 11px; letter-spacing: 0.16em;
    text-transform: uppercase;
    font-weight: 400;
}
.md-nav a,
.md-nav-catalogue__trigger {
    color: var(--md-ivoire);
    text-decoration: none;
    position: relative;
    padding: 5px 0;
    transition: color 300ms ease;
}
.md-nav-catalogue__trigger {
    appearance: none;
    border: 0;
    background: transparent;
    font: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
    cursor: pointer;
}
.md-nav a::after,
.md-nav-catalogue__trigger::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 0;
    height: 1px; background: var(--md-dore);
    transform: scaleX(0); transform-origin: left;
    transition: transform 450ms var(--md-ease);
}
.md-nav a:hover::after,
.md-nav a.active::after,
.md-nav-catalogue__trigger:hover::after,
.md-nav-catalogue__trigger.active::after,
.md-nav-catalogue__trigger[aria-expanded="true"]::after { transform: scaleX(1); }
.md-nav a.active,
.md-nav-catalogue__trigger.active,
.md-nav-catalogue__trigger:hover,
.md-nav-catalogue__trigger:focus-visible { color: var(--md-dore); }
.md-nav-catalogue__trigger:focus-visible { outline: none; }

.md-nav-catalogue {
    position: relative;
}
.md-catalogue-menu {
    position: absolute;
    left: 50%;
    top: calc(100% + 12px);
    width: 230px;
    transform: translateX(-50%) translateY(6px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 180ms var(--md-ease), transform 200ms var(--md-ease), visibility 0s linear 180ms;
}
.md-nav-catalogue:hover .md-catalogue-menu,
.md-nav-catalogue:focus-within .md-catalogue-menu,
.md-nav-catalogue.is-open .md-catalogue-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
    transition: opacity 180ms var(--md-ease), transform 200ms var(--md-ease);
}
.md-catalogue-menu::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -14px;
    height: 14px;
}
.md-catalogue-menu__inner {
    display: flex;
    flex-direction: column;
    padding: 7px;
    border: 1px solid rgba(206,179,124,0.38);
    border-radius: 4px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(206,179,124,0.14), transparent 68%),
        linear-gradient(155deg, rgba(26,37,69,0.98), rgba(5,16,44,0.98));
    box-shadow:
        0 18px 42px rgba(0,0,0,0.34),
        0 0 0 1px rgba(255,255,255,0.03) inset;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}
.md-catalogue-menu__item {
    display: flex;
    align-items: center;
    min-height: 31px;
    padding: 8px 10px;
    border-radius: 3px;
    font-size: 10px;
    line-height: 1.15;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--md-ivoire);
    transition: color 160ms ease, background 160ms ease;
}
.md-catalogue-menu__item::after { display: none; }
.md-catalogue-menu__item:hover,
.md-catalogue-menu__item:focus-visible,
.md-catalogue-menu__item.is-active {
    color: var(--md-dore-soft);
    background: rgba(206,179,124,0.10);
    outline: none;
}
.md-catalogue-menu__item + .md-catalogue-menu__item {
    border-top: 1px solid rgba(206,179,124,0.08);
}

.md-brand-logo {
    display: block;
    width: 152px; height: 42px;
    overflow: hidden;
    color: var(--md-dore);
    text-decoration: none;
}
.md-brand-logo__image {
    display: block;
    width: 152px; height: 42px;
    object-fit: cover;
    object-position: center 50%;
}
.md-brand-stem {
    width: 2px; height: 22px;
    background: linear-gradient(180deg, var(--md-dore), var(--md-dore-d));
    position: relative;
}
.md-brand-stem::before {
    content: ""; position: absolute; left: 50%; top: -9px;
    width: 10px; height: 10px;
    transform: translateX(-50%);
    border: 1.3px solid var(--md-dore);
    border-top-left-radius: 50%; border-top-right-radius: 50%;
    border-bottom: none;
}
.md-brand-stem::after {
    content: ""; position: absolute; left: 50%; top: -2px;
    width: 8px; height: 1.3px;
    transform: translateX(-50%); background: var(--md-dore);
}
.md-brand-word {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: 26px; letter-spacing: 0.01em;
    color: var(--md-dore); line-height: 1;
    display: inline-flex; align-items: baseline;
}
.md-brand-word .seg { font-style: italic; font-weight: 400; }
.md-brand-word .plain { letter-spacing: -0.01em; }

.md-header-right { display: flex; justify-content: flex-end; align-items: center; gap: 14px; }
.md-search-pill {
    display: flex; align-items: center; gap: 12px;
    padding: 9px 15px;
    width: 220px;
    border: 1px solid var(--md-hair);
    border-radius: 999px;
    background: rgba(239, 232, 214, 0.03);
    transition: border-color 300ms ease, background 300ms ease, width 500ms var(--md-ease);
}
.md-search-pill:focus-within { border-color: var(--md-dore); background: rgba(201,162,83,0.06); }
@media (hover: hover) and (pointer: fine) {
    .md-search-pill:focus-within { width: 280px; }
}
.md-search-pill svg { flex-shrink: 0; opacity: 0.7; color: var(--md-dore); }
.md-search-pill input {
    background: transparent; border: none; outline: none;
    color: var(--md-ivoire);
    font-family: 'Space Grotesk', sans-serif;
    font-size: 12px; letter-spacing: 0.12em;
    text-transform: uppercase; font-weight: 400;
    width: 100%;
}
.md-search-pill input::placeholder { color: var(--md-ink-faint); letter-spacing: 0.16em; }

/* Mobile nav */
.md-mobile-trigger {
    display: none;
    background: transparent;
    border: 1px solid var(--md-hair);
    color: var(--md-ivoire);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    padding: 10px 14px;
}
@media (max-width: 980px) {
    .md-header { grid-template-columns: auto 1fr auto; padding: 16px 22px; gap: 16px; }
    .md-header.scrolled { padding: 16px 22px; }
    .md-nav { display: none; }
    .md-header-right { gap: 10px; }
    .md-search-pill { display: none; }
    .md-mobile-trigger { display: inline-flex; }
    .md-brand-stem { height: 24px; }
    .md-brand-word { font-size: 28px; }
}

.md-mobile-panel {
    position: fixed; inset: 0;
    background: rgba(8,14,26,0.96);
    backdrop-filter: blur(18px);
    z-index: 60;
    padding: 90px 28px 40px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    overflow-y: auto;
    transition: opacity 300ms var(--md-ease), visibility 0s linear 300ms;
}
.md-mobile-panel.open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity 300ms var(--md-ease);
}
.md-mobile-panel a {
    font-family: 'Cardo', serif;
    font-size: 26px;
    color: var(--md-ivoire);
    text-decoration: none;
    padding: 10px 0;
    border-bottom: 1px solid var(--md-hair-faint);
}
.md-mobile-catalogue {
    border-bottom: 1px solid var(--md-hair-faint);
}
.md-mobile-catalogue__trigger {
    appearance: none;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 0;
    border: 0;
    background: transparent;
    font-family: 'Cardo', serif;
    font-size: 26px;
    color: var(--md-ivoire);
    cursor: pointer;
}
.md-mobile-catalogue__trigger:focus-visible {
    outline: 1px solid var(--md-dore);
    outline-offset: 4px;
}
.md-mobile-catalogue__mark {
    width: 16px;
    height: 16px;
    position: relative;
    flex: 0 0 auto;
}
.md-mobile-catalogue__mark::before,
.md-mobile-catalogue__mark::after {
    content: "";
    position: absolute;
    background: var(--md-dore);
    transition: transform 220ms var(--md-ease), opacity 220ms var(--md-ease);
}
.md-mobile-catalogue__mark::before {
    left: 0;
    right: 0;
    top: 7px;
    height: 1px;
}
.md-mobile-catalogue__mark::after {
    top: 0;
    bottom: 0;
    left: 7px;
    width: 1px;
}
.md-mobile-catalogue.open .md-mobile-catalogue__mark::after {
    transform: scaleY(0);
    opacity: 0;
}
.md-mobile-catalogue__panel {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 280ms var(--md-ease), opacity 220ms ease;
}
.md-mobile-catalogue.open .md-mobile-catalogue__panel {
    max-height: 520px;
    opacity: 1;
}
.md-mobile-catalogue__item {
    display: block;
    margin-left: 14px;
    padding: 7px 0;
    border-top: 1px solid rgba(206,179,124,0.10);
    border-bottom: 0;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 10px;
    line-height: 1.2;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(245,239,226,0.70);
}
.md-mobile-catalogue__item:hover,
.md-mobile-catalogue__item.is-active {
    color: var(--md-dore-soft);
}
.md-mobile-panel form { margin-top: 12px; }
.md-mobile-panel .md-search-pill { display: flex; width: 100%; }
.md-mobile-close {
    position: fixed; top: 22px; right: 22px;
    background: transparent; border: 1px solid var(--md-hair);
    color: var(--md-ivoire);
    padding: 10px 14px;
    font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
    z-index: 70;
    display: none;
}
.md-mobile-panel.open ~ .md-mobile-close,
body.md-menu-open .md-mobile-close { display: inline-flex; }

@media (min-width: 981px) {
    .md-header .md-header-search {
        --md-header-search-closed: 38px;
        --md-header-search-open: 220px;
        --md-header-search-input: 154px;
        justify-content: flex-start;
        gap: 0;
        width: var(--md-header-search-closed);
        min-width: var(--md-header-search-closed);
        height: 38px;
        padding: 0;
        overflow: hidden;
        flex: 0 0 auto;
        transition:
            width 340ms var(--md-ease),
            min-width 340ms var(--md-ease),
            border-color 300ms ease,
            background 300ms ease;
    }
    .md-header .md-header-search.md-header-search--open {
        gap: 10px;
        width: var(--md-header-search-open);
        min-width: var(--md-header-search-open);
        padding: 0 14px 0 1px;
    }
    .md-header .md-header-search__toggle {
        width: 36px;
        height: 36px;
        min-width: 36px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        border: 0;
        border-radius: 999px;
        background: transparent;
        color: var(--md-dore);
        cursor: pointer;
        transition: color 240ms ease, background 240ms ease;
    }
    .md-header .md-header-search__toggle:hover,
    .md-header .md-header-search__toggle:focus-visible {
        color: var(--md-ivoire);
        background: rgba(201,162,83,0.08);
        outline: none;
    }
    .md-header .md-header-search input {
        width: 0;
        min-width: 0;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: translateX(8px);
        transition:
            width 340ms var(--md-ease),
            opacity 260ms ease,
            transform 340ms var(--md-ease),
            visibility 0s linear 260ms;
    }
    .md-header .md-header-search.md-header-search--open input {
        width: var(--md-header-search-input);
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateX(0);
        transition:
            width 340ms var(--md-ease),
            opacity 260ms ease,
            transform 340ms var(--md-ease);
    }
}
@media (min-width: 981px) and (hover: hover) and (pointer: fine) {
    .md-header .md-header-search:focus-within {
        width: var(--md-header-search-closed);
        min-width: var(--md-header-search-closed);
    }
    .md-header .md-header-search.md-header-search--open:focus-within {
        width: var(--md-header-search-open);
        min-width: var(--md-header-search-open);
    }
}
@media (min-width: 981px) and (prefers-reduced-motion: reduce) {
    .md-header .md-header-search,
    .md-header .md-header-search input {
        transition-duration: 1ms;
    }
}

/* ===== Banner ===== */
.md-banner { padding: 120px 40px 40px; }
.md-banner-inner {
    position: relative;
    max-width: 1400px; margin: 0 auto;
    aspect-ratio: 21 / 8;
    border: 1px solid var(--md-hair-faint);
    overflow: hidden;
}
.md-banner-media {
    position: absolute; inset: 0;
    background:
      radial-gradient(ellipse 60% 50% at 50% 50%, rgba(201,162,83,0.10), transparent 65%),
      linear-gradient(135deg, var(--md-nuit-2) 0%, var(--md-nuit) 60%, var(--md-nuit-3) 100%);
    display: flex; align-items: center; justify-content: center;
    transform-origin: center;
}
.md-banner-media::before {
    content: ""; position: absolute; inset: 0;
    background-image: repeating-linear-gradient(135deg, rgba(201,162,83,0.05) 0 1px, transparent 1px 24px);
    pointer-events: none;
}
.md-banner-corner { position: absolute; width: 28px; height: 28px; }
.md-banner-corner span { position: absolute; background: var(--md-dore); }
.md-banner-corner.tl { top: 20px; left: 20px; }
.md-banner-corner.tl span:nth-child(1) { top: 0; left: 0; width: 28px; height: 1px; }
.md-banner-corner.tl span:nth-child(2) { top: 0; left: 0; width: 1px; height: 28px; }
.md-banner-corner.tr { top: 20px; right: 20px; }
.md-banner-corner.tr span:nth-child(1) { top: 0; right: 0; width: 28px; height: 1px; }
.md-banner-corner.tr span:nth-child(2) { top: 0; right: 0; width: 1px; height: 28px; }
.md-banner-corner.bl { bottom: 20px; left: 20px; }
.md-banner-corner.bl span:nth-child(1) { bottom: 0; left: 0; width: 28px; height: 1px; }
.md-banner-corner.bl span:nth-child(2) { bottom: 0; left: 0; width: 1px; height: 28px; }
.md-banner-corner.br { bottom: 20px; right: 20px; }
.md-banner-corner.br span:nth-child(1) { bottom: 0; right: 0; width: 28px; height: 1px; }
.md-banner-corner.br span:nth-child(2) { bottom: 0; right: 0; width: 1px; height: 28px; }
.md-banner-center { position: relative; z-index: 2; text-align: center; padding: 0 24px; }
.md-banner-kicker {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 10.5px; letter-spacing: 0.22em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 22px;
}
.md-banner-label {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: clamp(36px, 4.5vw, 64px);
    color: var(--md-ivoire);
    margin-bottom: 14px;
    letter-spacing: -0.005em;
    line-height: 1.05;
}
.md-banner-label em { font-style: italic; color: var(--md-dore); font-weight: 400; }
.md-banner-hint {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 18px; color: var(--md-ink-dim); margin-bottom: 20px;
}
.md-banner-dim {
    font-size: 10px; letter-spacing: 0.3em;
    color: var(--md-dore); text-transform: uppercase;
}
.md-banner-cta {
    display: inline-flex; align-items: center; gap: 14px;
    margin-top: 28px;
    padding: 14px 24px;
    border: 1px solid var(--md-dore);
    color: var(--md-dore);
    font-size: 11px; letter-spacing: 0.22em;
    text-transform: uppercase; text-decoration: none;
    transition: background 350ms ease, color 350ms ease;
}
.md-banner-cta:hover { background: var(--md-dore); color: var(--md-nuit); }

/* Hero image variant (real photo replaces placeholder) */
.md-banner-media.has-image { background-size: cover; background-position: center; }
.md-banner-media.has-image::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(16,29,53,0.35), rgba(16,29,53,0.85));
}
.md-banner-media.has-image .md-banner-center { padding: 80px 32px; }

/* ===== Featured homepage hero ===== */
.md-featured-hero {
    --md-hero-paper: var(--md-ivoire);
    --md-hero-paper-2: var(--md-ivoire-deep);
    --md-hero-blue: var(--md-nuit);
    --md-hero-text: var(--md-ivoire);
    --md-hero-muted: var(--md-ink-dim);
    --md-hero-faint: var(--md-hair-faint);
    --md-hero-gold: var(--md-dore);
    --md-hero-champagne: var(--md-dore-soft);
    padding: clamp(98px, 11vh, 112px) 40px 10px;
    color: var(--md-hero-text);
    background:
        radial-gradient(ellipse at 50% 46%, rgba(206,179,124,0.07), transparent 42%),
        linear-gradient(180deg, rgba(26,37,69,0.38), rgba(5,16,44,0) 72%);
    border-bottom: 1px solid var(--md-hair-faint);
}
.md-featured-hero-inner {
    max-width: 1260px;
    min-height: clamp(432px, 58vh, 500px);
    margin: 0 auto;
    position: relative;
    overflow: visible;
    display: grid;
    grid-template-columns: minmax(272px, 0.96fr) minmax(340px, 440px) minmax(248px, 0.7fr);
    gap: clamp(22px, 3.2vw, 48px);
    align-items: center;
    padding: clamp(24px, 3vw, 38px) clamp(22px, 3.2vw, 44px) 26px;
    border: 1px solid rgba(206,179,124,0.5);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 30%, rgba(255,255,255,0.6), transparent 70%),
        linear-gradient(160deg, #F9F6F0 0%, #EFE7D3 45%, #E6D8BA 100%);
    box-shadow:
        0 32px 64px rgba(5,16,44,0.25),
        0 4px 16px rgba(5,16,44,0.12);
}
.md-featured-copy,
.md-featured-stage,
.md-featured-panel {
    position: relative;
    z-index: 2;
}
.md-featured-copy {
    align-self: center;
    max-width: 460px;
}
.md-featured-copy > *,
.md-featured-panel,
.md-featured-bottle {
    opacity: 0;
    transform: translateY(16px);
    transition:
        opacity 820ms var(--md-ease),
        transform 900ms var(--md-ease);
}
.md-featured-bottle {
    transform: translateY(18px) scale(0.96);
}
.md-page.revealed .md-featured-hero.is-ready .md-featured-copy > *,
.md-page.revealed .md-featured-hero.is-ready .md-featured-panel {
    opacity: 1;
    transform: translateY(0);
}
.md-page.revealed .md-featured-hero.is-ready .md-featured-bottle {
    opacity: 1;
    transform: translateY(0) scale(1);
}
.md-page.revealed .md-featured-hero.is-ready .md-featured-kicker { transition-delay: 120ms; }
.md-page.revealed .md-featured-hero.is-ready .md-featured-title { transition-delay: 200ms; }
.md-page.revealed .md-featured-hero.is-ready .md-featured-description { transition-delay: 280ms; }
.md-page.revealed .md-featured-hero.is-ready .md-featured-profile { transition-delay: 340ms; }
.md-page.revealed .md-featured-hero.is-ready .md-featured-cta { transition-delay: 430ms; }
.md-page.revealed .md-featured-hero.is-ready .md-featured-bottle { transition-delay: 260ms; }
.md-page.revealed .md-featured-hero.is-ready .md-featured-panel { transition-delay: 520ms; }
.md-page.revealed .md-featured-hero.is-ready.is-switching .md-featured-kicker,
.md-page.revealed .md-featured-hero.is-ready.is-switching .md-featured-title,
.md-page.revealed .md-featured-hero.is-ready.is-switching .md-featured-description,
.md-page.revealed .md-featured-hero.is-ready.is-switching .md-featured-profile,
.md-page.revealed .md-featured-hero.is-ready.is-switching .md-featured-cta {
    opacity: 0;
    transform: translateY(10px);
    transition-delay: 0ms;
    transition-duration: 150ms;
}
.md-page.revealed .md-featured-hero.is-ready.is-switching .md-featured-bottle {
    opacity: 0;
    transform: translateY(12px) scale(0.98);
    transition-delay: 0ms;
    transition-duration: 150ms;
}
.md-featured-kicker,
.md-featured-panel-head,
.md-featured-suggestion-num {
    font-size: 10px;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--md-hero-gold);
}
.md-featured-kicker {
    margin-bottom: 16px;
}
.md-featured-title {
    max-width: 460px;
    margin: 0;
    /* TODO: replace with 'Amorah' once licensed. Cormorant Garamond is a transitional display fallback closer to Amorah than Cardo. */
    font-family: 'Cormorant Garamond', 'Cardo', serif;
    font-size: clamp(40px, 4.6vw, 62px);
    line-height: 0.98;
    font-weight: 400;
    letter-spacing: 0;
    color: var(--md-nuit);
}
.md-featured-description {
    max-width: 370px;
    margin: 16px 0 0;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 14px;
    line-height: 1.7;
    color: rgba(5,16,44,0.65);
}
.md-featured-profile {
    margin: 12px 0 0;
    font-size: 10px;
    line-height: 1.6;
    letter-spacing: 0;
    text-transform: uppercase;
    color: rgba(5,16,44,0.55);
}
.md-featured-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 22px;
    min-height: 42px;
    padding: 11px 19px;
    border: 1px solid var(--md-nuit);
    color: var(--md-nuit);
    background: transparent;
    font-size: 11px;
    letter-spacing: 0;
    text-transform: uppercase;
    text-decoration: none;
    transition:
        opacity 820ms var(--md-ease),
        transform 900ms var(--md-ease),
        background 300ms ease,
        color 300ms ease,
        border-color 300ms ease;
}
.md-featured-cta:hover {
    border-color: var(--md-nuit);
    background: var(--md-nuit);
    color: var(--md-ivoire);
}
.md-featured-stage {
    width: 100%;
    min-height: clamp(448px, 60vh, 540px);
    padding: clamp(40px, 5vh, 60px) clamp(32px, 4vw, 56px);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    background: transparent;
    border: none;
    box-shadow: none;
}
.md-featured-stage::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: clamp(18px, 4vh, 30px);
    width: min(64%, 240px);
    height: 12px;
    transform: translateX(-50%);
    background: radial-gradient(ellipse at center, rgba(5,16,44,0.08), transparent 70%);
}
.md-featured-orbit {
    position: absolute;
    width: min(82%, 284px);
    aspect-ratio: 0.72;
    border: 1px solid rgba(206,179,124,0.13);
    transform: rotate(-4deg);
    opacity: 0.32;
}
.md-featured-orbit::before,
.md-featured-orbit::after {
    content: "";
    position: absolute;
    left: 50%;
    width: 1px;
    height: 22px;
    background: rgba(206,179,124,0.13);
    transform: translateX(-50%);
}
.md-featured-orbit::before { top: -22px; }
.md-featured-orbit::after { bottom: -22px; }
.md-featured-bottle {
    position: relative;
    display: block;
    width: auto;
    height: clamp(356px, 52vh, 432px);
    max-width: min(100%, 254px);
    object-fit: contain;
    object-position: center;
    filter: drop-shadow(0 10px 16px rgba(5,16,44,0.11));
    transition: opacity 520ms var(--md-ease), transform 620ms var(--md-ease);
}
.md-featured-bottle.is-placeholder {
    width: min(72%, 215px);
    opacity: 0.78;
    filter: drop-shadow(0 8px 14px rgba(5,16,44,0.09));
}
.md-featured-stage-arrow {
    display: none;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 38px;
    height: 38px;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid rgba(5,16,44,0.22);
    border-radius: 50%;
    background: rgba(255,255,255,0.78);
    color: var(--md-nuit);
    cursor: pointer;
    z-index: 3;
    transition: background 240ms ease, border-color 240ms ease, color 240ms ease, transform 240ms ease;
}
.md-featured-stage-arrow--prev { left: 6px; }
.md-featured-stage-arrow--next { right: 6px; }
.md-featured-stage-arrow:hover {
    background: var(--md-nuit);
    border-color: var(--md-nuit);
    color: var(--md-ivoire);
}
.md-featured-stage-arrow:active { transform: translateY(-50%) scale(0.96); }
.md-featured-stage-arrow:focus-visible {
    outline: 1px solid var(--md-dore);
    outline-offset: 3px;
}
.md-featured-panel {
    align-self: center;
    color: var(--md-nuit);
}
.md-featured-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 8px;
    padding-bottom: 11px;
    border-bottom: 1px solid rgba(206,179,124,0.3);
}
.md-featured-suggestions {
    display: grid;
    gap: 0;
}
.md-featured-suggestion {
    width: 100%;
    min-height: 90px;
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 16px;
    align-items: center;
    padding: 12px 14px 12px 16px;
    border: 0;
    border-bottom: 1px solid rgba(206,179,124,0.15);
    border-left: 1px solid transparent;
    background: transparent;
    color: var(--md-nuit);
    text-align: left;
    cursor: pointer;
    transition: background 260ms ease, border-color 260ms ease, color 260ms ease;
}
.md-featured-suggestion-img-wrap {
    width: 100%;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.md-featured-suggestion-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 4px 8px rgba(5,16,44,0.08));
}
.md-featured-suggestion:hover {
    border-left-color: rgba(206,179,124,0.7);
    background: rgba(206,179,124,0.1);
}
.md-featured-suggestion.is-active {
    border-left-color: var(--md-dore);
    background: rgba(206,179,124,0.15);
}
.md-featured-suggestion:focus-visible {
    outline: 1px solid var(--md-dore);
    outline-offset: 4px;
}
.md-featured-suggestion-name {
    display: block;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 13px;
    line-height: 1.32;
    font-weight: 500;
    color: var(--md-nuit);
}
.md-featured-suggestion-meta {
    display: block;
    margin-top: 5px;
    font-size: 10.5px;
    line-height: 1.45;
    color: rgba(5,16,44,0.65);
    text-transform: uppercase;
}
.md-featured-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 24px;
    padding-top: 2px;
}
.md-featured-dashes {
    display: flex;
    gap: 6px;
    align-items: center;
}
.md-featured-dash {
    width: 14px;
    height: 1.5px;
    background: rgba(5,16,44,0.3);
    transition: background 300ms ease;
}
.md-featured-panel:has(.md-featured-suggestion:nth-child(1).is-active) .md-featured-dash:nth-child(1),
.md-featured-panel:has(.md-featured-suggestion:nth-child(2).is-active) .md-featured-dash:nth-child(2),
.md-featured-panel:has(.md-featured-suggestion:nth-child(3).is-active) .md-featured-dash:nth-child(3),
.md-featured-panel:has(.md-featured-suggestion:nth-child(4).is-active) .md-featured-dash:nth-child(4),
.md-featured-panel:has(.md-featured-suggestion:nth-child(5).is-active) .md-featured-dash:nth-child(5) {
    background: var(--md-nuit);
}
.md-featured-control {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(5,16,44,0.4);
    border-radius: 50%;
    background: transparent;
    color: var(--md-nuit);
    cursor: pointer;
    transition: background 260ms ease, color 260ms ease, border-color 260ms ease;
}
.md-featured-control:hover {
    border-color: var(--md-nuit);
    background: var(--md-nuit);
    color: var(--md-ivoire);
}
.md-featured-control:focus-visible {
    outline: 1px solid var(--md-nuit);
    outline-offset: 4px;
}

@media (max-width: 900px) {
    .md-featured-hero-inner {
        min-height: 0;
        grid-template-columns: 1fr;
        gap: 26px;
        padding: 38px 28px 34px;
    }
    .md-featured-title { font-size: 50px; max-width: 620px; }
    .md-featured-description { max-width: 560px; }
    .md-featured-stage {
        min-height: 388px;
        order: 2;
        padding-left: 56px;
        padding-right: 56px;
    }
    .md-featured-copy { order: 1; }
    .md-featured-panel { order: 3; }
    .md-featured-bottle { height: 392px; }
    .md-featured-stage-arrow { display: inline-flex; }
    .md-featured-controls .md-featured-control { display: none; }
    .md-featured-controls { justify-content: center; }
}

@media (max-width: 720px) {
    .md-featured-hero { padding: 92px 18px 22px; }
    .md-featured-hero-inner {
        padding: 30px 20px 28px;
    }
    .md-featured-title {
        font-size: 38px;
        line-height: 1;
    }
    .md-featured-description {
        font-size: 13.5px;
        line-height: 1.65;
    }
    .md-featured-stage {
        min-height: 330px;
    }
    .md-featured-orbit {
        width: min(88%, 280px);
    }
    .md-featured-bottle {
        height: 315px;
        max-width: min(88%, 260px);
    }
    .md-featured-suggestions {
        display: flex;
        gap: 12px;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        padding-bottom: 8px;
    }
    .md-featured-suggestion {
        flex: 0 0 238px;
        min-height: 98px;
        scroll-snap-align: start;
        padding: 14px;
        border: 1px solid rgba(206,179,124,0.3);
    }
    .md-featured-suggestion:hover,
    .md-featured-suggestion.is-active {
        border-left-color: var(--md-hero-gold);
    }
    .md-featured-controls {
        justify-content: center;
        gap: 24px;
    }
}

/* ===== Categories row ===== */
.md-cats {
    padding: 24px 40px 80px;
    border-bottom: 1px solid var(--md-hair-faint);
}
.md-cats-inner {
    max-width: 1260px; margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 24px;
    padding: 44px 28px;
    border: 1px solid rgba(206,179,124,0.5);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 30%, rgba(255,255,255,0.6), transparent 70%),
        linear-gradient(160deg, #F9F6F0 0%, #EFE7D3 45%, #E6D8BA 100%);
    box-shadow:
        0 32px 64px rgba(5,16,44,0.25),
        0 4px 16px rgba(5,16,44,0.12);
}
@media (max-width: 1100px) { .md-cats-inner { grid-template-columns: repeat(4, 1fr); row-gap: 40px; } }
@media (max-width: 600px)  { .md-cats-inner { grid-template-columns: repeat(2, 1fr); row-gap: 32px; } }

.md-cat-pill {
    text-decoration: none; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 16px;
    transition: transform 500ms var(--md-ease);
}
.md-cat-pill:hover { transform: translateY(-4px); }
.md-cat-disc {
    width: 96px; height: 96px;
    border-radius: 50%;
    background: radial-gradient(ellipse at 50% 60%, var(--md-nuit-3), var(--md-nuit) 75%);
    border: 1px solid rgba(206,179,124,0.25);
    display: flex; align-items: center; justify-content: center;
    transition: border-color 400ms ease, background 400ms ease;
    overflow: hidden;
}
.md-cat-disc svg { height: 70px; width: auto; transition: transform 900ms var(--md-ease); }
.md-cat-disc img { height: 70px; width: 78px; object-fit: contain; transition: transform 900ms var(--md-ease); }
.md-cat-pill:hover .md-cat-disc svg,
.md-cat-pill:hover .md-cat-disc img { transform: scale(1.03); }
.md-cat-pill:hover .md-cat-disc {
    border-color: var(--md-dore);
    background: radial-gradient(ellipse at 50% 60%, rgba(201,162,83,0.15), var(--md-nuit) 75%);
}
.md-cat-name {
    font-family: 'Cardo', serif;
    font-size: 18px;
    color: var(--md-nuit);
    letter-spacing: 0;
}
.md-cat-count {
    font-size: 10.5px; letter-spacing: 0;
    color: rgba(5,16,44,0.65); text-transform: uppercase;
}

/* ===== Feature cards ===== */
.md-features {
    padding: 86px 40px 80px;
    background: var(--md-nuit);
}
.md-features-inner {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 32px;
}
@media (max-width: 900px) { .md-features-inner { grid-template-columns: 1fr; } }

.md-feat-card {
    position: relative;
    min-height: 340px;
    background:
        radial-gradient(ellipse at 50% 30%, rgba(255,255,255,0.6), transparent 70%),
        linear-gradient(160deg, #F9F6F0 0%, #EFE7D3 45%, #E6D8BA 100%);
    border: 1px solid rgba(206,179,124,0.5);
    border-radius: 6px;
    box-shadow:
        0 32px 64px rgba(5,16,44,0.25),
        0 4px 16px rgba(5,16,44,0.12);
    padding: 44px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    align-items: end;
    overflow: hidden;
    transition: border-color 400ms ease, transform 500ms var(--md-ease), box-shadow 500ms var(--md-ease);
    text-decoration: none;
}
.md-feat-card:hover {
    border-color: rgba(206,179,124,0.8);
    transform: translateY(-4px);
    box-shadow:
        0 42px 74px rgba(5,16,44,0.3),
        0 8px 24px rgba(5,16,44,0.15);
}
.md-feat-card--wide {
    grid-column: 1 / -1;
    min-height: 300px;
}
.md-feat-card--editorial {
    align-items: center;
}
.md-feat-card--editorial .md-feat-note {
    max-width: 520px;
}
@media (max-width: 700px) { .md-feat-card { grid-template-columns: 1fr; padding: 32px; } }

.md-feat-content { position: relative; z-index: 2; display: flex; flex-direction: column; }
.md-feat-kicker {
    font-size: 10px; letter-spacing: 0.28em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 16px;
}
.md-feat-title {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: 44px; line-height: 1.05;
    color: var(--md-nuit);
    margin-bottom: 14px;
    letter-spacing: -0.01em;
    position: relative;
}
.md-feat-title em { font-style: italic; color: #8B6E30; font-weight: 400; }
.md-feat-title::after {
    content: ""; position: absolute; left: 0; bottom: -8px;
    height: 1px; width: 56px; background: var(--md-dore);
    transform: scaleX(0); transform-origin: left;
    transition: transform 600ms var(--md-ease);
}
.md-feat-card:hover .md-feat-title::after { transform: scaleX(1); }
.md-feat-card:not(:hover) .md-feat-title::after { transform-origin: right; }
.md-feat-note {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 16px; color: rgba(5,16,44,0.65);
    margin-bottom: 28px; line-height: 1.5;
}
.md-feat-link {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--md-nuit); text-decoration: none;
    padding-bottom: 6px; border-bottom: 1px solid var(--md-dore);
    transition: gap 350ms ease, color 350ms ease;
    width: fit-content;
}
.md-feat-link:hover { gap: 20px; color: var(--md-dore); }
.md-feat-media {
    position: relative;
    aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, var(--md-nuit-3), var(--md-nuit));
    border: 1px solid rgba(206,179,124,0.25);
    border-radius: 4px;
    display: flex; align-items: center; justify-content: center;
    background-image:
      repeating-linear-gradient(135deg, rgba(201,162,83,0.04) 0 1px, transparent 1px 16px),
      linear-gradient(135deg, var(--md-nuit-3), var(--md-nuit));
    overflow: hidden;
    transition: transform 900ms var(--md-ease);
}
.md-feat-card:hover .md-feat-media { transform: scale(1.03); }
.md-feat-media.alt {
    background-image:
      repeating-linear-gradient(45deg, rgba(201,162,83,0.04) 0 1px, transparent 1px 16px),
      linear-gradient(135deg, var(--md-nuit-3), var(--md-nuit));
}
.md-feat-media img {
    width: 90%;
    height: 90%;
    object-fit: contain;
    filter: drop-shadow(0 8px 16px rgba(5,16,44,0.15));
}
.md-feat-media svg { height: 70%; width: auto; max-width: 60%; }
.md-feat-media span {
    font-size: 9.5px; letter-spacing: 0.22em;
    color: var(--md-ink-faint); text-transform: uppercase;
    text-align: center; padding: 0 16px; line-height: 1.8;
}

/* ===== Maison ===== */
.md-maison {
    padding: 86px 40px 100px;
    background: var(--md-nuit);
    position: relative;
}
@media (max-width: 700px) { .md-maison { padding: 64px 18px 72px; } }

.md-maison-card {
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
    padding: 96px 64px;
    text-align: center;
    background:
        radial-gradient(ellipse at 50% 30%, rgba(255,255,255,0.6), transparent 70%),
        linear-gradient(160deg, #F9F6F0 0%, #EFE7D3 45%, #E6D8BA 100%);
    border: 1px solid rgba(206,179,124,0.5);
    border-radius: 6px;
    box-shadow:
        0 32px 64px rgba(5,16,44,0.25),
        0 4px 16px rgba(5,16,44,0.12);
    overflow: hidden;
}
@media (max-width: 900px) { .md-maison-card { padding: 72px 40px; } }
@media (max-width: 700px) { .md-maison-card { padding: 56px 28px; } }

.md-maison-kicker {
    font-size: 10.5px; letter-spacing: 0.32em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 44px;
    display: flex; justify-content: center; align-items: center; gap: 14px;
}
.md-maison-kicker .bar { width: 36px; height: 1px; background: var(--md-dore); }

.md-maison-quote {
    font-family: 'Cardo', serif; font-style: italic; font-weight: 400;
    font-size: clamp(26px, 3.6vw, 48px);
    line-height: 1.3;
    color: var(--md-nuit);
    letter-spacing: -0.005em;
    margin: 0 auto 44px;
    max-width: 880px;
}
.md-maison-quote .accent { color: #8B6E30; font-style: italic; }

.md-maison-attrib {
    font-size: 11px; letter-spacing: 0.26em;
    color: rgba(5,16,44,0.55);
    text-transform: uppercase;
}
.md-maison-attrib .name {
    display: block;
    margin-bottom: 8px;
    font-size: 13px; letter-spacing: 0.2em;
    color: var(--md-nuit);
    font-weight: 600;
}
.md-maison-map-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 22px;
    padding: 12px 18px;
    border: 1px solid rgba(139,110,48,0.42);
    color: var(--md-nuit);
    text-decoration: none;
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    transition: border-color 240ms ease, background 240ms ease, color 240ms ease;
}
.md-maison-map-link:hover {
    border-color: var(--md-dore);
    background: rgba(201,162,83,0.12);
    color: #8B6E30;
}

/* ===== Footer ===== */
.md-footer { padding: 80px 40px 40px; border-top: 1px solid var(--md-hair-faint); background: var(--md-nuit); }
.md-footer-inner {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    padding-bottom: 60px;
}
@media (max-width: 900px) { .md-footer-inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .md-footer-inner { grid-template-columns: 1fr; gap: 36px; } }
.md-footer-brand-big {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: clamp(56px, 7vw, 96px);
    line-height: 0.9;
    color: var(--md-ivoire);
    letter-spacing: -0.02em;
    margin-bottom: 20px;
}
.md-footer-brand-big em { font-style: italic; color: var(--md-dore); font-weight: 400; }
.md-footer-brand-logo {
    display: block;
    width: min(420px, 100%);
    height: 150px;
    object-fit: cover;
    object-position: center 50%;
    margin-bottom: 20px;
}
.md-footer-brand-note {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 17px; color: var(--md-ink-dim);
    max-width: 320px; line-height: 1.5;
}
.md-footer-col h4 {
    font-size: 10px; letter-spacing: 0.28em;
    color: var(--md-dore); text-transform: uppercase;
    margin: 0 0 20px;
    font-weight: 500;
}
.md-footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.md-footer-col a {
    font-family: 'Cardo', serif;
    font-size: 18px;
    color: var(--md-ivoire);
    text-decoration: none;
    transition: color 300ms ease;
}
.md-footer-col a:hover { color: var(--md-dore); }
.md-footer-bottom {
    padding-top: 32px;
    border-top: 1px solid var(--md-hair-faint);
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
    font-size: 10px; letter-spacing: 0.22em;
    color: var(--md-ink-faint); text-transform: uppercase;
}
.md-footer-bottom a { color: var(--md-ink-faint); text-decoration: none; margin-left: 24px; }
.md-footer-bottom a:hover { color: var(--md-dore); }
.md-footer-legal {
    margin-top: 40px;
    text-align: center;
    font-size: 9.5px; letter-spacing: 0.28em;
    color: var(--md-ink-faint); text-transform: uppercase;
}

/* ===== Page hero (replaces page-hero partial styling for inner pages) ===== */
.md-hero { padding: 160px 40px 70px; position: relative; }
@media (max-width: 700px) { .md-hero { padding: 130px 22px 50px; } }
.md-hero-inner { max-width: 1400px; margin: 0 auto; position: relative; }
.md-breadcrumbs {
    display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
    font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--md-ink-faint);
    margin-bottom: 32px;
}
.md-breadcrumbs a { color: var(--md-ink-dim); text-decoration: none; transition: color 300ms ease; }
.md-breadcrumbs a:hover { color: var(--md-dore); }
.md-breadcrumbs .sep { color: var(--md-hair); }
.md-breadcrumbs .current { color: var(--md-ivoire); }

.md-hero-grid {
    display: grid; grid-template-columns: minmax(0, 1.15fr) 360px;
    gap: 56px; align-items: end;
}
@media (max-width: 1100px) { .md-hero-grid { grid-template-columns: 1fr; gap: 40px; } }

.md-eyebrow {
    display: inline-flex; align-items: center; gap: 14px;
    font-size: 10.5px; letter-spacing: 0.28em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 26px;
}
.md-eyebrow .bar { width: 36px; height: 1px; background: var(--md-dore); }

.md-h1 {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: clamp(40px, 6vw, 96px);
    line-height: 0.95; letter-spacing: -0.015em;
    color: var(--md-ivoire);
    margin: 0 0 18px;
}
.md-h1 em { font-style: italic; color: var(--md-dore); font-weight: 400; }
.md-h2 {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: clamp(34px, 4vw, 56px);
    line-height: 1.05; letter-spacing: -0.01em;
    color: var(--md-ivoire);
    margin: 0 0 14px;
}
.md-h2 em { font-style: italic; color: var(--md-dore); font-weight: 400; }
.md-h3 {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: clamp(24px, 2.4vw, 34px);
    line-height: 1.15; letter-spacing: -0.005em;
    color: var(--md-ivoire);
    margin: 0 0 10px;
}

.md-rule { width: 56px; height: 1px; background: var(--md-dore); margin: 24px 0; }
.md-lead {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: clamp(17px, 1.4vw, 22px);
    line-height: 1.55;
    color: var(--md-ink-dim);
    max-width: 720px;
    margin: 0;
}

/* Hero side panel (matches the editorial readout look) */
.md-hero-panel {
    border: 1px solid var(--md-hair-faint);
    background: linear-gradient(155deg, var(--md-nuit-2) 0%, var(--md-nuit) 70%, var(--md-nuit-3) 100%);
    padding: 32px 30px;
    position: relative;
    overflow: hidden;
}
.md-hero-panel::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
}
.md-hero-panel h4 {
    margin: 0 0 18px;
    font-size: 10px; letter-spacing: 0.28em;
    color: var(--md-dore); text-transform: uppercase; font-weight: 500;
    font-family: 'Space Grotesk', sans-serif;
}
.md-hero-panel p {
    font-family: 'Cardo', serif; font-size: 15px; line-height: 1.65;
    color: var(--md-ink-dim);
    margin: 0 0 12px;
}
.md-hero-panel p:last-child { margin-bottom: 0; }
.md-hero-panel ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.md-hero-panel ul li {
    font-family: 'Cardo', serif; font-size: 15px; line-height: 1.55;
    color: var(--md-ink-dim);
    padding-left: 20px; position: relative;
}
.md-hero-panel ul li::before {
    content: ""; position: absolute; left: 0; top: 11px;
    width: 10px; height: 1px; background: var(--md-dore);
}

/* ===== Generic section wrapper ===== */
.md-section { padding: 80px 40px; max-width: 1400px; margin: 0 auto; }
@media (max-width: 700px) { .md-section { padding: 60px 22px; } }
.md-section-tight { padding: 40px 40px 80px; max-width: 1400px; margin: 0 auto; }
@media (max-width: 700px) { .md-section-tight { padding: 30px 22px 60px; } }

.md-section-head {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 48px; align-items: end;
    margin-bottom: 48px;
}
@media (max-width: 900px) { .md-section-head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 32px; } }
.md-section-head .note {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 17px; line-height: 1.55;
    color: var(--md-ink-dim);
    max-width: 380px;
    justify-self: end;
}
@media (max-width: 900px) { .md-section-head .note { justify-self: start; } }

/* ===== Buttons ===== */
.md-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 12px;
    padding: 14px 24px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
    font-weight: 500; text-decoration: none;
    border: 1px solid transparent;
    transition: all 350ms var(--md-ease);
    background: transparent;
    color: var(--md-ivoire);
}
.md-btn-primary { background: var(--md-dore); color: var(--md-nuit); border-color: var(--md-dore); }
.md-btn-primary:hover { background: var(--md-ivoire); border-color: var(--md-ivoire); color: var(--md-nuit); }
.md-btn-ghost { border-color: var(--md-hair); color: var(--md-ivoire); }
.md-btn-ghost:hover { border-color: var(--md-dore); color: var(--md-dore); background: rgba(201,162,83,0.06); }
.md-btn-link {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--md-ivoire); text-decoration: none;
    padding-bottom: 6px; border-bottom: 1px solid var(--md-dore);
    transition: gap 350ms ease, color 350ms ease;
}
.md-btn-link:hover { gap: 20px; color: var(--md-dore); }

/* ===== Surface panels ===== */
.md-panel {
    background: var(--md-nuit-2);
    border: 1px solid var(--md-hair-faint);
    padding: 36px;
    transition: border-color 400ms ease;
}
.md-panel:hover { border-color: var(--md-hair); }
@media (max-width: 700px) { .md-panel { padding: 24px; } }
.md-panel h2, .md-panel h3 { color: var(--md-ivoire); }
.md-panel p {
    font-family: 'Cardo', serif; font-size: 16px; line-height: 1.65;
    color: var(--md-ink-dim);
}
.md-panel-dim {
    background: var(--md-nuit);
    border: 1px solid var(--md-hair-faint);
    padding: 32px;
}
.md-mini-stat {
    border: 1px solid var(--md-hair-faint);
    background: rgba(201,162,83,0.04);
    padding: 22px 24px;
    margin-bottom: 12px;
}
.md-mini-stat .l {
    display: block; font-size: 10px; letter-spacing: 0.22em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 8px;
}
.md-mini-stat .v {
    font-family: 'Cardo', serif; font-size: 32px;
    color: var(--md-ivoire); line-height: 1;
}

/* ===== Chips & tabs ===== */
.md-chip {
    display: inline-flex; align-items: center;
    padding: 9px 16px;
    font-size: 10.5px; letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--md-ink-dim);
    text-decoration: none;
    border: 1px solid var(--md-hair-faint);
    background: transparent;
    transition: all 300ms ease;
}
.md-chip:hover { color: var(--md-dore); border-color: var(--md-hair); background: rgba(201,162,83,0.05); }
.md-chip.active, .md-chip[aria-current="page"] {
    color: var(--md-nuit); background: var(--md-dore); border-color: var(--md-dore);
}

.md-tabs {
    display: flex; flex-wrap: wrap; gap: 8px;
    border-top: 1px solid var(--md-hair-faint);
    border-bottom: 1px solid var(--md-hair-faint);
    padding: 18px 0;
    margin: 28px 0 0;
}
.md-tab {
    display: inline-flex; align-items: center;
    padding: 8px 16px;
    font-size: 10.5px; letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--md-ink-dim);
    text-decoration: none;
    border: 1px solid var(--md-hair-faint);
    transition: all 300ms ease;
}
.md-tab:hover { color: var(--md-dore); border-color: var(--md-hair); }
.md-tab.active { color: var(--md-nuit); background: var(--md-dore); border-color: var(--md-dore); }

/* ===== Catalogue grid ===== */
.md-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 2px;
    background: var(--md-hair-faint);
    border-top: 1px solid var(--md-hair);
    border-bottom: 1px solid var(--md-hair);
}
.md-grid-3 { grid-template-columns: repeat(3, 1fr); }
.md-grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1100px) { .md-grid-4 { grid-template-columns: repeat(2, 1fr); } .md-grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .md-grid-4, .md-grid-3 { grid-template-columns: 1fr; } }

/* ===== Product card ===== */
.md-pcard {
    position: relative;
    background: var(--md-nuit);
    padding: 20px 18px 16px;
    min-height: 360px;
    display: flex; flex-direction: column;
    text-decoration: none;
    overflow: hidden;
    transition: background 700ms ease, transform 500ms var(--md-ease);
}
.md-pcard:hover { background: var(--md-nuit-2); transform: translateY(-4px); }
.md-pcard-top {
    display: flex; justify-content: space-between;
    font-size: 9px; letter-spacing: 0.20em;
    color: var(--md-ink-faint); text-transform: uppercase;
    margin-bottom: 14px;
}
.md-pcard-top .brand { color: var(--md-dore); }
.md-pcard-vis {
    flex: 1;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 14px; position: relative;
    min-height: 160px;
}
.md-pcard-vis::before {
    content: "";
    position: absolute;
    left: 50%; bottom: 6px;
    width: 110px; height: 14px;
    background: radial-gradient(ellipse, rgba(201,162,83,0.30), transparent 70%);
    transform: translateX(-50%);
    filter: blur(6px);
    opacity: 0;
    transition: opacity 600ms ease;
}
.md-pcard:hover .md-pcard-vis::before { opacity: 1; }
.md-pcard-vis img,
.md-pcard-vis svg {
    height: 180px; width: auto; max-width: 100%;
    object-fit: contain;
    transition: transform 1200ms var(--md-ease);
}
.md-pcard:hover .md-pcard-vis img,
.md-pcard:hover .md-pcard-vis svg { transform: scale(1.03) translateY(-4px); }
.md-pcard-name {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: 17px; line-height: 1.2;
    color: var(--md-ivoire);
    margin: 0 0 4px;
    letter-spacing: -0.005em;
    position: relative;
    display: inline-block;
}
.md-pcard-name::after {
    content: ""; position: absolute;
    left: 0; bottom: -4px;
    height: 1px; width: 100%; background: var(--md-dore);
    transform: scaleX(0); transform-origin: left;
    transition: transform 600ms var(--md-ease);
}
.md-pcard:hover .md-pcard-name::after { transform: scaleX(1); }
.md-pcard:not(:hover) .md-pcard-name::after { transform-origin: right; }
.md-pcard-cat {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 12.5px; color: var(--md-ink-dim);
    margin: 0 0 12px;
}
.md-pcard-excerpt {
    color: var(--md-ink-dim);
    font-size: 12.5px;
    line-height: 1.45;
    margin: 0 0 12px;
}
.md-pcard-foot {
    display: flex; justify-content: space-between; align-items: end;
    font-size: 9px; letter-spacing: 0.18em;
    color: var(--md-ink-faint); text-transform: uppercase;
    padding-top: 10px;
    border-top: 1px solid var(--md-hair-faint);
}
.md-pcard-price {
    font-family: 'Cardo', serif;
    font-size: 18px; color: var(--md-ivoire);
    letter-spacing: 0;
    text-transform: none;
}
.md-pcard-stock {
    color: var(--md-dore);
}
.md-pcard-stock.soft { color: var(--md-ink-faint); }

/* ===== Product card promotion ===== */
.md-pcard { position: relative; }
.md-pcard-badge-promo {
    position: absolute;
    top: 10px; right: 10px;
    z-index: 2;
    font-family: 'Manrope', sans-serif;
    font-size: 9px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--md-nuit);
    background: linear-gradient(135deg, var(--md-dore) 0%, #d8b97c 100%);
    padding: 5px 10px;
    border: 1px solid rgba(255,255,255,0.2);
    box-shadow: 0 6px 14px rgba(0,0,0,0.18);
    overflow: hidden;
}
.md-pcard-prices {
    display: inline-flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
}
.md-pcard-price--old {
    font-size: 12.5px;
    color: var(--md-ink-faint);
    text-decoration: line-through;
    text-decoration-color: rgba(187, 147, 87, 0.55);
    text-decoration-thickness: 1px;
}
.md-pcard-price--promo {
    color: var(--md-dore);
}
.md-pcard--promo .md-pcard-name { color: var(--md-ivoire); }

/* ===== Product page ===== */
.md-product {
    display: grid; grid-template-columns: minmax(0, 1.1fr) 420px;
    gap: 48px; align-items: start;
}
@media (max-width: 1100px) { .md-product { grid-template-columns: 1fr; gap: 32px; } }

.md-product-stage {
    background: var(--md-nuit);
    border: 1px solid var(--md-hair-faint);
    aspect-ratio: 5 / 4;
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
    position: relative;
}
.md-product-stage img {
    width: 90%;
    height: 90%;
    object-fit: contain;
    filter: drop-shadow(0 8px 16px rgba(0,0,0,0.2));
}
.md-product-stage svg { height: 65%; width: auto; }
.md-product-thumbs {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 8px; margin-top: 8px;
}
.md-product-thumb {
    aspect-ratio: 4 / 5;
    background: var(--md-nuit);
    border: 1px solid var(--md-hair-faint);
    overflow: hidden;
    cursor: pointer;
    transition: border-color 300ms ease;
}
.md-product-thumb:hover { border-color: var(--md-dore); }
.md-product-thumb img {
    width: 90%;
    height: 90%;
    object-fit: contain;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.15));
}

.md-product-info {
    position: sticky; top: 110px;
    border: 1px solid var(--md-hair-faint);
    background: linear-gradient(155deg, var(--md-nuit-2) 0%, var(--md-nuit) 70%, var(--md-nuit-3) 100%);
    padding: 26px 24px;
}
@media (max-width: 1100px) { .md-product-info { position: static; } }
.md-product-brand {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 10px; letter-spacing: 0.26em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 12px;
}
.md-product-brand .bar { width: 20px; height: 1px; background: var(--md-dore); }
.md-product-name {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: clamp(24px, 2.8vw, 36px);
    line-height: 1.1;
    color: var(--md-ivoire);
    letter-spacing: -0.01em;
    margin: 0 0 6px;
}
.md-product-cat {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 14.5px; color: var(--md-ink-dim);
    margin: 0 0 18px;
}
.md-product-price-row {
    display: flex; align-items: baseline; justify-content: space-between; gap: 14px;
    padding: 16px 0;
    border-top: 1px solid var(--md-hair-faint);
    border-bottom: 1px solid var(--md-hair-faint);
    margin-bottom: 18px;
}
.md-product-price {
    font-family: 'Cardo', serif;
    font-size: 30px; color: var(--md-ivoire);
    line-height: 1;
}
.md-product-stock {
    font-size: 9.5px; letter-spacing: 0.20em;
    text-transform: uppercase;
    padding: 5px 10px;
    border: 1px solid var(--md-hair);
    color: var(--md-dore);
}
.md-product-stock.soft { color: var(--md-ink-faint); border-color: var(--md-hair-faint); }

.md-product-promo-block {
    margin: 12px 0 0;
    padding: 14px 16px;
    border: 1px solid rgba(187, 147, 87, 0.32);
    background: linear-gradient(140deg, rgba(187,147,87,0.08) 0%, rgba(7,17,32,0.0) 60%);
}
.md-product-promo-head {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.md-product-promo-badge {
    position: relative;
    font-family: 'Manrope', sans-serif;
    font-size: 10px;
    letter-spacing: 0.26em;
    text-transform: uppercase;
    color: var(--md-nuit);
    background: linear-gradient(135deg, var(--md-dore) 0%, #d8b97c 100%);
    padding: 5px 10px;
    overflow: hidden;
}
.md-product-promo-discount {
    font-family: 'Cardo', serif;
    font-size: 17px;
    color: var(--md-dore);
    letter-spacing: 0.02em;
}
.md-product-promo-meta {
    margin: 8px 0 0;
    font-size: 12px;
    letter-spacing: 0.04em;
    color: var(--md-ivoire);
    opacity: 0.82;
}
.md-product-promo-note {
    margin: 4px 0 0;
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 13.5px;
    color: var(--md-ink-dim);
}
.md-product-prices {
    display: inline-flex; align-items: baseline; gap: 12px; flex-wrap: wrap;
}
.md-product-price--old {
    font-size: 18px;
    color: var(--md-ink-faint);
    text-decoration: line-through;
    text-decoration-color: rgba(187, 147, 87, 0.55);
    text-decoration-thickness: 1px;
}
.md-product-price--promo {
    color: var(--md-dore);
}
.md-product-price-row--promo {
    border-top-color: rgba(187, 147, 87, 0.35);
    border-bottom-color: rgba(187, 147, 87, 0.35);
}

/* Promo badge sheen — runs once when the card/info panel enters the viewport. */
.md-pcard-badge-promo::after,
.md-product-promo-badge::after {
    content: "";
    position: absolute;
    top: 0; bottom: 0;
    left: 0;
    width: 50%;
    pointer-events: none;
    background: linear-gradient(
        110deg,
        rgba(255, 247, 225, 0) 0%,
        rgba(255, 247, 225, 0.55) 50%,
        rgba(255, 247, 225, 0) 100%
    );
    transform: translate3d(-120%, 0, 0);
    opacity: 0;
    will-change: transform, opacity;
}
.md-pcard--promo.in .md-pcard-badge-promo::after,
.md-product-info.in .md-product-promo-badge::after {
    animation: md-promo-sheen 1400ms cubic-bezier(0.22, 0.61, 0.36, 1) 500ms 1 forwards;
}
@keyframes md-promo-sheen {
    0%   { transform: translate3d(-120%, 0, 0); opacity: 0; }
    20%  {                                      opacity: 1; }
    80%  {                                      opacity: 1; }
    100% { transform: translate3d(220%,  0, 0); opacity: 0; }
}

.md-detail-list { display: grid; gap: 10px; margin-bottom: 20px; }
.md-detail-row {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: 12px;
    padding-bottom: 9px;
    border-bottom: 1px solid var(--md-hair-faint);
    font-size: 12.5px;
}
.md-detail-row .l {
    font-size: 9.5px; letter-spacing: 0.20em;
    text-transform: uppercase;
    color: var(--md-ink-faint);
}
.md-detail-row .v {
    font-family: 'Cardo', serif;
    color: var(--md-ivoire);
    font-size: 14.5px;
    text-align: right;
}

.md-product-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
@media (max-width: 480px) { .md-product-actions { grid-template-columns: 1fr; } }

.md-attr-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    background: var(--md-hair-faint);
    border-top: 1px solid var(--md-hair);
    border-bottom: 1px solid var(--md-hair);
}
@media (max-width: 900px) { .md-attr-grid { grid-template-columns: repeat(2, 1fr); } }
.md-attr-cell {
    background: var(--md-nuit);
    padding: 18px 18px;
}
.md-attr-cell .l {
    font-size: 9.5px; letter-spacing: 0.22em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 8px; display: block;
    font-weight: 600;
}
.md-attr-cell .v {
    font-family: 'Cardo', serif; font-size: 16px;
    color: var(--md-ivoire); line-height: 1.3;
}

/* ===== Filter panel ===== */
.md-filter {
    border: 1px solid var(--md-hair-faint);
    background: var(--md-nuit);
    padding: 28px 26px;
    position: sticky; top: 110px;
}
@media (max-width: 1100px) { .md-filter { position: static; } }
.md-filter-head {
    display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
    margin-bottom: 20px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--md-hair-faint);
}
.md-filter-head h3 {
    margin: 0;
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: 22px; color: var(--md-ivoire);
}
.md-filter-head .reset {
    font-size: 10px; letter-spacing: 0.22em;
    color: var(--md-dore); text-transform: uppercase;
    text-decoration: none;
    transition: color 300ms ease;
}
.md-filter-head .reset:hover { color: var(--md-ivoire); }

.md-filter-group { border-bottom: 1px solid var(--md-hair-faint); padding: 14px 0; }
.md-filter-group:last-of-type { border-bottom: none; }
.md-filter-group summary {
    display: flex; justify-content: space-between; align-items: center;
    cursor: pointer; padding: 4px 0;
    font-size: 11px; letter-spacing: 0.24em;
    color: var(--md-ivoire); text-transform: uppercase;
    list-style: none;
}
.md-filter-group summary::-webkit-details-marker { display: none; }
.md-filter-group summary::after { content: "+"; color: var(--md-dore); font-size: 16px; }
.md-filter-group[open] summary::after { content: "−"; }
.md-filter-options { display: grid; gap: 10px; padding: 14px 0 4px; }
.md-filter-option {
    display: flex; align-items: center; gap: 10px;
    font-family: 'Cardo', serif; font-size: 15px;
    color: var(--md-ink-dim);
    cursor: pointer;
}
.md-filter-option:hover { color: var(--md-ivoire); }
.md-filter-option input[type="checkbox"],
.md-filter-option input[type="radio"] {
    -webkit-appearance: none; appearance: none;
    width: 14px; height: 14px;
    border: 1px solid var(--md-hair);
    background: transparent;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
}
.md-filter-option input[type="radio"] {
    border-radius: 999px;
}
.md-filter-option input[type="checkbox"]:checked,
.md-filter-option input[type="radio"]:checked {
    background: var(--md-dore);
    border-color: var(--md-dore);
}
.md-filter-option input[type="checkbox"]:checked::after,
.md-filter-option input[type="radio"]:checked::after {
    content: "✓"; position: absolute;
    top: 50%; left: 50%; transform: translate(-50%, -50%);
    color: var(--md-nuit); font-size: 10px; font-weight: 700;
}
.md-filter-empty {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 13px; color: var(--md-ink-faint);
    padding: 8px 0;
}
.md-filter-apply {
    margin-top: 22px;
    width: 100%;
}
.md-filter-price-fields {
    display: grid;
    gap: 10px;
    padding: 14px 0 4px;
}
.md-filter-field {
    display: grid;
    gap: 6px;
}
.md-filter-field span {
    font-size: 9px;
    letter-spacing: 0.20em;
    text-transform: uppercase;
    color: var(--md-dore);
}
.md-filter-input {
    width: 100%;
    border: 1px solid var(--md-hair-faint);
    background: rgba(255,255,255,0.04);
    color: var(--md-ivoire);
    padding: 10px 11px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 13px;
    outline: none;
    transition: border-color 240ms ease, background 240ms ease;
}
.md-filter-input:focus {
    border-color: var(--md-dore);
    background: rgba(206,179,124,0.08);
}
.md-filter-input::placeholder {
    color: var(--md-ink-faint);
}

/* Catalogue layout */
.md-cat-layout {
    display: grid; grid-template-columns: 280px minmax(0, 1fr);
    gap: 32px;
}
@media (max-width: 1100px) { .md-cat-layout { grid-template-columns: 1fr; } }

.md-wine-cluster-link {
    padding-top: 18px;
    padding-bottom: 10px;
}
.md-wine-cluster-link__panel {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.35fr) auto;
    align-items: center;
    gap: 18px;
    padding: 18px 22px;
    border: 1px solid rgba(206,179,124,0.50);
    border-radius: 5px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.42), transparent 70%),
        linear-gradient(168deg, rgba(249,246,240,0.95) 0%, rgba(242,234,218,0.95) 100%);
    color: var(--md-nuit);
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(5,16,44,0.10);
}
.md-wine-cluster-link__kicker,
.md-wine-cluster-link__cta {
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--md-dore-d);
}
.md-wine-cluster-link__title {
    font-family: 'Cardo', serif;
    font-size: clamp(23px, 2.6vw, 34px);
    line-height: 1.05;
}
.md-wine-cluster-link__text {
    color: rgba(5,16,44,0.66);
    font-size: 14.5px;
    line-height: 1.55;
}
.md-wine-cluster-link__cta {
    justify-self: end;
    white-space: nowrap;
}
.md-wine-cluster-link__panel:hover {
    border-color: rgba(206,179,124,0.90);
}
@media (max-width: 900px) {
    .md-wine-cluster-link__panel {
        grid-template-columns: 1fr;
    }
    .md-wine-cluster-link__cta {
        justify-self: start;
    }
}

.md-results-bar {
    display: flex; justify-content: space-between; align-items: center; gap: 16px;
    padding: 18px 0;
    border-bottom: 1px solid var(--md-hair-faint);
    margin-bottom: 32px;
    flex-wrap: wrap;
}
.md-results-bar .count {
    font-family: 'Cardo', serif; font-size: 17px;
    color: var(--md-ivoire);
}
.md-results-bar .count em { color: var(--md-dore); font-style: italic; }
.md-results-bar .badges { display: flex; gap: 8px; flex-wrap: wrap; }
.md-results-bar .badge {
    font-size: 10px; letter-spacing: 0.22em;
    color: var(--md-dore); text-transform: uppercase;
    padding: 6px 12px;
    border: 1px solid var(--md-hair);
}
.md-results-bar a.badge {
    text-decoration: none;
    transition: border-color 300ms ease, color 300ms ease;
}
.md-results-bar a.badge:hover {
    border-color: var(--md-dore);
    color: var(--md-ivoire);
}

/* ===== Pagination ===== */
.md-pagination {
    display: flex; justify-content: center; align-items: center; gap: 8px;
    margin-top: 48px; padding: 24px 0;
    border-top: 1px solid var(--md-hair-faint);
}
.md-pagination a, .md-pagination span {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 40px; height: 40px;
    padding: 0 12px;
    font-size: 11px; letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--md-ink-dim);
    text-decoration: none;
    border: 1px solid var(--md-hair-faint);
    background: transparent;
    transition: all 300ms ease;
}
.md-pagination a:hover { color: var(--md-dore); border-color: var(--md-dore); }
.md-pagination .current,
.md-pagination [aria-current="page"] {
    color: var(--md-nuit); background: var(--md-dore); border-color: var(--md-dore);
}
.md-pagination .disabled { opacity: 0.35; cursor: not-allowed; }

/* ===== Empty state ===== */
.md-empty {
    border: 1px solid var(--md-hair-faint);
    background: var(--md-nuit);
    padding: 80px 40px;
    text-align: center;
}
.md-empty .md-eyebrow { justify-content: center; }
.md-empty h2 { color: var(--md-ivoire); margin-bottom: 14px; }
.md-empty p {
    font-family: 'Cardo', serif; font-style: italic;
    font-size: 17px; color: var(--md-ink-dim);
    max-width: 500px; margin: 0 auto 28px; line-height: 1.55;
}

/* ===== Search shell ===== */
.md-search-shell {
    border: 1px solid var(--md-hair-faint);
    background: var(--md-nuit-2);
    padding: 36px;
    display: flex; flex-direction: column; gap: 18px;
}
@media (max-width: 700px) { .md-search-shell { padding: 24px; } }
.md-search-input {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--md-hair);
    color: var(--md-ivoire);
    font-family: 'Cardo', serif;
    font-size: clamp(22px, 3vw, 36px);
    padding: 12px 0 14px;
    outline: none;
    transition: border-color 300ms ease;
}
.md-search-input::placeholder { color: var(--md-ink-faint); font-style: italic; }
.md-search-input:focus { border-color: var(--md-dore); }

/* ===== Long-form prose (about, legal, cookies) ===== */
.md-prose {
    font-family: 'Cardo', serif;
    color: var(--md-ink);
    max-width: 760px;
}
.md-prose h2 {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: clamp(26px, 2.6vw, 38px);
    color: var(--md-ivoire);
    letter-spacing: -0.005em;
    line-height: 1.15;
    margin: 56px 0 18px;
    padding-top: 28px;
    border-top: 1px solid var(--md-hair-faint);
}
.md-prose h2:first-child { margin-top: 0; padding-top: 0; border-top: none; }
.md-prose h2 em { font-style: italic; color: var(--md-dore); }
.md-prose p {
    font-size: 17px; line-height: 1.7;
    color: var(--md-ink-dim);
    margin: 0 0 18px;
}
.md-prose p strong { color: var(--md-ivoire); font-weight: 400; }
.md-prose a { color: var(--md-dore); text-decoration: none; border-bottom: 1px solid var(--md-hair); }
.md-prose a:hover { color: var(--md-ivoire); border-bottom-color: var(--md-dore); }

/* ===== Three-up principle cards (about, contact) ===== */
.md-cards-3 {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    background: var(--md-hair-faint);
    border-top: 1px solid var(--md-hair);
    border-bottom: 1px solid var(--md-hair);
}
@media (max-width: 900px) { .md-cards-3 { grid-template-columns: 1fr; } }
.md-card-3 {
    background: var(--md-nuit);
    padding: 36px 32px;
    min-height: 240px;
    display: flex; flex-direction: column;
    transition: background 700ms ease;
}
.md-card-3:hover { background: var(--md-nuit-2); }
.md-card-3 .num {
    font-size: 10px; letter-spacing: 0.28em;
    color: var(--md-dore); text-transform: uppercase;
    margin-bottom: 18px;
}
.md-card-3 h3 {
    font-family: 'Cardo', serif; font-weight: 400;
    font-size: 32px; line-height: 1.1;
    color: var(--md-ivoire);
    margin: 0 0 14px;
    letter-spacing: -0.005em;
}
.md-card-3 p {
    font-family: 'Cardo', serif; font-size: 15px;
    line-height: 1.6; color: var(--md-ink-dim);
    margin: 0 0 20px;
}
.md-card-3 .md-btn-link { margin-top: auto; }

/* ===== CTA band ===== */
.md-cta-band {
    border: 1px solid var(--md-hair-faint);
    background: var(--md-nuit-2);
    padding: 64px;
    display: grid; grid-template-columns: minmax(0, 1.4fr) auto;
    gap: 48px; align-items: end;
    margin: 0 40px;
    max-width: calc(1400px - 0px);
    margin-left: auto; margin-right: auto;
    width: calc(100% - 80px);
    position: relative; overflow: hidden;
}
@media (max-width: 900px) { .md-cta-band { grid-template-columns: 1fr; padding: 40px; } }
@media (max-width: 700px) { .md-cta-band { width: calc(100% - 44px); padding: 32px; margin-left: 22px; margin-right: 22px; } }
.md-cta-band::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
}
.md-cta-band .actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ===== Misc inline utilities ===== */
.md-text-center { text-align: center; }
.md-bullet-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.md-bullet-list li {
    font-family: 'Cardo', serif; font-size: 16px; line-height: 1.55;
    color: var(--md-ink-dim);
    padding-left: 22px; position: relative;
}
.md-bullet-list li::before {
    content: ""; position: absolute; left: 0; top: 12px;
    width: 12px; height: 1px; background: var(--md-dore);
}

/* Hours table (contact) */
.md-hours { display: grid; gap: 8px; }
.md-hours .row {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 14px 16px;
    border: 1px solid var(--md-hair-faint);
    background: rgba(201,162,83,0.03);
}
.md-hours .label { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--md-ink-dim); }
.md-hours .v { font-family: 'Cardo', serif; font-size: 16px; color: var(--md-ivoire); }

/* WhatsApp float — match dark theme */
/* ============================================================
   Notre cave: premium about + contact page
   ============================================================ */
.md-about-page {
    background:
        radial-gradient(ellipse at 50% 0%, rgba(206,179,124,0.08), transparent 42%),
        var(--md-nuit);
}

.md-about-hero {
    padding: 132px 40px 34px;
    position: relative;
    overflow: hidden;
}
.md-about-hero::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 420px;
    background:
        linear-gradient(90deg, rgba(5,16,44,0.95) 0%, rgba(5,16,44,0.76) 54%, rgba(5,16,44,0.92) 100%),
        url('/img/about/caviste-cellar.png') center 34% / cover no-repeat;
    opacity: 0.72;
    pointer-events: none;
}
.md-about-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 160px;
    background: linear-gradient(180deg, transparent, var(--md-nuit));
    pointer-events: none;
}
.md-about-hero__inner {
    position: relative;
    z-index: 1;
    max-width: 1260px;
    margin: 0 auto;
}
.md-about-hero__content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 44px;
    align-items: end;
    min-height: 330px;
}
.md-about-hero__title {
    margin: 0;
    max-width: 780px;
    font-family: 'Cormorant Garamond', 'Cardo', serif;
    font-size: clamp(48px, 7vw, 92px);
    line-height: 0.94;
    font-weight: 400;
    color: var(--md-ivoire);
}
.md-about-hero__lead {
    max-width: 560px;
    margin: 0;
    font-family: 'Cardo', serif;
    font-size: clamp(17px, 1.4vw, 21px);
    line-height: 1.62;
    color: rgba(245,239,226,0.78);
}
.md-about-hero__note {
    border: 1px solid var(--md-hair);
    background: rgba(5,16,44,0.72);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 28px;
}
.md-about-hero__note span {
    display: block;
    margin-bottom: 12px;
    font-size: 10px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--md-dore);
}
.md-about-hero__note p {
    margin: 0;
    font-family: 'Cardo', serif;
    font-size: 16px;
    line-height: 1.6;
    color: var(--md-ink-dim);
}

.md-about-intro {
    padding-top: 22px;
}
.md-about-panel,
.md-about-contact__panel {
    max-width: 1260px;
    margin: 0 auto;
    border: 1px solid rgba(206,179,124,0.55);
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.58), transparent 68%),
        linear-gradient(155deg, #FAF6ED 0%, #F1E8D5 56%, #E6D8BA 100%);
    box-shadow: 0 28px 60px rgba(0,0,0,0.34);
    position: relative;
    overflow: hidden;
}
.md-about-panel::before,
.md-about-contact__panel::before,
.md-about-cta::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
}
.md-about-panel {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 0;
    padding: clamp(14px, 1.8vw, 22px);
}
.md-about-image {
    min-height: 440px;
    overflow: hidden;
    background: var(--md-nuit);
}
.md-about-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    filter: saturate(0.92) contrast(1.02);
}
.md-about-copy {
    padding: clamp(34px, 4vw, 64px);
    align-self: center;
}
.md-about-copy .md-eyebrow {
    color: var(--md-dore-d);
}
.md-about-copy .md-eyebrow .bar {
    background: var(--md-dore-d);
}
.md-about-copy h2 {
    margin: 0 0 24px;
    font-family: 'Cormorant Garamond', 'Cardo', serif;
    font-weight: 400;
    font-size: clamp(36px, 4.2vw, 60px);
    line-height: 1;
    color: var(--md-nuit);
}
.md-about-copy p {
    max-width: 560px;
    margin: 0 0 18px;
    font-family: 'Cardo', serif;
    font-size: 18px;
    line-height: 1.72;
    color: rgba(5,16,44,0.72);
}

.md-about-expertise .md-section-head,
.md-about-contact .md-section-head {
    max-width: 1260px;
}
.md-about-values {
    max-width: 1260px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.md-about-value {
    min-height: 240px;
    border: 1px solid var(--md-hair);
    background:
        linear-gradient(155deg, rgba(26,37,69,0.88), rgba(5,16,44,0.98)),
        var(--md-nuit);
    padding: 30px 26px;
    transition: transform 420ms var(--md-ease), border-color 420ms var(--md-ease), background 420ms var(--md-ease);
}
.md-about-value:hover {
    transform: translateY(-4px);
    border-color: var(--md-dore);
    background:
        linear-gradient(155deg, rgba(34,48,90,0.96), rgba(5,16,44,0.98)),
        var(--md-nuit);
}
.md-about-value__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    margin-bottom: 28px;
    border: 1px solid var(--md-hair);
    border-radius: 50%;
    color: var(--md-dore);
    font-family: 'Cardo', serif;
    font-size: 15px;
}
.md-about-value h3 {
    margin: 0 0 12px;
    font-family: 'Cardo', serif;
    font-weight: 400;
    font-size: 28px;
    color: var(--md-ivoire);
}
.md-about-value p {
    margin: 0;
    font-family: 'Cardo', serif;
    font-size: 15.5px;
    line-height: 1.62;
    color: var(--md-ink-dim);
}

.md-about-contact__panel {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(260px, 0.72fr) minmax(260px, 0.8fr);
    gap: 0;
    padding: clamp(28px, 3vw, 42px);
}
.md-about-form,
.md-about-contact__details,
.md-about-map {
    min-width: 0;
}
.md-about-form,
.md-about-contact__details {
    padding-right: 30px;
    border-right: 1px solid rgba(5,16,44,0.10);
}
.md-about-contact__details {
    padding-left: 30px;
}
.md-about-form h3,
.md-about-contact__details h3 {
    margin: 0 0 20px;
    font-family: 'Cardo', serif;
    font-weight: 400;
    font-size: 28px;
    color: var(--md-nuit);
}
.md-about-form {
    display: grid;
    gap: 14px;
}
.md-about-form label {
    display: grid;
    gap: 7px;
}
.md-about-form label span {
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(5,16,44,0.48);
}
.md-about-form input,
.md-about-form textarea {
    width: 100%;
    border: 1px solid rgba(5,16,44,0.18);
    background: rgba(255,255,255,0.46);
    padding: 13px 14px;
    color: var(--md-nuit);
    font-family: 'Space Grotesk', sans-serif;
    font-size: 13px;
    outline: none;
    transition: border-color 240ms ease, background 240ms ease;
}
.md-about-form textarea {
    resize: vertical;
    min-height: 132px;
}
.md-about-form input::placeholder,
.md-about-form textarea::placeholder {
    color: rgba(5,16,44,0.42);
}
.md-about-form input:focus,
.md-about-form textarea:focus {
    border-color: var(--md-dore-d);
    background: rgba(255,255,255,0.72);
}
.md-about-contact-card {
    display: grid;
    gap: 4px;
    padding: 16px 0;
    border-bottom: 1px solid rgba(5,16,44,0.10);
}
.md-about-contact-card span {
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--md-dore-d);
}
.md-about-contact-card a,
.md-about-contact-card p {
    margin: 0;
    font-family: 'Cardo', serif;
    font-size: 18px;
    color: var(--md-nuit);
    text-decoration: none;
}
.md-about-contact-card a:hover {
    color: var(--md-dore-d);
}
.md-about-contact-card .md-map-link {
    width: fit-content;
    margin-top: 10px;
    padding: 11px 15px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 10px;
    letter-spacing: 0.18em;
    color: var(--md-nuit);
}
.md-about-map {
    position: relative;
    margin-left: 30px;
    border: 1px solid rgba(206,179,124,0.45);
    background: rgba(249,246,240,0.68);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    gap: 14px;
    padding: 10px;
}
.md-about-map__frame {
    width: 100%;
    height: 390px;
    border: 1px solid rgba(255,255,240,0.78);
    background: #F9F6F0;
    overflow: hidden;
}
.md-about-map__frame iframe {
    display: block;
    width: 100%;
    height: 100%;
}
.md-about-map .md-map-link {
    position: relative;
    z-index: 1;
    align-self: center;
    padding: 11px 16px;
    font-size: 10px;
    letter-spacing: 0.18em;
}
.md-panel-map-link {
    margin-top: 8px;
    padding: 11px 16px;
    font-size: 10px;
    letter-spacing: 0.18em;
}

.md-about-cta {
    max-width: 1260px;
    width: calc(100% - 80px);
    margin: 0 auto;
    border: 1px solid var(--md-hair);
    background:
        linear-gradient(135deg, rgba(5,16,44,0.84), rgba(5,16,44,0.98)),
        var(--md-nuit);
    padding: clamp(36px, 4vw, 58px);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 36px;
    align-items: center;
    position: relative;
    overflow: hidden;
}
.md-about-cta::after {
    content: "MAP";
    position: absolute;
    left: 28px;
    bottom: -16px;
    font-family: 'Cormorant Garamond', 'Cardo', serif;
    font-size: 132px;
    color: rgba(206,179,124,0.045);
    pointer-events: none;
}
.md-about-cta .md-lead {
    max-width: 560px;
    margin: 0;
    font-size: 17px;
}
.md-about-cta .actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    min-width: 220px;
    position: relative;
    z-index: 1;
}
.md-about-cta .md-btn {
    justify-content: center;
}

@media (max-width: 1100px) {
    .md-about-hero__content,
    .md-about-panel,
    .md-about-contact__panel,
    .md-about-cta {
        grid-template-columns: 1fr;
    }
    .md-about-hero__content { min-height: 280px; }
    .md-about-values { grid-template-columns: repeat(2, 1fr); }
    .md-about-form,
    .md-about-contact__details {
        padding-right: 0;
        padding-left: 0;
        border-right: none;
        border-bottom: 1px solid rgba(5,16,44,0.10);
        padding-bottom: 28px;
        margin-bottom: 28px;
    }
    .md-about-map { margin-left: 0; }
}
@media (max-width: 700px) {
    .md-about-hero { padding: 110px 22px 28px; }
    .md-about-hero__content { gap: 26px; }
    .md-about-hero__note { padding: 22px; }
    .md-about-panel,
    .md-about-contact__panel { width: calc(100% - 44px); }
    .md-about-image { min-height: 300px; }
    .md-about-copy { padding: 30px 22px; }
    .md-about-values { grid-template-columns: 1fr; gap: 10px; }
    .md-about-value { min-height: auto; padding: 26px 22px; }
    .md-about-contact__panel { padding: 22px; }
    .md-about-map__frame { height: 300px; }
    .md-about-cta {
        width: calc(100% - 44px);
        padding: 32px 24px;
    }
    .md-about-cta .actions { min-width: 0; }
}

.whatsapp-float {
    position: fixed !important; bottom: 22px; right: 22px;
    z-index: 40;
    display: inline-flex !important; align-items: center; gap: 10px;
    padding: 12px 20px;
    background: var(--md-nuit-2) !important;
    border: 1px solid var(--md-dore) !important;
    color: var(--md-dore) !important;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 11px !important; letter-spacing: 0.22em;
    text-transform: uppercase;
    text-decoration: none !important;
    border-radius: 0 !important;
    opacity: 0;
    transition: opacity 400ms var(--md-ease) 600ms, background 350ms var(--md-ease), color 350ms var(--md-ease);
}
.md-page.revealed .whatsapp-float { opacity: 1; transition-delay: 0s, 0s, 0s; }
.whatsapp-float:hover { background: var(--md-dore) !important; color: var(--md-nuit) !important; }
.whatsapp-float .inline-flex { background: var(--md-dore) !important; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 200ms !important; }
    .md-banner-media { animation: none; }
    .md-bar-live { animation: none; width: 32px; opacity: 0.8; }
    .md-featured-hero .md-featured-copy > *,
    .md-featured-hero .md-featured-panel,
    .md-featured-hero .md-featured-bottle {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    /* Scroll reveals: skip translate, show immediately */
    .md-reveal {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    /* Remove stagger delays on cat pills and feature cards */
    .md-cat-pill,
    .md-feat-card { transition-delay: 0ms !important; }
    /* WhatsApp button: always visible */
    .whatsapp-float { opacity: 1 !important; transition-delay: 0s !important; }
    /* Promo badge sheen: suppress entirely */
    .md-pcard-badge-promo::after,
    .md-product-promo-badge::after {
        animation: none !important;
        opacity: 0 !important;
    }
}

/* ============================================================
   Catalogue compact mode
   Scoped under .md-catalogue so the homepage / product page /
   editorial pages keep their current spacing untouched.
   Goal: premium wine-wall density — more references per screen,
   slimmer cards, refined hairlines, no supermarket feel.
   ============================================================ */

.md-catalogue .md-hero { padding: 130px 40px 36px; }
@media (max-width: 700px) { .md-catalogue .md-hero { padding: 110px 22px 28px; } }
.md-catalogue .md-hero-grid { grid-template-columns: 1fr; gap: 18px; }
.md-catalogue .md-hero .md-h1 {
    font-size: clamp(34px, 4.6vw, 64px);
    line-height: 1; margin-bottom: 14px;
}
.md-catalogue .md-hero .md-rule { margin: 16px 0; }
.md-catalogue .md-hero .md-lead {
    font-size: clamp(15px, 1.1vw, 18px);
    line-height: 1.5; max-width: 680px;
}
.md-catalogue .md-breadcrumbs { margin-bottom: 22px; }

/* Tabs band: shorter and quieter */
.md-catalogue .md-section-tight { padding: 8px 40px 24px; }
@media (max-width: 700px) { .md-catalogue .md-section-tight { padding: 6px 22px 18px; } }
.md-catalogue .md-tabs {
    padding: 12px 0; margin-top: 8px;
    gap: 6px;
}
.md-catalogue .md-tab {
    padding: 6px 12px;
    font-size: 10px; letter-spacing: 0.2em;
}

/* Catalogue section padding */
.md-catalogue .md-section { padding: 24px 40px 64px; }
@media (max-width: 700px) { .md-catalogue .md-section { padding: 18px 22px 48px; } }

/* Sidebar a touch narrower for more grid space */
.md-catalogue .md-cat-layout {
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 28px;
}
@media (max-width: 1100px) { .md-catalogue .md-cat-layout { grid-template-columns: 1fr; gap: 18px; } }

/* Results bar: compact, single-line where possible */
.md-catalogue .md-results-bar {
    padding: 12px 0; margin-bottom: 18px;
    gap: 12px;
}
.md-catalogue .md-results-bar .count { font-size: 14px; }
.md-catalogue .md-results-bar .badge {
    font-size: 9px; letter-spacing: 0.2em;
    padding: 4px 9px;
}

/* Filter panel: refined, denser */
.md-catalogue .md-filter {
    padding: 20px 20px;
    top: 96px;
}
.md-catalogue .md-filter-head {
    margin-bottom: 14px;
    padding-bottom: 12px;
}
.md-catalogue .md-filter-head h3 {
    font-size: 12px; letter-spacing: 0.28em;
    text-transform: uppercase;
    font-family: 'Space Grotesk', sans-serif; font-weight: 500;
    color: var(--md-dore);
}
.md-catalogue .md-filter-head .reset { font-size: 9px; }
.md-catalogue .md-filter-group { padding: 10px 0; }
.md-catalogue .md-filter-group summary {
    font-size: 10px; letter-spacing: 0.22em;
    padding: 2px 0;
}
.md-catalogue .md-filter-group summary::after { font-size: 14px; }
.md-catalogue .md-filter-options {
    gap: 7px; padding: 10px 0 2px;
    max-height: 220px; overflow-y: auto;
}
.md-catalogue .md-filter-options::-webkit-scrollbar { width: 4px; }
.md-catalogue .md-filter-options::-webkit-scrollbar-thumb { background: var(--md-hair-faint); }
.md-catalogue .md-filter-option { font-size: 13px; gap: 9px; }
.md-catalogue .md-filter-option input[type="checkbox"],
.md-catalogue .md-filter-option input[type="radio"] { width: 12px; height: 12px; }
.md-catalogue .md-filter-option input[type="checkbox"]:checked::after,
.md-catalogue .md-filter-option input[type="radio"]:checked::after { font-size: 9px; }
.md-catalogue .md-filter-apply {
    margin-top: 16px;
    padding: 11px 18px;
    font-size: 10px; letter-spacing: 0.22em;
}

/* Product grid: denser auto-fill so more bottles per row */
.md-catalogue .md-grid,
.md-catalogue .md-grid-3,
.md-catalogue .md-grid-4 {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1px;
}
@media (max-width: 700px) {
    .md-catalogue .md-grid,
    .md-catalogue .md-grid-3,
    .md-catalogue .md-grid-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}
/* Phones: collapse to a single column so each card has room to breathe. */
@media (max-width: 540px) {
    .md-catalogue .md-grid,
    .md-catalogue .md-grid-3,
    .md-catalogue .md-grid-4 {
        grid-template-columns: 1fr;
    }
}

/* Product card: slimmer, more elegant */
.md-catalogue .md-pcard {
    padding: 16px 16px 14px;
    min-height: 320px;
}
.md-catalogue .md-pcard-top {
    font-size: 8.5px; letter-spacing: 0.2em;
    margin-bottom: 12px;
}
.md-catalogue .md-pcard-vis {
    margin-bottom: 12px;
    min-height: 140px;
}
.md-catalogue .md-pcard-vis img,
.md-catalogue .md-pcard-vis svg {
    height: 156px;
}
.md-catalogue .md-pcard-name {
    font-size: 15.5px; line-height: 1.2;
    margin-bottom: 3px;
}
.md-catalogue .md-pcard-cat {
    font-size: 12px;
    margin-bottom: 10px;
}
.md-catalogue .md-pcard-foot {
    padding-top: 9px;
    font-size: 8.5px; letter-spacing: 0.18em;
}
.md-catalogue .md-pcard-price { font-size: 16.5px; }
/* Mobile catalogue card: compact, denser, easier to browse */
@media (max-width: 700px) {
    .md-catalogue .md-pcard { padding: 10px 10px 11px; min-height: 218px; }
    .md-catalogue .md-pcard-vis { min-height: 92px; margin-bottom: 8px; }
    .md-catalogue .md-pcard-vis img,
    .md-catalogue .md-pcard-vis svg { height: 104px; }
    .md-catalogue .md-pcard-top { margin-bottom: 7px; font-size: 7.5px; letter-spacing: 0.18em; }
    .md-catalogue .md-pcard-name { font-size: 13.5px; line-height: 1.18; margin-bottom: 2px; }
    .md-catalogue .md-pcard-cat { font-size: 11px; margin-bottom: 7px; }
    .md-catalogue .md-pcard-foot { padding-top: 7px; font-size: 7.5px; letter-spacing: 0.16em; }
    .md-catalogue .md-pcard-price { font-size: 14px; }
    .md-catalogue .md-pcard-price--old { font-size: 11px; }
    .md-catalogue .md-pcard-prices { gap: 5px; }
    .md-catalogue .md-pcard-badge-promo {
        top: 6px; right: 6px;
        padding: 3px 7px;
        font-size: 7.5px;
        letter-spacing: 0.18em;
    }
}
@media (max-width: 480px) {
    .md-catalogue .md-pcard { padding: 9px 9px 10px; min-height: 198px; }
    .md-catalogue .md-pcard-vis { min-height: 80px; margin-bottom: 7px; }
    .md-catalogue .md-pcard-vis img,
    .md-catalogue .md-pcard-vis svg { height: 92px; }
    .md-catalogue .md-pcard-top { margin-bottom: 6px; font-size: 7px; }
    .md-catalogue .md-pcard-name { font-size: 13px; }
    .md-catalogue .md-pcard-cat { font-size: 10.5px; margin-bottom: 6px; }
    .md-catalogue .md-pcard-foot { padding-top: 6px; font-size: 7px; }
    .md-catalogue .md-pcard-price { font-size: 13.5px; }
    .md-catalogue .md-pcard-price--old { font-size: 10.5px; }
    .md-catalogue .md-pcard-badge-promo {
        top: 5px; right: 5px;
        padding: 2px 6px;
        font-size: 7px;
    }
}

/* Pagination: tighter cells, premium not-Laravel */
.md-catalogue .md-pagination {
    margin-top: 28px; padding: 18px 0;
    gap: 4px;
}
.md-catalogue .md-pagination a,
.md-catalogue .md-pagination span {
    min-width: 34px; height: 34px;
    padding: 0 10px;
    font-size: 10.5px; letter-spacing: 0.16em;
}

/* Empty state: still premium, less vertical mass */
.md-catalogue .md-empty {
    padding: 56px 32px;
}
.md-catalogue .md-empty h2 {
    font-size: clamp(24px, 2.6vw, 34px);
}
.md-catalogue .md-empty p {
    font-size: 15px; margin-bottom: 22px;
}

/* Bottom CTA band: lower stature inside catalogue, flipped to ivory
   so it matches the catalogue hero and selection panel surfaces. */
.md-catalogue .md-section.md-text-center { padding: 24px 40px 72px; }
@media (max-width: 700px) { .md-catalogue .md-section.md-text-center { padding: 18px 22px 56px; } }

.md-catalogue .md-cta-band {
    padding: 36px 40px;
    border: 1px solid rgba(206,179,124,0.5);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.55), transparent 70%),
        linear-gradient(168deg, #F9F6F0 0%, #F2EADA 60%, #E8DDC4 100%);
    box-shadow:
        0 18px 38px rgba(5,16,44,0.14),
        0 3px 10px rgba(5,16,44,0.06);
    text-align: left;
}
@media (max-width: 900px) { .md-catalogue .md-cta-band { padding: 32px; } }
.md-catalogue .md-cta-band::before {
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
    opacity: 0.7;
}
.md-catalogue .md-cta-band .md-eyebrow { color: var(--md-dore-d); }
.md-catalogue .md-cta-band .md-eyebrow .bar { background: var(--md-dore-d); }
.md-catalogue .md-cta-band .md-h2 {
    font-size: clamp(24px, 2.6vw, 36px);
    color: var(--md-nuit);
}
.md-catalogue .md-cta-band .md-h2 em { color: var(--md-dore-d); }
.md-catalogue .md-cta-band .md-lead {
    font-size: 15px;
    color: rgba(5,16,44,0.70);
}
.md-catalogue .md-cta-band .actions { align-items: center; }

/* Phone (ghost) button on ivory: dark outline + bleu-nuit ink */
.md-catalogue .md-cta-band .md-btn-ghost {
    background: rgba(255,255,255,0.55);
    border-color: rgba(5,16,44,0.22);
    color: var(--md-nuit);
}
.md-catalogue .md-cta-band .md-btn-ghost:hover {
    border-color: var(--md-dore-d);
    color: var(--md-dore-d);
    background: rgba(255,255,255,0.85);
}

/* WhatsApp (primary) button: keep doré filled, ensure contrast on ivory */
.md-catalogue .md-cta-band .md-btn-primary {
    background: var(--md-dore-d);
    border-color: var(--md-dore-d);
    color: var(--md-ivoire);
}
.md-catalogue .md-cta-band .md-btn-primary:hover {
    background: var(--md-nuit);
    border-color: var(--md-nuit);
    color: var(--md-ivoire);
}

/* ============================================================
   Catalogue ivory hero
   Editorial ivory card sitting on the bleu-nuit page background.
   Mirrors the spirit of the homepage featured hero but compact,
   so the catalogue stays dense and practical.
   ============================================================ */
.md-catalogue-hero {
    padding: clamp(98px, 11vh, 124px) 40px 28px;
    position: relative;
}
@media (max-width: 700px) { .md-catalogue-hero { padding: 96px 18px 22px; } }

.md-catalogue-hero__inner {
    max-width: 1260px;
    margin: 0 auto;
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(220px, 0.85fr);
    gap: clamp(20px, 3vw, 44px);
    align-items: center;
    padding: clamp(24px, 3vw, 36px) clamp(22px, 3vw, 44px);
    border: 1px solid rgba(206,179,124,0.5);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 28%, rgba(255,255,255,0.6), transparent 70%),
        linear-gradient(160deg, #F9F6F0 0%, #EFE7D3 48%, #E6D8BA 100%);
    box-shadow:
        0 28px 56px rgba(5,16,44,0.22),
        0 4px 14px rgba(5,16,44,0.10);
}
.md-catalogue-hero__inner::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
    opacity: 0.7;
}
@media (max-width: 900px) {
    .md-catalogue-hero__inner {
        grid-template-columns: 1fr;
        gap: 18px;
    }
}

.md-catalogue-hero__copy { min-width: 0; }

.md-catalogue-hero__crumbs {
    display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
    color: rgba(5,16,44,0.55);
    margin-bottom: 18px;
}
.md-catalogue-hero__crumbs a {
    color: rgba(5,16,44,0.65);
    text-decoration: none;
    transition: color 240ms ease;
}
.md-catalogue-hero__crumbs a:hover { color: var(--md-dore-d); }
.md-catalogue-hero__crumbs .sep { color: rgba(5,16,44,0.30); }
.md-catalogue-hero__crumbs .current { color: var(--md-nuit); }

.md-catalogue-hero__kicker {
    display: inline-flex; align-items: center; gap: 12px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--md-dore-d);
    margin-bottom: 14px;
}
.md-catalogue-hero__kicker .bar {
    width: 30px; height: 1px;
    background: var(--md-dore);
}

.md-catalogue-hero__title {
    margin: 0;
    font-family: 'Cormorant Garamond', 'Cardo', serif;
    font-size: clamp(34px, 4.4vw, 58px);
    line-height: 1;
    font-weight: 400;
    letter-spacing: -0.005em;
    color: var(--md-nuit);
}
.md-catalogue-hero__title em {
    font-style: italic;
    color: var(--md-dore-d);
    font-weight: 400;
}

.md-catalogue-hero__rule {
    width: 48px; height: 1px;
    background: var(--md-dore);
    margin: 18px 0 14px;
}

.md-catalogue-hero__lead {
    margin: 0;
    max-width: 580px;
    font-family: 'Cardo', serif;
    font-style: italic;
    font-size: clamp(15px, 1.1vw, 17px);
    line-height: 1.55;
    color: rgba(5,16,44,0.68);
}

/* Right-side hero image. The asset is rendered as-is so transparent pixels sit
   directly on the existing ivory hero panel. */
.md-catalogue-hero__visual {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: clamp(260px, 36vh, 360px);
}
.md-catalogue-hero__bottle {
    display: block;
    width: 100%;
    max-width: min(100%, 480px);
    height: clamp(260px, 38vh, 380px);
    object-fit: contain;
    object-position: center center;
}
@media (max-width: 1100px) {
    .md-catalogue-hero__bottle {
        max-width: min(100%, 400px);
        height: clamp(240px, 34vh, 320px);
    }
}
@media (max-width: 900px) {
    .md-catalogue-hero__visual { min-height: clamp(220px, 30vh, 280px); }
    .md-catalogue-hero__bottle {
        max-width: min(100%, 420px);
        height: clamp(220px, 32vh, 280px);
    }
}
@media (max-width: 520px) {
    .md-catalogue-hero__visual { min-height: 200px; }
    .md-catalogue-hero__bottle {
        max-width: min(100%, 340px);
        height: clamp(200px, 30vh, 260px);
    }
}

/* ============================================================
   Catalogue selection panel
   Ivory editorial surface that mirrors the catalogue hero so the
   listing area feels like the same composition. The dark bleu-nuit
   product cards become elegant accents on the ivory canvas, and the
   filter / results / pagination chrome flips to dark-on-ivory.
   ============================================================ */
.md-catalogue .md-catalogue-selection {
    padding: 24px 40px 64px;
}
@media (max-width: 700px) {
    .md-catalogue .md-catalogue-selection { padding: 18px 22px 48px; }
}

.md-catalogue-selection__panel {
    position: relative;
    padding: clamp(28px, 3vw, 44px) clamp(22px, 3vw, 40px);
    border: 1px solid rgba(206,179,124,0.5);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.55), transparent 70%),
        linear-gradient(168deg, #F9F6F0 0%, #F2EADA 60%, #E8DDC4 100%);
    box-shadow:
        0 28px 56px rgba(5,16,44,0.20),
        0 4px 14px rgba(5,16,44,0.10);
}
.md-catalogue-selection__panel::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
    opacity: 0.7;
}
@media (max-width: 700px) {
    .md-catalogue-selection__panel { padding: 22px 16px; border-radius: 4px; }
}

/* Filter aside flipped to ivory */
.md-catalogue-selection .md-filter {
    background: rgba(255,255,255,0.45);
    border: 1px solid rgba(206,179,124,0.40);
    border-radius: 4px;
}
.md-catalogue-selection .md-filter-head {
    border-bottom-color: rgba(5,16,44,0.10);
}
.md-catalogue-selection .md-filter-head h3 { color: var(--md-nuit); }
.md-catalogue-selection .md-filter-head .reset { color: var(--md-dore-d); }
.md-catalogue-selection .md-filter-head .reset:hover { color: var(--md-nuit); }
.md-catalogue-selection .md-filter-group { border-bottom-color: rgba(5,16,44,0.08); }
.md-catalogue-selection .md-filter-group summary { color: var(--md-nuit); }
.md-catalogue-selection .md-filter-group summary::after { color: var(--md-dore-d); }
.md-catalogue-selection .md-filter-option { color: rgba(5,16,44,0.65); }
.md-catalogue-selection .md-filter-option:hover { color: var(--md-nuit); }
.md-catalogue-selection .md-filter-option input[type="checkbox"],
.md-catalogue-selection .md-filter-option input[type="radio"] {
    border-color: rgba(5,16,44,0.30);
    background: rgba(255,255,255,0.7);
}
.md-catalogue-selection .md-filter-option input[type="checkbox"]:checked,
.md-catalogue-selection .md-filter-option input[type="radio"]:checked {
    background: var(--md-dore);
    border-color: var(--md-dore);
}
.md-catalogue-selection .md-filter-empty { color: rgba(5,16,44,0.50); }
.md-catalogue-selection .md-filter-options::-webkit-scrollbar-thumb {
    background: rgba(5,16,44,0.18);
}
.md-catalogue-selection .md-filter-field span {
    color: var(--md-dore-d);
}
.md-catalogue-selection .md-filter-input {
    border-color: rgba(5,16,44,0.16);
    background: rgba(255,255,255,0.58);
    color: var(--md-nuit);
}
.md-catalogue-selection .md-filter-input:focus {
    border-color: rgba(206,179,124,0.78);
    background: rgba(255,255,255,0.82);
}
.md-catalogue-selection .md-filter-input::placeholder {
    color: rgba(5,16,44,0.35);
}

/* Results bar flipped to ivory */
.md-catalogue-selection .md-results-bar {
    border-bottom-color: rgba(5,16,44,0.10);
}
.md-catalogue-selection .md-results-bar .count { color: var(--md-nuit); }
.md-catalogue-selection .md-results-bar .count em { color: var(--md-dore-d); }
.md-catalogue-selection .md-results-bar .badge {
    color: var(--md-dore-d);
    border-color: rgba(206,179,124,0.55);
    background: rgba(255,255,255,0.50);
}
.md-catalogue-selection .md-results-bar a.badge:hover {
    border-color: rgba(206,179,124,0.85);
    color: var(--md-nuit);
}
.md-moroccan-wines-active {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 16px;
}
.md-moroccan-wines-active .badge {
    display: inline-flex;
    border: 1px solid rgba(206,179,124,0.55);
    background: rgba(255,255,255,0.50);
    color: var(--md-dore-d);
    padding: 5px 10px;
    font-size: 9px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

/* Product grid: a touch of breathing room so the ivory card tiles
   read as an editorial composition on the champagne surface. */
.md-catalogue-selection .md-grid,
.md-catalogue-selection .md-grid-3,
.md-catalogue-selection .md-grid-4 {
    gap: 14px;
    background: transparent;
    border-top: none;
    border-bottom: none;
}
@media (max-width: 700px) {
    .md-catalogue-selection .md-grid,
    .md-catalogue-selection .md-grid-3,
    .md-catalogue-selection .md-grid-4 {
        gap: 10px;
    }
}

/* ============================================================
   Ivory product cards — scoped to the catalogue selection panel
   so search results and related-product strips keep the dark
   editorial card. Light card with thin doré hairline, bleu nuit
   text, subtle warm shadow on hover.
   ============================================================ */
.md-catalogue-selection .md-pcard {
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.85), transparent 65%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 60%, #F5EFE2 100%);
    border: 1px solid rgba(206,179,124,0.55);
    border-radius: 4px;
    box-shadow:
        0 1px 0 rgba(255,255,255,0.6) inset,
        0 6px 18px rgba(5,16,44,0.06);
    transition:
        border-color 500ms var(--md-ease),
        box-shadow 500ms var(--md-ease),
        transform 500ms var(--md-ease);
}
.md-catalogue-selection .md-pcard:hover {
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.9), transparent 65%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 55%, #F2EADA 100%);
    border-color: rgba(206,179,124,0.95);
    box-shadow:
        0 1px 0 rgba(255,255,255,0.7) inset,
        0 14px 28px rgba(5,16,44,0.10),
        0 0 0 1px rgba(206,179,124,0.25);
    transform: translateY(-3px);
}

.md-catalogue-selection .md-pcard-top {
    color: rgba(5,16,44,0.45);
}
.md-catalogue-selection .md-pcard-top .brand {
    color: var(--md-dore-d);
}

.md-catalogue-selection .md-pcard-vis::before {
    background: radial-gradient(ellipse, rgba(201,162,83,0.22), transparent 70%);
}

.md-catalogue-selection .md-pcard-name {
    color: var(--md-nuit);
}
.md-catalogue-selection .md-pcard-name::after {
    background: var(--md-dore-d);
}

.md-catalogue-selection .md-pcard-cat {
    color: rgba(5,16,44,0.55);
}
.md-catalogue-selection .md-pcard-excerpt {
    color: rgba(5,16,44,0.62);
}

.md-catalogue-selection .md-pcard-foot {
    border-top-color: rgba(5,16,44,0.10);
    color: rgba(5,16,44,0.45);
}
.md-catalogue-selection .md-pcard-price {
    color: var(--md-nuit);
}
.md-catalogue-selection .md-pcard-stock {
    color: var(--md-dore-d);
}
.md-catalogue-selection .md-pcard-stock.soft {
    color: rgba(5,16,44,0.35);
}

/* Pagination flipped to ivory */
.md-catalogue-selection .md-pagination {
    border-top-color: rgba(5,16,44,0.10);
}
.md-catalogue-selection .md-pagination a,
.md-catalogue-selection .md-pagination span {
    color: rgba(5,16,44,0.65);
    border-color: rgba(5,16,44,0.18);
    background: rgba(255,255,255,0.45);
}
.md-catalogue-selection .md-pagination a:hover {
    color: var(--md-nuit);
    border-color: var(--md-dore);
    background: rgba(255,255,255,0.75);
}
.md-catalogue-selection .md-pagination .current,
.md-catalogue-selection .md-pagination [aria-current="page"] {
    color: var(--md-ivoire);
    background: var(--md-nuit);
    border-color: var(--md-nuit);
}
.md-catalogue-selection .md-pagination .disabled { opacity: 0.4; }

/* Empty state flipped to ivory */
.md-catalogue-selection .md-empty {
    background: rgba(255,255,255,0.55);
    border: 1px solid rgba(206,179,124,0.45);
}
.md-catalogue-selection .md-empty h2 { color: var(--md-nuit); }
.md-catalogue-selection .md-empty p { color: rgba(5,16,44,0.65); }

/* ============================================================
   Public compact editorial alignment
   Scoped to inner public pages that still used the older dark,
   roomier section language. Homepage and catalogue listing keep
   their existing structures; these rules mirror their compact
   bleu nuit / dore / ivoire rhythm.
   ============================================================ */

.md-public-page .md-hero {
    padding: clamp(96px, 10vh, 122px) 40px 24px;
}
.md-public-page .md-hero-inner {
    max-width: 1260px;
    padding: clamp(24px, 3vw, 36px) clamp(22px, 3vw, 44px);
    border: 1px solid rgba(206,179,124,0.50);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 12%, rgba(255,255,255,0.58), transparent 70%),
        linear-gradient(160deg, #F9F6F0 0%, #EFE7D3 52%, #E6D8BA 100%);
    box-shadow:
        0 28px 56px rgba(5,16,44,0.22),
        0 4px 14px rgba(5,16,44,0.10);
    overflow: hidden;
}
.md-public-page .md-hero-inner::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--md-dore), transparent);
    opacity: 0.75;
}
.md-public-page .md-breadcrumbs {
    margin-bottom: 18px;
    color: rgba(5,16,44,0.45);
}
.md-public-page .md-breadcrumbs a { color: rgba(5,16,44,0.62); }
.md-public-page .md-breadcrumbs a:hover { color: var(--md-dore-d); }
.md-public-page .md-breadcrumbs .sep { color: rgba(5,16,44,0.28); }
.md-public-page .md-breadcrumbs .current { color: var(--md-nuit); }
.md-public-page .md-hero-grid {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
    gap: clamp(18px, 3vw, 36px);
    align-items: center;
}
.md-public-page .md-eyebrow {
    margin-bottom: 14px;
    color: var(--md-dore-d);
}
.md-public-page .md-eyebrow .bar { background: var(--md-dore-d); }
.md-public-page .md-h1 {
    font-family: 'Cormorant Garamond', 'Cardo', serif;
    font-size: clamp(34px, 4.4vw, 58px);
    line-height: 1;
    color: var(--md-nuit);
    margin-bottom: 0;
}
.md-public-page .md-h1 em,
.md-public-page .md-h2 em,
.md-public-page .md-h3 em { color: var(--md-dore-d); }
.md-public-page .md-rule {
    width: 48px;
    margin: 18px 0 14px;
    background: var(--md-dore);
}
.md-public-page .md-lead {
    max-width: 610px;
    font-size: clamp(15px, 1.1vw, 17px);
    line-height: 1.55;
    color: rgba(5,16,44,0.68);
}
.md-public-page .md-hero-panel {
    border: 1px solid rgba(206,179,124,0.42);
    border-radius: 4px;
    background: rgba(255,255,255,0.42);
    padding: 22px;
    box-shadow: 0 8px 22px rgba(5,16,44,0.06);
}
.md-public-page .md-hero-panel h4 {
    margin-bottom: 14px;
    color: var(--md-dore-d);
}
.md-public-page .md-hero-panel ul { gap: 9px; }
.md-public-page .md-hero-panel ul li,
.md-public-page .md-hero-panel p {
    color: rgba(5,16,44,0.68);
    font-size: 14.5px;
}
.md-public-page .md-hero-panel ul li::before { background: var(--md-dore-d); }

.md-public-page .md-section {
    padding: 28px 40px 58px;
    max-width: 1260px;
}
.md-public-page .md-section + .md-section {
    padding-top: 12px;
}
.md-public-page .md-section-head {
    margin-bottom: 26px;
    gap: 28px;
}
.md-public-page .md-section-head .note {
    font-size: 15.5px;
}
.md-public-page .md-btn {
    min-height: 42px;
    padding: 12px 20px;
    font-size: 10px;
    letter-spacing: 0.20em;
}
.md-public-page .md-btn-primary {
    background: var(--md-dore-d);
    border-color: var(--md-dore-d);
    color: var(--md-ivoire);
}
.md-public-page .md-btn-primary:hover {
    background: var(--md-nuit);
    border-color: var(--md-nuit);
    color: var(--md-ivoire);
}
.md-public-page .md-btn-ghost {
    background: rgba(255,255,255,0.52);
    border-color: rgba(5,16,44,0.22);
    color: var(--md-nuit);
}
.md-public-page .md-btn-ghost:hover {
    background: rgba(255,255,255,0.82);
    border-color: var(--md-dore-d);
    color: var(--md-dore-d);
}
.md-public-page .md-panel {
    border: 1px solid rgba(206,179,124,0.45);
    border-radius: 4px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.78), transparent 68%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 60%, #F5EFE2 100%);
    padding: 20px;
    box-shadow: 0 8px 20px rgba(5,16,44,0.06);
}
.md-public-page .md-panel-spaced { margin-bottom: 12px; }
.md-public-page .md-panel-title {
    margin: 0 0 12px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 9.5px;
    letter-spacing: 0.24em;
    color: var(--md-dore-d);
    text-transform: uppercase;
    font-weight: 600;
}
.md-public-page .md-panel p {
    color: rgba(5,16,44,0.68);
    font-size: 14px;
    line-height: 1.55;
    margin-bottom: 6px;
}
.md-public-page .md-panel-link {
    color: var(--md-dore-d);
    border-bottom: 1px solid rgba(206,179,124,0.55);
    text-decoration: none;
}
.md-public-page .md-panel-link:hover { color: var(--md-nuit); }
.md-public-page .md-detail-row {
    border-bottom-color: rgba(5,16,44,0.10);
}
.md-public-page .md-detail-row .l { color: rgba(5,16,44,0.46); }
.md-public-page .md-detail-row .v { color: var(--md-nuit); }

/* Product detail page */
.md-product-page .md-product-main,
.md-product-page .md-product-story-grid,
.md-contact-page .md-contact-grid {
    padding: clamp(18px, 2.4vw, 28px);
    border: 1px solid rgba(206,179,124,0.50);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.55), transparent 70%),
        linear-gradient(168deg, #F9F6F0 0%, #F2EADA 60%, #E8DDC4 100%);
    box-shadow:
        0 24px 48px rgba(5,16,44,0.18),
        0 4px 14px rgba(5,16,44,0.08);
}
.md-product-page .md-product-main {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 380px);
    gap: clamp(20px, 2.6vw, 32px);
}
.md-product-page .md-product-story-grid,
.md-contact-page .md-contact-grid {
    grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
    gap: clamp(20px, 2.6vw, 30px);
}
.md-product-page .md-product-stage,
.md-product-page .md-product-thumb {
    border-color: rgba(206,179,124,0.45);
    border-radius: 4px;
    background:
        radial-gradient(ellipse at 50% 58%, rgba(206,179,124,0.16), transparent 58%),
        rgba(255,255,255,0.54);
}
.md-product-page .md-product-stage {
    aspect-ratio: 5 / 4;
}
.md-product-page .md-product-stage img,
.md-product-page .md-product-thumb img {
    object-fit: contain;
}
.md-product-page .md-product-thumbs { gap: 6px; margin-top: 6px; }
.md-product-page .md-product-info {
    top: 94px;
    border: 1px solid rgba(206,179,124,0.45);
    border-radius: 4px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.86), transparent 66%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 62%, #F5EFE2 100%);
    padding: clamp(18px, 2.2vw, 24px);
    box-shadow: 0 10px 26px rgba(5,16,44,0.07);
}
.md-product-page .md-product-brand { color: var(--md-dore-d); margin-bottom: 10px; }
.md-product-page .md-product-brand .bar { background: var(--md-dore-d); }
.md-product-page .md-product-name {
    font-family: 'Cormorant Garamond', 'Cardo', serif;
    font-size: clamp(24px, 2.6vw, 34px);
    color: var(--md-nuit);
    margin-bottom: 4px;
}
.md-product-page .md-product-cat {
    color: rgba(5,16,44,0.58);
    margin-bottom: 14px;
    font-size: 14px;
}
.md-product-page .md-product-price-row {
    padding: 14px 0;
    margin-bottom: 16px;
    border-color: rgba(5,16,44,0.10);
}
.md-product-page .md-product-price {
    font-size: clamp(24px, 2.6vw, 30px);
    color: var(--md-nuit);
}
.md-product-page .md-product-stock {
    border-color: rgba(206,179,124,0.58);
    color: var(--md-dore-d);
    background: rgba(255,255,255,0.48);
    font-weight: 600;
}
.md-product-page .md-product-stock.soft {
    color: rgba(5,16,44,0.42);
    border-color: rgba(5,16,44,0.14);
}
.md-product-page .md-detail-list { gap: 8px; margin-bottom: 16px; }
.md-product-page .md-detail-row { padding-bottom: 7px; font-size: 12.5px; }
.md-product-page .md-detail-row .v { font-size: 14px; }
.md-product-page .md-product-actions { gap: 8px; }
.md-product-page .md-product-actions .md-btn {
    padding-left: 14px;
    padding-right: 14px;
    letter-spacing: 0.16em;
    line-height: 1.25;
    text-align: center;
    white-space: normal;
}
.md-product-page .md-product-attrs {
    margin-top: 14px;
    gap: 8px;
    background: transparent;
    border: none;
}
.md-product-page .md-attr-cell {
    border: 1px solid rgba(206,179,124,0.55);
    border-radius: 4px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.95), transparent 70%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 100%);
    padding: 14px 14px;
    box-shadow: 0 2px 8px rgba(5,16,44,0.05);
}
.md-product-page .md-attr-cell .l {
    color: var(--md-dore-d);
    font-weight: 600;
    margin-bottom: 6px;
}
.md-product-page .md-attr-cell .v { color: var(--md-nuit); font-size: 15px; }
.md-product-page .md-product-story .md-section-head,
.md-product-page .md-product-related .md-section-head {
    margin-bottom: 16px;
}
.md-product-page .md-product-cluster-copy {
    max-width: 440px;
    justify-self: end;
}
.md-product-page .md-product-cluster-copy p {
    color: rgba(5,16,44,0.66);
    font-family: 'Cardo', serif;
    font-style: italic;
    font-size: 15.5px;
    line-height: 1.55;
    margin: 0 0 14px;
}
.md-product-page .md-product-cluster-copy .md-btn-link {
    color: var(--md-dore-d);
    border-bottom-color: rgba(206,179,124,0.70);
}
@media (max-width: 900px) {
    .md-product-page .md-product-cluster-copy {
        justify-self: start;
        max-width: none;
    }
}
.md-product-page .md-product-story-grid .md-prose,
.md-contact-page .md-contact-grid .md-prose {
    max-width: none;
}
.md-product-page .md-product-story-grid .md-prose p,
.md-contact-page .md-contact-grid .md-prose p {
    color: rgba(5,16,44,0.70);
}
.md-product-page .md-product-story-grid .md-prose h2,
.md-contact-page .md-contact-grid .md-prose h2 {
    color: var(--md-nuit);
    font-size: clamp(26px, 2.8vw, 36px);
    margin-bottom: 16px;
}
.md-product-page .md-product-related .md-grid {
    gap: 12px;
    background: transparent;
    border: none;
}
.md-product-page .md-pcard {
    min-height: 312px;
    border: 1px solid rgba(206,179,124,0.50);
    border-radius: 4px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.85), transparent 65%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 60%, #F5EFE2 100%);
    padding: 16px 16px 14px;
    box-shadow: 0 6px 18px rgba(5,16,44,0.06);
}
.md-product-page .md-pcard:hover {
    border-color: rgba(206,179,124,0.92);
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.9), transparent 65%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 55%, #F2EADA 100%);
}
.md-product-page .md-pcard-top { color: rgba(5,16,44,0.45); margin-bottom: 12px; }
.md-product-page .md-pcard-top .brand { color: var(--md-dore-d); }
.md-product-page .md-pcard-vis { min-height: 138px; margin-bottom: 12px; }
.md-product-page .md-pcard-vis img,
.md-product-page .md-pcard-vis svg { height: 152px; }
.md-product-page .md-pcard-name { color: var(--md-nuit); font-size: 15.5px; }
.md-product-page .md-pcard-name::after { background: var(--md-dore-d); }
.md-product-page .md-pcard-cat { color: rgba(5,16,44,0.55); font-size: 12px; margin-bottom: 10px; }
.md-product-page .md-pcard-foot {
    border-top-color: rgba(5,16,44,0.10);
    color: rgba(5,16,44,0.45);
    padding-top: 9px;
}
.md-product-page .md-pcard-price { color: var(--md-nuit); font-size: 16.5px; }
.md-product-page .md-pcard-stock { color: var(--md-dore-d); }
.md-product-page .md-pcard-stock.soft { color: rgba(5,16,44,0.35); }

/* Search page */
.md-search-page .md-search-selection {
    padding-top: 24px;
}
.md-search-page .md-catalogue-selection__panel {
    max-width: 1120px;
    margin: 0 auto;
}
.md-catalogue-selection .md-search-shell {
    border: 1px solid rgba(206,179,124,0.45);
    border-radius: 4px;
    background: rgba(255,255,255,0.52);
    padding: clamp(20px, 2.6vw, 30px);
}
.md-search-actions,
.md-chip-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.md-search-actions { margin-top: 16px; }
.md-chip-row { margin-top: 18px; }
.md-catalogue-selection .md-search-input {
    color: var(--md-nuit);
    border-bottom-color: rgba(5,16,44,0.18);
    font-size: clamp(21px, 2.8vw, 32px);
}
.md-catalogue-selection .md-search-input::placeholder { color: rgba(5,16,44,0.36); }
.md-catalogue-selection .md-search-input:focus { border-color: var(--md-dore-d); }
.md-search-followup {
    margin-top: 28px;
}
.md-catalogue-selection .md-search-followup .md-h2,
.md-catalogue-selection .md-search-followup .md-h3 {
    color: var(--md-nuit);
}
.md-catalogue-selection .md-chip {
    color: rgba(5,16,44,0.62);
    border-color: rgba(206,179,124,0.48);
    background: rgba(255,255,255,0.42);
}
.md-catalogue-selection .md-chip:hover {
    color: var(--md-dore-d);
    border-color: rgba(206,179,124,0.82);
    background: rgba(255,255,255,0.72);
}
.md-search-explore {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid rgba(5,16,44,0.10);
}

/* Contact page */
.md-contact-page .md-contact-options { padding-bottom: 26px; }
.md-contact-page .md-cards-3 {
    gap: 14px;
    background: transparent;
    border: none;
}
.md-contact-page .md-card-3 {
    min-height: 210px;
    border: 1px solid rgba(206,179,124,0.50);
    border-radius: 4px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.78), transparent 68%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 60%, #F5EFE2 100%);
    padding: 24px 22px;
    box-shadow: 0 8px 20px rgba(5,16,44,0.06);
}
.md-contact-page .md-card-3:hover {
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.9), transparent 68%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 55%, #F2EADA 100%);
}
.md-contact-page .md-card-3 .num { color: var(--md-dore-d); margin-bottom: 14px; }
.md-contact-page .md-card-3 h3 {
    color: var(--md-nuit);
    font-size: clamp(24px, 2.4vw, 30px);
}
.md-contact-page .md-card-3 p { color: rgba(5,16,44,0.64); }
.md-contact-page .md-card-3 .md-btn-link {
    color: var(--md-dore-d);
    border-bottom-color: rgba(206,179,124,0.60);
}
.md-contact-page .md-contact-guidance { padding-top: 8px; }
.md-contact-page .md-hours .row {
    border-color: rgba(5,16,44,0.10);
    background: rgba(255,255,255,0.46);
    padding: 12px 14px;
}
.md-contact-page .md-hours .label { color: rgba(5,16,44,0.52); }
.md-contact-page .md-hours .v { color: var(--md-nuit); }

/* Legal and cookie pages */
.md-legal-page .md-legal-section {
    padding-top: 24px;
}
.md-legal-panel {
    max-width: 920px;
    margin: 0 auto;
    border: 1px solid rgba(206,179,124,0.50);
    border-radius: 6px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,255,255,0.72), transparent 68%),
        linear-gradient(168deg, #FFFFFF 0%, #FBF7EE 60%, #F5EFE2 100%);
    padding: clamp(28px, 4vw, 48px);
    box-shadow:
        0 24px 48px rgba(5,16,44,0.16),
        0 4px 14px rgba(5,16,44,0.07);
}
.md-legal-panel .md-prose {
    max-width: none;
    color: var(--md-nuit);
}
.md-legal-panel .md-prose h2 {
    color: var(--md-nuit);
    font-size: clamp(25px, 2.5vw, 34px);
    margin: 34px 0 14px;
    padding-top: 22px;
    border-top-color: rgba(5,16,44,0.10);
}
.md-legal-panel .md-prose h2:first-child {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}
.md-legal-panel .md-prose p {
    color: rgba(5,16,44,0.72);
    font-size: 16px;
    line-height: 1.68;
}

/* Notre cave density tuning, CSS-only */
.md-about-page .md-section {
    padding-top: 46px;
    padding-bottom: 52px;
}
.md-about-hero {
    padding-top: 118px;
    padding-bottom: 26px;
}
.md-about-hero__content {
    min-height: 300px;
    gap: 36px;
}
.md-about-hero__title {
    font-size: clamp(42px, 6vw, 76px);
    max-width: 720px;
}
.md-about-hero__lead {
    font-size: clamp(16px, 1.25vw, 19px);
}
.md-about-hero__note {
    padding: 24px;
}
.md-about-intro { padding-top: 16px; }
.md-about-panel { padding: clamp(12px, 1.6vw, 18px); }
.md-about-image { min-height: 380px; }
.md-about-copy { padding: clamp(30px, 3.4vw, 48px); }
.md-about-copy h2 {
    font-size: clamp(34px, 3.8vw, 52px);
    margin-bottom: 18px;
}
.md-about-copy p {
    font-size: 16.5px;
    line-height: 1.66;
}
.md-about-values { gap: 12px; }
.md-about-value {
    min-height: 210px;
    padding: 26px 22px;
}
.md-about-value__icon {
    width: 42px;
    height: 42px;
    margin-bottom: 22px;
}
    .md-about-value h3 { font-size: 26px; }
    .md-about-contact__panel { padding: clamp(24px, 2.6vw, 34px); }
    .md-about-cta {
        padding: clamp(32px, 3.4vw, 44px);
    }

@media (max-width: 1100px) {
    .md-public-page .md-hero-grid,
    .md-product-page .md-product-main,
    .md-product-page .md-product-story-grid,
    .md-contact-page .md-contact-grid {
        grid-template-columns: 1fr;
    }
    .md-product-page .md-product-info {
        position: static;
    }
}

@media (max-width: 700px) {
    .md-public-page .md-hero {
        padding: 94px 18px 20px;
    }
    .md-public-page .md-hero-inner {
        padding: 22px 18px;
        border-radius: 4px;
    }
    .md-public-page .md-hero-panel {
        padding: 18px;
    }
    .md-public-page .md-section {
        padding: 20px 18px 42px;
    }
    .md-public-page .md-section + .md-section {
        padding-top: 4px;
    }
    .md-public-page .md-section-head {
        gap: 16px;
        margin-bottom: 20px;
    }
    .md-public-page .md-h1 {
        font-size: clamp(31px, 10vw, 42px);
    }
    .md-public-page .md-h2 {
        font-size: clamp(27px, 8vw, 36px);
    }
    .md-product-page .md-product-main,
    .md-product-page .md-product-story-grid,
    .md-contact-page .md-contact-grid {
        padding: 14px 12px;
        border-radius: 4px;
        gap: 16px;
    }
    .md-product-page .md-product-stage {
        aspect-ratio: 4 / 3;
    }
    .md-product-page .md-product-thumbs {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .md-product-page .md-product-attrs {
        grid-template-columns: repeat(2, 1fr);
        gap: 6px;
        margin-top: 12px;
    }
    .md-product-page .md-attr-cell { padding: 11px 12px; }
    .md-product-page .md-attr-cell .l { font-size: 9px; letter-spacing: 0.18em; margin-bottom: 4px; }
    .md-product-page .md-attr-cell .v { font-size: 13.5px; }
    .md-product-page .md-product-related .md-grid,
    .md-search-page .md-catalogue-selection .md-grid {
        gap: 10px;
    }
    .md-public-page .md-panel { padding: 16px 14px; }
    .md-public-page .md-panel-title { margin-bottom: 10px; }
    .md-catalogue-selection .md-search-shell {
        padding: 18px 14px;
    }
    .md-search-actions .md-btn {
        width: 100%;
    }
    .md-contact-page .md-card-3 {
        min-height: auto;
        padding: 22px 18px;
    }
    .md-legal-panel {
        padding: 24px 18px;
        border-radius: 4px;
    }
    .md-about-page .md-section {
        padding-top: 34px;
        padding-bottom: 40px;
    }
    .md-about-hero {
        padding: 104px 18px 22px;
    }
    .md-about-hero__content {
        min-height: 250px;
    }
    .md-about-panel,
    .md-about-contact__panel,
    .md-about-cta {
        width: calc(100% - 36px);
    }
    .md-about-image {
        min-height: 260px;
    }
    .md-about-copy {
        padding: 26px 18px;
    }
    .md-about-value {
        padding: 22px 18px;
    }
    .md-about-map__frame { height: 290px; }
}

/* ============================================================
   Mobile polish
   Scoped responsive refinements only. Desktop layouts (>=981px
   / >=1101px) must remain untouched. No new tokens, no markup
   changes — every selector reuses an existing md-* class.
   Order: safety net → header → home hero → home rhythm →
   catalogue → product → notre cave → search/legal → tap targets.
   ============================================================ */

/* ---- Global safety net ---- */
body.md-body img,
body.md-body svg,
body.md-body iframe {
    max-width: 100%;
}

/* ---- 1. Header — compact, centered logo, generous tap target ---- */
@media (max-width: 980px) {
    .md-header {
        grid-template-columns: 1fr auto 1fr;
        padding: 12px 18px;
        gap: 14px;
    }
    .md-header.scrolled { padding: 10px 18px; }
    .md-brand-logo { justify-self: center; }
    .md-header-right { justify-self: end; }
    .md-brand-logo,
    .md-brand-logo__image {
        width: 128px;
        height: 36px;
    }
    .md-mobile-trigger {
        min-height: 40px;
        padding: 10px 13px;
        font-size: 10.5px;
        letter-spacing: 0.20em;
    }
    .md-mobile-close {
        min-height: 40px;
        padding: 10px 13px;
    }
    .md-mobile-panel { padding: 84px 22px 36px; }
    .md-mobile-panel a,
    .md-mobile-catalogue__trigger { font-size: 23px; }
}

@media (max-width: 390px) {
    .md-header { padding: 11px 14px; gap: 10px; }
    .md-header.scrolled { padding: 10px 14px; }
    .md-brand-logo,
    .md-brand-logo__image {
        width: 118px;
        height: 34px;
    }
    .md-mobile-trigger { padding: 9px 11px; letter-spacing: 0.18em; }
}

/* ---- 2. Featured hero (home) — vertical mobile composition ---- */
@media (max-width: 768px) {
    .md-featured-hero { padding: 88px 16px 18px; }
    .md-featured-hero-inner {
        grid-template-columns: 1fr;
        gap: 22px;
        padding: 26px 18px 24px;
        min-height: 0;
        overflow: hidden;
    }
    .md-featured-copy {
        order: 1;
        width: 100%;
        max-width: 100%;
        align-self: stretch;
    }
    .md-featured-title {
        font-size: clamp(26px, 7.4vw, 34px);
        line-height: 1.05;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
        word-break: break-word;
        hyphens: auto;
    }
    .md-featured-description {
        font-size: 13px;
        line-height: 1.6;
        max-width: 100%;
    }
    .md-featured-profile { max-width: 100%; }
    .md-featured-cta { min-height: 44px; }

    .md-featured-stage {
        order: 2;
        width: 100%;
        max-width: 100%;
        min-height: 0;
        padding: 8px 48px 14px;
        margin: 0 auto;
        overflow: hidden;
        justify-content: center;
    }
    .md-featured-stage::before {
        bottom: 6px;
        width: min(60%, 200px);
    }
    .md-featured-orbit { width: min(64%, 220px); }
    .md-featured-bottle {
        position: relative;
        display: block;
        width: auto;
        height: auto;
        max-width: 100%;
        max-height: clamp(240px, 56vw, 280px);
        margin: 0 auto;
        object-fit: contain;
        object-position: center;
    }
    .md-featured-bottle.is-placeholder {
        max-width: 60%;
    }
    .md-featured-stage-arrow {
        display: inline-flex;
        width: 36px;
        height: 36px;
        background: rgba(255,255,255,0.92);
        z-index: 4;
    }
    .md-featured-stage-arrow--prev { left: 4px; }
    .md-featured-stage-arrow--next { right: 4px; }

    /* Hide the suggestion card panel — arrows are enough on mobile */
    .md-featured-panel { display: none; }
}

@media (max-width: 430px) {
    .md-featured-hero { padding: 84px 14px 16px; }
    .md-featured-hero-inner {
        padding: 22px 16px 22px;
        gap: 18px;
    }
    .md-featured-title { font-size: clamp(24px, 7.2vw, 30px); }
    .md-featured-stage { padding: 6px 42px 12px; }
    .md-featured-bottle { max-height: clamp(220px, 58vw, 256px); }
    .md-featured-stage-arrow {
        width: 34px;
        height: 34px;
    }
    .md-featured-stage-arrow--prev { left: 3px; }
    .md-featured-stage-arrow--next { right: 3px; }
}

@media (max-width: 360px) {
    .md-featured-title { font-size: clamp(22px, 7vw, 28px); }
    .md-featured-stage { padding: 4px 38px 10px; }
    .md-featured-bottle { max-height: 220px; }
    .md-featured-stage-arrow {
        width: 32px;
        height: 32px;
    }
    .md-featured-stage-arrow--prev { left: 2px; }
    .md-featured-stage-arrow--next { right: 2px; }
}

/* ---- 3. Home rhythm — categories / features / maison / footer ---- */
@media (max-width: 700px) {
    .md-cats { padding: 18px 18px 56px; }
    .md-cats-inner { padding: 32px 20px; gap: 22px; row-gap: 28px; }
    .md-cat-disc { width: 84px; height: 84px; }
    .md-cat-disc svg,
    .md-cat-disc img { height: 60px; }
    .md-cat-name { font-size: 16px; }

    .md-features { padding: 56px 18px 60px; }
    .md-features-inner { gap: 18px; }
    .md-feat-card {
        padding: 26px 22px;
        min-height: 0;
        gap: 22px;
    }
    .md-feat-title { font-size: clamp(28px, 7vw, 36px); margin-bottom: 12px; }
    .md-feat-note { font-size: 14px; margin-bottom: 20px; }
    .md-feat-media { aspect-ratio: 16 / 11; }

    .md-maison { padding: 56px 18px 60px; }

    .md-footer { padding: 60px 18px 32px; }
    .md-footer-inner { padding-bottom: 44px; gap: 30px; }
    .md-footer-brand-logo {
        width: min(330px, 100%);
        height: 118px;
    }
    .md-footer-brand-note { font-size: 15px; }
    .md-footer-bottom {
        gap: 12px;
        padding-top: 24px;
        flex-direction: column;
        align-items: flex-start;
    }
    .md-footer-bottom > div + div { display: flex; flex-wrap: wrap; gap: 16px; }
    .md-footer-bottom > div + div a { margin-left: 0; }
    .md-footer-legal { margin-top: 28px; line-height: 1.7; }
}

/* ---- 4. Catalogue — tighten filter panel, refine ivory hero/CTA ---- */
@media (max-width: 1100px) {
    .md-catalogue .md-cat-layout { gap: 16px; }
    .md-catalogue .md-filter { padding: 16px 16px; }
    .md-catalogue .md-filter-head { margin-bottom: 10px; padding-bottom: 10px; }
    .md-catalogue .md-filter-head h3 { font-size: 11px; letter-spacing: 0.26em; }
    .md-catalogue .md-filter-group { padding: 8px 0; }
    .md-catalogue .md-filter-group summary {
        padding: 6px 0;
        min-height: 36px;
    }
    .md-catalogue .md-filter-options {
        max-height: 180px;
        gap: 8px;
        padding: 8px 0 2px;
    }
    .md-catalogue .md-filter-option { font-size: 13px; }
    .md-catalogue .md-filter-apply {
        margin-top: 12px;
        min-height: 42px;
        padding: 11px 16px;
    }
}

@media (max-width: 700px) {
    .md-catalogue .md-catalogue-hero { padding: 92px 16px 20px; }
    .md-catalogue-hero__inner { padding: 22px 18px; gap: 16px; }
    .md-catalogue-hero__title {
        font-size: clamp(30px, 8.5vw, 44px);
        line-height: 1;
    }
    .md-catalogue-hero__lead { font-size: 14.5px; line-height: 1.55; }
    .md-catalogue .md-section.md-catalogue-selection {
        padding: 14px 16px 44px;
    }
    .md-catalogue-selection__panel { padding: 18px 14px; }
    .md-catalogue .md-results-bar {
        padding: 10px 0;
        margin-bottom: 12px;
        gap: 10px;
    }
    .md-catalogue .md-results-bar .count { font-size: 13px; }
    /* Mobile .md-pcard sizing lives in the consolidated block above (≈ line 2921) */
    .md-catalogue .md-cta-band { padding: 28px 22px; }
    .md-catalogue .md-cta-band .md-h2 {
        font-size: clamp(22px, 6vw, 30px);
    }
    .md-catalogue .md-cta-band .md-lead { font-size: 14px; }
    .md-catalogue .md-cta-band .actions { width: 100%; }
    .md-catalogue .md-cta-band .actions .md-btn {
        flex: 1 1 140px;
        min-height: 44px;
    }
}

/* ---- 5. Product page — CTA stacking up to 600px, larger tap targets ---- */
@media (max-width: 600px) {
    .md-product-actions {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .md-product-page .md-product-actions .md-btn { min-height: 44px; }
    .md-product-page .md-product-info { padding: 18px 14px; }
    .md-product-page .md-product-brand { margin-bottom: 8px; font-size: 9.5px; }
    .md-product-page .md-product-name { font-size: clamp(22px, 6.4vw, 28px); }
    .md-product-page .md-product-cat { margin-bottom: 12px; font-size: 13.5px; }
    .md-product-page .md-product-price-row { padding: 12px 0; margin-bottom: 14px; }
    .md-product-page .md-product-price { font-size: clamp(22px, 6.4vw, 26px); }
    .md-product-page .md-product-stock { padding: 4px 9px; font-size: 9px; }
    .md-product-page .md-detail-list { gap: 7px; margin-bottom: 14px; }
    .md-product-page .md-detail-row { padding-bottom: 6px; }
    .md-product-page .md-detail-row .v { font-size: 13.5px; }
    .md-product-page .md-product-thumbs {
        grid-template-columns: repeat(4, 1fr);
        gap: 6px;
    }
    .md-product-page .md-product-promo-block { padding: 12px 14px; margin-top: 10px; }
    .md-product-page .md-product-prices { gap: 10px; }
    .md-product-page .md-product-price--old { font-size: 16px; }
}

/* ---- 6. Notre cave — CTA, map, contact polish ---- */
@media (max-width: 700px) {
    .md-about-hero { padding: 100px 16px 22px; }
    .md-about-hero__title {
        font-size: clamp(34px, 9vw, 48px);
        line-height: 0.98;
    }
    .md-about-hero__lead { font-size: 15px; line-height: 1.6; }
    .md-about-contact__panel { padding: 20px 16px; }
    .md-about-form input,
    .md-about-form textarea {
        padding: 12px 12px;
        font-size: 14px;
    }
    .md-about-form .md-btn { width: 100%; min-height: 46px; }
    .md-about-map { padding: 8px; }
    .md-about-map__frame { height: 260px; }
    .md-about-cta {
        padding: 28px 20px;
        grid-template-columns: 1fr;
        gap: 22px;
    }
    .md-about-cta .actions {
        grid-template-columns: 1fr;
        min-width: 0;
        width: 100%;
        gap: 10px;
    }
    .md-about-cta .actions .md-btn { min-height: 46px; }
}

@media (max-width: 390px) {
    .md-about-hero__title { font-size: clamp(30px, 9vw, 40px); }
    .md-about-map__frame { height: 230px; }
}

/* ---- 7. Search and legal mobile spacing ---- */
@media (max-width: 700px) {
    .md-search-page .md-search-shell { padding: 18px 14px; }
    .md-search-page .md-search-actions .md-btn { min-height: 44px; }
    .md-search-page .md-chip-row .md-chip { min-height: 38px; }
    .md-legal-panel { padding: 22px 16px; }
    .md-legal-panel .md-prose p {
        font-size: 15.5px;
        line-height: 1.66;
    }
    .md-legal-panel .md-prose h2 {
        font-size: clamp(22px, 6.5vw, 28px);
        margin-top: 26px;
    }
}

/* ---- 8. Tap targets and pagination on mobile ---- */
@media (max-width: 768px) {
    .md-btn { min-height: 44px; }
    .md-pagination a,
    .md-pagination span,
    .md-catalogue .md-pagination a,
    .md-catalogue .md-pagination span { min-height: 40px; }
}
