/* ──────────────────────────────────────────────────────────────────────
   ECOSERRE · STYLES GLOBAUX DU SITE
   Surcharge GeneratePress avec le design system de marque.
   Mobile-first. Tout composant ne consomme que les tokens.
   ────────────────────────────────────────────────────────────────────── */

/* ── POLICES SELF-HOSTED ─────────────────────────────────────────────── */
@font-face {
  font-family: "Fraunces";
  src: url("../fonts/fraunces-variable.woff2") format("woff2-variations");
  font-weight: 400 700;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Inter";
  src: url("../fonts/inter-variable.woff2") format("woff2-variations");
  font-weight: 400 700;
  font-display: swap;
  font-style: normal;
}

/* ── BASE ────────────────────────────────────────────────────────────── */
body {
  background: var(--color-cream);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

@media (min-width: 1024px) {
  body { font-size: var(--fs-body-lg); }
}

h1, h2, h3, .entry-title, .page-title {
  font-family: var(--font-display);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-snug);
  color: var(--color-ink);
}
h1, .entry-title { font-size: var(--fs-h1); line-height: var(--lh-tight); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); font-family: var(--font-body); }

@media (min-width: 1024px) {
  h1, .entry-title { font-size: 3rem; }
  h2 { font-size: 2.25rem; }
  h3 { font-size: 1.75rem; }
}

a { color: var(--color-forest-900); text-underline-offset: 3px; }
a:hover { color: var(--color-forest-700); }

img { max-width: 100%; height: auto; }

::selection { background: var(--color-forest-200); color: var(--color-forest-900); }

.site-content,
.inside-article { background: transparent; }

/* Conteneur centre */
.ecoserre-container,
.grid-container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter-mobile);
}
@media (min-width: 640px)  { .ecoserre-container, .grid-container { padding-inline: var(--gutter-tablet); } }
@media (min-width: 1024px) { .ecoserre-container, .grid-container { padding-inline: var(--gutter-desktop); } }

/* ── ACCESSIBILITE ───────────────────────────────────────────────────── */
:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline: var(--border-w-strong) solid var(--color-forest-900);
  outline-offset: 2px;
  border-radius: var(--radius-xs);
}
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 1000;
  background: var(--color-forest-900);
  color: var(--color-cream);
  padding: var(--space-3) var(--space-5);
  border-radius: 0 0 var(--radius-md) 0;
}
.skip-link:focus { left: 0; color: var(--color-cream); }

.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

/* ── BOUTONS ─────────────────────────────────────────────────────────── */
.btn,
.wp-block-button__link,
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: var(--tap-min);
  padding: 0 var(--space-5);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: var(--fw-semi);
  line-height: 1;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}
.btn:active { transform: translateY(1px); }
.btn .ec-icon { width: 18px; height: 18px; flex: 0 0 auto; }

.btn-primary,
.button.alt,
.wp-block-button__link {
  background: var(--color-forest-900);
  color: var(--color-cream);
}
.btn-primary:hover,
.button.alt:hover,
.wp-block-button__link:hover {
  background: var(--color-forest-700);
  color: var(--color-cream);
}

.btn-secondary {
  background: var(--color-clay-500);
  color: var(--color-white);
}
.btn-secondary:hover { background: var(--color-clay-600); color: var(--color-white); }

.btn-outline {
  background: transparent;
  color: var(--color-forest-900);
  border-color: var(--color-forest-900);
}
.btn-outline:hover { background: var(--color-forest-50); color: var(--color-forest-900); }

.btn-ghost { background: transparent; color: var(--color-forest-900); }
.btn-ghost:hover { background: var(--color-forest-50); }

.btn-sm { min-height: 36px; padding: 0 var(--space-4); font-size: var(--fs-small); }
.btn-lg { min-height: 52px; padding: 0 var(--space-6); font-size: var(--fs-body-lg); }
.btn-block { width: 100%; }

.btn[disabled], .btn[aria-disabled="true"] {
  opacity: 0.45; cursor: not-allowed; pointer-events: none;
}

/* ── HEADER ──────────────────────────────────────────────────────────── */
.site-header {
  background: var(--color-white);
  border-bottom: var(--border-default);
}
.main-navigation,
.main-navigation .menu {
  background: var(--color-white);
}
.main-navigation .main-nav ul li a {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: var(--fs-small);
  color: var(--color-ink-700);
}
.main-navigation .main-nav ul li a:hover,
.main-navigation .main-nav ul li.current-menu-item > a {
  color: var(--color-forest-900);
}
.site-logo img,
.site-header .header-image { max-height: 48px; width: auto; }

.ecoserre-header-cta {
  margin-left: var(--space-4);
}

