/* ============================================================
   DOMAINE.CSS — Domaines Expérimentaux
   Layout : station de terrain — hero panoramique,
   données techniques, cultures, équipements
   ============================================================ */

/* ── HERO DOMAINE ─────────────────────────────────────────── */
.domaine-hero {
  min-height: 460px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}

/* Fond photo (placeholder) */
.domaine-hero-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(13,27,42,.1) 0%,
    rgba(13,27,42,.7) 100%
  ),
  var(--domaine-bg, linear-gradient(135deg, #1a3a2a 0%, #0d1f15 100%));
}

.domaine-hero-bg img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .55;
}

/* Motif terrain agricole */
.domaine-hero-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    0deg,
    rgba(255,255,255,.015) 0,
    rgba(255,255,255,.015) 1px,
    transparent 1px,
    transparent 40px
  );
}

.domaine-hero-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--max);
  margin: 0 auto;
  padding: var(--s16) var(--s8) var(--s10);
}

.domaine-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  font-size: var(--t-xs);
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold-400);
  margin-bottom: var(--s4);
  padding: var(--s2) var(--s4);
  border: 1px solid rgba(201,168,76,.3);
  border-radius: 20px;
  background: rgba(201,168,76,.07);
}

.domaine-title {
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 700;
  color: var(--white);
  line-height: 1.1;
  letter-spacing: -.02em;
  margin-bottom: var(--s4);
}

.domaine-location {
  display: flex;
  align-items: center;
  gap: var(--s2);
  font-size: var(--t-md);
  font-weight: 400;
  color: rgba(255,255,255,.55);
  margin-bottom: var(--s8);
}

.domaine-location svg { color: var(--gold-400); flex-shrink: 0 }

/* Bande de stats au bas du hero */
.domaine-specs-bar {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: rgba(255,255,255,.12);
  border-radius: var(--r-sm);
  overflow: hidden;
}

.domaine-spec {
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(8px);
  padding: 16px 20px;
  text-align: center;
}

.domaine-spec-n {
  font-family: var(--serif);
  font-size: var(--t-xl);
  font-weight: 700;
  color: var(--white);
  display: block;
  line-height: 1;
  margin-bottom: 4px;
}

.domaine-spec-n sub {
  font-family: var(--sans);
  font-size: var(--t-xs);
  color: var(--gold-400);
  font-weight: 600;
  vertical-align: baseline;
}

.domaine-spec-l {
  font-size: var(--t-xs);
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
  display: block;
}

/* ── SECTION DESCRIPTION ──────────────────────────────────── */
.domaine-desc-section {
  background: var(--white);
  padding: var(--s12) 0;
  border-bottom: 1px solid var(--slate-200);
}

.domaine-desc-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--s12);
  align-items: start;
}

.domaine-desc-text {
  font-size: var(--t-base);
  color: var(--ink);
  line-height: 1.85;
}

.domaine-desc-text p { margin-bottom: var(--s5) }
.domaine-desc-text p:last-child { margin-bottom: 0 }
.domaine-desc-text strong { color: var(--ink); font-weight: 600 }

.domaine-info-card {
  background: var(--parchment);
  border: 1px solid var(--slate-200);
  border-radius: var(--r);
  overflow: hidden;
}

.domaine-info-card-head {
  background: var(--ink);
  padding: var(--s3) var(--s5);
  display: flex;
  align-items: center;
  gap: var(--s2);
}

.domaine-info-card-head::before {
  content: '';
  width: 3px;
  height: 14px;
  background: var(--gold-500);
  border-radius: 2px;
}

.domaine-info-card-head h3 {
  font-family: var(--sans);
  font-size: var(--t-xs);
  font-weight: 700;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: .12em;
}

.domaine-info-card-body {
  padding: var(--s4) var(--s5);
}

.domaine-info-row {
  display: flex;
  gap: var(--s3);
  padding: var(--s2) 0;
  border-bottom: 1px solid var(--slate-200);
  font-size: var(--t-sm);
  align-items: flex-start;
}

.domaine-info-row:last-child { border-bottom: none }

.domaine-info-key {
  font-weight: 700;
  color: var(--slate-700);
  flex-shrink: 0;
  min-width: 90px;
}

.domaine-info-val {
  color: var(--slate-500);
  line-height: 1.55;
}

/* ── CULTURES & ACTIVITÉS ─────────────────────────────────── */
.domaine-activities {
  background: var(--parchment);
  padding: var(--s12) 0;
  border-bottom: 1px solid var(--slate-200);
}

.domaine-act-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--slate-200);
  border-radius: var(--r);
  overflow: hidden;
  margin-top: var(--s8);
}

.domaine-act-cell {
  background: var(--white);
  padding: 28px 24px;
  text-align: justify;
  transition: background var(--dur) var(--ease);
}

.domaine-act-cell:hover { background: var(--green-50) }

.domaine-act-icon {
  font-size: 32px;
  display: block;
  margin-bottom: var(--s4);
}

.domaine-act-name {
  font-family: var(--serif);
  font-size: var(--t-md);
  font-weight: 600;
  color: var(--ink);
  margin-bottom: var(--s2);
  line-height: 1.3;
  text-align: left;
}

.domaine-act-desc {
  font-size: var(--t-sm);
  color: var(--slate-500);
  line-height: 1.55;
  margin: 0;
}

/* ── GALERIE / PAYSAGE ────────────────────────────────────── */
.domaine-gallery {
  background: var(--ink);
  padding: var(--s10) 0;
}

.domaine-gallery-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 200px 200px;
  gap: 3px;
  border-radius: var(--r);
  overflow: hidden;
}

.domaine-gallery-cell {
  background: #222;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.domaine-gallery-cell:first-child {
  grid-row: span 2;
}

.domaine-gallery-cell img {
  width: 100%;
  height: 90%;
  object-fit: cover;
  opacity: .65;
  transition: opacity var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease);
}

.domaine-gallery-cell:hover img {
  opacity: .85;
  transform: scale(1.04);
}

.domaine-gallery-placeholder {
    font-size: var(--t-xs);
    color: rgba(255, 255, 255, .25);
    text-align: center;
    padding: var(--s1);
    line-height: 1.55;
    height: 10%;
    display: flex;
    align-items: center;
}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 1024px) {
  .domaine-specs-bar   { grid-template-columns: repeat(3, 1fr) }
  .domaine-desc-grid   { grid-template-columns: 1fr }
  .domaine-act-grid    { grid-template-columns: repeat(2, 1fr) }
  .domaine-gallery-grid { grid-template-columns: 1fr 1fr }
}

@media (max-width: 768px) {
  .domaine-title      { font-size: 28px }
  .domaine-specs-bar  { grid-template-columns: repeat(2, 1fr) }
  .domaine-act-grid   { grid-template-columns: 1fr 1fr }
  .domaine-gallery-grid { grid-template-columns: 1fr }
}
