/* ============================================================
   NOUGAT DE MONTÉLIMAR — Design System
   Palette : miel, caramel, amande, lavande, crème
   Typo : Playfair Display + Mulish
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Mulish:wght@300;400;500;600&display=swap');

:root {
  --miel:          #C8860A;
  --miel-light:    #E8A820;
  --miel-pale:     #F5D98A;
  --amande:        #A07850;
  --amande-pale:   #E8D5BC;
  --creme:         #FDF8F0;
  --blanc:         #FFFCF7;
  --caramel:       #8B5E2E;
  --caramel-dark:  #5C3A14;
  --lavande:       #7B6FA0;
  --lavande-pale:  #E8E4F0;
  --texte:         #3A2810;
  --texte-light:   #6B4E2A;
  --border:        rgba(200,134,10,0.15);
  --shadow:        rgba(139,94,46,0.12);
  --shadow-md:     rgba(139,94,46,0.2);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:18px; }
body { font-family:'Mulish',sans-serif; font-weight:300; background:var(--blanc); color:var(--texte); line-height:1.7; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
ul, ol { list-style:none; }
p { margin-bottom:1rem; }
p:last-child { margin-bottom:0; }

/* ── GRAIN TEXTURE ── */
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9000;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.02'/%3E%3C/svg%3E");
  opacity:0.5;
}

/* ══════════════════════════════════════
   BANDEAU DISCLAIMER
══════════════════════════════════════ */
.disclaimer-bar {
  position:sticky; top:0; z-index:501;
  background:var(--caramel-dark);
  border-bottom:2px solid var(--miel);
  padding:0.55rem 2rem;
  text-align:center;
  font-size:0.78rem;
  font-family:'Mulish',sans-serif;
  font-weight:500;
  color:var(--amande-pale);
  line-height:1.5;
  letter-spacing:0.02em;
}

/* ══════════════════════════════════════
   NAVIGATION
══════════════════════════════════════ */
.site-nav {
  position:sticky; top:0; z-index:500;
  background:rgba(253,248,240,0.96);
  backdrop-filter:blur(14px);
  border-bottom:2px solid var(--miel-pale);
  padding:0 2rem;
  display:flex; align-items:center; justify-content:space-between;
  height:62px;
}
.nav-logo {
  font-family:'Playfair Display',serif;
  font-size:1.35rem; font-weight:700;
  color:var(--caramel); text-decoration:none;
  display:flex; align-items:center;
  white-space:nowrap; letter-spacing:0.01em;
}
.nav-logo span { color:var(--miel); margin-right:0.2rem; }
.nav-logo-info {
  font-style:normal;
  font-family:'Mulish',sans-serif;
  font-size:0.65rem; font-weight:600;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--lavande);
  margin-left:0.4rem;
  opacity:0.85;
}
.nav-logo::before {
  content:'';
  display:inline-block;
  width:8px; height:8px;
  background:var(--miel);
  border-radius:50%;
  margin-right:0.55rem;
  flex-shrink:0;
}
.nav-links { display:flex; gap:0; list-style:none; }
.nav-links a {
  display:block; padding:0 0.6rem;
  font-size:0.75rem; font-weight:500;
  letter-spacing:0.07em; text-transform:uppercase;
  color:var(--caramel); text-decoration:none;
  line-height:62px;
  border-bottom:3px solid transparent;
  transition:color 0.2s, border-color 0.2s;
}
.nav-links a:hover, .nav-links a.active {
  color:var(--miel);
  border-bottom-color:var(--miel);
}

/* Dropdown */
.nav-item { position:relative; }
.nav-dropdown {
  position:absolute; top:calc(100% + 1px); left:0;
  min-width:210px; background:var(--blanc);
  border:1px solid var(--border);
  border-top:2px solid var(--miel);
  box-shadow:0 12px 32px var(--shadow-md);
  opacity:0; visibility:hidden;
  transform:translateY(-6px);
  transition:all 0.2s; z-index:600;
}
.nav-item:hover .nav-dropdown,
.nav-item:focus-within .nav-dropdown {
  opacity:1; visibility:visible; transform:translateY(0);
}
.nav-dropdown a {
  display:block; padding:0.6rem 1.1rem;
  font-size:0.75rem; letter-spacing:0.04em;
  text-transform:none; line-height:1.4;
  color:var(--texte); border-bottom:1px solid var(--border);
  transition:background 0.15s, color 0.15s;
}
.nav-dropdown a:last-child { border-bottom:none; }
.nav-dropdown a:hover { background:var(--creme); color:var(--miel); }

