/* ============================================================
   Domaine de la Pierre Dorée — CSS principal monolithique
   Palette : bordeaux / doré / ivoire
   Typographies : Playfair Display + Inter
   ============================================================ */

:root {
    --v-bordeaux:    #5A0E1C;
    --v-bordeaux-dk: #3A0710;
    --v-gold:        #B89058;
    --v-gold-dk:     #957043;
    --v-ivory:       #FAF6EF;
    --v-cream:       #F2ECDF;
    --v-sand:        #E8DFCD;
    --v-charcoal:    #201914;
    --v-ink:         #2B2420;
    --v-muted:       #6E6358;
    --v-line:        rgba(32,25,20,.12);
    --v-red:         #8A1028;
    --v-rose:        #E4A5A0;
    --v-blanc:       #EADBA5;
    --v-success:     #4A7C3D;

    --v-shadow-sm: 0 2px 6px rgba(32,25,20,.06);
    --v-shadow-md: 0 8px 24px rgba(32,25,20,.10);
    --v-shadow-lg: 0 24px 60px rgba(32,25,20,.18);

    --v-radius: 4px;
    --v-radius-lg: 8px;

    --v-font-serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
    --v-font-sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

    --v-container: 1240px;
    --v-container-narrow: 860px;
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.vign-body {
    margin: 0;
    font-family: var(--v-font-sans);
    color: var(--v-ink);
    background: var(--v-ivory);
    font-size: 17px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--v-bordeaux); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; transition: color .2s ease; }
a:hover { color: var(--v-gold-dk); }
h1, h2, h3, h4 { font-family: var(--v-font-serif); color: var(--v-charcoal); line-height: 1.2; margin: 0 0 .5em; font-weight: 700; }
h1 { font-size: clamp(2rem, 5vw, 3.4rem); }
h2 { font-size: clamp(1.6rem, 3.8vw, 2.4rem); }
h3 { font-size: 1.35rem; }
p  { margin: 0 0 1em; }