/* ── HERO HOMEPAGE ───────────────────────────────────────────────────── */
.ec-hero {
  display: grid;
  gap: var(--space-6);
  padding-block: var(--space-10);
}
.ec-hero__media {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--color-forest-50);
}
.ec-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.ec-hero__text { display: flex; flex-direction: column; gap: var(--space-5); }
.ec-hero__title {
  font-size: var(--fs-display);
  line-height: var(--lh-tight);
  text-wrap: balance;
}
.ec-hero__lede {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-ink-700);
  max-width: 52ch;
}
.ec-hero__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }

@media (min-width: 1024px) {
  .ec-hero {
    grid-template-columns: 4fr 5fr;
    align-items: center;
    gap: var(--space-12);
    padding-block: var(--space-16);
  }
  .ec-hero__media { aspect-ratio: 5 / 4; }
  .ec-hero__title { font-size: clamp(2.5rem, 4vw, 3.5rem); }
}

.eyebrow {
  display: inline-block;
  font-size: var(--fs-micro);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-clay-600);
}

/* ── SECTIONS ────────────────────────────────────────────────────────── */
.ec-section { padding-block: var(--space-16); }
.ec-section--tint { background: var(--color-forest-50); }
.ec-section--dark { background: var(--color-forest-900); color: var(--color-cream); }
.ec-section--dark h2, .ec-section--dark h3 { color: var(--color-cream); }
.ec-section__head { margin-bottom: var(--space-8); max-width: 60ch; }
.ec-section__head p { color: var(--color-ink-700); }

/* ── TRUST BAR ───────────────────────────────────────────────────────── */
.trust-bar {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-5);
  background: var(--color-cream);
  border-top: var(--border-default);
  border-bottom: var(--border-default);
  padding: var(--space-6) var(--gutter-mobile);
}
@media (min-width: 1024px) {
  .trust-bar {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: var(--space-6) var(--gutter-desktop);
  }
}
.trust-item { display: flex; gap: var(--space-3); align-items: flex-start; }
.trust-item .icon-wrap {
  width: 36px; height: 36px; flex: 0 0 auto;
  display: grid; place-items: center;
  background: var(--color-forest-900);
  color: var(--color-cream);
  border-radius: var(--radius-sm);
}
.trust-item-text { font-size: var(--fs-small); line-height: 1.4; }
.trust-item-text strong { display: block; color: var(--color-ink); font-weight: var(--fw-semi); }
.trust-item-text span { color: var(--color-mute); }

/* ── TRUST BLOCK (vertical) ──────────────────────────────────────────── */
.trust-block {
  display: flex; flex-direction: column; gap: var(--space-3);
  border: var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  background: var(--color-white);
}
.trust-line {
  display: flex; gap: var(--space-3); align-items: flex-start;
  font-size: var(--fs-small); line-height: 1.45;
  text-decoration: none; color: inherit;
}
.trust-line .icon-wrap {
  width: 32px; height: 32px; flex: 0 0 auto;
  display: grid; place-items: center;
  background: var(--color-forest-50);
  color: var(--color-forest-900);
  border-radius: var(--radius-sm);
}
.trust-line strong { display: block; color: var(--color-ink); }
.trust-line .muted { color: var(--color-mute); }
.trust-line--link:hover .icon-wrap { background: var(--color-forest-200); }

/* ── BANDEAU FEADER ──────────────────────────────────────────────────── */
.feader-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  background: var(--color-sand-100);
  border: 1px solid var(--color-sand-500);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
}
.feader-banner__icon {
  display: grid; place-items: center;
  width: 44px; height: 44px; flex: 0 0 auto;
  background: var(--color-forest-900);
  color: var(--color-sand-500);
  border-radius: var(--radius-md);
}
.feader-banner__text {
  flex: 1 1 260px;
  margin: 0;
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  color: #6A4A1A;
}

/* ── CARTES CATEGORIES ───────────────────────────────────────────────── */
.ec-cat-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .ec-cat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ec-cat-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1024px) { .ec-cat-grid--3 { grid-template-columns: repeat(3, 1fr); } }
.ec-cat-card {
  display: flex; flex-direction: column;
  background: var(--color-white);
  border: var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-ink);
  transition: box-shadow var(--duration-base) var(--ease-out),
              transform var(--duration-base) var(--ease-out);
}
.ec-cat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.ec-cat-card__media { aspect-ratio: 4 / 3; background: var(--color-forest-50); overflow: hidden; }
.ec-cat-card__media img { width: 100%; height: 100%; object-fit: cover; }
.ec-cat-card__body { padding: var(--space-4) var(--space-5); }
.ec-cat-card__title { font-family: var(--font-display); font-size: var(--fs-h4); font-weight: var(--fw-semi); }
.ec-cat-card__count { font-size: var(--fs-caption); color: var(--color-mute); }

