/* =====================================================================
 * Bulles & Frometons - main.css
 * Extrait de la maquette validée. Adaptations WP minimales.
 * ===================================================================== */

:root{
  --teal-deep:    #0B3437;
  --teal:         #114B50;
  --teal-soft:    #1A5C61;
  --teal-line:    rgba(241,231,207,0.14);
  --cream:        #F1E7CF;
  --cream-warm:   #EFE2C2;
  --cream-deep:   #E0D2A8;
  --yolk:         #E8B23A;
  --yolk-deep:    #C98E1A;
  --yolk-glow:    rgba(232,178,58,0.18);
  --ink:          #07191B;
  --ink-soft:     rgba(7,25,27,0.7);
  --bordeaux:     #5C1A1B;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--teal-deep)}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--teal-deep);
  color:var(--cream);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-weight:400;
}
::selection{background:var(--yolk);color:var(--ink)}
img{max-width:100%;display:block;height:auto}
a{color:inherit}
button{font-family:inherit}

/* GRAIN GLOBAL */
body::before{
  content:"";position:fixed;inset:0;
  pointer-events:none;z-index:1;opacity:0.06;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* TYPO BASES */
.display{
  font-family:'Fraunces',serif;
  font-weight:200;
  letter-spacing:-0.035em;
  line-height:0.92;
  font-variation-settings:"opsz" 144, "SOFT" 50;
}
.display em{font-style:italic;font-weight:400;color:var(--yolk)}
.display .stencil{
  font-weight:700;
  -webkit-text-stroke:1.5px var(--yolk);
  text-stroke:1.5px var(--yolk);
  color:transparent;
  font-style:italic;
}

.label{
  font-size:11px;
  letter-spacing:0.34em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--yolk);
}
.lead{
  font-size:clamp(17px, 1.4vw, 19px);
  line-height:1.55;
  color:var(--cream);
  opacity:0.85;
  font-weight:300;
  max-width:60ch;
}

/* PROGRESS / CURSOR / BUBBLES */
.progress-bar{
  position:fixed;top:0;left:0;height:2px;
  background:var(--yolk);
  width:0%;z-index:200;
  box-shadow:0 0 12px var(--yolk-glow);
}
.cursor-dot{
  position:fixed;top:0;left:0;
  width:10px;height:10px;border-radius:50%;
  background:var(--yolk);
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s, height .3s, opacity .3s, background .3s;
  mix-blend-mode:difference;
  opacity:0;
}
.cursor-dot.show{opacity:0.95}
.cursor-dot.large{width:56px;height:56px;background:var(--cream);mix-blend-mode:exclusion}
@media (pointer:coarse){.cursor-dot{display:none}}

.bubbles{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1;
}
.bubbles span{
  position:absolute;bottom:-40px;
  border-radius:50%;border:1px solid currentColor;
  opacity:0;animation:rise linear infinite;
}
.bubbles.on-light span{color:var(--ink)}
.bubbles.on-dark span{color:var(--yolk)}
@keyframes rise{
  0%{transform:translateY(0) translateX(0);opacity:0}
  6%{opacity:0.22}
  50%{transform:translateY(-50vh) translateX(8px);opacity:0.28}
  100%{transform:translateY(-110vh) translateX(-6px);opacity:0}
}
.bubbles span:nth-child(1){left:6%;width:8px;height:8px;animation-duration:14s;animation-delay:0s}
.bubbles span:nth-child(2){left:16%;width:12px;height:12px;animation-duration:18s;animation-delay:2s}
.bubbles span:nth-child(3){left:28%;width:5px;height:5px;animation-duration:11s;animation-delay:5s}
.bubbles span:nth-child(4){left:42%;width:16px;height:16px;animation-duration:22s;animation-delay:1s}
.bubbles span:nth-child(5){left:54%;width:8px;height:8px;animation-duration:16s;animation-delay:8s}
.bubbles span:nth-child(6){left:66%;width:11px;height:11px;animation-duration:20s;animation-delay:3s}
.bubbles span:nth-child(7){left:78%;width:6px;height:6px;animation-duration:13s;animation-delay:6s}
.bubbles span:nth-child(8){left:90%;width:13px;height:13px;animation-duration:19s;animation-delay:10s}
.bubbles span:nth-child(9){left:22%;width:4px;height:4px;animation-duration:9s;animation-delay:12s}
.bubbles span:nth-child(10){left:62%;width:5px;height:5px;animation-duration:10s;animation-delay:7s}
.bubbles span:nth-child(11){left:12%;width:9px;height:9px;animation-duration:17s;animation-delay:9s}
.bubbles span:nth-child(12){left:74%;width:7px;height:7px;animation-duration:15s;animation-delay:4s}

/* GHOST TYPE */
.ghost-type{
  position:absolute;
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  color:transparent;
  -webkit-text-stroke:1px rgba(232,178,58,0.18);
  text-stroke:1px rgba(232,178,58,0.18);
  font-size:clamp(180px, 28vw, 480px);
  letter-spacing:-0.06em;line-height:0.78;
  pointer-events:none;z-index:0;user-select:none;white-space:nowrap;
}
.ghost-type.right{right:-3vw;bottom:-4vw}
.ghost-type.left{left:-4vw;top:-3vw}
.ghost-type.dark{-webkit-text-stroke-color:rgba(7,25,27,0.10);text-stroke-color:rgba(7,25,27,0.10)}
.ghost-type.solid{
  -webkit-text-stroke:0;text-stroke:0;
  color:rgba(232,178,58,0.05);
}

/* SIDE VERTICAL TYPO */
.side-vertical{
  position:fixed;
  left:24px;top:50%;
  transform:translateY(-50%) rotate(-90deg);
  transform-origin:left center;
  z-index:40;
  font-family:'Inter',sans-serif;
  font-size:11px;letter-spacing:0.4em;text-transform:uppercase;
  color:var(--cream);font-weight:500;
  opacity:0.55;
  pointer-events:none;white-space:nowrap;
  display:flex;align-items:center;gap:18px;
  transition:opacity .8s ease;
}
.side-vertical .dot{width:5px;height:5px;border-radius:50%;background:var(--yolk)}
.side-vertical em{
  color:var(--yolk);font-style:italic;letter-spacing:0.05em;
  text-transform:none;font-family:'Fraunces',serif;font-weight:400;font-size:14px;
}
.side-vertical.right{left:auto;right:24px;transform:translateY(-50%) rotate(90deg);transform-origin:right center}
@media(max-width:1100px){.side-vertical{display:none}}

/* NAV */
nav.top{
  position:fixed;top:0;left:0;right:0;z-index:80;
  padding:22px clamp(20px,5vw,72px);
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(11,52,55,0.6);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:all .3s ease;
}
nav.top.scrolled{
  border-bottom-color:var(--teal-line);
  padding-top:14px;padding-bottom:14px;
  background:rgba(11,52,55,0.92);
}
.brand{
  font-family:'Fraunces',serif;font-weight:400;font-size:18px;
  letter-spacing:-0.005em;
  display:flex;align-items:center;gap:12px;
  color:var(--cream);text-decoration:none;
}
.brand-mark{
  width:34px;height:34px;border:1px solid var(--yolk);
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;font-style:italic;font-weight:400;
  color:var(--yolk);
}
.brand em{font-style:italic;font-weight:300;color:var(--yolk)}
.brand img{max-height:34px;width:auto}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{
  font-size:13px;letter-spacing:0.04em;font-weight:500;
  text-decoration:none;color:var(--cream);opacity:0.65;
  transition:all .25s;
}
.nav-links a:hover,
.nav-links li.current-menu-item a,
.nav-links li.current_page_item a{opacity:1;color:var(--yolk)}
.nav-cta{
  background:var(--yolk);color:var(--ink);
  padding:12px 22px;border-radius:0;text-decoration:none;
  font-size:13px;letter-spacing:0.06em;font-weight:600;
  transition:all .25s;
  display:inline-flex;align-items:center;gap:8px;
}
.nav-cta:hover{background:var(--cream);transform:translateY(-2px)}
.nav-toggle{
  display:none;
  background:transparent;border:1px solid var(--cream);
  color:var(--cream);
  width:42px;height:42px;
  align-items:center;justify-content:center;
  cursor:pointer;
}
@media(max-width:880px){
  .nav-links{display:none}
  .nav-toggle{display:inline-flex}
  nav.top.menu-open .nav-links{
    display:flex;flex-direction:column;
    position:fixed;top:64px;left:0;right:0;
    background:var(--teal-deep);
    padding:24px clamp(20px,5vw,72px);
    border-top:1px solid var(--teal-line);
    border-bottom:1px solid var(--teal-line);
    gap:16px;
  }
  nav.top.menu-open .nav-links a{font-size:18px}
}

/* HERO */
.hero{
  min-height:auto;
  padding:120px clamp(20px,5vw,72px) 80px;
  position:relative;
  overflow:hidden;
}
@media(min-height:900px) and (min-width:1100px){
  .hero{padding-top:140px;padding-bottom:100px}
}
.hero-bg-image{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  opacity:0.18;
  filter:saturate(0.9) contrast(1.05);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr;
  gap:64px;align-items:end;
  max-width:1400px;margin:0 auto;
  width:100%;
  position:relative;z-index:3;
}
.hero-eyebrow{display:inline-flex;align-items:center;gap:14px;margin-bottom:48px}
.hero-eyebrow::before{content:"";width:48px;height:1px;background:var(--yolk)}

h1.hero-title{
  font-size:clamp(48px,8.5vw,140px);
  margin-bottom:32px;
  position:relative;
}
h1.hero-title .word{display:inline-block;overflow:hidden;vertical-align:bottom;line-height:0.92}
h1.hero-title .word > span{
  display:inline-block;transform:translateY(110%);
  transition:transform 1.1s cubic-bezier(.2,.8,.2,1);
}
h1.hero-title.in .word > span{transform:translateY(0)}
h1.hero-title .word:nth-of-type(2) > span{transition-delay:.12s}
h1.hero-title .word:nth-of-type(3) > span{transition-delay:.24s}
h1.hero-title .word:nth-of-type(4) > span{transition-delay:.36s}
h1.hero-title .word:nth-of-type(5) > span{transition-delay:.48s}
h1.hero-title .word:nth-of-type(6) > span{transition-delay:.60s}
h1.hero-title .rotate-i{display:inline-block;transform:rotate(-4deg);transform-origin:center;margin:0 0.05em}
h1.hero-title .outline{
  -webkit-text-stroke:1.5px var(--cream);text-stroke:1.5px var(--cream);
  color:transparent;font-weight:300;
}