.sr-only {
    position: absolute !important;
    width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ---------- SKIP LINK ---------- */
.vign-skip-link {
    position: absolute; left: -999px; top: 0; padding: .75rem 1rem;
    background: var(--v-bordeaux); color: #fff; z-index: 9999; text-decoration: none;
}
.vign-skip-link:focus { left: 0; color: #fff; }

/* ---------- BANDEAU DÉMO (Gradly Concept) ---------- */
.vign-demo-banner {
    background: linear-gradient(135deg, var(--v-bordeaux) 0%, var(--v-bordeaux-dk) 100%);
    color: #fff;
    padding: .7rem 1.25rem;
    text-align: center;
    font-size: .85rem;
    font-weight: 500;
    border-bottom: 2px solid var(--v-gold);
    letter-spacing: .01em;
}
.vign-demo-banner strong { color: var(--v-gold); font-weight: 700; }
.vign-demo-short { display: none; }

@media (max-width: 768px) {
    .vign-demo-banner { padding: .55rem 1rem; font-size: .78rem; }
    .vign-demo-full   { display: none; }
    .vign-demo-short  { display: inline; }
}

/* ---------- BANDEAU ALCOOL ---------- */
.vign-top-banner {
    background: var(--v-charcoal);
    color: var(--v-sand);
    text-align: center;
    padding: .5rem 1rem;
    font-size: .78rem;
    letter-spacing: .02em;
}

/* ---------- HEADER ---------- */
.vign-header {
    position: sticky; top: 0; z-index: 100;
    background: var(--v-ivory);
    border-bottom: 1px solid var(--v-line);
    box-shadow: var(--v-shadow-sm);
}
.vign-header__inner {
    max-width: var(--v-container);
    margin: 0 auto;
    padding: 1rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
}
.vign-logo {
    display: flex; align-items: center; gap: .8rem;
    color: var(--v-charcoal);
    text-decoration: none;
}
.vign-logo__symbol { font-size: 2rem; line-height: 1; }
.vign-logo__image {
    width: 52px;
    height: 52px;
    object-fit: contain;
    flex-shrink: 0;
}
.vign-logo__text { display: flex; flex-direction: column; }
.vign-logo__name {
    font-family: var(--v-font-serif);
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: .01em;
}
.vign-logo__tagline {
    font-size: .72rem;
    color: var(--v-muted);
    letter-spacing: .06em;
    text-transform: uppercase;
}

.vign-nav__menu {
    list-style: none; margin: 0; padding: 0;
    display: flex; gap: 1.75rem; align-items: center;
}
.vign-nav__menu a {
    color: var(--v-charcoal);
    text-decoration: none;
    font-weight: 500;
    font-size: .96rem;
    position: relative;
    padding: .4rem 0;
}
.vign-nav__menu a[aria-current="page"],
.vign-nav__menu a:hover { color: var(--v-bordeaux); }
.vign-nav__menu a[aria-current="page"]::after {
    content: ''; position: absolute; left: 0; right: 0; bottom: -3px;
    height: 2px; background: var(--v-gold);
}
.vign-nav__cta-mobile { display: none; }

.vign-nav__toggle {
    display: none;
    background: none; border: 0;
    flex-direction: column; justify-content: center; gap: 5px;
    width: 38px; height: 38px; padding: 0; cursor: pointer;
}
.vign-nav__burger { display: block; width: 24px; height: 2px; background: var(--v-charcoal); transition: transform .3s, opacity .3s; }

.vign-header__actions { display: flex; align-items: center; gap: 1rem; }
.vign-header__phone {
    display: inline-flex; align-items: center; gap: .4rem;
    color: var(--v-charcoal); text-decoration: none; font-weight: 600; font-size: .9rem;
    white-space: nowrap;
    flex-shrink: 0;
}
.vign-header__phone:hover { color: var(--v-bordeaux); }
.vign-header__phone-text { white-space: nowrap; }

/* ---------- BUTTONS ---------- */
.vign-btn {
    display: inline-block;
    padding: .85rem 1.5rem;
    border-radius: var(--v-radius);
    font-weight: 600;
    text-decoration: none;
    font-size: .94rem;
    letter-spacing: .03em;
    border: 2px solid transparent;
    cursor: pointer;
    transition: background .25s ease, transform .2s ease, box-shadow .25s ease, color .25s ease, border-color .25s ease;
    line-height: 1.2;
    text-align: center;
    font-family: var(--v-font-sans);
}
.vign-btn--gold {
    background: var(--v-gold);
    color: #fff;
    border-color: var(--v-gold);
    box-shadow: 0 4px 14px rgba(184,144,88,.35);
}
.vign-btn--gold:hover { background: var(--v-gold-dk); border-color: var(--v-gold-dk); color: #fff; transform: translateY(-1px); box-shadow: var(--v-shadow-md); }

.vign-btn--outline {
    background: transparent;
    color: var(--v-ivory);
    border-color: var(--v-ivory);
}
.vign-btn--outline:hover { background: var(--v-ivory); color: var(--v-bordeaux); }

.vign-btn--ghost {
    background: transparent;
    color: var(--v-ivory);
    border-color: transparent;
    text-decoration: underline;
}
.vign-btn--ghost:hover { color: var(--v-gold); }

.vign-btn--lg  { padding: 1.05rem 2rem; font-size: 1rem; }
.vign-btn--sm  { padding: .55rem 1rem;   font-size: .85rem; }
.vign-btn--block { display: block; width: 100%; }

/* ---------- LAYOUT HELPERS ---------- */
.vign-main { display: block; }
.vign-container { max-width: var(--v-container); margin: 0 auto; padding: 0 1.5rem; }
.vign-container--narrow { max-width: var(--v-container-narrow); }
.vign-center { text-align: center; }
.vign-mt-lg { margin-top: 2.5rem; }

.vign-section { padding: clamp(3.5rem, 7vw, 6rem) 0; position: relative; }

/* Section claire avec texture subtile (vagues dorées) */
.vign-section--alt {
    background-color: var(--v-cream);
    background-image:
        radial-gradient(circle at 10% 20%, rgba(184,144,88,.06) 0%, transparent 40%),
        radial-gradient(circle at 90% 80%, rgba(90,14,28,.05) 0%, transparent 45%);
    background-attachment: fixed, fixed;
}

/* Section ivoire (intro, etc.) avec micro-texture papier */
.vign-intro,
.vign-pillars,
.vign-visit-teaser,
.vign-final-cta {
    position: relative;
}
.vign-intro::before,
.vign-pillars::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(184,144,88,.04) 0%, transparent 30%),
        radial-gradient(circle at 80% 70%, rgba(90,14,28,.03) 0%, transparent 30%);
    z-index: 0;
}
.vign-intro > *,
.vign-pillars > * { position: relative; z-index: 1; }

/* ---------- ORNEMENT (séparateur grappe + lignes dorées) ---------- */
.vign-ornament {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    margin: 3rem auto 0;
    max-width: 480px;
}
.vign-ornament__line {
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, var(--v-gold) 50%, transparent 100%);
}
.vign-ornament__icon {
    font-size: 1.4rem;
    opacity: .85;
    filter: drop-shadow(0 1px 2px rgba(184,144,88,.3));
}
.vign-ornament--small {
    margin: 1rem auto 2.5rem;
    max-width: 280px;
    gap: 1rem;
}
.vign-ornament--small .vign-ornament__icon { font-size: 1.1rem; }

/* ---------- SECTION PARALLAXE (citation sur fond photo) ---------- */
.vign-parallax {
    position: relative;
    min-height: 60vh;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--v-ivory);
    padding: 6rem 1.5rem;
    overflow: hidden;
}
.vign-parallax__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(58,7,16,.78) 0%, rgba(32,25,20,.65) 100%);
    z-index: 1;
}
.vign-parallax__content {
    position: relative;
    z-index: 2;
    max-width: 800px;
    text-align: center;
}
.vign-parallax__eyebrow {
    color: var(--v-gold);
    font-size: .8rem;
    letter-spacing: .3em;
    text-transform: uppercase;
    font-weight: 600;
    margin: 0 0 1.5rem;
}
.vign-parallax__quote {
    font-family: var(--v-font-serif);
    font-size: clamp(1.4rem, 3vw, 2.1rem);
    line-height: 1.4;
    font-style: italic;
    font-weight: 500;
    color: #fff;
    margin: 0 0 1.5rem;
    text-shadow: 0 2px 12px rgba(0,0,0,.35);
}
.vign-parallax__quote::before {
    content: "\201C";
    display: block;
    font-family: var(--v-font-serif);
    font-size: 5rem;
    color: var(--v-gold);
    line-height: .3;
    margin-bottom: 1.5rem;
    opacity: .8;
}
.vign-parallax__sig {
    color: rgba(250,246,239,.85);
    font-size: .95rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin: 0;
}

