/*
Theme Name:  Clos Galant
Theme URI:   https://clos-galant.com
Author:      Clos Galant
Description: Thème sur mesure multi-pages — Domaine viticole Clos Galant, Aubussargues, Gard.
Version:     2.1.0
License:     GNU General Public License v2 or later
Text Domain: clos-galant
*/

/* ════════════════════════════════════════════════
   0. RESET & VARIABLES
════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --noir:           #1a1a1a;
  --bordeaux:       #6B1F2A;
  --bordeaux-light: #8B3540;
  --or:             #B8973A;
  --or-light:       #D4AF55;
  --ivoire:         #F5F2ED;
  --lin:            #E8E3DA;
  --vert:           #2C4A3E;
  --blanc:          #FFFFFF;
  --gris:           #555; /* v14 : ratio contraste WCAG AA ~4.8:1 sur fond lin */
  --transition:     cubic-bezier(0.4, 0, 0.2, 1);
}

html { scroll-behavior: smooth; }
body { font-family: 'Lato', sans-serif; background: #FDFAF4; color: var(--noir); overflow-x: hidden; cursor: none; }
/* Accessibilité : cursor:none seulement sur body, pointer sur les éléments interactifs */
a, button, [role="button"], input, select, textarea, label, [tabindex] { cursor: pointer; }
/* v14 : curseur désactivé sur touch ET sur tablet (pointer:fine sans hover = trackpad tablette) */
@media (pointer: coarse) { body { cursor: auto; } .cursor { display: none !important; } a, button, [role="button"], input, select, textarea, label, [tabindex] { cursor: auto; } }
@media (pointer: fine) and (max-width: 1024px) { body { cursor: auto; } .cursor { display: none !important; } a, button, [role="button"], input, select, textarea, label, [tabindex] { cursor: auto; } }

/* v14 : utilitaire accessibilité — masqué visuellement, lisible par lecteurs d'écran */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
@media (max-height: 500px) and (orientation: landscape) {
  #hero { min-height: 100svh; height: 100svh; }
  .hero-title { font-size: 36px; }
  .hero-content { padding: 20px; }
}

/* 1. CURSEUR */
.cursor { width: 7px; height: 7px; background: var(--or); border-radius: 50%; position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); transition: transform .15s var(--transition), background .2s; }
.cursor.hover { transform: translate(-50%,-50%) scale(1.8); background: var(--bordeaux); }

/* 2. HEADER */
header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 0 60px; display: flex; align-items: center; justify-content: space-between; height: 80px; transition: background .5s var(--transition), height .4s, box-shadow .4s; }
body.page-interieure header { background: rgba(253,250,244,.97); height: 64px; box-shadow: 0 2px 20px rgba(0,0,0,.08); backdrop-filter: blur(10px); }
header.scrolled { background: rgba(253,250,244,.97); height: 64px; box-shadow: 0 2px 20px rgba(0,0,0,.08); backdrop-filter: blur(10px); }
.logo-wrap { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.logo-wrap img { height: 44px; width: 44px; object-fit: contain; transition: opacity .3s, filter .4s; filter: brightness(0) invert(1); }
.logo-wrap:hover img { opacity: .8; }
.logo-name { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 400; letter-spacing: 4px; text-transform: uppercase; color: #ffffff; transition: color .4s var(--transition), max-width .4s var(--transition); white-space: nowrap; overflow: hidden; max-width: 200px; }
header.scrolled .logo-wrap img, body.page-interieure header .logo-wrap img { filter: none; }
header.scrolled .logo-name, body.page-interieure header .logo-name { color: #1a1a1a !important; }
nav { display: flex; align-items: center; gap: 36px; }
nav a { font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 500; color: rgba(255,255,255,.92); text-decoration: none; letter-spacing: 2px; text-transform: uppercase; transition: color .3s; position: relative; }
nav a::after { content: ''; position: absolute; bottom: -4px; left: 0; right: 0; height: 1px; background: var(--or); transform: scaleX(0); transform-origin: left; transition: transform .3s var(--transition); }
nav a:hover { color: var(--or); }
nav a:hover::after { transform: scaleX(1); }
header.scrolled nav a, body.page-interieure header nav a { color: rgba(26,26,26,.75); }
header.scrolled nav a:hover, body.page-interieure header nav a:hover { color: var(--bordeaux); }
header.scrolled .hamburger span, body.page-interieure header .hamburger span { background: var(--noir); }
.nav-cta { font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 500; color: var(--noir) !important; background: var(--or); padding: 10px 22px; letter-spacing: 2px; text-transform: uppercase; text-decoration: none; transition: background .3s, transform .2s !important; clip-path: polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%); }
.nav-cta:hover { background: var(--or-light) !important; transform: translateY(-1px); }
.nav-cta::after { display: none !important; }
nav a.current { color: var(--or) !important; }
nav a.current::after { transform: scaleX(1); }
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 8px; }
.hamburger span { width: 26px; height: 1.5px; background: #fff; transition: all .3s; }
.mobile-menu { display: none; position: fixed; inset: 0; background: var(--noir); z-index: 999; flex-direction: column; align-items: center; justify-content: center; gap: 40px; opacity: 0; pointer-events: none; transition: opacity .4s; }
.mobile-menu.open { opacity: 1; pointer-events: all; display: flex; }
.mobile-menu a { font-family: 'Cormorant Garamond', serif; font-size: 42px; font-weight: 300; color: var(--blanc); text-decoration: none; letter-spacing: 2px; transition: color .3s; }
.mobile-menu a:hover { color: var(--or); }

/* 3. COMPOSANTS COMMUNS */
.section-eyebrow { font-family: 'Montserrat', sans-serif; font-size: 10px; font-weight: 500; letter-spacing: 5px; color: #7B3040; text-transform: uppercase; margin-bottom: 16px; }
.section-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px,5vw,60px); font-weight: 300; line-height: 1.05; margin-bottom: 24px; }
.section-body { font-family: 'Lato', sans-serif; font-size: 17px; line-height: 1.8; font-weight: 300; color: #5a4a3a; max-width: 580px; }
.reveal { opacity: 0; transform: translateY(40px); transition: opacity .8s var(--transition), transform .8s var(--transition); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }
.btn-primary { font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--noir); background: var(--or); padding: 16px 40px; text-decoration: none; transition: background .3s, transform .2s; clip-path: polygon(12px 0%,100% 0%,calc(100% - 12px) 100%,0% 100%); display: inline-block; }
.btn-primary:hover { background: var(--or-light); transform: translateY(-2px); }
.btn-outline { font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--blanc); border: 1px solid rgba(255,255,255,.4); padding: 16px 40px; text-decoration: none; transition: border-color .3s, color .3s, transform .2s; backdrop-filter: blur(4px); display: inline-block; }
.btn-outline:hover { border-color: var(--or); color: var(--or); transform: translateY(-2px); }
.btn-bordeaux { font-family: 'Montserrat', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--bordeaux); border: 1px solid var(--bordeaux); padding: 14px 32px; text-decoration: none; transition: background .3s, color .3s; display: inline-block; }
.btn-bordeaux:hover { background: var(--bordeaux); color: var(--blanc); }