.hero-sub{
  font-size:clamp(18px,1.6vw,24px);
  line-height:1.45;
  max-width:50ch;
  color:var(--cream);
  font-weight:300;
  margin-bottom:48px;
  font-family:'Fraunces',serif;
  font-style:italic;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;
  font-family:'Inter',sans-serif;
  font-size:13px;letter-spacing:0.06em;font-weight:600;
  text-decoration:none;cursor:pointer;border:none;
  transition:all .25s ease;
}
.btn-primary{background:var(--yolk);color:var(--ink)}
.btn-primary:hover{background:var(--cream);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid var(--cream)}
.btn-ghost:hover{background:var(--cream);color:var(--ink)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(6px)}

.hero-side{
  border-left:1px solid var(--teal-line);
  padding-left:40px;
  padding-bottom:40px;
}
.hero-side .label{margin-bottom:16px}
.hero-side h3{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:32px;letter-spacing:-0.02em;line-height:1.1;
  color:var(--cream);margin-bottom:24px;
}
.hero-side p{
  font-size:14px;line-height:1.6;color:var(--cream);opacity:0.75;font-weight:300;
}
.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--teal-line);
  margin-top:32px;padding-top:24px;gap:16px;
}
.hero-stat .num{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:42px;color:var(--yolk);line-height:1;
}
.hero-stat .desc{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;margin-top:8px;font-weight:600;
}

.hero-signature{
  display:flex;align-items:center;gap:14px;
  margin-top:32px;padding-top:24px;
  border-top:1px solid var(--teal-line);
  max-width:420px;
}
.hero-signature .avatar{
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--yolk);
  overflow:hidden;flex-shrink:0;
}
.hero-signature .avatar img{width:100%;height:100%;object-fit:cover}
.hero-signature .who{
  font-size:13px;color:var(--cream);opacity:0.85;line-height:1.35;
}
.hero-signature .who strong{
  color:var(--yolk);font-weight:400;display:block;
  font-family:'Fraunces',serif;font-style:italic;font-size:16px;
}

.hero-scroll-cue{
  position:absolute;bottom:32px;left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  z-index:5;
  font-size:10px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--cream);opacity:0.5;font-weight:600;
}
.hero-scroll-cue .line{
  width:1px;height:40px;background:var(--yolk);
  animation:cue-slide 2.4s infinite ease-in-out;
  transform-origin:top;
}
@keyframes cue-slide{
  0%,100%{transform:scaleY(0.3)}
  50%{transform:scaleY(1)}
}

@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-side{border-left:none;border-top:1px solid var(--teal-line);padding-left:0;padding-top:32px}
  .hero-scroll-cue{display:none}
}

/* MARQUEE */
.marquee{
  border-top:1px solid var(--teal-line);
  border-bottom:1px solid var(--teal-line);
  overflow:hidden;
  padding:34px 0;
  background:var(--teal);
  position:relative;
}
.marquee-track{
  display:flex;gap:48px;
  white-space:nowrap;
  animation:marquee-scroll 60s linear infinite;
  font-family:'Fraunces',serif;
  font-size:clamp(32px,5vw,72px);
  font-weight:200;
  color:var(--cream);
  letter-spacing:-0.03em;
}
.marquee-track span{display:inline-flex;align-items:center;gap:48px}
.marquee-track .dot{color:var(--yolk);font-style:normal;font-size:0.5em;vertical-align:0.6em}
.marquee-track em{color:var(--yolk);font-style:italic;font-weight:400}
@keyframes marquee-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
section{
  padding:clamp(80px,12vh,160px) clamp(20px,5vw,72px);
  position:relative;
}
.section-cream{background:var(--cream);color:var(--ink)}
.section-cream .label{color:var(--bordeaux)}
.section-cream .display em{color:var(--bordeaux)}

.container{max-width:1400px;margin:0 auto;position:relative}
.section-head{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:64px;align-items:end;
  margin-bottom:80px;
  padding-bottom:36px;
  border-bottom:1px solid var(--teal-line);
  position:relative;
}
.section-cream .section-head{border-bottom-color:rgba(7,25,27,0.12)}
.section-head .num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:32px;color:var(--yolk);
  position:relative;
}
.section-cream .section-head .num{color:var(--bordeaux)}
.section-head .num::after{
  content:attr(data-big);
  position:absolute;
  left:-30px;top:-50px;
  font-size:200px;
  color:transparent;
  -webkit-text-stroke:1px rgba(232,178,58,0.20);
  text-stroke:1px rgba(232,178,58,0.20);
  font-style:italic;font-weight:200;
  pointer-events:none;
  z-index:-1;
  letter-spacing:-0.06em;
}
.section-cream .section-head .num::after{
  -webkit-text-stroke-color:rgba(92,26,27,0.15);
  text-stroke-color:rgba(92,26,27,0.15);
}
.section-head h2{
  font-size:clamp(40px,7vw,108px);
}
.section-head .right{
  justify-self:end;
  max-width:38ch;
  font-size:15px;
  color:var(--cream);opacity:0.75;
  font-weight:300;
}
.section-cream .section-head .right{color:var(--ink-soft);opacity:1}
@media(max-width:880px){
  .section-head{grid-template-columns:1fr;gap:24px}
  .section-head .right{justify-self:start}
  .section-head .num::after{font-size:120px;left:-20px;top:-30px}
}

/* PUNCHLINE */
.punchline{
  padding:clamp(80px,10vh,140px) clamp(20px,5vw,72px);
  text-align:center;
  border-top:1px solid var(--teal-line);
  border-bottom:1px solid var(--teal-line);
  position:relative;
  background:var(--teal);
}
.punchline blockquote{
  font-family:'Fraunces',serif;font-weight:200;font-style:italic;
  font-size:clamp(34px,6vw,84px);
  line-height:1.05;letter-spacing:-0.025em;
  max-width:22ch;margin:0 auto;
  color:var(--cream);
}
.punchline blockquote em{font-style:normal;color:var(--yolk);font-weight:400}
.punchline .attribution{
  margin-top:32px;
  font-size:11px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;
}
.punchline .attribution span{color:var(--yolk);opacity:1}

/* MANIFESTE */
.manifeste{
  padding:clamp(120px,18vh,220px) clamp(20px,5vw,72px);
  position:relative;
  overflow:hidden;
  background:var(--teal-deep);
}
.manifeste-inner{max-width:1200px;margin:0 auto;position:relative;z-index:2}
.manifeste .label{margin-bottom:32px}
.manifeste h2{
  color:var(--cream);
  margin-bottom:64px;
  font-family:'Fraunces',serif;font-weight:200;
  font-size:clamp(40px,8vw,124px);
  line-height:0.95;letter-spacing:-0.035em;
  max-width:18ch;
}
.manifeste h2 em{font-style:italic;color:var(--yolk);font-weight:300}
.manifeste h2 .word-stack{display:inline-block;position:relative}
.manifeste h2 .word-stack::after{
  content:"";position:absolute;bottom:0.08em;left:0;right:0;height:0.05em;
  background:var(--yolk);opacity:0.6;
}

.manifeste .body{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  margin-top:24px;
}
.manifeste .body p{
  font-size:18px;line-height:1.65;color:var(--cream);
  opacity:0.85;font-weight:300;
}
.manifeste .body p strong{color:var(--yolk);font-weight:500}
@media(max-width:880px){.manifeste .body{grid-template-columns:1fr;gap:24px}.manifeste h2{font-size:clamp(36px,11vw,72px)}}

.dispersed{display:inline-block}
.dispersed .ch{
  display:inline-block;
  transition:transform .8s cubic-bezier(.2,.8,.2,1), color .6s;
}
.dispersed:hover .ch:nth-child(3n){transform:translateY(-10px) rotate(-6deg)}
.dispersed:hover .ch:nth-child(3n+1){transform:translateY(8px) rotate(4deg)}
.dispersed:hover .ch:nth-child(3n+2){transform:translateY(-4px) rotate(-2deg)}

/* CERCLE */
.cercle-intro{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  margin-bottom:80px;align-items:start;
}
.cercle-intro .lead{font-size:19px;color:var(--cream);opacity:0.95}
.cercle-meta{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--teal-line);
}
.cercle-meta-item{padding:24px 0;border-bottom:1px solid var(--teal-line)}
.cercle-meta-item:nth-child(odd){padding-right:24px;border-right:1px solid var(--teal-line)}
.cercle-meta-item:nth-child(even){padding-left:24px}
.cercle-meta-item .k{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:500;margin-bottom:6px;
}
.cercle-meta-item .v{
  font-family:'Fraunces',serif;font-weight:400;font-size:22px;
  color:var(--cream);
}
@media(max-width:880px){.cercle-intro{grid-template-columns:1fr;gap:40px}}

.passages{border-top:1px solid var(--teal-line)}
.passage{
  display:grid;
  grid-template-columns:90px 1fr 1.2fr;
  gap:48px;
  padding:56px 0;
  border-bottom:1px solid var(--teal-line);
  align-items:start;
  position:relative;
  transition:background .4s;
}
.passage::before{
  content:"";position:absolute;left:0;top:0;height:1px;width:0;
  background:var(--yolk);
  transition:width .8s cubic-bezier(.2,.8,.2,1);
}
.passage:hover::before{width:100%}
.passage:hover{background:rgba(232,178,58,0.04)}
.passage .roman{
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:64px;color:var(--yolk);line-height:1;
  transition:transform .6s, color .4s;
}
.passage:hover .roman{transform:scale(1.08) rotate(-3deg)}
.passage h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:42px;letter-spacing:-0.02em;line-height:1.0;
  margin-bottom:10px;color:var(--cream);
}
.passage h3 em{font-style:italic;color:var(--yolk);font-weight:400}
.passage h3 .aop{
  font-family:'Inter',sans-serif;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;
  vertical-align:0.7em;margin-left:10px;
}
.passage .pairing{
  font-style:italic;color:var(--yolk);font-size:16px;
  font-family:'Fraunces',serif;font-weight:300;
}
.passage p.note,
.passage .note{font-size:15px;line-height:1.7;color:var(--cream);opacity:0.78}
.passage .note strong{color:var(--cream);font-weight:500;opacity:1}
.passage-image{
  margin-top:18px;border:1px solid var(--teal-line);
  aspect-ratio:4/3;overflow:hidden;
}
.passage-image img{width:100%;height:100%;object-fit:cover}
@media(max-width:880px){
  .passage{grid-template-columns:1fr;gap:18px;padding:40px 0}
  .passage .roman{font-size:42px}
  .passage h3{font-size:32px}
}