/* Désactive parallax sur mobile (perf + bug iOS) */
@media (max-width: 768px) {
    .vign-parallax { background-attachment: scroll; min-height: 50vh; padding: 4rem 1.5rem; }
    .vign-section--alt { background-attachment: scroll, scroll; }
}
.vign-section__eyebrow {
    color: var(--v-gold-dk);
    font-weight: 600;
    font-size: .8rem;
    letter-spacing: .22em;
    text-transform: uppercase;
    margin: 0 0 .75rem;
}
.vign-section__title {
    font-family: var(--v-font-serif);
    margin: 0 0 1rem;
}
.vign-section__subtitle {
    color: var(--v-muted);
    font-size: 1.1rem;
    max-width: 680px;
    margin: 0 auto 2.5rem;
}

/* ---------- HERO ACCUEIL ---------- */
.vign-hero {
    position: relative;
    min-height: 90vh;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-ivory);
    overflow: hidden;
}
.vign-hero__image {
    position: absolute; inset: 0;
    width: 100%; height: 100%; object-fit: cover;
    z-index: 1;
}
.vign-hero__overlay {
    position: absolute; inset: 0; z-index: 2;
    background: linear-gradient(180deg, rgba(32,25,20,.55) 0%, rgba(58,7,16,.7) 100%);
}
.vign-hero__content {
    position: relative; z-index: 3;
    max-width: 860px; padding: 4rem 1.5rem; text-align: center;
}
.vign-hero__eyebrow {
    color: var(--v-gold);
    font-size: .85rem;
    letter-spacing: .3em;
    text-transform: uppercase;
    margin: 0 0 1.5rem;
    font-weight: 600;
}
.vign-hero__title {
    color: var(--v-ivory);
    font-size: clamp(2.4rem, 6vw, 4.5rem);
    line-height: 1.05;
    margin: 0 0 1.5rem;
    text-shadow: 0 2px 12px rgba(0,0,0,.35);
}
.vign-hero__tagline {
    font-size: clamp(1.05rem, 1.6vw, 1.3rem);
    color: rgba(250,246,239,.9);
    margin: 0 0 2.5rem;
}
.vign-hero__ctas { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2rem; }
.vign-hero__trust {
    color: rgba(250,246,239,.8);
    font-size: .95rem;
    letter-spacing: .04em;
    margin: 0;
}

/* ---------- HERO PAGE (interne) ---------- */
.vign-page-hero {
    position: relative;
    min-height: 55vh;
    display: flex; align-items: flex-end;
    color: var(--v-ivory);
    overflow: hidden;
}
.vign-page-hero__image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.vign-page-hero__overlay { position: absolute; inset: 0; z-index: 2; background: linear-gradient(180deg, rgba(32,25,20,.35) 0%, rgba(58,7,16,.8) 100%); }
.vign-page-hero__content { position: relative; z-index: 3; max-width: var(--v-container); width: 100%; margin: 0 auto; padding: 5rem 1.5rem 3rem; }
.vign-page-hero__eyebrow { color: var(--v-gold); font-size: .8rem; letter-spacing: .25em; text-transform: uppercase; margin: 0 0 1rem; font-weight: 600; }
.vign-page-hero__title { color: var(--v-ivory); margin: 0 0 1rem; text-shadow: 0 2px 12px rgba(0,0,0,.35); }
.vign-page-hero__tagline { color: rgba(250,246,239,.9); font-size: 1.15rem; max-width: 720px; margin: 0; }

/* ---------- BREADCRUMB ---------- */
.vign-breadcrumb { font-size: .85rem; color: rgba(250,246,239,.8); margin-bottom: 1rem; }
.vign-breadcrumb a { color: rgba(250,246,239,.95); text-decoration: none; }
.vign-breadcrumb a:hover { color: var(--v-gold); text-decoration: underline; }
.vign-breadcrumb span[aria-hidden="true"] { margin: 0 .5rem; opacity: .5; }

/* ---------- INTRO ACCUEIL ---------- */
.vign-intro                  { text-align: center; }
.vign-intro .vign-section__eyebrow,
.vign-intro .vign-section__title { text-align: center; }
.vign-intro .vign-section__title { max-width: 820px; margin-left: auto; margin-right: auto; }
.vign-intro__lead {
    font-size: 1.15rem;
    color: var(--v-muted);
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

/* ---------- POINTS FORTS ---------- */
.vign-pillars__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}
.vign-pillar {
    background: #fff;
    padding: 2.5rem 2rem;
    border-radius: var(--v-radius-lg);
    border: 1px solid var(--v-line);
    box-shadow: var(--v-shadow-sm);
    text-align: center;
    transition: transform .3s ease, box-shadow .3s ease;
}
.vign-pillar:hover { transform: translateY(-4px); box-shadow: var(--v-shadow-md); }
.vign-pillar__icon { font-size: 2.8rem; margin-bottom: 1rem; }
.vign-pillar__title { color: var(--v-bordeaux); }

/* ---------- WINE CARDS (accueil + page vins) ---------- */
.vign-featured__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}
/* Flex centré pour éviter l'orpheline avec 5 cuvées */
.vign-wines__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
    margin-top: 3rem;
}
.vign-wines__grid > .vign-wine-detail {
    flex: 1 1 320px;
    max-width: 380px;
}

.vign-wine-card,
.vign-wine-detail {
    background: #fff;
    border: 1px solid var(--v-line);
    border-radius: var(--v-radius-lg);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .3s ease, box-shadow .3s ease;
    position: relative;
}
.vign-wine-card:hover,
.vign-wine-detail:hover { transform: translateY(-4px); box-shadow: var(--v-shadow-md); }
.vign-wine-card__media,
.vign-wine-detail__media {
    position: relative;
    background: var(--v-cream);
    aspect-ratio: 3/4;
    overflow: hidden;
}
.vign-wine-card__img,
.vign-wine-detail__media img { width: 100%; height: 100%; object-fit: contain; padding: 1.5rem; }