/* Hamburger */
.nav-burger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:8px; background:none; border:none;
}
.nav-burger span { display:block; width:22px; height:1.5px; background:var(--caramel); transition:all 0.3s; }

.mobile-nav {
  display:none; flex-direction:column;
  background:var(--blanc); border-top:1px solid var(--amande-pale);
  padding:0.5rem 0;
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  padding:0.65rem 2rem; font-size:0.8rem;
  letter-spacing:0.08em; text-transform:uppercase;
  color:var(--caramel); border-bottom:1px solid var(--amande-pale);
  transition:color 0.2s;
}
.mobile-nav a:hover { color:var(--miel); }
.mobile-nav a.sub { padding-left:3rem; font-size:0.75rem; text-transform:none; color:var(--texte-light); }

/* ══════════════════════════════════════
   BREADCRUMB
══════════════════════════════════════ */
.breadcrumb {
  padding:0.8rem 0; border-bottom:1px solid var(--border);
  margin-bottom:2.5rem;
}
.breadcrumb ol { display:flex; flex-wrap:wrap; gap:0.4rem; align-items:center; }
.breadcrumb li {
  font-size:0.78rem; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--amande);
  display:flex; align-items:center; gap:0.4rem;
}
.breadcrumb li:not(:last-child)::after { content:'›'; color:var(--miel); }
.breadcrumb a { color:var(--amande); transition:color 0.2s; }
.breadcrumb a:hover { color:var(--miel); }
.breadcrumb li:last-child { color:var(--miel); }

/* ══════════════════════════════════════
   LAYOUT HELPERS
══════════════════════════════════════ */
.container { max-width:1160px; margin:0 auto; padding:0 2rem; }
.section { padding:5rem 0; }
.section--alt { background:var(--creme); }
.section--dark { background:var(--caramel-dark); color:var(--blanc); }

/* ══════════════════════════════════════
   TYPOGRAPHY
══════════════════════════════════════ */
h1,h2,h3,h4 { font-family:'Playfair Display',serif; line-height:1.2; }
h1 { font-size:clamp(2.4rem,5vw,4.5rem); font-weight:700; }
h2 { font-size:clamp(1.8rem,3.5vw,3rem); font-weight:700; }
h3 { font-size:clamp(1.3rem,2vw,1.8rem); font-weight:600; }
h4 { font-size:1.15rem; font-weight:600; }

