/*
Theme Name: ViniLux
Theme URI: https://vinilux.ch/
Author: PTL
Description: Thème sur-mesure ViniLux — design luxe (hospitalité de luxe & expérience client), bilingue FR/EN via le plugin ViniLux i18n. ACF-driven.
Version: 1.0.0
Requires PHP: 8.0
Text Domain: vinilux
*/

/* =========================================================================
   1. DESIGN TOKENS — palette officielle (extraite des SVG du logo)
   ========================================================================= */
:root {
	--vl-green:      #2c342a; /* primaire — vert foncé */
	--vl-green-deep: #1a1f19; /* texte max sur crème */
	--vl-gold:       #d9ab52; /* accent */
	--vl-gold-soft:  #c79a45;
	--vl-cream:      #f0e5d7; /* fond clair */
	--vl-cream-2:    #f6efe6;
	--vl-olive:      #71715f; /* secondaire */
	--vl-sage:       #a19a6f;
	--vl-white:      #ffffff;

	/* Typographie */
	--vl-font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--vl-font-body:    "Jost", system-ui, -apple-system, "Segoe UI", sans-serif;

	/* Échelle */
	--vl-maxw: 1240px;
	--vl-gutter: clamp(1.25rem, 4vw, 4rem);
	--vl-section-y: clamp(4rem, 9vw, 9rem);

	/* Transitions */
	--vl-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* =========================================================================
   2. RESET / BASE
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--vl-font-body);
	font-weight: 300;
	font-size: clamp(1rem, 0.5vw + 0.9rem, 1.125rem);
	line-height: 1.7;
	color: var(--vl-green-deep);
	background: var(--vl-cream);
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .3s var(--vl-ease); }

h1, h2, h3, h4 {
	font-family: var(--vl-font-display);
	font-weight: 500;
	line-height: 1.08;
	letter-spacing: .01em;
	margin: 0 0 .5em;
	color: var(--vl-green);
}
h1 { font-size: clamp(2.6rem, 6vw, 5rem); }
h2 { font-size: clamp(2rem, 4vw, 3.25rem); }
h3 { font-size: clamp(1.4rem, 2vw, 1.9rem); }

.vl-eyebrow {
	font-family: var(--vl-font-body);
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: .28em;
	font-size: .72rem;
	color: var(--vl-gold-soft);
	margin: 0 0 1.25rem;
	display: inline-block;
}
.vl-lead { font-size: clamp(1.15rem, 1.4vw, 1.4rem); color: var(--vl-olive); }

/* =========================================================================
   3. LAYOUT
   ========================================================================= */
.vl-container { max-width: var(--vl-maxw); margin-inline: auto; padding-inline: var(--vl-gutter); }
.vl-section { padding-block: var(--vl-section-y); }
.vl-section--green { background: var(--vl-green); color: var(--vl-cream); }
.vl-section--green h1, .vl-section--green h2, .vl-section--green h3 { color: var(--vl-cream); }
.vl-section--cream { background: var(--vl-cream); }
.vl-grid { display: grid; gap: clamp(1.5rem, 3vw, 3rem); }
.vl-grid--2 { grid-template-columns: repeat(2, 1fr); }
.vl-grid--3 { grid-template-columns: repeat(3, 1fr); }
.vl-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .vl-grid--3, .vl-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .vl-grid--2, .vl-grid--3, .vl-grid--4 { grid-template-columns: 1fr; } }

/* =========================================================================
   4. BOUTONS
   ========================================================================= */
.vl-btn {
	display: inline-block;
	font-family: var(--vl-font-body);
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: .18em;
	font-size: .78rem;
	padding: 1rem 2.2rem;
	border: 1px solid var(--vl-gold);
	color: var(--vl-gold);
	background: transparent;
	transition: all .35s var(--vl-ease);
}
.vl-btn:hover { background: var(--vl-gold); color: var(--vl-green); }
.vl-btn--solid { background: var(--vl-gold); color: var(--vl-green); }
.vl-btn--solid:hover { background: transparent; color: var(--vl-gold); }

/* =========================================================================
   5. HEADER + SÉLECTEUR DE LANGUE
   ========================================================================= */