.vign-wine-card__medals,
.vign-wine-detail__medals {
    position: absolute; top: .75rem; left: .75rem; right: .75rem;
    display: flex; flex-wrap: wrap; gap: .35rem;
    pointer-events: none;
}

.vign-wine-card__body,
.vign-wine-detail__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.vign-wine-card__color,
.vign-wine-detail__color-tag {
    font-size: .75rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--v-gold-dk);
    font-weight: 600;
    margin: 0 0 .5rem;
}
.vign-wine-card__name,
.vign-wine-detail__name {
    font-size: 1.2rem;
    line-height: 1.3;
    margin: 0 0 .25rem;
    color: var(--v-charcoal);
}
.vign-wine-detail__year { font-weight: 400; color: var(--v-muted); }

.vign-wine-card__appellation,
.vign-wine-card__cepage {
    font-size: .88rem;
    color: var(--v-muted);
    margin: 0 0 .2rem;
}

.vign-wine-card__footer {
    margin-top: auto;
    padding-top: 1rem;
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem;
}
.vign-wine-card__price,
.vign-wine-detail__price {
    font-family: var(--v-font-serif);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--v-bordeaux);
}

/* Wine detail (page Vins) */
.vign-wine-detail__specs {
    margin: 1rem 0;
    display: flex; flex-direction: column; gap: .35rem;
    font-size: .9rem;
}
.vign-wine-detail__specs > div { display: flex; gap: .5rem; }
.vign-wine-detail__specs dt { color: var(--v-muted); min-width: 110px; margin: 0; }
.vign-wine-detail__specs dd { margin: 0; color: var(--v-ink); font-weight: 500; }

.vign-wine-detail__tasting,
.vign-wine-detail__pairing { margin-top: 1rem; }
.vign-wine-detail__tasting h4,
.vign-wine-detail__pairing h4 {
    font-family: var(--v-font-sans);
    text-transform: uppercase;
    letter-spacing: .14em;
    font-size: .72rem;
    color: var(--v-gold-dk);
    margin: 0 0 .3rem;
}
.vign-wine-detail__tasting p,
.vign-wine-detail__pairing p { font-size: .92rem; color: var(--v-ink); margin: 0; }

.vign-wine-detail__footer {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--v-line);
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.vign-wine-detail__price-unit { font-family: var(--v-font-sans); font-size: .85rem; color: var(--v-muted); font-weight: 400; }

