/*
Theme Name: Graine d’Artisans
Theme URI: https://example.com/
Author: OpenAI — design complet FR
Description: Thème WordPress premium pour portail d’artisans locaux : accueil éditorial, annuaire, fiches homogènes, WooCommerce et Dokan.
Version: 5.0.0
Requires at least: 6.4
Tested up to: 6.8
Requires PHP: 8.0
Text Domain: graine-artisans
Tags: custom-logo, featured-images, ecommerce, accessibility-ready
*/

:root {
  --ga-logo-header-height: 112px;
  --ga-logo-header-height-tablet: 92px;
  --ga-logo-header-height-mobile: 66px;
  --ga-blue: #2F3E4F;
  --ga-beige: #F2E9DC;
  --ga-red: #8C3B2E;
  --ga-green: #3A6B35;
  --ga-green-light: #6FAF5B;
  --ga-brown: #6B4F2C;
  --ga-cream: #FBF8F2;
  --ga-surface: #FFFFFF;
  --ga-text: #2F3E4F;
  --ga-muted: rgba(47, 62, 79, .78);
  --ga-border: #E6DAC8;
  --ga-shadow: 0 14px 32px rgba(55, 36, 20, .08);
  --ga-shadow-lg: 0 24px 60px rgba(55, 36, 20, .12);
  --ga-radius: 30px;
  --ga-radius-md: 24px;
  --ga-radius-sm: 18px;
  --ga-container: 1240px;
  --ga-header-height: 96px;
  --ga-font-heading: "Playfair Display", Georgia, serif;
  --ga-font-body: "Poppins", system-ui, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--ga-font-body);
  background:
    radial-gradient(circle at top left, rgba(58,107,53,.08), transparent 30%),
    radial-gradient(circle at top right, rgba(140,59,46,.08), transparent 25%),
    var(--ga-cream);
  color: var(--ga-text);
  line-height: 1.7;
  font-size: 16px;
}
img { display: block; max-width: 100%; height: auto; }
.hero-visual img,
.showcase-inner img,
.single-artisan-hero .cover img,
.card-media img,
.gallery-grid img,
.woocommerce ul.products li.product a img {
  width: 100%;
  height: 100%;
}
a { color: var(--ga-brown); text-decoration: none; transition: .2s ease; }
a:hover { color: var(--ga-red); }
button, input, textarea, select { font: inherit; }

h1,h2,h3,h4,h5,h6 {
  margin: 0 0 .75rem;
  font-family: var(--ga-font-heading);
  line-height: 1.14;
  letter-spacing: -.02em;
}
h1 { font-size: clamp(2.4rem, 4vw, 4.8rem); }
h2 { font-size: clamp(1.8rem, 3vw, 3.2rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.8rem); }

p { margin: 0 0 1rem; }