/* POUR QUI */
.pour-qui{display:grid;grid-template-columns:1fr 1fr;gap:0}
.pq-block{
  padding:56px 48px;
  border:1px solid var(--teal-line);
  transition:all .4s;
  background:var(--teal);
}
.pq-block:first-child{border-right:none}
.pq-block:hover{background:var(--teal-soft);transform:translateY(-4px)}
.pq-block .label{margin-bottom:18px}
.pq-block h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:42px;letter-spacing:-0.02em;line-height:1.0;
  margin-bottom:32px;color:var(--cream);
}
.pq-block h3 em{font-style:italic;color:var(--yolk);font-weight:400}
.pq-block ul{list-style:none}
.pq-block li{
  padding:14px 0;
  border-top:1px solid var(--teal-line);
  font-size:15px;color:var(--cream);opacity:0.82;
  display:flex;align-items:baseline;gap:14px;font-weight:300;
}
.pq-block li::before{
  content:"·";color:var(--yolk);font-weight:700;font-size:24px;
  line-height:0;flex-shrink:0;
}
.pq-block .price{
  margin-top:32px;padding-top:20px;
  border-top:1px solid var(--teal-line);
  display:flex;align-items:baseline;gap:14px;
  font-family:'Fraunces',serif;
}
.pq-block .price .from{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;
}
.pq-block .price .num{
  font-size:48px;font-weight:300;font-style:italic;color:var(--yolk);
}
.pq-block .price .unit{font-size:13px;color:var(--cream);opacity:0.7}
@media(max-width:880px){
  .pour-qui{grid-template-columns:1fr}
  .pq-block:first-child{border-right:1px solid var(--teal-line);border-bottom:none}
}

/* BOISSONS */
.boissons{padding:clamp(80px,12vh,160px) clamp(20px,5vw,72px);position:relative}
.boissons-price{
  display:inline-flex;align-items:baseline;gap:14px;
  margin-bottom:48px;padding:18px 32px;
  border:1px solid var(--teal-line);
  font-family:'Fraunces',serif;
}
.boissons-price .from{
  font-family:'Inter',sans-serif;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;
}
.boissons-price .num{font-size:48px;font-weight:300;font-style:italic;color:var(--yolk);line-height:1}
.boissons-price .unit{font-family:'Inter',sans-serif;font-size:13px;color:var(--cream);opacity:0.7}
.boissons-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:0;
  border-top:1px solid var(--teal-line);
  border-left:1px solid var(--teal-line);
}
.boisson-card{
  padding:36px 28px;
  border-right:1px solid var(--teal-line);
  border-bottom:1px solid var(--teal-line);
  background:transparent;
  transition:all .4s;
  display:flex;flex-direction:column;align-items:flex-start;gap:14px;
  text-align:left;
}
.boisson-card:hover{background:rgba(232,178,58,0.04);transform:translateY(-2px)}
.boisson-icon{
  width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--teal-line);border-radius:50%;
  background:var(--teal);
  color:var(--yolk);
  flex-shrink:0;
}
.boisson-icon img{max-width:36px;max-height:36px;object-fit:contain}
.boisson-icon .icon-text{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:24px;color:var(--yolk);line-height:1;
}
.boisson-card h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:24px;letter-spacing:-0.015em;line-height:1.1;
  color:var(--cream);margin:0;
}
.boisson-card h3 .aop{
  display:inline-block;margin-left:6px;
  font-family:'Inter',sans-serif;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;vertical-align:0.25em;
}
.boisson-card p{font-size:14px;line-height:1.55;color:var(--cream);opacity:0.78;font-weight:300;margin:0}
@media(max-width:680px){
  .boissons-grid{grid-template-columns:1fr}
}

/* EMPORTER */
.emporter-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--teal-line);
}
.emporter-cell{
  padding:56px 36px 56px 0;
  border-bottom:1px solid var(--teal-line);
}
.emporter-cell:not(:last-child){border-right:1px solid var(--teal-line);padding-right:36px}
.emporter-cell:not(:first-child){padding-left:36px}
.emporter-cell .num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:48px;color:var(--yolk);margin-bottom:24px;line-height:1;
}
.emporter-cell h4{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:30px;letter-spacing:-0.015em;line-height:1.05;
  margin-bottom:14px;color:var(--cream);
}
.emporter-cell h4 em{font-style:italic;color:var(--yolk);font-weight:400}
.emporter-cell p{font-size:14px;line-height:1.65;color:var(--cream);opacity:0.78;font-weight:300}
.emporter-cell .image{margin-top:18px;border:1px solid var(--teal-line);aspect-ratio:4/3;overflow:hidden}
.emporter-cell .image img{width:100%;height:100%;object-fit:cover}
@media(max-width:880px){
  .emporter-grid{grid-template-columns:1fr}
  .emporter-cell{border-right:none !important;padding:40px 0 !important}
}

/* REPAS */
.repas{
  background:var(--cream);
  color:var(--ink);
  padding:clamp(80px,14vh,160px) clamp(20px,5vw,72px);
  position:relative;overflow:hidden;
}
.repas .label{color:var(--bordeaux)}
.repas-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:center;
  max-width:1400px;margin:0 auto;position:relative;z-index:2;
}
.repas h2{
  font-size:clamp(40px,7vw,96px);
  color:var(--ink);margin-top:24px;
}
.repas h2 em{color:var(--bordeaux)}
.repas .lead{margin-top:24px;color:var(--ink);opacity:0.75}
.repas-card{
  border:1px solid rgba(7,25,27,0.18);
  padding:40px;
  background:var(--cream-warm);
}
.repas-card .label{margin-bottom:16px}
.repas-card .price-line{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:64px;color:var(--ink);margin-bottom:8px;letter-spacing:-0.03em;
}
.repas-card .price-line em{font-style:italic;color:var(--bordeaux);font-weight:400}
.repas-card .small{font-size:13px;color:var(--ink);opacity:0.7;margin-bottom:24px}
.repas-card ul{list-style:none;border-top:1px solid rgba(7,25,27,0.12)}
.repas-card li{
  padding:14px 0;border-bottom:1px solid rgba(7,25,27,0.12);
  font-size:14px;color:var(--ink);opacity:0.8;font-weight:400;
}
.repas-gallery{
  margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  max-width:1400px;margin-left:auto;margin-right:auto;
}
.repas-gallery img{aspect-ratio:1;object-fit:cover;width:100%}
@media(max-width:880px){.repas-grid{grid-template-columns:1fr;gap:40px}}

/* YOAN */
.yoan{
  background:var(--cream);color:var(--ink);
  padding:clamp(80px,14vh,160px) clamp(20px,5vw,72px);
  position:relative;overflow:hidden;
}
.yoan .label{color:var(--bordeaux)}
.yoan .section-head{border-bottom-color:rgba(7,25,27,0.12)}
.yoan .section-head .num{color:var(--bordeaux)}
.yoan .section-head h2{color:var(--ink)}
.yoan .section-head h2 em{color:var(--bordeaux)}
.yoan .section-head .right{color:var(--ink);opacity:0.75}

.yoan-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;
  position:relative;z-index:2;
}
.yoan-photo{
  aspect-ratio:4/5;
  background:var(--cream-warm);
  border:1px solid rgba(7,25,27,0.18);
  position:relative;overflow:hidden;margin:0;
}
.yoan-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(0.95) contrast(1.04);
  transition:transform 1.4s ease;
}
.yoan-photo:hover img{transform:scale(1.04)}
.yoan-photo .overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px;
  background:linear-gradient(180deg, transparent, rgba(7,25,27,0.7));
  display:flex;justify-content:space-between;align-items:flex-end;
}
.yoan-photo .overlay .name{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:24px;color:var(--cream);
}
.yoan-photo .overlay .role{
  font-size:10px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;
}
.yoan-text h2{margin-bottom:32px;font-size:clamp(40px,5.6vw,72px)}
.yoan-text p{
  font-size:18px;line-height:1.65;color:var(--ink);opacity:0.85;
  margin-bottom:18px;font-weight:400;
}
.yoan-text p:first-of-type::first-line{font-weight:600;color:var(--ink);opacity:1}
.yoan-text p strong{color:var(--bordeaux);font-weight:500}
.yoan-sign{
  margin-top:36px;padding-top:24px;
  border-top:1px solid rgba(7,25,27,0.12);
  font-family:'Fraunces',serif;font-style:italic;
  font-size:20px;color:var(--bordeaux);
}
.yoan-gallery{
  margin-top:32px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
}
.yoan-gallery img{aspect-ratio:1;object-fit:cover;width:100%}
@media(max-width:880px){.yoan-grid{grid-template-columns:1fr;gap:40px}}

/* RECETTES */
.recettes-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:48px;
  border-top:1px solid var(--teal-line);
  padding-top:48px;
}
.recette-feature{
  display:grid;grid-template-rows:auto 1fr;
  border:1px solid var(--teal-line);
  background:var(--teal);
  overflow:hidden;
  transition:all .5s;
  text-decoration:none;color:inherit;
}
.recette-feature:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(0,0,0,0.4)}
.recette-cover{
  aspect-ratio:16/10;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(232,178,58,0.22) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 70%, rgba(26,92,97,0.4) 0%, transparent 65%),
    var(--teal-soft);
  border-bottom:1px solid var(--teal-line);
  position:relative;display:flex;align-items:flex-end;padding:32px;overflow:hidden;
}
.recette-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.recette-cover .overlay-tag{
  position:relative;z-index:1;
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:140px;color:var(--yolk);line-height:0.78;
  opacity:0.85;letter-spacing:-0.05em;
}
.recette-cover .photo-tag{
  position:absolute;top:24px;right:24px;z-index:1;
  font-size:10px;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--cream);opacity:0.65;font-weight:600;
}
.recette-feature .body{padding:40px}
.recette-feature .label{margin-bottom:14px}
.recette-feature h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:38px;line-height:1.0;letter-spacing:-0.02em;
  margin-bottom:14px;color:var(--cream);
}
.recette-feature h3 em{font-style:italic;color:var(--yolk);font-weight:400}
.recette-feature .pairing{
  font-style:italic;color:var(--yolk);font-size:16px;margin-bottom:24px;
  font-family:'Fraunces',serif;
}
.recette-feature p{font-size:15px;line-height:1.6;color:var(--cream);opacity:0.78;margin-bottom:24px;font-weight:300}
.recette-feature .cta{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;text-decoration:none;
  border-bottom:1px solid var(--yolk);padding-bottom:6px;
  transition:all .25s;
}
.recette-feature .cta:hover{color:var(--cream);border-color:var(--cream)}

.recettes-list{display:flex;flex-direction:column;border-top:1px solid var(--teal-line)}
.recette-card{
  padding:28px 0;
  border-bottom:1px solid var(--teal-line);
  display:grid;grid-template-columns:60px 1fr auto;gap:24px;align-items:center;
  text-decoration:none;color:inherit;
  transition:all .4s;
}
.recette-card:hover{padding-left:16px;background:rgba(232,178,58,0.04)}
.recette-card .roman{
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:32px;color:var(--yolk);line-height:1;
}
.recette-card h4{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:24px;letter-spacing:-0.01em;line-height:1.1;margin-bottom:6px;
  color:var(--cream);
}
.recette-card .pair{font-size:13px;color:var(--yolk);font-style:italic;font-family:'Fraunces',serif}
.recette-card .arrow{font-size:20px;color:var(--yolk);font-family:'Fraunces',serif;transition:transform .3s}
.recette-card:hover .arrow{transform:translateX(8px)}
.recette-card .badge{
  font-size:9px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;
  border:1px solid var(--teal-line);padding:4px 8px;
  margin-top:8px;display:inline-block;
}
@media(max-width:880px){
  .recettes-grid{grid-template-columns:1fr;gap:32px}
  .recette-feature .body{padding:28px}
  .recette-card{grid-template-columns:40px 1fr 24px;gap:14px}
  .recette-card h4{font-size:19px}
}