/* ---------- FILTERS ---------- */
.vign-wines__filters {
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: .75rem;
    margin: 2rem 0 1rem;
}
.vign-filter {
    border: 2px solid var(--v-line);
    background: #fff;
    color: var(--v-charcoal);
    padding: .65rem 1.25rem;
    border-radius: 99px;
    font-weight: 600;
    font-size: .9rem;
    cursor: pointer;
    font-family: var(--v-font-sans);
    transition: all .2s ease;
}
.vign-filter:hover { border-color: var(--v-bordeaux); color: var(--v-bordeaux); }
.vign-filter.is-active { background: var(--v-bordeaux); color: #fff; border-color: var(--v-bordeaux); }
.vign-filter__count { opacity: .6; font-weight: 400; margin-left: .3rem; }
.vign-wines__empty { text-align: center; color: var(--v-muted); font-style: italic; margin-top: 3rem; }

/* Couleur cuvée */
.vign-wine-card--rouge,
.vign-wine-detail--rouge { border-top: 4px solid var(--v-red); }
.vign-wine-card--blanc,
.vign-wine-detail--blanc { border-top: 4px solid var(--v-blanc); }
.vign-wine-card--rose,
.vign-wine-detail--rose  { border-top: 4px solid var(--v-rose); }

/* ---------- MEDAL BADGES ---------- */
.medal-badge {
    display: inline-flex; align-items: center; gap: .35rem;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(4px);
    color: var(--v-charcoal);
    font-size: .72rem;
    font-weight: 600;
    padding: .3rem .55rem;
    border-radius: 99px;
    line-height: 1.2;
    box-shadow: var(--v-shadow-sm);
    pointer-events: auto;
    max-width: 100%;
}
.medal-icon { font-size: .95rem; }
.medal-label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px; }
.medal-or       { color: #8a6914; }
.medal-argent   { color: #5a5a5a; }
.medal-bronze   { color: #8a4d14; }
.medal-hachette { color: var(--v-bordeaux); }
.medal-parker   { color: #1a4a6b; }

/* ---------- BANDEAU MÉDAILLES ACCUEIL ---------- */
.vign-medals-banner__list {
    list-style: none; padding: 0; margin: 3rem 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.5rem;
}
.vign-medals-banner__list li {
    background: #fff;
    border: 1px solid var(--v-line);
    padding: 1.5rem;
    border-radius: var(--v-radius-lg);
    display: flex; flex-direction: column; gap: .35rem;
    text-align: center;
    box-shadow: var(--v-shadow-sm);
    flex: 1 1 220px;
    max-width: 280px;
}
.vign-medals-banner__icon { font-size: 2rem; }
.vign-medals-banner__list strong { font-family: var(--v-font-serif); color: var(--v-bordeaux); font-size: 1.05rem; }
.vign-medals-banner__list span { color: var(--v-muted); font-size: .88rem; }

/* ---------- VISITE TEASER ---------- */
.vign-visit-teaser__grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center;
}
.vign-visit-teaser__media img { border-radius: var(--v-radius-lg); box-shadow: var(--v-shadow-lg); width: 100%; }
.vign-visit-teaser__address { font-style: normal; margin: 1rem 0; color: var(--v-ink); }
.vign-visit-teaser__hours { color: var(--v-muted); }
.vign-visit-teaser__ctas { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1.5rem; }
.vign-visit-teaser__ctas .vign-btn--ghost { color: var(--v-charcoal); border-color: transparent; text-decoration: none; }
.vign-visit-teaser__ctas .vign-btn--ghost:hover { color: var(--v-bordeaux); }

/* ---------- FAQ ---------- */
.vign-faq__list { margin-top: 2.5rem; }
.vign-faq__item {
    background: #fff;
    border: 1px solid var(--v-line);
    border-radius: var(--v-radius-lg);
    margin-bottom: 1rem;
    overflow: hidden;
    transition: box-shadow .2s ease;
}
.vign-faq__item[open] { box-shadow: var(--v-shadow-md); }
.vign-faq__item summary {
    cursor: pointer;
    padding: 1.25rem 1.5rem;
    font-weight: 600;
    font-family: var(--v-font-serif);
    font-size: 1.1rem;
    color: var(--v-charcoal);
    list-style: none;
    position: relative;
    padding-right: 3rem;
}
.vign-faq__item summary::-webkit-details-marker { display: none; }
.vign-faq__item summary::after {
    content: '+'; position: absolute; right: 1.5rem; top: 50%; transform: translateY(-50%);
    font-size: 1.5rem; color: var(--v-gold-dk); font-weight: 300; transition: transform .25s;
}
.vign-faq__item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.vign-faq__item p { padding: 0 1.5rem 1.5rem; margin: 0; color: var(--v-muted); }

/* ---------- CTA FINAL ---------- */
.vign-final-cta {
    background: var(--v-bordeaux);
    color: var(--v-ivory);
    text-align: center;
}
.vign-final-cta .vign-section__title,
.vign-final-cta .vign-section__subtitle {
    color: var(--v-ivory);
}
.vign-final-cta__buttons { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-top: 2rem; }
.vign-final-cta .vign-btn--outline { color: var(--v-ivory); border-color: var(--v-ivory); }
.vign-final-cta .vign-btn--outline:hover { background: var(--v-ivory); color: var(--v-bordeaux); }

/* ---------- DOMAINE ---------- */
.vign-history__grid {
    display: grid; grid-template-columns: 1.3fr 1fr; gap: 3rem; align-items: start;
}
.vign-history__media img { border-radius: var(--v-radius-lg); box-shadow: var(--v-shadow-lg); width: 100%; }

.vign-philosophy__lead {
    font-family: var(--v-font-serif);
    font-size: 1.4rem;
    line-height: 1.5;
    font-style: italic;
    color: var(--v-charcoal);
    margin: 1.5rem 0 .75rem;
}
.vign-philosophy__sig { color: var(--v-muted); font-size: .95rem; margin-bottom: 3rem; }
.vign-philosophy__grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
    gap: 2rem; margin-top: 2rem; text-align: left;
}
.vign-philosophy__grid h3 { color: var(--v-bordeaux); }

.vign-terroir__grid {
    display: grid; grid-template-columns: 1fr 1.3fr; gap: 3rem; align-items: center;
}
.vign-terroir__media img { border-radius: var(--v-radius-lg); box-shadow: var(--v-shadow-lg); }
.vign-terroir__specs { display: flex; flex-direction: column; gap: .6rem; margin: 0; }
.vign-terroir__specs > div { display: grid; grid-template-columns: 180px 1fr; gap: 1rem; padding-bottom: .5rem; border-bottom: 1px solid var(--v-line); }
.vign-terroir__specs dt { color: var(--v-gold-dk); font-weight: 600; font-size: .85rem; text-transform: uppercase; letter-spacing: .08em; margin: 0; }
.vign-terroir__specs dd { margin: 0; color: var(--v-ink); }

.vign-engagements__grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem; margin-top: 3rem;
}
.vign-engagement {
    background: #fff; border: 1px solid var(--v-line); padding: 2rem 1.5rem;
    border-radius: var(--v-radius-lg); text-align: center; box-shadow: var(--v-shadow-sm);
}
.vign-engagement__icon { font-size: 2.2rem; margin-bottom: .75rem; }
.vign-engagement h3 { color: var(--v-bordeaux); font-size: 1.15rem; }

.vign-team__grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr));
    gap: 2rem; margin-top: 3rem;
}
.vign-team-member {
    background: #fff; border: 1px solid var(--v-line);
    padding: 2rem; border-radius: var(--v-radius-lg);
    box-shadow: var(--v-shadow-sm);
}
.vign-team-member h3 { color: var(--v-charcoal); margin: 0; }
.vign-team-member__role {
    color: var(--v-gold-dk);
    text-transform: uppercase;
    font-size: .78rem;
    letter-spacing: .15em;
    margin: .35rem 0 .75rem;
    font-weight: 600;
}

/* ---------- MÉDAILLES PAGE ---------- */
.vign-stats {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(170px,1fr));
    gap: 1.5rem;
}
.vign-stat {
    background: #fff; border: 1px solid var(--v-line);
    padding: 1.75rem 1rem; text-align: center; border-radius: var(--v-radius-lg);
    box-shadow: var(--v-shadow-sm);
}
.vign-stat strong {
    display: block;
    font-family: var(--v-font-serif);
    font-size: 2.4rem;
    color: var(--v-bordeaux);
    line-height: 1;
    margin-bottom: .5rem;
}
.vign-stat span { color: var(--v-muted); font-size: .88rem; }