.container { width: min(calc(100% - 2rem), var(--ga-container)); margin-inline: auto; }
.screen-reader-text { position:absolute; left:-9999px; }
.screen-reader-text:focus {
  left:1rem; top:1rem; z-index:9999; background:#fff; padding:.75rem 1rem; border-radius:12px;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(251,248,242,.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ga-border);
}
.header-inner {
  min-height: var(--ga-header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.site-branding { min-width: 0; }
.brand-link {
  display: inline-flex;
  align-items: center;
  gap: .95rem;
  min-width: 0;
}
.brand-icon {
  width: auto;
  height: var(--ga-logo-header-height);
  max-width: 320px;
  object-fit: contain;
  object-position: left center;
  border-radius: 18px;
  background: transparent;
}
.site-branding .custom-logo-link img,
.site-branding .brand-link img {
  width: auto;
  height: var(--ga-logo-header-height);
  max-width: 320px;
  object-fit: contain;
  object-position: left center;
}
.header-inner .site-branding {
  flex: 0 1 auto;
}
.brand-text {
  min-width: 0;
}
.site-title {
  margin: 0;
  font-family: var(--ga-font-heading);
  font-size: clamp(1.35rem, 1.8vw, 2rem);
  color: var(--ga-brown);
  line-height: 1.05;
  text-wrap: balance;
}
.site-description {
  margin: .25rem 0 0;
  color: rgba(107,79,44,.78);
  font-size: 1.06rem;
}
.nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  padding: 0;
  border: 1px solid var(--ga-border);
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 8px 18px rgba(0,0,0,.05);
  color: var(--ga-brown);
  flex: 0 0 56px;
}
.nav-toggle-bars { display:grid; gap:5px; }
.nav-toggle-bar {
  display:block;
  width:22px;
  height:2px;
  border-radius:999px;
  background: currentColor;
  transition: transform .2s ease, opacity .2s ease;
}
.nav-toggle.is-open .nav-toggle-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open .nav-toggle-bar:nth-child(2) { opacity: 0; }
.nav-toggle.is-open .nav-toggle-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-toggle-label { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.primary-nav ul {
  list-style: none;
  display: flex;
  align-items: center;
  gap: .35rem;
  margin: 0;
  padding: 0;
}
.primary-nav a {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: .8rem 1rem;
  border-radius: 999px;
  color: var(--ga-text);
  font-weight: 600;
}
.primary-nav a:hover,
.primary-nav .current-menu-item > a,
.primary-nav .current_page_item > a {
  background: #fff;
  color: var(--ga-red);
  box-shadow: 0 6px 18px rgba(0,0,0,.05);
}
.primary-nav .menu-item-cta > a,
.header-cta {
  background: var(--ga-green);
  color: #fff !important;
  box-shadow: var(--ga-shadow);
}
.primary-nav .menu-item-cta > a:hover,
.header-cta:hover { background: #2f562c; }

.section { padding: 5rem 0; }
.section-sm { padding: 3rem 0; }
.section-white { background: #fff; border-block: 1px solid var(--ga-border); }
.section-dark { background: var(--ga-blue); color: #fff; }
.section-dark .eyebrow-alt, .section-dark h2, .section-dark p { color: inherit; }

.eyebrow, .eyebrow-alt {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  border-radius: 999px;
  padding: .5rem .9rem;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.eyebrow { background: #fff; color: var(--ga-red); border: 1px solid var(--ga-border); box-shadow: var(--ga-shadow); }
.eyebrow-alt { background: rgba(255,255,255,.12); color: var(--ga-beige); border: 1px solid rgba(255,255,255,.15); }

.muted { color: var(--ga-muted); }
.grid { display: grid; gap: 1rem; }
.grid.cols-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid.cols-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.grid.cols-4 { grid-template-columns: repeat(4, minmax(0,1fr)); }

.panel,
.card,
.artisan-card,
.value-card,
.info-card,
.search-panel,
.feature-card,
.stat-card {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(230, 218, 200, .9);
  border-radius: var(--ga-radius-md);
  box-shadow: 0 16px 34px rgba(55, 36, 20, .07);
}

/* Effet carte premium */
.panel,
.card,
.artisan-card,
.value-card,
.info-card,
.search-panel,
.feature-card,
.stat-card,
.hero-copy,
.hero-visual,
.showcase-panel,
.showcase-inner,
.cta-panel,
.widget {
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.panel:hover,
.card:hover,
.artisan-card:hover,
.value-card:hover,
.info-card:hover,
.feature-card:hover,
.stat-card:hover,
.widget:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 48px rgba(55, 36, 20, .11);
  border-color: rgba(214, 194, 170, .95);
}

.hero {
  position: relative;
  overflow: hidden;
  padding: 4.5rem 0 2rem;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 10%, rgba(58,107,53,.10), transparent 28%),
    radial-gradient(circle at 92% 18%, rgba(140,59,46,.12), transparent 24%);
  pointer-events: none;
}
.hero-grid {
  position: relative;
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
  align-items: center;
}
.hero-copy {
  padding: clamp(1.5rem, 3vw, 2.8rem);
  text-align: center;
}
.hero-copy h1 {
  font-size: clamp(1.95rem, 3vw, 3.3rem);
  max-width: 18ch;
  margin-inline: auto;
  text-align: center;
  line-height: 1.15;
  letter-spacing: -0.015em;
  text-wrap: balance;
}
.hero-copy .eyebrow { margin-inline: auto; }
.hero-copy p {
  font-size: clamp(1rem, 1.2vw, 1.12rem);
  max-width: 52ch;
  margin-inline: auto;
}
.hero-actions { display:flex; flex-wrap:wrap; gap:.9rem; margin-top: 2rem; justify-content:center; }
.button,
button,
input[type="submit"],
.wp-block-button__link,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  appearance: none;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: .95rem 1.3rem;
  border-radius: 999px;
  background: var(--ga-red);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  transition: .2s ease;
}
.button:hover,
button:hover,
input[type="submit"]:hover,
.wp-block-button__link:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover { transform: translateY(-1px); background: #77402d; color:#fff; }
.button.secondary {
  background: #fff;
  color: var(--ga-brown);
  border: 1px solid var(--ga-border);
}
.button.secondary:hover { background: var(--ga-beige); color: var(--ga-brown); }

.stats {
  display: grid;
  gap: 1.15rem;
  grid-template-columns: repeat(3, minmax(0,1fr));
  margin-top: 2rem;
  max-width: 760px;
  margin-inline: auto;
}
.stat-card { padding: 1.2rem; }
.stat-card strong {
  display:block;
  font-size: 1.7rem;
  color: var(--ga-green);
  line-height: 1;
}
.stat-card span { display:block; margin-top:.35rem; color: var(--ga-muted); font-size:.95rem; }

.hero-visual {
  overflow: hidden;
  padding: .85rem;
  background: var(--ga-cream);
}
.hero-visual,
.showcase-panel {
  align-self: start;
}
.hero-visual-frame {
  overflow: hidden;
  border-radius: calc(var(--ga-radius) - 6px);
  background: transparent;
  min-height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-visual img {
  width: 100%;
  height: 320px;
  object-fit: contain;
  object-position: center;
  background: transparent;
  padding: .15rem;
  mix-blend-mode: multiply;
}
.hero-visual-cards {
  display:grid;
  gap:1.15rem;
  grid-template-columns: repeat(2,minmax(0,1fr));
  padding: 1rem;
}
.mini-card {
  background: var(--ga-cream);
  border-radius: 20px;
  padding: 1rem;
}
.mini-card strong { display:block; margin-bottom: .4rem; color: var(--ga-brown); }

.ribbon-grid { display:grid; gap:1rem; grid-template-columns: repeat(4, minmax(0,1fr)); }
.ribbon-item {
  padding: 1rem 1.2rem;
  text-align: center;
  border-radius: 20px;
  background: var(--ga-cream);
  border: 1px solid var(--ga-border);
  font-weight: 700;
  color: var(--ga-brown);
  box-shadow: var(--ga-shadow);
}

.section-header {
  display:flex;
  gap:1.25rem;
  align-items:end;
  justify-content:space-between;
  margin-bottom: 1.5rem;
}
.filter-pills {
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
}
.filter-pills a,
.filter-pills button,
.chip {
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:.72rem 1rem;
  border:1px solid var(--ga-border);
  background:#fff;
  color: var(--ga-text);
  font-size:.92rem;
  font-weight:600;
}
.filter-pills a:hover,
.filter-pills button:hover,
.chip:hover { border-color: var(--ga-red); color: var(--ga-red); }

.artisan-card { overflow:hidden; display:flex; flex-direction:column; }
.card-media {
  display:block;
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, rgba(58,107,53,.12), rgba(140,59,46,.08));
  overflow: hidden;
  position: relative;
}
.card-media img { width:100%; height:100%; object-fit:cover; transition: transform .35s ease; }
.artisan-card:hover .card-media img { transform: scale(1.03); }
.card-overlay-label {
  position:absolute;
  left:1rem;
  top:1rem;
  display:inline-flex;
  padding:.45rem .75rem;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  color: var(--ga-brown);
  font-size:.75rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:700;
}
.card-sale-badge {
  position:absolute;
  top:1rem;
  right:1rem;
  display:inline-flex;
  padding:.45rem .75rem;
  border-radius:999px;
  color:#fff;
  font-size:.75rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:700;
  background: var(--ga-green);
}
.card-sale-badge.is-vitrine { background: var(--ga-red); }
.card-body { padding: 1.3rem; }
.card-title { color: var(--ga-brown); margin-bottom: .3rem; }
.card-meta { color: var(--ga-green); font-weight: 700; margin-bottom: .55rem; }
.card-actions { display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.2rem; }
.button.small { min-height: 42px; padding: .75rem 1rem; font-size: .92rem; }

.tags, .artisan-card-badges { display:flex; flex-wrap:wrap; gap:.45rem; margin-top: .85rem; }
.tag {
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:.35rem .7rem;
  background: rgba(58,107,53,.1);
  color: var(--ga-green);
  font-size:.8rem;
  font-weight:700;
}
.tag.is-sale { background: rgba(140,59,46,.12); color: var(--ga-red); }

.showcase-grid {
  display:grid;
  gap:2rem;
  grid-template-columns: minmax(320px,.95fr) minmax(0,1.05fr);
  align-items:center;
}
.showcase-panel { padding: 1.4rem; }
.showcase-inner {
  background: var(--ga-cream);
  border-radius: 26px;
  padding: .85rem;
}
.showcase-inner .cover {
  border-radius: 22px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background: var(--ga-cream);
  isolation: isolate;
}
.showcase-inner img {
  width:100%;
  height: 320px;
  object-fit:contain;
  object-position:center;
  background: transparent;
  padding:.15rem;
  mix-blend-mode:multiply;
}
.showcase-meta {
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
  margin-top:1rem;
}
.showcase-grid-list {
  display:grid;
  gap:1rem;
  grid-template-columns: repeat(2,minmax(0,1fr));
  margin-top:1rem;
}
.showcase-grid-list div {
  background:#fff;
  border-radius:18px;
  padding:.95rem 1rem;
  font-weight:600;
}

.feature-grid {
  display:grid;
  gap:1.25rem;
  grid-template-columns: repeat(2,minmax(0,1fr));
  margin-top: 1.4rem;
}
.feature-card { padding: 1.25rem; }
.feature-card h3 { margin-bottom:.4rem; color: var(--ga-brown); }
.feature-card p { margin:0; color: var(--ga-muted); }

.products .product,
.product-card {
  background:#fff;
  border:1px solid var(--ga-border);
  border-radius: var(--ga-radius-md);
  box-shadow: var(--ga-shadow);
  overflow:hidden;
}
.woocommerce ul.products {
  display:grid !important;
  gap:1rem;
  grid-template-columns: repeat(3,minmax(0,1fr));
  margin:0;
  padding:0;
}
.woocommerce ul.products li.product {
  width:auto !important;
  margin:0 !important;
  float:none !important;
  padding:0 0 1rem !important;
  border:1px solid var(--ga-border);
  border-radius: var(--ga-radius-md);
  background:#fff;
  box-shadow: var(--ga-shadow);
  overflow:hidden;
}
.woocommerce ul.products li.product a img {
  margin:0 0 .8rem !important;
  aspect-ratio: 4/3;
  object-fit: cover;
}
.woocommerce ul.products li.product .woocommerce-loop-category__title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3 {
  font-family: var(--ga-font-heading);
  color: var(--ga-brown);
  padding: 0 1rem;
}
.woocommerce ul.products li.product .price { padding: 0 1rem; color: var(--ga-green) !important; font-weight:700; }
.woocommerce ul.products li.product .button { margin-left:1rem !important; }

.single-artisan-hero {
  display:grid;
  gap:1.4rem;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
}
.single-artisan-hero .cover,
.single-artisan-hero .cover img {
  height:100%;
  min-height: 420px;
  border-radius: var(--ga-radius);
  object-fit: contain;
  background:#f8f4ec;
  padding:1rem;
}
.artisan-header-card { padding: clamp(1.5rem,3vw,2.4rem); }
.artisan-name { color: var(--ga-brown); }
.artisan-subtitle { color: var(--ga-green); font-weight:700; margin-bottom:.85rem; }
.contact-list {
  list-style:none;
  display:grid;
  gap:.55rem;
  margin: 1rem 0 0;
  padding:0;
}
.contact-list li { color: var(--ga-muted); }
.social-inline {
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  margin-top: 1rem;
}
.social-inline a {
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:.65rem .9rem;
  background:#fff;
  border:1px solid var(--ga-border);
  color: var(--ga-brown);
}
.social-inline a:hover { background: var(--ga-beige); }

.notice {
  padding: .95rem 1rem;
  border-radius: 16px;
  font-weight: 700;
  background: rgba(58,107,53,.12);
  color: var(--ga-green);
}
.notice.warning { background: rgba(140,59,46,.12); color: var(--ga-red); }

.content-wrap { padding: 2.5rem 0 3.5rem; }
.page-header { margin-bottom: 1.5rem; }
.page-title { color: var(--ga-brown); }

.search-panel {
  display:grid;
  gap:.9rem;
  grid-template-columns: 2fr 1fr auto;
  align-items:end;
  padding: 1rem;
}
.search-panel input,
.search-panel select,
.widget input,
.widget select,
.entry-content input:not([type=submit]),
.entry-content textarea,
.entry-content select,
.woocommerce input:not([type=submit]),
.woocommerce textarea,
.woocommerce select {
  width:100%;
  min-height:48px;
  padding:.85rem 1rem;
  border-radius:16px;
  border:1px solid var(--ga-border);
  background:#fff;
  color: var(--ga-text);
}
.entry-content textarea,
.woocommerce textarea { min-height: 140px; }

.grid.sidebar {
  grid-template-columns: minmax(0,1.5fr) minmax(280px,.8fr);
  align-items:start;
}
.content-card,
.info-card,
.panel,
.search-panel,
.widget { padding:1.25rem; }
.widget {
  border:1px solid var(--ga-border);
  border-radius: var(--ga-radius-sm);
  background:#fff;
  margin-bottom:1rem;
  box-shadow: var(--ga-shadow);
}
.widget-title { color: var(--ga-brown); }

.gallery-grid {
  display:grid;
  gap:.85rem;
  grid-template-columns: repeat(2,minmax(0,1fr));
}
.gallery-grid img {
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:20px;
}

.vendor-mini-grid {
  display:grid;
  gap:.8rem;
  grid-template-columns: repeat(2,minmax(0,1fr));
}
.vendor-mini-card {
  padding: 1rem;
  border-radius: 18px;
  background: var(--ga-cream);
}

.cta-panel {
  display:grid;
  gap:1rem;
  grid-template-columns: 1fr auto;
  align-items:center;
  background: linear-gradient(90deg, var(--ga-beige), #fff);
  border:1px solid var(--ga-border);
  border-radius: var(--ga-radius);
  box-shadow: var(--ga-shadow-lg);
  padding: 2rem;
}

.site-footer {
  margin-top: 2rem;
  background: #fff;
  border-top: 1px solid var(--ga-border);
}
.footer-grid {
  display:grid;
  gap:2rem;
  grid-template-columns: 1.3fr .7fr .7fr;
  padding: 3rem 0;
}
.footer-title { color: var(--ga-red); font-size: .85rem; text-transform: uppercase; letter-spacing: .16em; font-weight: 700; margin-bottom: 1rem; }
.footer-brand { color: var(--ga-brown); font-size: 2rem; }
.footer-links { display:grid; gap:.75rem; color: var(--ga-muted); }

.footer-legal-note {
  margin-top: 0;
  padding: 1rem 1.2rem;
  border: 1px solid var(--ga-border);
  border-radius: 20px;
  background: var(--ga-cream);
}
.footer-legal-note strong {
  display:block;
  margin-bottom: .45rem;
  color: var(--ga-brown);
  font-family: var(--ga-font-heading);
  font-size: 1.15rem;
}
.footer-legal-note p {
  margin:0;
  color: var(--ga-muted);
}

.post-navigation,
.posts-navigation,
.pagination,
nav.navigation.pagination { margin-top: 1.5rem; }
.nav-links { display:flex; flex-wrap:wrap; gap:.5rem; }
.nav-links .page-numbers {
  display:inline-flex; min-width:44px; min-height:44px; align-items:center; justify-content:center; padding:.6rem .9rem;
  border-radius:999px; background:#fff; border:1px solid var(--ga-border); color: var(--ga-text);
}
.nav-links .current { background: var(--ga-green); color:#fff; border-color: var(--ga-green); }


.hero-copy {
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(230, 218, 200, .92);
  border-radius: 32px;
  box-shadow: 0 18px 42px rgba(55, 36, 20, .06);
}

.hero-copy p {
  line-height: 1.85;
}

.hero-actions {
  gap: 1rem;
}

.stat-card {
  border-radius: 22px;
}

@media (max-width: 1100px) {
  .hero-grid,
  .showcase-grid,
  .single-artisan-hero,
  .grid.sidebar,
  .cta-panel { grid-template-columns: 1fr; }
  .ribbon-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .stats { grid-template-columns: 1fr; }
  .woocommerce ul.products { grid-template-columns: repeat(2,minmax(0,1fr)) !important; }
}
@media (max-width: 880px) {
  .header-inner {
    min-height: 88px;
    position: relative;
    display: grid;
    grid-template-columns: minmax(0,1fr) auto;
    align-items: center;
    gap: .75rem;
  }
  .site-branding {
    min-width: 0;
    width: 100%;
  }
  .brand-link {
    display: grid;
    grid-template-columns: auto minmax(0,1fr);
    align-items: center;
    gap: .75rem;
    max-width: 100%;
  }
  .brand-text {
    min-width: 0;
  }
  .site-title,
  .site-description {
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .site-title {
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    font-size: 1.35rem;
    line-height: 1.05;
  }
  .site-description {
    white-space: nowrap;
    font-size: .94rem;
  }
  .nav-toggle {
    display:inline-flex;
    justify-self: end;
  }
  .primary-nav {
    position:absolute;
    top: calc(100% + .5rem);
    right: 0;
    left: 0;
    display:none;
  }
  .primary-nav.is-open { display:block; }
  .primary-nav ul {
    flex-direction:column;
    align-items:stretch;
    gap:.35rem;
    background:#fff;
    border:1px solid var(--ga-border);
    box-shadow: var(--ga-shadow-lg);
    border-radius: 24px;
    padding:.7rem;
  }
  .primary-nav a { width:100%; justify-content:flex-start; border-radius:16px; }
  .section-header { flex-direction:column; align-items:flex-start; }
  .feature-grid,
  .showcase-grid-list,
  .grid.cols-3,
  .grid.cols-4,
  .footer-grid { grid-template-columns:1fr; }
  .search-panel { grid-template-columns: 1fr; }
  .hero-copy h1 { font-size: clamp(1.9rem, 5vw, 2.8rem); }
}
@media (max-width: 640px) {
  body { font-size: 15px; }
  .hero { padding-top: 3rem; }
  .hero-visual img { height: 280px; }
  .hero-visual-cards,
  .ribbon-grid,
  .grid.cols-2,
  .gallery-grid,
  .vendor-mini-grid,
  .woocommerce ul.products { grid-template-columns:1fr !important; }
  .card-actions,
  .hero-actions { flex-direction:column; align-items:stretch; }
  .button, button, input[type="submit"] { width:100%; }

  .header-inner {
    min-height: 82px;
    grid-template-columns: minmax(0,1fr) 52px;
  }
  .brand-link {
    gap: .6rem;
  }
  .brand-icon,
  .site-branding .custom-logo-link img,
  .site-branding .brand-link img {
    height: var(--ga-logo-header-height-mobile);
    max-width: 100px;
  }
  .brand-text {
    min-width: 0;
  }
  .site-title {
    font-size: 1rem;
    line-height: 1.05;
    margin: 0;
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .site-description { display: none; }
  .nav-toggle {
    width: 52px;
    height: calc(var(--ga-logo-header-height-mobile) - 6px);
    flex-basis: 52px;
  }

  .hero-copy { text-align: center; }
  .hero-copy h1 {
    font-size: clamp(1.75rem, 8vw, 2.4rem);
    max-width: 11ch;
  }
  .hero-copy p { max-width: 30ch; }
}



@media (max-width: 480px) {
  .container { width: min(calc(100% - 1rem), var(--ga-container)); }

  .header-inner {
    min-height: 76px;
    grid-template-columns: minmax(0,1fr) 48px;
    gap: .5rem;
  }
  .brand-link {
    gap: .5rem;
  }
  .brand-icon,
  .site-branding .custom-logo-link img,
  .site-branding .brand-link img {
    height: 52px;
    max-width: 86px;
  }
  .site-title {
    font-size: .92rem;
    line-height: 1.02;
    letter-spacing: -.01em;
  }
  .site-description { display: none; }
  .nav-toggle {
    width: 48px;
    height: 48px;
    border-radius: 16px;
  }

  .hero-copy {
    padding: 1.1rem;
  }
  .hero-copy h1 {
    font-size: clamp(1.6rem, 9vw, 2.1rem);
    max-width: 10ch;
  }
  .hero-copy p {
    max-width: 100%;
  }
}
/* ===== Footer premium ===== */
.footer-premium .footer-grid{
  grid-template-columns: 1.2fr .8fr .9fr .95fr;
  gap: 2rem;
  align-items: start;
}
.footer-brand-col .muted{
  max-width: 42ch;
}
.footer-links-premium{
  display: grid;
  gap: .7rem;
}
.footer-links-premium a,
.footer-contact-link{
  display:flex;
  align-items:center;
  gap:.7rem;
  padding:.8rem .9rem;
  border:1px solid var(--ga-border);
  border-radius:16px;
  background:rgba(255,255,255,.72);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.footer-links-premium a:hover,
.footer-contact-link:hover{
  transform:translateY(-1px);
  background:#fff;
  border-color:#d8c7af;
  box-shadow:0 12px 26px rgba(55,36,20,.08);
}
.footer-icon{
  width:1.4rem;
  min-width:1.4rem;
  text-align:center;
  font-size:1rem;
  opacity:.9;
}
.footer-quick-contact{
  min-width:0;
}
.footer-contact-card{
  padding:1rem;
  border:1px solid var(--ga-border);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(242,233,220,.72));
  box-shadow: var(--ga-shadow);
}
.footer-contact-card p{
  margin:0 0 .9rem;
  color:var(--ga-muted);
  line-height:1.7;
}
.footer-contact-actions{
  display:grid;
  gap:.75rem;
}
.footer-contact-link{
  font-weight:600;
  color:var(--ga-brown);
}
.footer-contact-link.is-alt{
  background:rgba(58,107,53,.08);
}
.footer-contact-link.is-alt:hover{
  background:rgba(58,107,53,.14);
}

/* ===== Mobile / tablette ===== */
@media (max-width: 1100px){
  .footer-premium .footer-grid{
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 768px){
  .footer-premium .footer-grid{
    grid-template-columns: 1fr;
    gap: 1.25rem;
    padding: 2rem 0;
  }
  .footer-title{
    margin-bottom:.75rem;
  }
  .footer-links-premium a,
  .footer-contact-link{
    padding:.78rem .85rem;
    border-radius:14px;
  }
  .footer-legal-note{
    padding:.9rem 1rem;
  }
}
@media (max-width: 480px){
  .footer-brand{
    font-size:1.65rem;
  }
  .footer-links-premium a,
  .footer-contact-link{
    font-size:.95rem;
  }
  .footer-icon{
    font-size:.95rem;
    width:1.25rem;
    min-width:1.25rem;
  }
}

/* ===== Icônes footer harmonisées avec le style du header ===== */
.footer-links-premium a .footer-icon,
.footer-contact-link .footer-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:2rem;
  min-width:2rem;
  height:2rem;
  border-radius:999px;
  background: linear-gradient(180deg, #fff, rgba(242,233,220,.92));
  border:1px solid var(--ga-border);
  box-shadow: 0 8px 18px rgba(55,36,20,.06);
  color: var(--ga-brown);
  font-size:.95rem;
  line-height:1;
}

.footer-links-premium a:hover .footer-icon,
.footer-contact-link:hover .footer-icon{
  background: linear-gradient(180deg, rgba(255,255,255,1), rgba(242,233,220,1));
  border-color:#d8c7af;
  color: var(--ga-red);
  box-shadow: 0 10px 22px rgba(55,36,20,.08);
}

.footer-contact-link.is-alt .footer-icon{
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(230,242,229,.96));
  color: var(--ga-green);
}

@media (max-width: 480px){
  .footer-links-premium a .footer-icon,
  .footer-contact-link .footer-icon{
    width:1.85rem;
    min-width:1.85rem;
    height:1.85rem;
    font-size:.88rem;
  }
}