.vl-header {
	position: fixed; inset: 0 0 auto 0; z-index: 100;
	display: flex; align-items: center; justify-content: space-between;
	padding: 1.25rem var(--vl-gutter);
	transition: background .4s var(--vl-ease), padding .4s var(--vl-ease);
}
.vl-header.is-scrolled { background: var(--vl-green); padding-block: .85rem; box-shadow: 0 1px 0 rgba(217,171,82,.18); }
.vl-header__logo img { height: 48px; width: auto; }
.vl-nav { display: flex; align-items: center; gap: clamp(1rem, 2vw, 2.25rem); }
.vl-nav a {
	font-family: var(--vl-font-body); font-weight: 300;
	text-transform: uppercase; letter-spacing: .14em; font-size: .8rem;
	color: var(--vl-cream);
}
.vl-nav a:hover { color: var(--vl-gold); }

.vl-lang-switcher { display: inline-flex; align-items: center; gap: .5rem; font-size: .8rem; letter-spacing: .1em; }
.vl-lang { color: var(--vl-cream); opacity: .65; }
.vl-lang.is-active { color: var(--vl-gold); opacity: 1; }
.vl-lang-sep { opacity: .35; color: var(--vl-cream); }

/* =========================================================================
   6. HERO
   ========================================================================= */
.vl-hero { position: relative; min-height: 100svh; display: grid; place-items: center; overflow: hidden; color: var(--vl-cream); text-align: center; }
.vl-hero__media, .vl-hero__media video, .vl-hero__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.vl-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(26,31,25,.45), rgba(26,31,25,.65)); z-index: 1; }
.vl-hero__inner { position: relative; z-index: 2; max-width: 60rem; padding-inline: var(--vl-gutter); }
.vl-hero h1 { color: var(--vl-cream); }
.vl-hero .vl-lead { color: rgba(240,229,215,.86); margin-block: 1.5rem 2.5rem; }

/* =========================================================================
   7. DOMAINES — grille (archive + galerie home) & fiche (single)
   ========================================================================= */
.vl-domaines-cat { margin-bottom: 1.5rem; }
.vl-domaines-cat__label { text-align: center; }
.vl-domaine-card { position: relative; display: block; overflow: hidden; background: var(--vl-green); color: var(--vl-cream); }
.vl-domaine-card__img { aspect-ratio: 4 / 5; overflow: hidden; }
.vl-domaine-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--vl-ease); }
.vl-domaine-card:hover .vl-domaine-card__img img { transform: scale(1.05); }
.vl-domaine-card__body { padding: 1.5rem 1.75rem 2rem; }
.vl-domaine-card__region { text-transform: uppercase; letter-spacing: .2em; font-size: .68rem; color: var(--vl-gold); }
.vl-domaine-card__name { font-family: var(--vl-font-display); font-size: 1.6rem; margin: .35rem 0 0; color: var(--vl-cream); }

.vl-domaine-single__hero { position: relative; min-height: 70svh; display: grid; align-items: end; color: var(--vl-cream); }
.vl-domaine-single__hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.vl-domaine-single__hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent, rgba(26,31,25,.8)); }
.vl-domaine-single__heading { position: relative; z-index: 2; padding: var(--vl-gutter); }
.vl-domaine-single__body { max-width: 46rem; }
.vl-domaine-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 1rem; }

/* =========================================================================
   8. FOOTER
   ========================================================================= */
.vl-footer { background: var(--vl-green-deep); color: rgba(240,229,215,.8); padding-block: clamp(3rem,6vw,5rem); }
.vl-footer a:hover { color: var(--vl-gold); }
.vl-footer__brand img { height: 64px; width: auto; margin-bottom: 1.25rem; }
.vl-footer__nav { display: flex; flex-wrap: wrap; gap: .35rem 1.25rem; text-transform: uppercase; letter-spacing: .12em; font-size: .78rem; }

/* =========================================================================
   9. UTILITAIRES
   ========================================================================= */
.vl-divider { width: 48px; height: 1px; background: var(--vl-gold); border: 0; margin: 1.5rem 0; }
.vl-text-center { text-align: center; }
.vl-mx-auto { margin-inline: auto; }
.vl-stat__num { font-family: var(--vl-font-display); font-size: clamp(2.6rem,5vw,4rem); color: var(--vl-gold); line-height: 1; }
.vl-pullquote { font-family: var(--vl-font-display); font-style: italic; font-size: clamp(1.5rem,2.6vw,2.4rem); line-height: 1.3; color: var(--vl-cream); }

/* Accessibilité : focus visible */
a:focus-visible, .vl-btn:focus-visible { outline: 2px solid var(--vl-gold); outline-offset: 3px; }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); }