.vign-palmares__year {
    background: #fff; border: 1px solid var(--v-line);
    border-radius: var(--v-radius-lg); padding: 2rem;
    margin-bottom: 1.5rem; box-shadow: var(--v-shadow-sm);
}
.vign-palmares__year-title {
    font-size: 2rem;
    color: var(--v-bordeaux);
    border-bottom: 2px solid var(--v-gold);
    display: inline-block;
    padding-bottom: .35rem; margin-bottom: 1.25rem;
}
.vign-palmares__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .85rem; }
.vign-palmares__list li {
    display: flex; align-items: center; gap: 1rem;
    padding: .75rem 1rem;
    background: var(--v-cream);
    border-radius: var(--v-radius);
}
.vign-palmares__list li .medal-badge { flex-shrink: 0; }
.vign-palmares__list li > div strong { color: var(--v-charcoal); }

.vign-medals-by-wine__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem; margin-top: 3rem;
}
.vign-medals-by-wine__grid > .vign-medal-card {
    flex: 1 1 260px;
    max-width: 320px;
}
.vign-medal-card {
    background: #fff; border: 1px solid var(--v-line);
    border-radius: var(--v-radius-lg); overflow: hidden;
    box-shadow: var(--v-shadow-sm); display: flex; flex-direction: column;
}
.vign-medal-card__img { background: var(--v-cream); padding: 1.5rem; aspect-ratio: 3/4; object-fit: contain; width: 100%; }
.vign-medal-card__body { padding: 1.5rem; }
.vign-medal-card__body h3 { font-size: 1.1rem; margin: 0 0 .4rem; }
.vign-medal-card__body h3 span { color: var(--v-muted); font-weight: 400; }
.vign-medal-card__appel { color: var(--v-gold-dk); text-transform: uppercase; letter-spacing: .1em; font-size: .78rem; margin: 0 0 1rem; font-weight: 600; }
.vign-medal-card__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; align-items: flex-start; }

/* ---------- BOUTIQUE ---------- */
.vign-trust__list {
    list-style: none; padding: 0; margin: 0;
    display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem;
}
.vign-trust__list li {
    background: #fff; border: 1px solid var(--v-line);
    padding: 1.25rem 1rem; text-align: center;
    border-radius: var(--v-radius-lg); font-size: .88rem;
    box-shadow: var(--v-shadow-sm);
}
.vign-trust__list span[aria-hidden="true"] { font-size: 1.6rem; display: block; margin-bottom: .5rem; }

.vign-shop__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem; margin-top: 2rem;
}
.vign-shop__grid > .vign-shop-item {
    flex: 1 1 280px;
    max-width: 340px;
}
.vign-shop-item {
    background: #fff; border: 1px solid var(--v-line);
    border-radius: var(--v-radius-lg); overflow: hidden;
    display: flex; flex-direction: column;
    box-shadow: var(--v-shadow-sm);
    transition: transform .3s ease, box-shadow .3s ease;
}
.vign-shop-item:hover { transform: translateY(-3px); box-shadow: var(--v-shadow-md); }
.vign-shop-item__media { background: var(--v-cream); aspect-ratio: 4/5; padding: 1.5rem; }
.vign-shop-item__media img { width: 100%; height: 100%; object-fit: contain; }
.vign-shop-item__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.vign-shop-item__color { font-size: .75rem; letter-spacing: .15em; text-transform: uppercase; color: var(--v-gold-dk); font-weight: 600; margin: 0 0 .3rem; }
.vign-shop-item__name { font-size: 1.15rem; margin: 0 0 .2rem; }
.vign-shop-item__appel { font-size: .85rem; color: var(--v-muted); margin: 0 0 .75rem; }
.vign-shop-item__price { font-family: var(--v-font-serif); font-size: 1.4rem; color: var(--v-bordeaux); margin: 0 0 1rem; font-weight: 700; }
.vign-shop-item__price span { font-family: var(--v-font-sans); font-size: .8rem; color: var(--v-muted); font-weight: 400; }
.vign-shop-item__form { margin-top: auto; display: flex; flex-direction: column; gap: .75rem; }
.vign-shop-item__form select {
    padding: .6rem .8rem; border: 1px solid var(--v-line); border-radius: var(--v-radius);
    font-family: var(--v-font-sans); background: #fff; width: 100%;
}
.vign-shop__note { margin-top: 2.5rem; color: var(--v-muted); }

.vign-boxes__grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem; margin-top: 2.5rem;
}
.vign-box {
    background: #fff; border: 1px solid var(--v-line);
    border-radius: var(--v-radius-lg); overflow: hidden;
    box-shadow: var(--v-shadow-sm);
    display: flex; flex-direction: column;
}
.vign-box img { width: 100%; aspect-ratio: 3/2; object-fit: cover; }
.vign-box__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.vign-box__body h3 { color: var(--v-bordeaux); margin: 0 0 .5rem; }
.vign-box__content { font-size: .92rem; color: var(--v-ink); flex: 1; }
.vign-box__price { font-family: var(--v-font-serif); font-size: 1.2rem; margin: 1rem 0 1rem; }
.vign-box__price strong { color: var(--v-bordeaux); font-size: 1.5rem; }
.vign-box__price span { color: var(--v-muted); font-size: .85rem; font-family: var(--v-font-sans); }