/* ══════════════════════════════════════
   PAGE HERO (inner pages)
══════════════════════════════════════ */
.page-hero {
  position:relative; min-height:50vh;
  display:flex; align-items:flex-end;
  overflow:hidden;
}
.page-hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:brightness(0.45);
}
.page-hero-gradient {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(92,58,20,0.85) 0%, transparent 60%);
}
.page-hero-content {
  position:relative; z-index:2;
  padding:3rem 2rem; max-width:1160px; margin:0 auto; width:100%;
  animation:fadeUp 0.8s ease both;
}
.hero-eyebrow {
  display:block; font-size:0.68rem; letter-spacing:0.25em;
  text-transform:uppercase; color:var(--miel-pale); margin-bottom:0.75rem;
}
.page-hero h1 { color:#fff; }
.page-hero h1 em { font-style:italic; color:var(--miel-pale); }
.hero-intro {
  font-size:1.05rem; line-height:1.85;
  color:rgba(255,255,255,0.82); max-width:660px; margin-top:1rem;
}

/* Hero sans image (fond dégradé) */
.page-hero--gradient {
  background:linear-gradient(150deg, var(--caramel-dark) 0%, var(--caramel) 100%);
  min-height:42vh; align-items:center;
}
.page-hero--gradient .page-hero-content { padding:4rem 2rem; }

/* ══════════════════════════════════════
   STATS BAND
══════════════════════════════════════ */
.stats-band {
  background:var(--caramel-dark);
  display:grid; grid-template-columns:repeat(4,1fr);
}
.stat-item { text-align:center; padding:2.2rem 1.5rem; border-right:1px solid rgba(255,255,255,0.08); }
.stat-item:last-child { border-right:none; }
.stat-num {
  font-family:'Playfair Display',serif;
  font-size:2.8rem; font-weight:700;
  color:var(--miel-pale); line-height:1; margin-bottom:0.4rem;
}
.stat-label { font-size:0.68rem; letter-spacing:0.15em; text-transform:uppercase; color:rgba(255,255,255,0.55); }

/* ══════════════════════════════════════
   BUTTONS
══════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.85rem 2rem;
  font-family:'Mulish',sans-serif; font-size:0.72rem;
  font-weight:600; letter-spacing:0.12em; text-transform:uppercase;
  cursor:pointer; transition:all 0.25s; border:none;
}
.btn-primary { background:var(--miel); color:var(--caramel-dark); }
.btn-primary:hover { background:var(--miel-light); transform:translateY(-2px); box-shadow:0 8px 24px rgba(200,134,10,0.3); }
.btn-caramel { background:var(--caramel); color:#fff; }
.btn-caramel:hover { background:var(--caramel-dark); transform:translateY(-2px); }
.btn-outline { background:transparent; border:2px solid rgba(255,255,255,0.4); color:#fff; }
.btn-outline:hover { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.7); }
.btn-outline-dark { background:transparent; border:2px solid var(--miel); color:var(--miel); }
.btn-outline-dark:hover { background:var(--miel); color:var(--caramel-dark); }

/* ══════════════════════════════════════
   SECTION HEADER
══════════════════════════════════════ */
.section-header { margin-bottom:3.5rem; text-align:center; }
.section-label {
  display:inline-block; font-size:0.74rem;
  letter-spacing:0.25em; text-transform:uppercase;
  color:var(--miel); margin-bottom:0.6rem;
}
.section-header h2 { color:var(--caramel-dark); margin-bottom:0.85rem; }
.section-header h2 em { font-style:italic; color:var(--miel); }
.section-header p { max-width:600px; margin:0 auto; color:var(--texte-light); }

/* ══════════════════════════════════════
   CARDS GRID
══════════════════════════════════════ */
.cards-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.cards-grid--4 { grid-template-columns:repeat(4,1fr); }
.cards-grid--2 { grid-template-columns:repeat(2,1fr); }

.card {
  background:var(--blanc); border:1px solid var(--border);
  padding:2rem 1.75rem; text-decoration:none; color:inherit;
  transition:all 0.25s; box-shadow:0 2px 12px var(--shadow);
  display:flex; flex-direction:column;
}
.card:hover { transform:translateY(-4px); box-shadow:0 12px 32px var(--shadow-md); border-color:var(--miel); }
.card-icon { font-size:1.8rem; margin-bottom:0.85rem; display:block; }
.card h3 { font-size:1.1rem; color:var(--caramel-dark); margin-bottom:0.5rem; }
.card p { font-size:0.9rem; line-height:1.75; color:var(--texte); flex:1; }
.card-link {
  display:inline-block; margin-top:1rem;
  font-size:0.7rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--miel); transition:gap 0.2s;
}
.card:hover .card-link { text-decoration:underline; }

/* Image card */
.card--img { padding:0; overflow:hidden; }
.card--img img { width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform 0.5s; }
.card--img:hover img { transform:scale(1.05); }
.card--img .card-body { padding:1.5rem 1.75rem; flex:1; display:flex; flex-direction:column; }

/* ══════════════════════════════════════
   ARTICLE LAYOUT (prose + sidebar)
══════════════════════════════════════ */
.article-layout {
  display:grid; grid-template-columns:1fr 320px;
  gap:4rem; align-items:start;
  padding:3.5rem 0;
  max-width:1160px; margin:0 auto; padding-left:2rem; padding-right:2rem;
}

/* Prose */
.article-body h2 {
  font-size:1.9rem; color:var(--caramel-dark);
  margin:2.5rem 0 0.85rem; padding-bottom:0.5rem;
  border-bottom:2px solid var(--miel-pale);
}
.article-body h2:first-child { margin-top:0; }
.article-body h3 { font-size:1.35rem; color:var(--caramel); margin:1.75rem 0 0.6rem; }
.article-body p { font-size:1rem; line-height:1.95; color:var(--texte); margin-bottom:1.1rem; }
.article-body ul { list-style:none; margin-bottom:1.1rem; }
.article-body ul li { padding-left:1.4rem; position:relative; margin-bottom:0.45rem; font-size:1rem; color:var(--texte); line-height:1.75; }
.article-body ul li::before { content:'›'; position:absolute; left:0; color:var(--miel); }
.article-body a { color:var(--miel); text-decoration:underline; text-underline-offset:3px; }
.article-body a:hover { color:var(--caramel); }

.highlight-box {
  background:linear-gradient(135deg, var(--caramel-dark), var(--caramel));
  padding:1.75rem 2rem; margin:2rem 0;
}
.highlight-box p {
  font-family:'Playfair Display',serif;
  font-size:1.2rem; font-style:italic; font-weight:400;
  color:#fff; line-height:1.6; margin:0;
}