/* CONFIANCE / LOGOS */
.confiance{
  border-top:1px solid var(--teal-line);
  border-bottom:1px solid var(--teal-line);
  padding:80px clamp(20px,5vw,72px);
  text-align:center;background:var(--teal-deep);
}
.confiance .label{margin-bottom:16px}
.confiance p{
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:clamp(22px,3vw,34px);color:var(--cream);
  max-width:54ch;margin:0 auto 40px;line-height:1.3;
}
.logos-row{
  display:flex;flex-wrap:wrap;justify-content:center;gap:0;
  border-top:1px solid var(--teal-line);
  max-width:1400px;margin:0 auto;
}
.logo-slot{
  flex:1 1 200px;min-height:90px;
  border-right:1px solid var(--teal-line);
  border-bottom:1px solid var(--teal-line);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--cream);opacity:0.4;font-weight:600;
  padding:24px;
}
.logo-slot:last-child{border-right:none}
.logo-slot img{max-height:48px;width:auto;opacity:0.85;filter:grayscale(1) brightness(1.4)}

/* FAQ */
details.faq-item{border-bottom:1px solid var(--teal-line);padding:32px 0;cursor:pointer}
details.faq-item summary{
  list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:32px;
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(22px,2.6vw,30px);
  color:var(--cream);letter-spacing:-0.015em;line-height:1.2;
}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item .plus{
  font-size:26px;color:var(--yolk);font-weight:200;font-family:'Fraunces',serif;
  transition:transform .3s;flex-shrink:0;
}
details.faq-item[open] .plus{transform:rotate(45deg)}
details.faq-item .answer{
  margin-top:18px;font-size:15px;line-height:1.65;
  color:var(--cream);opacity:0.78;max-width:75ch;font-weight:300;
}
details.faq-item .answer p{margin-bottom:12px}

/* DEVIS */
.devis{
  background:var(--ink);
  padding:clamp(80px,14vh,180px) clamp(20px,5vw,72px);
  position:relative;overflow:hidden;
}
.devis-grid{
  display:grid;grid-template-columns:1fr 1.3fr;gap:80px;
  max-width:1400px;margin:0 auto;align-items:start;position:relative;z-index:2;
}
.devis .label{color:var(--yolk)}
.devis h2{
  color:var(--cream);
  font-size:clamp(40px,7vw,108px);
  margin:32px 0 32px;font-family:'Fraunces',serif;font-weight:200;
  letter-spacing:-0.035em;line-height:0.95;
}
.devis h2 em{font-style:italic;color:var(--yolk);font-weight:300}
.devis .lead{color:rgba(241,231,207,0.75);max-width:38ch;margin-bottom:48px;font-style:italic;font-family:'Fraunces',serif;font-weight:300;font-size:20px}
.devis-info p{font-size:14px;color:rgba(241,231,207,0.65);line-height:1.6;margin-bottom:6px}
.devis-info a{color:var(--yolk);text-decoration:underline;text-underline-offset:3px}
.devis-info .label{margin:24px 0 8px;display:block}

.devis-form-wrap{position:relative;z-index:2}
.devis-form-fallback{
  border:1px solid rgba(241,231,207,0.18);
  padding:32px;color:rgba(241,231,207,0.75);
  font-family:'Fraunces',serif;font-style:italic;
  font-size:18px;line-height:1.5;
}
.devis-form-fallback a{color:var(--yolk);text-decoration:underline;text-underline-offset:3px}

@media(max-width:880px){.devis-grid{grid-template-columns:1fr;gap:48px}}

/* CHEESES (ambient) */
.cheese{
  position:absolute;
  width:clamp(140px,18vw,260px);
  height:clamp(140px,18vw,260px);
  pointer-events:auto;cursor:grab;z-index:4;user-select:none;
  transition:transform 1.4s cubic-bezier(.22,.85,.22,1), opacity 1.2s ease, filter .4s;
  opacity:0;
  filter:drop-shadow(0 30px 30px rgba(0,0,0,0.35));
}
.cheese.from-left{transform:translateX(-30vw) rotate(-12deg)}
.cheese.from-right{transform:translateX(30vw) rotate(12deg)}
.cheese.in{opacity:1;transform:translate(var(--cx,0px),var(--cy,0px)) rotate(var(--cr,0deg))}
.cheese:hover{filter:drop-shadow(0 40px 50px rgba(232,178,58,0.35)) brightness(1.06)}
.cheese:active{cursor:grabbing;transition:none}
.cheese.dragging{transition:none;z-index:30;filter:drop-shadow(0 50px 80px rgba(0,0,0,0.5))}
.cheese svg{width:100%;height:100%;display:block;overflow:visible}
.cheese img{width:100%;height:100%;object-fit:contain;display:block}
.cheese .label-tag{
  position:absolute;bottom:-22px;left:50%;
  transform:translateX(-50%);
  font-family:'Inter',sans-serif;
  font-size:10px;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;
  white-space:nowrap;opacity:0;transition:opacity .35s;
}
.cheese:hover .label-tag{opacity:0.95}

.cheese.c-1{top:18%;left:-3%;--cr:-8deg}
.cheese.c-2{top:56%;right:-2%;--cr:6deg}
.cheese.c-3{top:30%;right:5%;--cr:-4deg}
.cheese.c-4{top:62%;left:4%;--cr:9deg}

@media(max-width:880px){
  .cheese{width:130px;height:130px}
  .cheese.c-1,.cheese.c-3{left:-6%;right:auto}
  .cheese.c-2,.cheese.c-4{right:-6%;left:auto}
}
@media(max-width:560px){
  .cheese{width:90px;height:90px;opacity:0.6 !important}
  .cheese:hover{opacity:0.9 !important}
}

/* HERO CHEESES (4 corners) */
.hero-cheese{
  position:absolute;
  width:clamp(120px, 16vw, 220px);
  height:clamp(120px, 16vw, 220px);
  pointer-events:auto;cursor:grab;z-index:2;user-select:none;
  opacity:0;
  filter:drop-shadow(0 30px 40px rgba(0,0,0,0.5));
  transition:filter .4s;
}
.hero-cheese svg{width:100%;height:100%;display:block;overflow:visible}
.hero-cheese img{width:100%;height:100%;object-fit:contain;display:block}
.hero-cheese.tl{top:14vh;left:3vw}
.hero-cheese.tr{top:18vh;right:3vw}
.hero-cheese.bl{bottom:8vh;left:6vw}
.hero-cheese.br{bottom:12vh;right:8vw}
.hero-cheese.tl{animation:dropTL 1.8s cubic-bezier(.2,.8,.2,1) 0.3s forwards}
.hero-cheese.tr{animation:dropTR 1.8s cubic-bezier(.2,.8,.2,1) 0.6s forwards}
.hero-cheese.bl{animation:dropBL 1.8s cubic-bezier(.2,.8,.2,1) 0.9s forwards}
.hero-cheese.br{animation:dropBR 1.8s cubic-bezier(.2,.8,.2,1) 1.2s forwards}

@keyframes dropTL{
  0%{opacity:0;transform:translate(-60vw,-60vh) rotate(-540deg) scale(0.2)}
  60%{opacity:1}
  100%{opacity:1;transform:translate(0,0) rotate(-12deg) scale(1)}
}
@keyframes dropTR{
  0%{opacity:0;transform:translate(60vw,-60vh) rotate(540deg) scale(0.2)}
  60%{opacity:1}
  100%{opacity:1;transform:translate(0,0) rotate(8deg) scale(1)}
}
@keyframes dropBL{
  0%{opacity:0;transform:translate(-60vw,60vh) rotate(-540deg) scale(0.2)}
  60%{opacity:1}
  100%{opacity:1;transform:translate(0,0) rotate(-6deg) scale(1)}
}
@keyframes dropBR{
  0%{opacity:0;transform:translate(60vw,60vh) rotate(540deg) scale(0.2)}
  60%{opacity:1}
  100%{opacity:1;transform:translate(0,0) rotate(10deg) scale(1)}
}

.hero-cheese.float-1{animation:dropTL 1.8s cubic-bezier(.2,.8,.2,1) 0.3s forwards, floatY 6s ease-in-out 2.5s infinite}
.hero-cheese.float-2{animation:dropTR 1.8s cubic-bezier(.2,.8,.2,1) 0.6s forwards, floatY 7s ease-in-out 2.8s infinite}
.hero-cheese.float-3{animation:dropBL 1.8s cubic-bezier(.2,.8,.2,1) 0.9s forwards, floatY 8s ease-in-out 3.1s infinite}
.hero-cheese.float-4{animation:dropBR 1.8s cubic-bezier(.2,.8,.2,1) 1.2s forwards, floatY 9s ease-in-out 3.4s infinite}

@keyframes floatY{
  0%,100%{transform:translateY(0) rotate(var(--final-r,0deg))}
  50%{transform:translateY(-14px) rotate(calc(var(--final-r,0deg) + 3deg))}
}
.hero-cheese.tl{--final-r:-12deg}
.hero-cheese.tr{--final-r:8deg}
.hero-cheese.bl{--final-r:-6deg}
.hero-cheese.br{--final-r:10deg}
.hero-cheese:hover{filter:drop-shadow(0 40px 60px rgba(232,178,58,0.4)) brightness(1.06)}
.hero-cheese:active{cursor:grabbing}

@media(max-width:880px){
  .hero-cheese{width:90px;height:90px;opacity:0.7}
  .hero-cheese.tl{top:12vh;left:1vw}
  .hero-cheese.tr{top:14vh;right:1vw}
  .hero-cheese.bl{bottom:4vh;left:2vw}
  .hero-cheese.br{bottom:6vh;right:2vw}
}
@media(max-width:560px){.hero-cheese{width:70px;height:70px}}

/* BLOG (section home, sélecteur spécifique pour éviter de matcher body.blog) */
section.blog{padding:clamp(80px,12vh,160px) clamp(20px,5vw,72px);position:relative;overflow:hidden}
section.blog .ghost-type{font-size:clamp(160px,24vw,400px)}