/* ── POURQUOI ECOSERRE ───────────────────────────────────────────────── */
.ec-reasons {
  display: grid; gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .ec-reasons { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ec-reasons { grid-template-columns: repeat(4, 1fr); } }
.ec-reason__icon {
  display: grid; place-items: center;
  width: 48px; height: 48px;
  background: var(--color-forest-50);
  color: var(--color-forest-900);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
}
.ec-reason h3 { font-size: var(--fs-h4); font-family: var(--font-body); margin-bottom: var(--space-2); }
.ec-reason p { color: var(--color-ink-700); font-size: var(--fs-small); }

/* ── TEMOIGNAGES ─────────────────────────────────────────────────────── */
.ec-testimonials { display: grid; gap: var(--space-5); grid-template-columns: 1fr; }
@media (min-width: 768px) { .ec-testimonials { grid-template-columns: repeat(3, 1fr); } }
.ec-testimonial {
  background: var(--color-white);
  border: var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.ec-testimonial blockquote { margin: 0 0 var(--space-4); font-size: var(--fs-body); line-height: var(--lh-relaxed); }
.ec-testimonial__author { display: flex; align-items: center; gap: var(--space-3); }
.ec-testimonial__avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--color-forest-200); object-fit: cover;
}
.ec-testimonial__name { font-weight: var(--fw-semi); font-size: var(--fs-small); }
.ec-testimonial__farm { font-size: var(--fs-caption); color: var(--color-mute); }

/* ── BADGES ──────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-micro);
  font-weight: var(--fw-semi);
  line-height: 1;
}
.badge-promo    { background: var(--color-clay-500); color: #fff; }
.badge-photov   { background: var(--color-sand-100); color: #6A4A1A; border: 1px solid var(--color-sand-500); }
.badge-occasion { background: var(--color-line); color: var(--color-ink); }
.badge-stock    { background: var(--color-success-bg); color: var(--color-success); }
.badge-rupture  { background: var(--color-danger-bg); color: var(--color-danger); }
.badge-feader   { background: var(--color-forest-900); color: var(--color-sand-500); }

/* ── FORMULAIRES ─────────────────────────────────────────────────────── */
.ec-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--space-4); }
.ec-field label {
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-ink);
}
.ec-field .req { color: var(--color-clay-600); margin-left: 2px; }
.ec-field-help { font-size: var(--fs-caption); color: var(--color-mute); }
.ec-field-error {
  font-size: var(--fs-caption);
  color: var(--color-danger);
  display: flex; gap: 6px; align-items: center;
}

.ec-input, .ec-select, .ec-textarea,
input[type="text"], input[type="email"], input[type="tel"],
input[type="number"], input[type="search"], textarea, select {
  width: 100%;
  min-height: var(--tap-min);
  padding: 0 var(--space-4);
  background: var(--color-white);
  border: 1px solid var(--color-line-strong);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--color-ink);
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}
textarea, .ec-textarea {
  padding: var(--space-3) var(--space-4);
  min-height: 110px;
  resize: vertical;
  line-height: var(--lh-normal);
}
input:hover, select:hover, textarea:hover { border-color: var(--color-forest-700); }
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--color-forest-900);
  box-shadow: var(--shadow-focus);
}
[aria-invalid="true"] { border-color: var(--color-danger) !important; }

/* ── ETAPES (form devis multi-step) ──────────────────────────────────── */
.ec-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}
.ec-step {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  border: var(--border-default);
}
.ec-step__num {
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
  font-size: var(--fs-caption); font-weight: var(--fw-semi);
  background: var(--color-cream); color: var(--color-mute);
  border: var(--border-strong);
  flex: 0 0 auto;
}
.ec-step__label { font-size: var(--fs-caption); font-weight: var(--fw-medium); color: var(--color-ink-700); }
.ec-step.is-active { background: var(--color-forest-50); border-color: var(--color-forest-900); }
.ec-step.is-active .ec-step__num { background: var(--color-forest-900); color: var(--color-cream); border-color: var(--color-forest-900); }
.ec-step.is-done .ec-step__num { background: var(--color-success); color: #fff; border-color: var(--color-success); }
.ec-quote-step[hidden] { display: none; }
.ec-quote-nav { display: flex; justify-content: space-between; gap: var(--space-3); margin-top: var(--space-6); }

/* ── GUIDE ───────────────────────────────────────────────────────────── */
.ec-guide-grid { display: grid; gap: var(--space-6); grid-template-columns: 1fr; }
@media (min-width: 640px)  { .ec-guide-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ec-guide-grid { grid-template-columns: repeat(3, 1fr); } }
.ec-guide-card {
  background: var(--color-white);
  border: var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: box-shadow var(--duration-base) var(--ease-out);
}
.ec-guide-card:hover { box-shadow: var(--shadow-md); }
.ec-guide-card__media { aspect-ratio: 16 / 10; background: var(--color-forest-50); overflow: hidden; }
.ec-guide-card__media img { width: 100%; height: 100%; object-fit: cover; }
.ec-guide-card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-2); flex: 1; }
.ec-guide-card__cat {
  font-size: var(--fs-micro); font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-eyebrow); text-transform: uppercase;
  color: var(--color-clay-600);
}
.ec-guide-card__title { font-family: var(--font-display); font-size: var(--fs-h4); font-weight: var(--fw-semi); }
.ec-guide-card__title a { text-decoration: none; color: var(--color-ink); }
.ec-guide-card__excerpt { font-size: var(--fs-small); color: var(--color-ink-700); }