/* 4. PAGE HERO */
/* v14 : fond par défaut remplacé par couleur neutre — l'image spécifique est en style inline sur chaque page */
.page-hero { background: linear-gradient(160deg,rgba(107,31,42,.7) 0%,rgba(26,26,26,.9) 100%) var(--bordeaux) center/cover no-repeat; padding: 160px 60px 80px; text-align: center; position: relative; }
.page-hero-eyebrow { font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 5px; color: var(--or); text-transform: uppercase; margin-bottom: 16px; }
.page-hero-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(48px,7vw,90px); font-weight: 300; color: var(--blanc); line-height: 1; }
.page-hero-title em { font-style: italic; color: var(--or); }
.page-hero-sub { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 300; font-style: italic; color: rgba(255,255,255,.88); margin-top: 16px; }


/* 6. ACCESSIBILITÉ */
.skip-link { position: absolute; top: -100px; left: 16px; z-index: 9999; background: var(--bordeaux); color: #fff; padding: 10px 20px; font-family: 'Montserrat', sans-serif; font-size: 12px; letter-spacing: 1px; text-decoration: none; transition: top .2s; }
.skip-link:focus { top: 16px; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible { outline: 2px solid var(--or); outline-offset: 3px; border-radius: 2px; }
.nav-cta:focus-visible { outline: 2px solid var(--or); outline-offset: 3px; }


/* 7. FOOTER */
footer { background: #2a0a0e; padding: 60px 60px 40px; }
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 60px; max-width: 1300px; margin: 0 auto; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.07); }
.footer-logo { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 600; color: var(--blanc); letter-spacing: 4px; text-transform: uppercase; display: block; margin-bottom: 8px; }
.footer-tagline { font-family: 'Montserrat', sans-serif; font-size: 9px; letter-spacing: 3px; color: var(--or); text-transform: uppercase; margin-bottom: 20px; }
.footer-desc { font-family: 'Lato', sans-serif; font-size: 14px; line-height: 1.7; color: rgba(255,255,255,.80); font-weight: 300; margin-bottom: 24px; }
.footer-col-title { font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 3px; color: rgba(255,255,255,.70); text-transform: uppercase; margin-bottom: 20px; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-links a { font-family: 'Lato', sans-serif; font-size: 14px; color: rgba(255,255,255,.75); text-decoration: none; transition: color .3s; font-weight: 300; }
.footer-links a:hover { color: var(--or); }
.footer-bottom { max-width: 1300px; margin: 32px auto 0; display: flex; justify-content: space-between; align-items: center; }
/* v28 : contraste amélioré — Lighthouse exige ratio ≥ 4.5:1 sur fond #1a1a1a */
.footer-copy { font-family: 'Lato', sans-serif; font-size: 12px; color: rgba(255,255,255,.65); }
.footer-hve { display: flex; align-items: center; gap: 8px; font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 2px; color: rgba(255,255,255,.65); text-transform: uppercase; }
/* v14 : badge HVE utilise la couleur --vert du domaine */
.hve-badge-mini { width: 10px; height: 10px; background: var(--vert); border-radius: 50%; box-shadow: 0 0 0 2px rgba(44,74,62,.3); }
.footer-hve { color: rgba(255,255,255,.7); }
.footer-hve span { color: #7EC8A4; }

/* 8. RESPONSIVE GLOBAL */
@media (max-width: 1024px) {
  header { padding: 0 30px; }
  nav { display: none; }
  .hamburger { display: flex; }
  .page-hero { padding: 140px 30px 60px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 640px) {
  header { padding: 0 20px; }
  footer { padding: 40px 20px 30px; }
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; gap: 16px; text-align: center; }
}

/* v29 : Image LCP helper — invisible mais découverte par le navigateur dès le HTML */
.lcp-img-hint {
  position: absolute;
  width: 1px;
  height: 1px;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
  z-index: -1;
}