.blog-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
  border-top:1px solid var(--teal-line);padding-top:48px;
}
.blog-card{
  background:var(--teal);
  border:1px solid var(--teal-line);
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
  transition:all .5s cubic-bezier(.2,.8,.2,1);
  overflow:hidden;
}
.blog-card:hover{
  transform:translateY(-8px);
  border-color:var(--yolk);
  box-shadow:0 30px 60px -30px rgba(0,0,0,0.5);
}
.blog-cover{
  aspect-ratio:16/10;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(232,178,58,0.18) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 70%, rgba(26,92,97,0.5) 0%, transparent 65%),
    var(--teal-soft);
  border-bottom:1px solid var(--teal-line);
  position:relative;
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:24px;overflow:hidden;
}
.blog-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.blog-cover::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, transparent 0%, rgba(232,178,58,0.05) 100%);
  pointer-events:none;
}
.blog-cover .photo-tag{
  position:relative;z-index:1;
  font-size:9px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--cream);opacity:0.7;font-weight:700;
}
.blog-cover .cat-pill{
  position:absolute;top:18px;left:18px;z-index:2;
  font-size:9px;letter-spacing:0.28em;text-transform:uppercase;
  background:var(--yolk);color:var(--ink);padding:6px 12px;font-weight:700;
}
.blog-body{padding:28px 28px 32px;display:flex;flex-direction:column;flex:1}
.blog-meta{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);opacity:0.85;font-weight:600;margin-bottom:14px;
}
.blog-card h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:24px;letter-spacing:-0.015em;line-height:1.15;
  color:var(--cream);margin-bottom:14px;
  transition:color .3s;
}
.blog-card:hover h3{color:var(--yolk)}
.blog-card p{
  font-size:14px;line-height:1.55;color:var(--cream);opacity:0.7;
  margin-bottom:18px;font-weight:300;
}
.blog-card .read-more{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;margin-top:auto;
  display:inline-flex;align-items:center;gap:8px;
}
.blog-all{
  text-align:center;margin-top:48px;
}
.blog-all a{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 36px;
  background:transparent;color:var(--cream);
  border:1px solid var(--cream);
  font-size:13px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;
  text-decoration:none;transition:all .3s;
}
.blog-all a:hover{background:var(--yolk);color:var(--ink);border-color:var(--yolk)}
@media(max-width:880px){.blog-grid{grid-template-columns:1fr;gap:24px}}

/* SINGLE RECETTE */
.single-recette{padding:140px clamp(20px,5vw,72px) 120px;background:var(--teal-deep)}
.single-recette__inner{max-width:1100px;margin:0 auto}
.single-recette__hero{margin-bottom:48px}
.single-recette__crumbs{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;margin-bottom:18px;
}
.single-recette__crumbs a{text-decoration:none;color:var(--yolk)}
.single-recette h1{
  font-family:'Fraunces',serif;font-weight:200;
  font-size:clamp(40px,6vw,90px);letter-spacing:-0.03em;line-height:0.95;
  color:var(--cream);margin-bottom:24px;
}
.single-recette h1 em{font-style:italic;color:var(--yolk);font-weight:300}
.single-recette__pairing{
  font-family:'Fraunces',serif;font-style:italic;color:var(--yolk);
  font-size:22px;margin-bottom:32px;
}
.single-recette__cover{
  aspect-ratio:16/10;overflow:hidden;border:1px solid var(--teal-line);
  margin-bottom:48px;
}
.single-recette__cover img{width:100%;height:100%;object-fit:cover}
.single-recette__meta{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--teal-line);
  border-bottom:1px solid var(--teal-line);
  margin-bottom:48px;
}
.single-recette__meta-item{
  padding:24px;border-right:1px solid var(--teal-line);
}
.single-recette__meta-item:last-child{border-right:none}
.single-recette__meta-k{
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;margin-bottom:6px;
}
.single-recette__meta-v{
  font-family:'Fraunces',serif;font-weight:400;font-size:22px;color:var(--cream);
}
.single-recette__intro{
  font-family:'Fraunces',serif;font-weight:300;font-size:22px;line-height:1.5;
  color:var(--cream);opacity:0.92;max-width:60ch;margin-bottom:48px;
}
.single-recette__cols{
  display:grid;grid-template-columns:1fr 2fr;gap:64px;
}
.single-recette__ingredients{
  border-top:1px solid var(--teal-line);
}
.single-recette__ingredients h2,
.single-recette__steps h2,
.single-recette__tips h2,
.single-recette__chef h2{
  font-family:'Fraunces',serif;font-weight:300;font-size:32px;
  color:var(--cream);margin:32px 0 24px;letter-spacing:-0.015em;
}
.single-recette__ingredients ul,
.single-recette__tips ul{list-style:none}
.single-recette__ingredients li,
.single-recette__tips li{
  padding:14px 0;border-bottom:1px solid var(--teal-line);
  color:var(--cream);font-size:15px;line-height:1.5;
}
.single-recette__ingredients .qty{color:var(--yolk);font-family:'Fraunces',serif;font-style:italic;margin-right:10px}
.single-recette__ingredients .note{display:block;font-size:13px;opacity:0.65;font-style:italic;margin-top:4px}
.single-recette__steps ol{list-style:none;counter-reset:step}
.single-recette__steps li{
  counter-increment:step;
  padding:24px 0 24px 90px;
  border-bottom:1px solid var(--teal-line);
  position:relative;
}
.single-recette__steps li::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;left:0;top:24px;
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:42px;color:var(--yolk);line-height:1;
}
.single-recette__steps h3{
  font-family:'Fraunces',serif;font-weight:400;font-size:22px;color:var(--cream);
  margin-bottom:12px;
}
.single-recette__steps .desc{color:var(--cream);opacity:0.85;font-size:15px;line-height:1.6}
.single-recette__chef{
  margin-top:48px;padding:32px;border:1px solid var(--teal-line);
  background:var(--teal);
}
.single-recette__chef h2{margin-top:0}
.single-recette__chef p{color:var(--cream);opacity:0.85;line-height:1.6}
.single-recette__related{
  margin-top:80px;padding-top:48px;border-top:1px solid var(--teal-line);
}
@media(max-width:880px){
  .single-recette__cols{grid-template-columns:1fr;gap:32px}
  .single-recette__meta{grid-template-columns:repeat(2,1fr)}
  .single-recette__meta-item{border-bottom:1px solid var(--teal-line)}
  .single-recette__meta-item:nth-child(2n){border-right:none}
}

/* ARCHIVE RECETTES */
.archive-recettes{padding:140px clamp(20px,5vw,72px) 120px}
.archive-recettes__head{margin-bottom:48px}
.archive-recettes__filters{
  display:flex;flex-wrap:wrap;gap:12px;margin-bottom:48px;
  border-top:1px solid var(--teal-line);padding-top:24px;
}
.archive-recettes__filters .group{
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
}
.archive-recettes__filters .group .gl{
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;margin-right:8px;
}
.archive-recettes__filters button,
.archive-recettes__filters a{
  background:transparent;color:var(--cream);
  border:1px solid var(--teal-line);
  padding:6px 14px;font-size:12px;letter-spacing:0.06em;font-weight:500;
  cursor:pointer;transition:all .25s;
  text-decoration:none;
}
.archive-recettes__filters button:hover,
.archive-recettes__filters button.is-active,
.archive-recettes__filters a.is-active{
  background:var(--yolk);color:var(--ink);border-color:var(--yolk);
}
.archive-recettes__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.recipe-card{
  background:var(--teal);border:1px solid var(--teal-line);
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;overflow:hidden;
  transition:all .4s;
}
.recipe-card:hover{transform:translateY(-6px);border-color:var(--yolk)}
.recipe-card .cover{aspect-ratio:16/10;overflow:hidden;background:var(--teal-soft);position:relative}
.recipe-card .cover img{width:100%;height:100%;object-fit:cover}
.recipe-card .body{padding:24px;display:flex;flex-direction:column;flex:1}
.recipe-card .terms{
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;margin-bottom:10px;
}
.recipe-card h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:22px;line-height:1.15;color:var(--cream);margin-bottom:8px;
}
.recipe-card .pair{font-style:italic;color:var(--yolk);font-family:'Fraunces',serif;font-size:13px;margin-bottom:auto;padding-bottom:14px}
@media(max-width:880px){.archive-recettes__grid{grid-template-columns:1fr;gap:20px}}

/* SINGLE POST */
.single-post{padding:140px clamp(20px,5vw,72px) 120px;background:var(--teal-deep)}
.single-post__inner{max-width:780px;margin:0 auto}
.single-post__crumbs{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;margin-bottom:18px;
}
.single-post__crumbs a{color:var(--yolk);text-decoration:none}
.single-post__cat{
  display:inline-block;font-size:9px;letter-spacing:0.28em;text-transform:uppercase;
  background:var(--yolk);color:var(--ink);padding:6px 12px;font-weight:700;margin-bottom:24px;
}
.single-post h1{
  font-family:'Fraunces',serif;font-weight:200;
  font-size:clamp(32px,5vw,72px);letter-spacing:-0.03em;line-height:1;
  color:var(--cream);margin-bottom:24px;
}
.single-post__chapeau{
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:22px;line-height:1.45;color:var(--cream);
  border-left:1px solid var(--yolk);padding-left:24px;margin:32px 0;
}
.single-post__cover{
  aspect-ratio:16/10;overflow:hidden;border:1px solid var(--teal-line);margin:32px 0 48px;
}
.single-post__cover img{width:100%;height:100%;object-fit:cover}
.single-post__meta{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;margin-bottom:18px;
}
.single-post__content{font-size:17px;line-height:1.7;color:var(--cream);opacity:0.92}
.single-post__content p{margin-bottom:24px}
.single-post__content h2,
.single-post__content h3{
  font-family:'Fraunces',serif;font-weight:300;color:var(--cream);
  margin:48px 0 20px;letter-spacing:-0.015em;line-height:1.1;
}
.single-post__content h2{font-size:34px}
.single-post__content h3{font-size:26px}
.single-post__content em{color:var(--yolk);font-style:italic}
.single-post__content strong{color:var(--cream);font-weight:600}
.single-post__content blockquote{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:24px;line-height:1.4;color:var(--cream);
  border-left:1px solid var(--yolk);padding-left:24px;margin:32px 0;
}
.single-post__content a{color:var(--yolk);text-decoration:underline;text-underline-offset:3px}
.single-post__content img{margin:32px 0}
.single-post__related{margin-top:80px;padding-top:48px;border-top:1px solid var(--teal-line)}

/* PAGE GENERIQUE */
.page-generic{padding:140px clamp(20px,5vw,72px) 120px;background:var(--teal-deep)}
.page-generic__inner{max-width:780px;margin:0 auto;color:var(--cream)}
.page-generic h1{font-family:'Fraunces',serif;font-weight:200;font-size:clamp(40px,5vw,72px);margin-bottom:32px;color:var(--cream);letter-spacing:-0.025em;line-height:1}
.page-generic h2{font-family:'Fraunces',serif;font-weight:300;font-size:32px;margin:40px 0 16px;color:var(--cream)}
.page-generic h3{font-family:'Fraunces',serif;font-weight:300;font-size:24px;margin:32px 0 12px;color:var(--cream)}
.page-generic p{margin-bottom:18px;line-height:1.7;font-size:16px;opacity:0.92}
.page-generic ul,.page-generic ol{padding-left:24px;margin-bottom:18px}
.page-generic li{margin-bottom:8px;opacity:0.9}
.page-generic a{color:var(--yolk);text-decoration:underline;text-underline-offset:3px}