.vign-shipping__grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; margin: 2.5rem 0;
}
.vign-shipping__grid h3 { color: var(--v-bordeaux); }
.vign-shipping__grid ul { padding-left: 1.25rem; }
.vign-shipping__grid li { margin-bottom: .5rem; color: var(--v-ink); }
.vign-shipping__legal { color: var(--v-muted); margin-top: 2rem; }

/* ---------- VISITE ---------- */
.vign-formulas__grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(270px,1fr));
    gap: 2rem; margin-top: 2.5rem;
}
.vign-formula {
    background: #fff; border: 1px solid var(--v-line);
    border-radius: var(--v-radius-lg); padding: 2rem;
    box-shadow: var(--v-shadow-sm);
    display: flex; flex-direction: column;
    position: relative;
}
.vign-formula--featured {
    border: 2px solid var(--v-gold);
    box-shadow: var(--v-shadow-lg);
    transform: translateY(-6px);
}
.vign-formula__badge {
    position: absolute; top: -12px; right: 1rem;
    background: var(--v-gold); color: #fff;
    font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    padding: .3rem .7rem; border-radius: 99px; margin: 0;
}
.vign-formula h3 { color: var(--v-bordeaux); margin-bottom: .35rem; }
.vign-formula__duration { color: var(--v-gold-dk); font-size: .85rem; font-weight: 600; margin: 0 0 1rem; letter-spacing: .05em; }
.vign-formula ul { padding-left: 1.25rem; margin: 0 0 1rem; flex: 1; }
.vign-formula li { margin-bottom: .4rem; font-size: .92rem; }
.vign-formula__price { font-family: var(--v-font-serif); font-size: 1.3rem; margin: .5rem 0 .2rem; }
.vign-formula__price strong { color: var(--v-bordeaux); }
.vign-formula__note { color: var(--v-muted); margin-bottom: 1.25rem; }

.vign-hours {
    margin: 2rem auto;
    border-collapse: collapse;
    width: 100%; max-width: 500px;
}
.vign-hours th, .vign-hours td {
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--v-line);
    text-align: left;
}
.vign-hours th { color: var(--v-bordeaux); font-weight: 600; width: 40%; }

/* ---------- FORMS ---------- */
.vign-form { margin-top: 2rem; display: flex; flex-direction: column; gap: 1.25rem; }
.vign-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.vign-form label { display: flex; flex-direction: column; gap: .35rem; font-size: .9rem; color: var(--v-charcoal); font-weight: 500; }
.vign-form label em { color: var(--v-bordeaux); font-style: normal; }
.vign-form input, .vign-form select, .vign-form textarea {
    padding: .75rem .9rem; border: 1px solid var(--v-line); border-radius: var(--v-radius);
    font-family: var(--v-font-sans); font-size: 1rem; background: #fff;
    transition: border-color .2s ease, box-shadow .2s ease;
}
.vign-form input:focus, .vign-form select:focus, .vign-form textarea:focus {
    outline: none;
    border-color: var(--v-gold);
    box-shadow: 0 0 0 3px rgba(184,144,88,.18);
}
.vign-form textarea { resize: vertical; }
.vign-form__check { flex-direction: row; align-items: flex-start; gap: .6rem; font-size: .85rem; color: var(--v-muted); }
.vign-form__check input { flex-shrink: 0; margin-top: .25rem; }
.vign-form__note { color: var(--v-muted); text-align: center; margin-top: .5rem; }

/* ---------- CONTACT ---------- */
.vign-contact__grid {
    display: grid; grid-template-columns: 1fr 1.4fr; gap: 3rem; align-items: start;
}
.vign-contact__block { margin-bottom: 1.75rem; }
.vign-contact__block h3 { font-size: 1rem; color: var(--v-bordeaux); margin-bottom: .35rem; }
.vign-contact__block address { font-style: normal; }
.vign-contact__block p { margin: 0; }
.vign-contact__social { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .35rem; }

.vign-access__grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr));
    gap: 2rem; margin-top: 2.5rem;
}
.vign-access__grid article {
    background: #fff; border: 1px solid var(--v-line);
    padding: 1.75rem; border-radius: var(--v-radius-lg);
    box-shadow: var(--v-shadow-sm);
}
.vign-access__grid h3 { color: var(--v-bordeaux); margin-bottom: .75rem; }
.vign-access__map {
    margin-top: 3rem;
}
.vign-access__map h3 {
    color: var(--v-bordeaux);
    margin-bottom: 1.5rem;
    font-size: 1.5rem;
}
.vign-map-wrap {
    position: relative;
    overflow: hidden;
    border-radius: var(--v-radius-lg);
    box-shadow: var(--v-shadow-md);
    border: 1px solid var(--v-line);
    background: var(--v-cream);
}
.vign-map-wrap iframe {
    display: block;
    width: 100%;
    height: 450px;
    filter: saturate(.92) contrast(1.02);
}
.vign-map-note {
    margin-top: 1.5rem;
}
@media (max-width: 768px) {
    .vign-map-wrap iframe { height: 360px; }
}

/* ---------- ARTICLE SEO ---------- */
.vign-article__lead {
    font-size: 1.15rem; line-height: 1.7;
    color: var(--v-ink);
    border-left: 4px solid var(--v-gold);
    padding-left: 1.5rem;
    font-style: italic;
    margin: 0 0 2.5rem;
}
.vign-article h2 { color: var(--v-bordeaux); margin-top: 2.5rem; }
.vign-article__cta {
    margin-top: 3.5rem;
    padding: 2rem;
    background: var(--v-cream);
    border-radius: var(--v-radius-lg);
    border: 1px solid var(--v-line);
    text-align: center;
}
.vign-article__cta h3 { margin-top: 0; color: var(--v-charcoal); }