.info-box {
  background:var(--creme); border-left:3px solid var(--miel);
  padding:1.3rem 1.75rem; margin:2rem 0;
}
.info-box h4 {
  font-family:'Mulish',sans-serif; font-size:0.68rem;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--miel); margin-bottom:0.65rem;
}
.info-box p { font-size:0.92rem; margin:0; color:var(--texte); }

/* Sidebar */
.sidebar { position:sticky; top:78px; }
.sidebar-block {
  background:var(--creme); border:1px solid var(--border);
  padding:1.6rem; margin-bottom:1.25rem;
}
.sidebar-block h4 {
  font-family:'Mulish',sans-serif; font-size:0.68rem;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--miel); margin-bottom:1rem;
  padding-bottom:0.6rem; border-bottom:1px solid var(--border);
}
.sidebar-toc, .sidebar-links { display:flex; flex-direction:column; gap:0.5rem; }
.sidebar-toc a, .sidebar-links a {
  font-size:0.88rem; color:var(--texte);
  padding-left:0.85rem; border-left:2px solid transparent;
  transition:all 0.2s; display:block;
}
.sidebar-toc a:hover, .sidebar-links a:hover {
  color:var(--miel); border-left-color:var(--miel); padding-left:1.1rem;
}
.sidebar-cta {
  background:linear-gradient(135deg,var(--caramel-dark),var(--caramel));
  padding:1.6rem; text-align:center;
}
.sidebar-cta h4 { color:var(--miel-pale); border-color:rgba(255,255,255,0.15); }
.sidebar-cta p { font-size:0.82rem; color:rgba(255,255,255,0.75); margin-bottom:1rem; }
.sidebar-cta a {
  display:inline-block; background:var(--miel); color:var(--caramel-dark);
  padding:0.6rem 1.4rem; font-size:0.7rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase;
  transition:background 0.2s;
}
.sidebar-cta a:hover { background:var(--miel-light); }

/* Specs table */
.specs-table { width:100%; border-collapse:collapse; font-size:0.92rem; border:2px solid var(--miel); }
.specs-table tr { border-bottom:1px solid var(--miel-pale); }
.specs-table tr:first-child td { background:var(--caramel-dark); color:#fff; font-weight:600; }
.specs-table tr:last-child { border-bottom:none; }
.specs-table td { padding:0.65rem 0.75rem; border-right:1px solid var(--miel-pale); }
.specs-table td:last-child { border-right:none; }
.specs-table td:first-child { color:var(--caramel-dark); width:45%; font-weight:500; }
.specs-table td:last-child { color:var(--texte); font-weight:400; }
.specs-table tr:nth-child(even) td { background:var(--creme); }


/* ══════════════════════════════════════
   DATA TABLE (IGP, ingrédients, étiquette, prix)
══════════════════════════════════════ */
.data-table { overflow-x:auto; margin:1.5rem 0; }
.data-table table { width:100%; border-collapse:collapse; font-size:0.92rem; border:2px solid var(--miel); }
.data-table th { background:var(--caramel-dark); color:#fff; padding:0.75rem 1rem; text-align:left; font-family:'Mulish',sans-serif; font-size:0.72rem; letter-spacing:0.08em; text-transform:uppercase; font-weight:600; }
.data-table td { padding:0.7rem 1rem; border-bottom:1px solid var(--miel-pale); border-right:1px solid var(--miel-pale); color:var(--texte); vertical-align:top; }
.data-table td:last-child { border-right:none; }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:nth-child(even) td { background:var(--creme); }
.data-table tr:hover td { background:var(--amande-pale); }
/* ══════════════════════════════════════
   PULL QUOTE
══════════════════════════════════════ */
.pull-quote { background:var(--caramel-dark); padding:4.5rem 2rem; text-align:center; }
.pull-quote blockquote {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.3rem,2.5vw,2.2rem); font-style:italic; font-weight:400;
  color:#fff; max-width:800px; margin:0 auto; line-height:1.5;
}
.pull-quote cite {
  display:block; margin-top:1.2rem;
  font-family:'Mulish',sans-serif; font-size:0.7rem;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--miel-pale); font-style:normal;
}