/* FOOTER */
footer.foot{
  background:var(--ink);color:var(--cream);
  border-top:1px solid rgba(241,231,207,0.12);
}
.foot-inner{
  max-width:1400px;margin:0 auto;
  padding:60px clamp(20px,5vw,72px) 32px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
}
.foot-brand{
  font-family:'Fraunces',serif;font-weight:400;font-size:28px;
  letter-spacing:-0.015em;color:var(--cream);margin-bottom:20px;
}
.foot-brand em{font-style:italic;color:var(--yolk);font-weight:300}
.foot p{font-size:13px;color:rgba(241,231,207,0.6);line-height:1.6}
.foot h5{
  font-size:11px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;margin-bottom:18px;
}
.foot ul{list-style:none}
.foot li{margin-bottom:10px}
.foot a{font-size:13px;color:rgba(241,231,207,0.78);text-decoration:none;transition:color .25s}
.foot a:hover{color:var(--yolk)}
.foot-bottom{
  border-top:1px solid rgba(241,231,207,0.12);
  padding:24px clamp(20px,5vw,72px);
  max-width:1400px;margin:0 auto;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:11px;color:rgba(241,231,207,0.5);letter-spacing:0.05em;
}
.foot-alpha{
  font-style:italic;color:rgba(241,231,207,0.45);
  font-family:'Fraunces',serif;font-size:12px;letter-spacing:0;
}
.evin-fixed{
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:120;
  background:var(--bordeaux);
  padding:10px clamp(20px,5vw,72px);
  text-align:center;
  font-size:11px;color:var(--cream);
  letter-spacing:0.04em;
  border-top:1px solid rgba(241,231,207,0.18);
  box-shadow:0 -8px 24px rgba(0,0,0,0.25);
}
.evin-fixed strong{color:var(--cream);font-weight:700}
body{padding-bottom:42px}
@media(max-width:560px){
  .evin-fixed{font-size:10px;padding:8px 14px;line-height:1.3}
  body{padding-bottom:48px}
}
@media(max-width:880px){.foot-inner{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:560px){.foot-inner{grid-template-columns:1fr}.foot-bottom{flex-direction:column;align-items:flex-start}}

/* =====================================================================
 * SINGLE RECETTE — design magazine premium
 * ===================================================================== */
.recipe{position:relative;background:var(--teal-deep);color:var(--cream)}

/* Hero plein écran */
.recipe-hero{
  position:relative;
  min-height:80vh;
  padding:120px clamp(20px,5vw,72px) 60px;
  background-size:cover;
  background-position:center;
  background-color:var(--teal-deep);
  display:flex;align-items:flex-end;
  overflow:hidden;
}
.recipe-hero__inner{
  position:relative;z-index:2;
  max-width:1100px;width:100%;margin:0 auto;
}
.recipe-hero__crumbs{
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:rgba(241,231,207,0.7);margin-bottom:20px;font-weight:500;
}
.recipe-hero__crumbs a{color:var(--yolk);text-decoration:none}
.recipe-hero__crumbs a:hover{color:var(--cream)}
.recipe-hero__crumbs span{margin:0 8px;color:rgba(241,231,207,0.4)}
.recipe-hero__terms{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.recipe-hero__pill{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--yolk);color:var(--ink);
  padding:6px 14px;border-radius:30px;
  font-size:12px;letter-spacing:0.06em;font-weight:600;text-transform:uppercase;
  text-decoration:none;transition:all .2s;
}
.recipe-hero__pill span{font-size:9px;opacity:0.7;letter-spacing:0.15em}
.recipe-hero__pill:hover{background:var(--cream);transform:translateY(-1px)}
.recipe-hero__title{
  font-family:'Fraunces',serif;font-weight:200;
  font-size:clamp(38px,6.5vw,96px);line-height:0.98;letter-spacing:-0.03em;
  color:var(--cream);margin-bottom:18px;
}
.recipe-hero__pairing{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:clamp(18px,2vw,26px);color:var(--yolk);
  margin-bottom:36px;
}
.recipe-hero__stats{
  display:flex;gap:32px;flex-wrap:wrap;
  border-top:1px solid rgba(241,231,207,0.18);padding-top:24px;
}
.recipe-hero__stat{display:flex;align-items:center;gap:14px}
.recipe-hero__stat .dashicons{
  font-size:24px;width:24px;height:24px;color:var(--yolk);
}
.recipe-hero__stat strong{
  display:block;font-family:'Fraunces',serif;font-weight:300;
  font-size:24px;color:var(--cream);line-height:1;
}
.recipe-hero__stat small{
  font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--cream);opacity:0.6;margin-top:4px;display:block;
}
.recipe-hero__stars{display:inline-flex;gap:2px;color:rgba(241,231,207,0.25);font-size:18px}
.recipe-hero__stars .is-on{color:var(--yolk)}
.recipe-hero__scroll{
  position:absolute;bottom:32px;left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  text-decoration:none;color:rgba(241,231,207,0.6);
  font-size:10px;letter-spacing:0.32em;text-transform:uppercase;font-weight:600;
}
.recipe-hero__scroll-line{
  width:1px;height:34px;background:var(--yolk);
  animation:cue-slide 2.4s infinite ease-in-out;transform-origin:top;
}
@media(max-width:680px){
  .recipe-hero{min-height:auto;padding:100px 20px 50px}
  .recipe-hero__stats{gap:18px}
  .recipe-hero__scroll{display:none}
}

/* Intro */
.recipe-intro{padding:80px clamp(20px,5vw,72px);background:var(--teal-deep)}
.recipe-intro__inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:start;
}
.recipe-intro__text{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(18px,1.6vw,22px);line-height:1.55;
  color:var(--cream);opacity:0.92;
}
.recipe-intro__text p{margin-bottom:18px}
.recipe-intro__text em{color:var(--yolk);font-style:italic}
.recipe-intro__meta{
  border-top:1px solid var(--teal-line);
  border-bottom:1px solid var(--teal-line);
  padding:24px 0;
}
.recipe-meta-item{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:14px 0;
  border-bottom:1px solid var(--teal-line);
}
.recipe-meta-item:last-child{border-bottom:none}
.recipe-meta-item__label{
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;
}
.recipe-meta-item__value{
  font-family:'Fraunces',serif;font-weight:400;font-size:18px;color:var(--cream);
  text-align:right;
}
@media(max-width:880px){
  .recipe-intro__inner{grid-template-columns:1fr;gap:32px}
}

/* Body : ingrédients sticky + étapes */
.recipe-body{padding:60px clamp(20px,5vw,72px) 80px;background:var(--teal-deep)}
.recipe-body__inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:start;
}
.recipe-section-head{
  display:flex;align-items:baseline;gap:18px;margin-bottom:28px;
}
.recipe-section-head__num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:48px;color:var(--yolk);line-height:1;
}
.recipe-section-head h2{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(26px,3.5vw,38px);
  letter-spacing:-0.02em;line-height:1;color:var(--cream);margin:0;
}

.recipe-ingredients__sticky{position:sticky;top:96px}
.recipe-ingredients__yield{
  font-family:'Fraunces',serif;font-style:italic;
  font-size:15px;color:var(--yolk);margin-bottom:20px;
}
.recipe-ingredients__list{list-style:none;border-top:1px solid var(--teal-line);margin:0;padding:0}
.recipe-ingredients__item{
  padding:14px 0;border-bottom:1px solid var(--teal-line);
  position:relative;padding-left:22px;
  font-size:15px;line-height:1.5;color:var(--cream);
}
.recipe-ingredients__item::before{
  content:"";position:absolute;left:0;top:23px;
  width:8px;height:8px;border-radius:50%;background:var(--yolk);
}
.recipe-ingredients__qty{
  display:inline-block;font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  color:var(--yolk);margin-right:8px;font-size:16px;
}
.recipe-ingredients__name{color:var(--cream)}
.recipe-ingredients__note{
  display:block;margin-top:4px;font-size:12px;
  color:var(--cream);opacity:0.6;font-style:italic;
}
.recipe-ingredients__empty{font-style:italic;opacity:0.6}
.recipe-ingredients__accord{
  margin-top:24px;padding:18px 20px;
  background:rgba(232,178,58,0.08);
  border-left:2px solid var(--yolk);
}
.recipe-ingredients__accord-label{
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;display:block;margin-bottom:6px;
}
.recipe-ingredients__accord p{
  font-size:13px;line-height:1.55;color:var(--cream);opacity:0.85;margin:0;
}

/* Étapes */
.recipe-steps__list{list-style:none;margin:0;padding:0;counter-reset:step}
.recipe-step{
  display:grid;grid-template-columns:auto 1fr;gap:32px;
  padding:36px 0;
  border-bottom:1px solid var(--teal-line);
  position:relative;
}
.recipe-step:last-child{border-bottom:none}
.recipe-step__num{
  display:flex;flex-direction:column;align-items:center;
  width:90px;flex-shrink:0;
}
.recipe-step__num-big{
  font-family:'Fraunces',serif;font-style:italic;font-weight:200;
  font-size:80px;color:var(--yolk);line-height:0.9;
  letter-spacing:-0.05em;
}
.recipe-step__num-label{
  font-size:9px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--cream);opacity:0.5;font-weight:600;margin-top:6px;
}
.recipe-step__title{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(20px,2vw,26px);letter-spacing:-0.015em;
  color:var(--cream);margin:0 0 10px;
}
.recipe-step__desc{
  font-size:16px;line-height:1.65;color:var(--cream);opacity:0.88;
}
.recipe-step__desc p{margin-bottom:12px}
.recipe-step__desc strong{color:var(--yolk)}
.recipe-step__desc em{color:var(--yolk);font-style:italic}