/* ---------- 404 ---------- */
.vign-404 { padding: 5rem 0 6rem; }
.vign-404__number {
    font-family: var(--v-font-serif);
    font-size: clamp(5rem, 15vw, 10rem);
    font-weight: 800;
    color: var(--v-gold);
    line-height: 1;
    margin: 0 0 1rem;
    opacity: .8;
}
.vign-404__title { color: var(--v-bordeaux); }
.vign-404__lead { color: var(--v-muted); font-size: 1.1rem; max-width: 540px; margin: 1rem auto 2.5rem; }
.vign-404__links { list-style: none; padding: 0; margin: 0 0 2.5rem; display: flex; flex-direction: column; gap: .6rem; }
.vign-404__links a { font-size: 1.05rem; }
.vign-404__ctas { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ---------- FOOTER ---------- */
.vign-footer {
    background: var(--v-charcoal);
    color: var(--v-sand);
    padding-top: 4rem;
}
.vign-footer__inner {
    max-width: var(--v-container);
    margin: 0 auto;
    padding: 0 1.5rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 2.5rem;
}
.vign-footer__title {
    color: var(--v-gold);
    font-size: .95rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    margin: 0 0 1rem;
}
.vign-footer__col { font-size: .9rem; line-height: 1.7; }
.vign-footer__address { font-style: normal; margin: 0 0 1rem; }
.vign-footer__address strong { color: #fff; display: block; margin-bottom: .35rem; }
.vign-footer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .4rem; }
.vign-footer a { color: var(--v-sand); text-decoration: none; }
.vign-footer a:hover { color: var(--v-gold); }
.vign-footer__contact a { color: #fff; font-weight: 500; }
.vign-footer__hours { color: rgba(232,223,205,.75); font-size: .85rem; }
.vign-footer__about { color: rgba(232,223,205,.85); font-size: .9rem; margin-bottom: 1rem; }
.vign-footer__about strong { color: var(--v-gold); }
.vign-footer__social { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }

.vign-footer__alcohol {
    margin-top: 3rem;
    padding: 1.25rem 1.5rem;
    background: var(--v-bordeaux-dk);
    text-align: center;
    font-size: .85rem;
    color: var(--v-ivory);
}
.vign-footer__alcohol strong { color: #fff; }
.vign-footer__alcohol p { margin: 0; }

.vign-footer__bottom {
    max-width: var(--v-container);
    margin: 0 auto;
    padding: 1.5rem;
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 1rem;
    font-size: .8rem;
    color: rgba(232,223,205,.6);
}
.vign-footer__credit a strong { color: var(--v-gold); }
.vign-footer__copyright, .vign-footer__credit { margin: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
    .vign-visit-teaser__grid,
    .vign-history__grid,
    .vign-terroir__grid,
    .vign-contact__grid,
    .vign-shipping__grid { grid-template-columns: 1fr; gap: 2rem; }
    .vign-terroir__specs > div { grid-template-columns: 140px 1fr; }
}

@media (max-width: 768px) {
    .vign-header__phone-text { display: none; }
    .vign-header__cta { display: none; }

    .vign-nav__toggle { display: flex; }
    .vign-nav__menu {
        position: fixed; inset: 0 0 0 20%;
        background: var(--v-ivory);
        flex-direction: column; justify-content: flex-start;
        gap: 0;
        padding: 5rem 2rem 2rem;
        transform: translateX(100%);
        transition: transform .35s ease;
        box-shadow: var(--v-shadow-lg);
        overflow-y: auto;
    }
    .vign-nav__menu.is-open { transform: translateX(0); }
    .vign-nav__menu li { border-bottom: 1px solid var(--v-line); width: 100%; }
    .vign-nav__menu a { display: block; padding: 1.1rem 0; font-size: 1.05rem; }
    .vign-nav__cta-mobile { display: block; border-bottom: 0; margin-top: 1.5rem; }
    .vign-nav__cta-mobile a { display: block; text-align: center; }

    .vign-nav__toggle[aria-expanded="true"] .vign-nav__burger:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .vign-nav__toggle[aria-expanded="true"] .vign-nav__burger:nth-child(2) { opacity: 0; }
    .vign-nav__toggle[aria-expanded="true"] .vign-nav__burger:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    .vign-hero { min-height: 80vh; }
    .vign-form__row { grid-template-columns: 1fr; }
    .vign-terroir__specs > div { grid-template-columns: 1fr; gap: .2rem; }
    .vign-footer__inner { grid-template-columns: 1fr 1fr; }
    .vign-footer__bottom { flex-direction: column; text-align: center; }
}

@media (max-width: 480px) {
    body.vign-body { font-size: 16px; }
    .vign-hero__ctas .vign-btn { width: 100%; }
    .vign-footer__inner { grid-template-columns: 1fr; }
    .vign-container, .vign-footer__inner, .vign-header__inner { padding-left: 1rem; padding-right: 1rem; }
    .vign-logo__tagline { display: none; }
    .vign-palmares__list li { flex-direction: column; align-items: flex-start; gap: .5rem; }
}

/* ============================================================
   SCROLL REVEAL (IntersectionObserver)
   ============================================================ */
.vign-reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.vign-reveal.is-visible { opacity: 1; transform: translateY(0); }

/* Respect des préférences utilisateur */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
    .vign-reveal { opacity: 1; transform: none; }
}