/* ══════════════════════════════════════
   FEATURE SPLIT
══════════════════════════════════════ */
.feature-split {
  display:grid; grid-template-columns:1fr 1fr;
  gap:0; overflow:hidden; border:1px solid var(--border);
  min-height:520px;
}
.feature-split img { width:100%; height:100%; object-fit:cover; }
.feature-content {
  padding:4rem; display:flex; flex-direction:column; justify-content:center;
  background:var(--blanc);
}
.feature-content h2 { color:var(--caramel-dark); margin-bottom:1rem; }
.feature-content h2 em { font-style:italic; color:var(--miel); }
.feature-content p { font-size:0.93rem; line-height:1.95; color:var(--texte-light); margin-bottom:1rem; }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.site-footer {
  background:var(--caramel-dark); color:rgba(255,255,255,0.65);
  padding:4rem 0 2rem;
}
.footer-inner { max-width:1160px; margin:0 auto; padding:0 2rem; }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:2.5rem; padding-bottom:2.5rem;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
.footer-brand h3 {
  font-family:'Playfair Display',serif; font-size:1.2rem;
  color:#fff; margin-bottom:0.85rem;
}
.footer-brand p { font-size:0.86rem; line-height:1.85; }
.footer-col h4 {
  font-family:'Mulish',sans-serif; font-size:0.65rem;
  letter-spacing:0.22em; text-transform:uppercase;
  color:var(--miel-pale); margin-bottom:1rem;
}
.footer-col ul { display:flex; flex-direction:column; gap:0.5rem; }
.footer-col a { font-size:0.86rem; color:rgba(255,255,255,0.65); transition:color 0.2s; }
.footer-col a:hover { color:#fff; }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding-top:1.75rem; flex-wrap:wrap; gap:0.75rem;
  font-size:0.73rem; color:rgba(255,255,255,0.35);
}
.footer-bottom a { color:rgba(255,255,255,0.45); transition:color 0.2s; }
.footer-bottom a:hover { color:#fff; }

/* ══════════════════════════════════════
   BACK TO TOP
══════════════════════════════════════ */
.back-to-top {
  position:fixed; bottom:2rem; right:2rem;
  width:42px; height:42px; background:var(--miel); color:var(--caramel-dark);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; opacity:0; pointer-events:none;
  transition:all 0.3s; font-size:1rem; border:none; z-index:99;
  font-weight:700;
}
.back-to-top.visible { opacity:1; pointer-events:all; }
.back-to-top:hover { background:var(--miel-light); transform:translateY(-3px); }

/* ══════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════ */
@keyframes fadeUp { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:translateY(0); } }
.reveal { opacity:0; transform:translateY(20px); transition:opacity 0.7s, transform 0.7s; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ══════════════════════════════════════
   FAQ
══════════════════════════════════════ */
.faq-item { border-bottom:1px solid var(--border); }
.faq-q {
  width:100%; background:none; border:none;
  text-align:left; padding:1.3rem 0;
  font-family:'Playfair Display',serif; font-size:1.05rem;
  font-weight:600; color:var(--caramel-dark); cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  gap:1rem; transition:color 0.2s;
}
.faq-q:hover { color:var(--miel); }
.faq-q::after { content:'+'; font-size:1.4rem; font-weight:300; color:var(--miel); flex-shrink:0; transition:transform 0.3s; }
.faq-item.open .faq-q::after { transform:rotate(45deg); }
.faq-a { display:none; padding:0 0 1.3rem; font-size:0.92rem; line-height:1.85; color:var(--texte-light); }
.faq-item.open .faq-a { display:block; }

/* ══════════════════════════════════════
   LEGAL
══════════════════════════════════════ */
.legal-block { margin-bottom:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid var(--border); }
.legal-block:last-child { border-bottom:none; }
.legal-block h3 { font-size:1.4rem; color:var(--caramel); margin-bottom:0.85rem; }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width:1024px) {
  .cards-grid { grid-template-columns:repeat(2,1fr); }
  .cards-grid--4 { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .article-layout { grid-template-columns:1fr; }
  .sidebar { position:static; }
  .stats-band { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
  .disclaimer-bar { padding:0.5rem 1rem; font-size:0.72rem; }
  .nav-links, .nav-burger + .mobile-nav { }
  .nav-links { display:none; }
  .nav-burger { display:flex; }
  .cards-grid, .cards-grid--4, .cards-grid--2 { grid-template-columns:1fr; }
  .feature-split { grid-template-columns:1fr; }
  .feature-split img { height:260px; }
  .feature-content { padding:2.5rem 1.5rem; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .section { padding:3.5rem 0; }
  .article-layout { padding-left:1.25rem; padding-right:1.25rem; }
}

/* ══════════════════════════════════════
   PRODUCERS GRID
══════════════════════════════════════ */
.producers-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.75rem;margin-top:2rem}
.producer-card{background:var(--blanc);border:1px solid var(--border);padding:1.75rem;box-shadow:0 2px 12px var(--shadow);transition:all .25s}
.producer-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px var(--shadow-md);border-color:var(--miel)}
.producer-name{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;color:var(--caramel-dark);margin-bottom:.2rem}
.producer-founded{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--miel);margin-bottom:.85rem}
.producer-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.85rem}
.tag{font-size:.68rem;padding:.25rem .65rem;background:var(--creme);border:1px solid var(--border);color:var(--caramel);letter-spacing:.05em}
.producer-link{display:inline-block;margin-top:.85rem;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--miel)}
.producer-link:hover{text-decoration:underline}
@media(max-width:768px){.producers-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════
   RECIPES GRID
══════════════════════════════════════ */
.recipes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.recipe-card{background:var(--blanc);border:1px solid var(--border);overflow:hidden;transition:all .3s;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.recipe-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px var(--shadow-md);border-color:var(--miel)}
.recipe-card img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s;background:var(--amande-pale)}
.recipe-card:hover img{transform:scale(1.05)}
.recipe-card-body{padding:1.25rem 1.5rem;flex:1;display:flex;flex-direction:column}
.recipe-card-label{font-size:.63rem;letter-spacing:.2em;text-transform:uppercase;color:var(--miel);margin-bottom:.4rem}
.recipe-card h3{font-size:1.1rem;color:var(--caramel-dark);margin-bottom:.5rem}
.recipe-card-meta{display:flex;gap:1rem;font-size:.78rem;color:var(--texte-light);margin-top:auto;padding-top:.75rem;flex-wrap:wrap}
.recipe-card-link{display:inline-block;margin-top:.75rem;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--miel)}
.recipe-card:hover .recipe-card-link{text-decoration:underline}
@media(max-width:960px){.recipes-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.recipes-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════
   HOME PAGE
══════════════════════════════════════ */
.home-hero{position:relative;min-height:96vh;display:flex;align-items:center;overflow:hidden}
.home-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.42)}
.home-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(92,58,20,.75) 0%,rgba(92,58,20,.2) 100%)}
.home-hero-content{position:relative;z-index:2;max-width:760px;padding:5rem 2rem;animation:fadeUp 1s ease both}
.home-tag{display:inline-block;font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;color:var(--miel-pale);border:1px solid rgba(245,217,138,.35);padding:.3rem 1rem;margin-bottom:1.5rem}
.home-hero h1{font-size:clamp(3rem,6vw,5.5rem);font-weight:700;line-height:1.05;color:#fff;margin-bottom:1.4rem}
.home-hero h1 em{font-style:italic;color:var(--miel-pale)}
.home-hero-desc{font-size:1.05rem;line-height:1.9;color:rgba(255,255,255,.8);max-width:560px;margin-bottom:2.5rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.home-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.home-card{background:var(--blanc);border:1px solid var(--border);overflow:hidden;transition:all .3s;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.home-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px var(--shadow-md);border-color:var(--miel)}
.home-card img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s;background:var(--amande-pale)}
.home-card:hover img{transform:scale(1.05)}
.home-card-body{padding:1.5rem 1.75rem;flex:1;display:flex;flex-direction:column}
.home-card-label{font-size:.63rem;letter-spacing:.2em;text-transform:uppercase;color:var(--miel);margin-bottom:.4rem}
.home-card h3{font-size:1.2rem;color:var(--caramel-dark);margin-bottom:.5rem}
.home-card p{font-size:.85rem;line-height:1.75;color:var(--texte-light);flex:1}
.home-card-link{display:inline-block;margin-top:1rem;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--miel)}
.home-card:hover .home-card-link{text-decoration:underline}
.about-band{background:#fdf8f0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:3.5rem 0}
.about-inner{max-width:780px;margin:0 auto;padding:0 2rem;display:flex;gap:2.5rem;align-items:flex-start}
.about-avatar{width:72px;height:72px;border-radius:50%;background:var(--caramel-dark);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--miel-pale);flex-shrink:0}
.about-text h4{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--miel);margin-bottom:.5rem}
.about-text p{font-size:.9rem;line-height:1.9;color:var(--texte-light)}
@media(max-width:960px){
  .home-cards-grid{grid-template-columns:1fr}
  .about-inner{flex-direction:column;gap:1.5rem}
}