/* Astuces */
.recipe-tips{margin-top:64px;padding-top:48px;border-top:1px solid var(--teal-line)}
.recipe-tips__list{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.recipe-tips__item{
  background:var(--teal);
  padding:18px 22px;border-radius:8px;
  font-size:14px;line-height:1.55;color:var(--cream);opacity:0.92;
  position:relative;padding-left:48px;
}
.recipe-tips__item::before{
  content:"💡";position:absolute;left:18px;top:18px;font-size:16px;
}

@media(max-width:880px){
  .recipe-body__inner{grid-template-columns:1fr;gap:48px}
  .recipe-ingredients__sticky{position:static}
  .recipe-step{grid-template-columns:1fr;gap:14px}
  .recipe-step__num{width:auto;flex-direction:row;gap:12px;align-items:baseline}
  .recipe-step__num-big{font-size:48px}
}

/* Vidéo */
.recipe-video{padding:60px clamp(20px,5vw,72px);background:var(--teal-deep)}
.recipe-video__inner{max-width:1100px;margin:0 auto}
.recipe-video__frame{position:relative;aspect-ratio:16/9;background:var(--teal);border-radius:8px;overflow:hidden}
.recipe-video__frame iframe{width:100%;height:100%;display:block;border:none}

/* Mot du chef */
.recipe-chef{
  padding:80px clamp(20px,5vw,72px);
  background:var(--teal);
  border-top:1px solid var(--teal-line);border-bottom:1px solid var(--teal-line);
}
.recipe-chef__inner{
  max-width:780px;margin:0 auto;text-align:center;
}
.recipe-chef__label{
  display:inline-block;font-size:10px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;margin-bottom:24px;
}
.recipe-chef__quote{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:clamp(22px,3vw,32px);line-height:1.4;color:var(--cream);
  margin:0 0 32px;quotes:"« " " »";
}
.recipe-chef__quote::before{content:open-quote;color:var(--yolk);margin-right:6px}
.recipe-chef__quote::after{content:close-quote;color:var(--yolk);margin-left:6px}
.recipe-chef__quote p{margin-bottom:16px}
.recipe-chef__producer{
  margin-top:24px;padding-top:24px;
  border-top:1px solid var(--teal-line);
  font-size:14px;color:var(--cream);
}
.recipe-chef__producer-label{
  display:block;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--cream);opacity:0.55;font-weight:600;margin-bottom:8px;
}
.recipe-chef__producer a{color:var(--yolk);text-decoration:none;font-weight:500}
.recipe-chef__producer a:hover{color:var(--cream)}
.recipe-chef__sign{
  margin-top:36px;font-family:'Fraunces',serif;font-style:italic;
  font-size:18px;color:var(--yolk);
}

/* Galerie */
.recipe-gallery{padding:80px clamp(20px,5vw,72px);background:var(--teal-deep)}
.recipe-gallery .recipe-section-head{justify-content:center;margin-bottom:48px}
.recipe-gallery__grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:8px;
}
.recipe-gallery__item{
  display:block;aspect-ratio:1;overflow:hidden;
  background:var(--teal-soft);
  position:relative;
  transition:transform .3s;
}
.recipe-gallery__item:hover{transform:scale(0.98)}
.recipe-gallery__item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s ease;
}
.recipe-gallery__item:hover img{transform:scale(1.05)}

/* Recettes liées */
.recipe-related{padding:80px clamp(20px,5vw,72px);background:var(--teal)}
.recipe-related .recipe-section-head{justify-content:center;margin-bottom:48px}
.recipe-related__grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:24px;
}
.recipe-related__card{
  display:flex;flex-direction:column;
  background:var(--teal-deep);border:1px solid var(--teal-line);
  border-radius:8px;overflow:hidden;
  text-decoration:none;color:inherit;
  transition:all .4s;
}
.recipe-related__card:hover{transform:translateY(-4px);border-color:var(--yolk)}
.recipe-related__cover{aspect-ratio:16/10;overflow:hidden}
.recipe-related__cover img{width:100%;height:100%;object-fit:cover}
.recipe-related__body{padding:20px 22px;flex:1;display:flex;flex-direction:column}
.recipe-related__body h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:20px;letter-spacing:-0.01em;line-height:1.15;
  color:var(--cream);margin:0 0 8px;
}
.recipe-related__body p{
  font-size:13px;color:var(--yolk);font-style:italic;
  font-family:'Fraunces',serif;margin:0 0 12px;
}
.recipe-related__cta{
  font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;margin-top:auto;
}

/* CTA fin recette */
.recipe-cta{padding:80px clamp(20px,5vw,72px);background:var(--ink);text-align:center}
.recipe-cta__inner{max-width:680px;margin:0 auto}
.recipe-cta h2{
  font-family:'Fraunces',serif;font-weight:200;
  font-size:clamp(28px,4vw,48px);color:var(--cream);
  margin:0 0 18px;
}
.recipe-cta p{font-size:15px;color:var(--cream);opacity:0.78;line-height:1.6;margin-bottom:32px}

/* =====================================================================
 * SINGLE ARTICLE — design éditorial premium
 * ===================================================================== */
.article{background:var(--teal-deep);color:var(--cream)}

.article-hero{
  position:relative;
  min-height:65vh;
  padding:120px clamp(20px,5vw,72px) 60px;
  background-size:cover;background-position:center;
  background-color:var(--teal-deep);
  display:flex;align-items:flex-end;
  overflow:hidden;
}
.article-hero__inner{position:relative;z-index:2;max-width:880px;width:100%;margin:0 auto}
.article-hero__crumbs{
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:rgba(241,231,207,0.7);margin-bottom:20px;font-weight:500;
}
.article-hero__crumbs a{color:var(--yolk);text-decoration:none}
.article-hero__crumbs a:hover{color:var(--cream)}
.article-hero__crumbs span{margin:0 8px;color:rgba(241,231,207,0.4)}
.article-hero__pill{
  display:inline-block;background:var(--yolk);color:var(--ink);
  padding:6px 14px;border-radius:30px;
  font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-weight:700;
  text-decoration:none;margin-bottom:24px;
}
.article-hero__title{
  font-family:'Fraunces',serif;font-weight:200;
  font-size:clamp(34px,5.5vw,72px);line-height:1.05;letter-spacing:-0.02em;
  color:var(--cream);margin:0 0 24px;
}
.article-hero__chapeau{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(18px,1.8vw,22px);line-height:1.45;
  color:var(--cream);opacity:0.92;
  border-left:2px solid var(--yolk);padding-left:24px;
  margin:0 0 24px;
}
.article-hero__meta{
  font-size:12px;letter-spacing:0.1em;color:rgba(241,231,207,0.7);
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
}
.article-hero__meta .dot{color:rgba(241,231,207,0.4)}

/* Body article */
.article-body{padding:80px clamp(20px,5vw,72px);background:var(--teal-deep)}
.article-body__inner{max-width:780px;margin:0 auto}
.article-content{
  font-size:17px;line-height:1.75;color:var(--cream);opacity:0.95;
}
.article-content p{margin-bottom:24px}
.article-content h2{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:34px;color:var(--cream);
  letter-spacing:-0.015em;margin:48px 0 18px;line-height:1.1;
}
.article-content h3{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:24px;color:var(--cream);
  margin:32px 0 12px;line-height:1.2;
}
.article-content em{color:var(--yolk);font-style:italic}
.article-content strong{color:var(--cream);font-weight:600}
.article-content a{color:var(--yolk);text-decoration:underline;text-underline-offset:3px}
.article-content blockquote{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:24px;line-height:1.4;color:var(--cream);
  border-left:2px solid var(--yolk);padding-left:24px;margin:32px 0;
}
.article-content ul,.article-content ol{padding-left:24px;margin-bottom:24px}
.article-content li{margin-bottom:10px;opacity:0.92}
.article-content img,
.article-content__inline-image{
  margin:32px 0;border-radius:6px;display:block;width:100%;height:auto;
}
.article-content figure{margin:32px 0}
.article-content figure img{margin:0}
.article-content figcaption{
  font-size:13px;color:var(--cream);opacity:0.6;font-style:italic;
  text-align:center;margin-top:8px;
}

.article-source{
  margin-top:48px;padding:18px 22px;
  background:var(--teal);border-left:2px solid var(--yolk);border-radius:4px;
  font-size:14px;color:var(--cream);
}
.article-source__label{
  display:block;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;margin-bottom:6px;
}

.article-share{
  margin-top:48px;padding:24px 0;
  border-top:1px solid var(--teal-line);border-bottom:1px solid var(--teal-line);
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  font-size:13px;color:var(--cream);opacity:0.85;
}
.article-share span:first-child{
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--cream);opacity:0.6;font-weight:600;margin-right:6px;
}
.article-share a,.article-share button{
  background:transparent;border:1px solid var(--teal-line);
  color:var(--cream);padding:6px 14px;border-radius:30px;
  font-size:12px;text-decoration:none;cursor:pointer;
  transition:all .2s;font-family:inherit;
}
.article-share a:hover,.article-share button:hover{
  background:var(--yolk);color:var(--ink);border-color:var(--yolk);
}

/* Articles & recettes liés */
.article-related{padding:64px clamp(20px,5vw,72px);background:var(--teal)}
.article-related__head{
  max-width:1100px;margin:0 auto 32px;
  display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:12px;
}
.article-related__head h2{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(24px,3vw,34px);color:var(--cream);margin:0;
}
.article-related__all{
  font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;text-decoration:none;
}
.article-related__grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:20px;
}
.article-related__card{
  display:flex;flex-direction:column;
  background:var(--teal-deep);border:1px solid var(--teal-line);border-radius:8px;
  overflow:hidden;text-decoration:none;color:inherit;transition:all .3s;
}
.article-related__card:hover{transform:translateY(-3px);border-color:var(--yolk)}
.article-related__cover{aspect-ratio:16/10;overflow:hidden}
.article-related__cover img{width:100%;height:100%;object-fit:cover}
.article-related__body{padding:18px 22px}
.article-related__type{
  display:inline-block;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;margin-bottom:8px;
}
.article-related__body h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:18px;color:var(--cream);margin:0 0 6px;line-height:1.2;
}
.article-related__body p{
  font-size:13px;color:var(--yolk);font-style:italic;font-family:'Fraunces',serif;margin:0;
}

/* CTA article */
.article-cta{padding:80px clamp(20px,5vw,72px);background:var(--ink);text-align:center}
.article-cta__inner{max-width:680px;margin:0 auto}
.article-cta__label{
  display:inline-block;font-size:10px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;margin-bottom:18px;
}
.article-cta h2{
  font-family:'Fraunces',serif;font-weight:200;font-style:italic;
  font-size:clamp(28px,4vw,48px);color:var(--cream);
  margin:0 0 18px;
}
.article-cta p{font-size:15px;color:var(--cream);opacity:0.78;line-height:1.6;margin-bottom:32px}
.article-cta__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* =====================================================================
 * ARCHIVE BLOG — Le Journal premium
 * ===================================================================== */

/* Hero */
.journal-hero{
  position:relative;
  padding:140px clamp(20px,5vw,72px) 60px;
  text-align:center;
  background:var(--teal-deep);
  overflow:hidden;
}
.journal-hero__inner{position:relative;z-index:2;max-width:780px;margin:0 auto}
.journal-hero__eyebrow{
  display:inline-block;font-size:11px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;margin-bottom:18px;
}
.journal-hero__title{
  font-family:'Fraunces',serif;font-weight:200;
  font-size:clamp(48px,8vw,128px);line-height:0.95;letter-spacing:-0.035em;
  color:var(--cream);margin:0 0 24px;
}
.journal-hero__title em{color:var(--yolk);font-style:italic;font-weight:300}
.journal-hero__lead{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:clamp(17px,1.6vw,21px);line-height:1.5;
  color:var(--cream);opacity:0.85;max-width:60ch;margin:0 auto;
}