.ec-guide-single { max-width: var(--container-narrow); margin-inline: auto; }
.ec-guide-single .entry-content { font-size: var(--fs-body-lg); line-height: var(--lh-relaxed); }
.ec-guide-single .entry-content > * + * { margin-top: var(--space-5); }

/* ── FIL D'ARIANE ────────────────────────────────────────────────────── */
.ec-breadcrumb {
  font-size: var(--fs-caption);
  color: var(--color-mute);
  padding-block: var(--space-4);
}
.ec-breadcrumb a { color: var(--color-mute); text-decoration: none; }
.ec-breadcrumb a:hover { color: var(--color-forest-900); }
.ec-breadcrumb [aria-current="page"] { color: var(--color-ink); }
.ec-breadcrumb .sep { margin-inline: var(--space-2); color: var(--color-line-strong); }

/* ── FOOTER ──────────────────────────────────────────────────────────── */
.site-footer,
.ec-footer {
  background: var(--color-forest-900);
  color: var(--color-cream);
}
.ec-footer { padding-block: var(--space-16) var(--space-6); }
.ec-footer a { color: var(--color-cream); opacity: 0.85; text-decoration: none; }
.ec-footer a:hover { opacity: 1; text-decoration: underline; }
.ec-footer__grid {
  display: grid; gap: var(--space-8);
  grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .ec-footer__grid { grid-template-columns: 2fr 1fr 1fr; } }
.ec-footer h2, .ec-footer h3, .ec-footer__col-title {
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-sand-500);
  margin-bottom: var(--space-3);
}
.ec-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.ec-footer__tagline { font-size: var(--fs-small); opacity: 0.85; max-width: 38ch; }
.ec-footer__legal {
  margin-top: var(--space-8);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(250,250,247,0.15);
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-4);
  font-size: var(--fs-caption); opacity: 0.7;
}

/* ── NEWSLETTER ──────────────────────────────────────────────────────── */
.ec-newsletter { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.ec-newsletter input { flex: 1 1 200px; }

/* ── UTILITAIRES ─────────────────────────────────────────────────────── */
.ec-flow > * + * { margin-top: var(--space-4); }
.ec-flow-lg > * + * { margin-top: var(--space-8); }
.text-center { text-align: center; }
.ec-callout {
  background: var(--color-forest-50);
  border-left: 3px solid var(--color-forest-900);
  padding: var(--space-4) var(--space-5);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.ec-notice { padding: var(--space-4) var(--space-5); border-radius: var(--radius-md); font-size: var(--fs-small); }
.ec-notice--success { background: var(--color-success-bg); color: var(--color-success); }
.ec-notice--error   { background: var(--color-danger-bg);  color: var(--color-danger); }

/* ── BOUTON CTA DANS LE MENU ──────────────────────────────────────────── */
.main-navigation .main-nav ul li.ec-nav-cta { display: flex; align-items: center; }
.main-navigation .main-nav ul li.ec-nav-cta > a {
  margin: 6px var(--space-2);
  padding: 0 var(--space-4) !important;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  background: var(--color-clay-500);
  color: var(--color-white) !important;
  border-radius: var(--radius-md);
  font-weight: var(--fw-semi);
  line-height: 1;
}
.main-navigation .main-nav ul li.ec-nav-cta > a:hover {
  background: var(--color-clay-600);
  color: var(--color-white) !important;
}

/* ── FOOTER — complements ─────────────────────────────────────────────── */
.ec-footer__logo {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: var(--fw-semi);
  color: var(--color-cream);
  margin: 0 0 var(--space-3);
}
.ec-footer__legal-entity,
.ec-footer__contact {
  font-size: var(--fs-small);
  opacity: 0.85;
  margin: var(--space-3) 0 0;
}
.ec-footer__menu,
.ec-footer__legal-menu {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ec-footer__menu { display: flex; flex-direction: column; gap: var(--space-2); }
.ec-footer__legal-menu { display: flex; flex-wrap: wrap; gap: var(--space-4); }
.ec-footer__legal-menu a,
.ec-footer__menu a { font-size: var(--fs-small); }
.ec-footer__legal { align-items: center; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