/* Filtres */
.journal-filters{
  padding:24px clamp(20px,5vw,72px);
  background:var(--teal-deep);
  border-top:1px solid var(--teal-line);border-bottom:1px solid var(--teal-line);
  position:sticky;top:64px;z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(11,52,55,0.95);
}
.journal-filters__inner{
  max-width:1100px;margin:0 auto;
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
}
.journal-filter{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--cream);
  border:1px solid var(--teal-line);
  padding:8px 16px;border-radius:30px;
  font-size:12px;letter-spacing:0.04em;font-weight:500;
  text-decoration:none;transition:all .25s;
}
.journal-filter:hover{border-color:var(--yolk);color:var(--yolk)}
.journal-filter.is-active{background:var(--yolk);color:var(--ink);border-color:var(--yolk);font-weight:600}
.journal-filter__count{
  font-size:10px;opacity:0.6;font-weight:400;
  padding:1px 6px;background:rgba(255,255,255,0.1);border-radius:10px;
}
.journal-filter.is-active .journal-filter__count{background:rgba(7,25,27,0.15);opacity:0.85}

/* Article en vedette */
.journal-feature{padding:60px clamp(20px,5vw,72px);background:var(--teal-deep)}
.journal-feature__inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;
  background:var(--teal);
  border:1px solid var(--teal-line);border-radius:12px;overflow:hidden;
  text-decoration:none;color:inherit;
  transition:all .4s;
}
.journal-feature__inner:hover{transform:translateY(-4px);border-color:var(--yolk);box-shadow:0 20px 60px -20px rgba(0,0,0,0.4)}
.journal-feature__cover{position:relative;aspect-ratio:4/3;overflow:hidden}
.journal-feature__cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.journal-feature__inner:hover .journal-feature__cover img{transform:scale(1.04)}
.journal-feature__pill{
  position:absolute;top:18px;left:18px;
  background:var(--yolk);color:var(--ink);
  padding:6px 14px;border-radius:30px;
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;font-weight:700;
}
.journal-feature__body{padding:48px 48px 48px 0}
.journal-feature__label{
  display:inline-block;font-size:11px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--yolk);font-weight:700;margin-bottom:16px;
}
.journal-feature__title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(28px,3.5vw,42px);line-height:1.1;letter-spacing:-0.02em;
  color:var(--cream);margin:0 0 18px;
}
.journal-feature__chapeau{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:17px;line-height:1.5;color:var(--cream);opacity:0.85;
  margin:0 0 24px;
}
.journal-feature__meta{
  font-size:12px;color:var(--cream);opacity:0.65;
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;
}
.journal-feature__meta .dot{color:var(--yolk)}
.journal-feature__cta{
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--yolk);font-weight:600;
  border-bottom:1px solid var(--yolk);padding-bottom:6px;
  display:inline-block;
}

@media(max-width:880px){
  .journal-feature__inner{grid-template-columns:1fr;gap:0}
  .journal-feature__body{padding:32px}
}

/* Grille des articles */
.journal-grid{padding:60px clamp(20px,5vw,72px);background:var(--teal-deep)}
.journal-grid__inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:32px;
}
.journal-pagination{
  margin-top:60px;text-align:center;
}
.journal-pagination .nav-links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.journal-pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 14px;
  border:1px solid var(--teal-line);
  color:var(--cream);text-decoration:none;font-size:13px;font-weight:500;
  transition:all .2s;border-radius:6px;
}
.journal-pagination .page-numbers:hover{border-color:var(--yolk);color:var(--yolk)}
.journal-pagination .page-numbers.current{background:var(--yolk);color:var(--ink);border-color:var(--yolk);font-weight:700}
.journal-pagination .dots{border:none}

/* Empty state */
.journal-empty{padding:120px clamp(20px,5vw,72px);text-align:center;background:var(--teal-deep)}
.journal-empty__inner{max-width:520px;margin:0 auto}
.journal-empty h2{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:clamp(28px,4vw,42px);color:var(--cream);margin:0 0 16px;
}
.journal-empty p{font-size:15px;color:var(--cream);opacity:0.78;margin-bottom:32px}

/* CTA blog */
.journal-cta{padding:80px clamp(20px,5vw,72px);background:var(--ink);text-align:center}
.journal-cta__inner{max-width:680px;margin:0 auto}
.journal-cta h2{
  font-family:'Fraunces',serif;font-weight:200;font-style:italic;
  font-size:clamp(28px,4vw,48px);color:var(--cream);margin:0 0 18px;
}
.journal-cta p{font-size:15px;color:var(--cream);opacity:0.78;line-height:1.6;margin-bottom:32px}

/* PLACEHOLDER COVER */
.bf-placeholder-cover{
  width:100%;height:100%;
  display:block;object-fit:cover;
  background:var(--teal-deep);
}

/* Blog cover : placeholder décoratif quand pas d'image */
.blog-cover--placeholder{
  position:relative;display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.blog-cover--placeholder::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 30%, rgba(232,178,58,0.16) 0%, transparent 60%),
             radial-gradient(ellipse at 70% 70%, rgba(241,231,207,0.06) 0%, transparent 65%);
  pointer-events:none;
}
.blog-cover__decor{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.blog-cover__decor svg{
  position:absolute;inset:0;width:100%;height:100%;
}
.blog-cover__brand{
  position:relative;z-index:1;
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:clamp(20px,3vw,28px);
  color:var(--cream);opacity:0.92;
  letter-spacing:-0.01em;
  text-shadow:0 2px 16px rgba(0,0,0,0.25);
}
.blog-cover__brand em{color:var(--yolk);font-style:italic;font-weight:400}

/* Idem pour les autres covers placeholders */
.journal-feature__cover .blog-cover__brand,
.recipe-related__cover .blog-cover__brand{font-size:32px}

/* RESPONSIVE FIXES — mobile */
@media (max-width:880px){
  .article-hero{padding:90px 20px 40px;min-height:auto}
  .article-hero__title{font-size:clamp(30px,7vw,52px)}
  .article-hero__chapeau{font-size:16px;padding-left:18px}
  .article-hero__pill{padding:5px 12px;font-size:10px}
  .article-body{padding:50px 20px}
  .article-content{font-size:16px;line-height:1.7}
  .article-content h2{font-size:26px;margin:36px 0 14px}
  .article-content h3{font-size:20px;margin:24px 0 10px}
  .article-content blockquote{font-size:18px;padding-left:18px}

  .recipe-hero{padding:90px 20px 40px}
  .recipe-hero__title{font-size:clamp(28px,8vw,46px)}
  .recipe-hero__pairing{font-size:16px;margin-bottom:24px}
  .recipe-hero__stats{gap:14px;flex-direction:column;align-items:flex-start}
  .recipe-hero__stat strong{font-size:20px}
  .recipe-intro{padding:50px 20px}
  .recipe-body{padding:40px 20px 60px}
  .recipe-section-head__num{font-size:36px}
  .recipe-section-head h2{font-size:24px}
  .recipe-step__num-big{font-size:36px}
  .recipe-step__desc{font-size:15px}
  .recipe-chef{padding:50px 20px}
  .recipe-chef__quote{font-size:20px}
  .recipe-gallery{padding:50px 20px}
  .recipe-gallery__grid{grid-template-columns:repeat(2,1fr)}
  .recipe-related{padding:50px 20px}
  .recipe-related__grid{grid-template-columns:1fr}
  .recipe-cta{padding:50px 20px}

  .journal-hero{padding:90px 20px 40px}
  .journal-hero__title{font-size:clamp(40px,11vw,72px)}
  .journal-hero__lead{font-size:16px}
  .journal-filters{padding:14px 16px;position:static}
  .journal-filters__inner{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .journal-filter{flex-shrink:0;font-size:11px;padding:6px 12px}
  .journal-feature{padding:30px 20px}
  .journal-feature__inner{grid-template-columns:1fr;gap:0}
  .journal-feature__body{padding:24px}
  .journal-feature__title{font-size:24px}
  .journal-feature__chapeau{font-size:15px}
  .journal-grid{padding:40px 20px}
  .journal-grid__inner{grid-template-columns:1fr;gap:20px}
  .journal-cta{padding:50px 20px}
  .journal-cta h2{font-size:26px}

  .archive-recettes{padding:90px 20px 60px}
  .archive-recettes__head h1{font-size:clamp(36px,10vw,64px)}
  .archive-recettes__filters{flex-direction:column;align-items:flex-start;gap:14px}
  .archive-recettes__filters .group{margin-left:0 !important;flex-wrap:nowrap;overflow-x:auto;width:100%}

  .blog-cover__brand{font-size:18px}
}

@media (max-width:560px){
  .recipe-hero__stats{padding-top:18px}
  .recipe-hero__stat{gap:10px}
  .recipe-hero__stat .dashicons{font-size:20px;width:20px;height:20px}
  .article-content{font-size:15px}
  .article-hero__meta{font-size:11px}
  .recipe-step{gap:14px;padding:24px 0}
  .recipe-step__num-big{font-size:32px}
  .recipe-gallery__grid{grid-template-columns:1fr}
  .blog-cover__brand{font-size:16px}
}

/* Body padding pour Évin fixed - ajustable selon mobile */
@media (max-width:560px){
  .evin-fixed{font-size:10px;padding:7px 12px;line-height:1.35}
  body{padding-bottom:54px}
}


/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s ease,transform 1s ease}
.reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
  .bubbles span{display:none}
}

/* RESPONSIVE FINS */
@media(max-width:680px){
  section{padding:80px 20px}
  .manifeste{padding:80px 20px}
  .repas{padding:80px 20px}
  .devis{padding:80px 20px}
  .yoan{padding:80px 20px}
  .yoan-grid,.repas-grid,.cercle-intro{gap:32px !important}
  .hero{padding:120px 20px 60px}
  .hero-grid{gap:48px}
  .hero-stats{gap:8px}
  .hero-stat .num{font-size:28px}
  .pq-block{padding:36px 24px}
  .pq-block h3{font-size:30px}
  .repas-card{padding:28px 24px}
  .recette-feature .body{padding:24px 22px}
  .marquee{padding:24px 0}
  .marquee-track{font-size:36px;gap:32px}
  .marquee-track span{gap:32px}
  .punchline blockquote{font-size:32px}
  .single-post__chapeau{font-size:18px}
  .single-recette__steps li{padding-left:60px}
  .single-recette__steps li::before{font-size:32px}
}
@media(max-width:420px){
  .section-head h2{font-size:42px}
  .pq-block h3{font-size:26px}
  .recette-feature h3{font-size:26px}
  .recette-card h4{font-size:18px}
  details.faq-item summary{font-size:19px}
}
