/*
Theme Name: Bulles & Frometons
Theme URI: https://bullesetfrometons.com
Author: Yoan Lureault
Author URI: https://bullesetfrometons.com
Description: Theme sur-mesure pour Bulles & Frometons - Ateliers accords fromages & alcools normands. Page d'accueil entierement personnalisable via le Customizer WordPress.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bulles-frometons
Tags: one-column, custom-menu, featured-images, theme-options, blog
*/

/* ══════════════════════════════════════
   CSS VARIABLES
══════════════════════════════════════ */
:root {
  --bg: #FFFBF0;
  --bg-alt: #FFF6E0;
  --bg-dark: #1a1714;
  --black: #1a1714;
  --black70: rgba(26,23,20,0.7);
  --black45: rgba(26,23,20,0.45);
  --black10: rgba(26,23,20,0.1);
  --white: #ffffff;
  --orange: #FF6B2C;
  --orange-h: #FF8347;
  --yellow: #FFD23F;
  --yellow-pale: #FFF3C4;
  --green: #2D6A4F;
  --green-soft: #40916C;
  --green-light: #D8F3DC;
  --cream: #F5E6C8;
  --purple: #6C3D91;
  --purple-light: #EDE3F5;
  --r: 20px;
  --r-sm: 12px;
  --sh: 4px 4px 0 var(--black);
  --sh-lg: 6px 6px 0 var(--black);
  --sh-xl: 8px 8px 0 var(--black);
  --ease: 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
}

/* ══════════════════════════════════════
   RESET & BASE
══════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
::selection{background:var(--orange);color:#fff}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--black);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}

/* ── TYPE ── */
.td{font-family:'Outfit',sans-serif;font-weight:900;letter-spacing:-0.04em;line-height:0.94}
.ts{font-family:'Fraunces',serif;font-style:italic;font-weight:400}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.85rem 2rem;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.9rem;text-decoration:none;border:2.5px solid var(--black);border-radius:50px;transition:all var(--ease);cursor:pointer;white-space:nowrap}
.btn-fill{background:var(--orange);color:#fff;box-shadow:var(--sh)}
.btn-fill:hover{background:var(--orange-h);transform:translate(-2px,-2px);box-shadow:var(--sh-lg)}
.btn-fill:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--black)}
.btn-outline{background:transparent;color:var(--black);box-shadow:var(--sh)}
.btn-outline:hover{background:var(--yellow);transform:translate(-2px,-2px);box-shadow:var(--sh-lg)}
.btn-white{background:#fff;color:var(--orange);box-shadow:var(--sh)}
.btn-white:hover{transform:translate(-2px,-2px);box-shadow:var(--sh-lg)}
.btn-dark{background:var(--black);color:#fff;box-shadow:none}
.btn-dark:hover{background:#333;transform:translate(-1px,-1px)}
.btn-sm{padding:0.6rem 1.4rem;font-size:0.8rem}
.btn-lg{padding:1rem 2.8rem;font-size:1.05rem}

/* ── PILLS ── */
.pill{display:inline-flex;align-items:center;gap:0.4rem;background:var(--yellow);border:2px solid var(--black);border-radius:50px;padding:0.35rem 1rem;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;box-shadow:3px 3px 0 var(--black)}
.pill-green{background:var(--green-light)}
.pill-purple{background:var(--purple-light)}
.pill-orange{background:var(--orange);color:#fff}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:0.7rem 2rem;display:flex;justify-content:space-between;align-items:center;background:rgba(255,251,240,0.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:2.5px solid var(--black)}
.nav-logo{font-weight:900;font-size:1.3rem;color:var(--black);text-decoration:none;display:flex;align-items:center;gap:0.3rem;letter-spacing:-0.02em}
.nav-logo .amp{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:var(--orange);color:#fff;border-radius:50%;font-size:0.85rem;font-weight:800;flex-shrink:0}
.nav-links{display:flex;gap:0.3rem;align-items:center;list-style:none}
.nav-links a{color:var(--black);text-decoration:none;font-size:0.85rem;font-weight:500;padding:0.5rem 0.9rem;border-radius:50px;transition:all var(--ease)}
.nav-links a:hover{background:var(--yellow-pale)}
.nav-links .btn{margin-left:0.5rem}
.nav-toggle{display:none;background:none;border:2px solid var(--black);border-radius:8px;width:42px;height:42px;cursor:pointer;position:relative;flex-shrink:0}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--black);position:absolute;left:50%;transform:translateX(-50%);transition:all 0.3s;border-radius:2px}
.nav-toggle span:nth-child(1){top:13px}
.nav-toggle span:nth-child(2){top:20px}
.nav-toggle span:nth-child(3){top:27px}
.nav-toggle.open span:nth-child(1){top:20px;transform:translateX(-50%) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:20px;transform:translateX(-50%) rotate(-45deg)}

/* MOBILE MENU */
.mmenu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:150;background:var(--bg);padding:5.5rem 2rem 2rem;flex-direction:column;gap:0.3rem;overflow-y:auto}
.mmenu.open{display:flex}
.mmenu a{display:block;font-size:1.6rem;font-weight:800;color:var(--black);text-decoration:none;padding:0.7rem 0;border-bottom:2px solid var(--black10);transition:color 0.2s}
.mmenu a:hover{color:var(--orange)}
.mmenu .btn{margin-top:1.5rem;text-align:center;justify-content:center;font-size:1.05rem;padding:1rem}

/* MOBILE CTA */
.mcta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;padding:0.7rem 1rem;background:rgba(255,251,240,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:2.5px solid var(--black)}
.mcta .btn{width:100%;justify-content:center}

/* ── IMAGES ── */
.img-frame{border:2.5px solid var(--black);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-xl);position:relative}
.img-frame img{display:block;width:100%;height:100%;object-fit:cover}

/* ── SECTION UTILS ── */
section{padding:6rem 3rem}
.ctn{max-width:1140px;margin:0 auto}
.s-head{margin-bottom:3.5rem}
.s-title{font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.08;letter-spacing:-0.035em;max-width:650px}
.s-sub{margin-top:1rem;font-size:1.05rem;color:var(--black70);max-width:520px;line-height:1.7}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:1.1fr 1fr;align-items:center;gap:4rem;padding:7rem 3rem 4rem;overflow:hidden}
.hero-content{position:relative;z-index:2}
.hero-badge{margin-bottom:1.5rem;opacity:0;animation:popIn 0.5s ease forwards 0.2s}
.hero h1{font-size:clamp(3rem,7vw,6rem);opacity:0;animation:slideUp 0.7s ease forwards 0.35s}
.hero h1 .line{display:block}
.hero h1 .hl{color:var(--orange)}
.hero-desc{max-width:480px;margin-top:1.8rem;font-size:1.1rem;color:var(--black70);line-height:1.75;opacity:0;animation:slideUp 0.7s ease forwards 0.55s}
.hero-cta{margin-top:2.2rem;display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:slideUp 0.7s ease forwards 0.7s}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center}
.hero-img-main{width:100%;max-width:480px;aspect-ratio:4/5;opacity:0;animation:slideUp 0.8s ease forwards 0.5s}
.hero-img-main img{border-radius:var(--r)}
.hero-float{position:absolute;background:#fff;border:2.5px solid var(--black);border-radius:var(--r-sm);padding:0.8rem 1.2rem;box-shadow:var(--sh-lg);display:flex;align-items:center;gap:0.7rem;opacity:0}
.hero-float-1{bottom:15%;left:-10%;animation:floatIn 0.6s ease forwards 0.9s}
.hero-float-2{top:10%;right:-5%;animation:floatIn 0.6s ease forwards 1.1s}
.hero-float-emoji{font-size:1.8rem}
.hero-float-text{font-weight:700;font-size:0.85rem;line-height:1.3}
.hero-float-text small{display:block;font-weight:400;font-size:0.75rem;color:var(--black45)}

@keyframes floatIn{from{opacity:0;transform:translateY(20px) scale(0.9)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes slideUp{from{opacity:0;transform:translateY(35px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{opacity:0;transform:scale(0.85)}to{opacity:1;transform:scale(1)}}

/* ── TICKER ── */
.ticker{padding:0.85rem 0;border-top:2.5px solid var(--black);border-bottom:2.5px solid var(--black);background:var(--orange);overflow:hidden}
.ticker-track{display:flex;animation:tick 24s linear infinite;width:max-content}
.ticker-item{font-weight:800;font-size:0.85rem;text-transform:uppercase;letter-spacing:0.06em;color:#fff;white-space:nowrap;padding:0 0.8rem;display:flex;align-items:center;gap:0.8rem}
.ticker-dot{width:6px;height:6px;background:var(--yellow);border-radius:50%;flex-shrink:0}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══════════════════════════════════════
   HOW IT WORKS
══════════════════════════════════════ */
.how{background:var(--bg)}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.how-step{background:#fff;border:2.5px solid var(--black);border-radius:var(--r);padding:2rem 1.5rem;position:relative;box-shadow:var(--sh);transition:all var(--ease)}
.how-step:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-xl)}
.how-num{position:absolute;top:-12px;left:16px;background:var(--orange);color:#fff;font-weight:800;font-size:0.8rem;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:2.5px solid var(--black)}
.how-icon{font-size:2.2rem;margin-bottom:1rem;display:block}
.how-step h3{font-weight:800;font-size:1.05rem;margin-bottom:0.5rem}
.how-step p{color:var(--black70);font-size:0.88rem;line-height:1.6}

/* ══════════════════════════════════════
   OFFERS
══════════════════════════════════════ */
/* ── PARTICULIERS ── */
.offer-part{background:var(--bg-alt);border-top:2.5px solid var(--black)}
.offer-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.offer-img{aspect-ratio:4/3}
.offer-img img{width:100%;height:100%;object-fit:cover}
.offer-occasions{display:flex;flex-wrap:wrap;gap:0.5rem;margin:1.2rem 0 1.5rem}
.offer-occ{display:inline-flex;align-items:center;gap:0.3rem;background:#fff;border:2px solid var(--black);border-radius:50px;padding:0.4rem 1rem;font-size:0.8rem;font-weight:600;box-shadow:2px 2px 0 var(--black);transition:all var(--ease)}
.offer-occ:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--black);background:var(--yellow-pale)}
.offer-text p{color:var(--black70);font-size:1rem;line-height:1.75;margin-bottom:1rem}
.offer-text p strong{color:var(--orange);font-weight:600}

/* ── ENTREPRISES ── */
.offer-corp{background:var(--green);color:#fff;border-top:2.5px solid var(--black)}
.offer-corp .pill{color:var(--black)}
.offer-corp .s-title{color:#fff}
.offer-corp .offer-text p{color:rgba(255,255,255,0.75)}
.offer-corp .offer-text p strong{color:var(--yellow)}
.offer-corp .offer-occ{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.25);color:#fff;box-shadow:none}
.offer-corp .offer-occ:hover{background:rgba(255,255,255,0.2)}

/* ── ESCAPE GAME ── */
.offer-escape{background:var(--bg-dark);color:#fff;border-top:2.5px solid var(--black);position:relative;overflow:hidden}
.offer-escape::before{content:'';position:absolute;font-size:8rem;opacity:0.04;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;letter-spacing:3rem;pointer-events:none}
.offer-escape .pill{color:var(--black)}
.offer-escape .s-title{color:#fff}
.offer-escape .offer-text p{color:rgba(255,255,255,0.7)}
.offer-escape .offer-text p strong{color:var(--yellow)}
.escape-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.escape-step{background:rgba(255,255,255,0.06);border:2px solid rgba(255,255,255,0.12);border-radius:var(--r-sm);padding:1.5rem;text-align:center;transition:all var(--ease)}
.escape-step:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.25)}
.escape-step-icon{font-size:2rem;margin-bottom:0.8rem;display:block}
.escape-step h4{font-weight:800;font-size:0.95rem;margin-bottom:0.3rem}
.escape-step p{font-size:0.82rem;color:rgba(255,255,255,0.5);line-height:1.5}
.new-badge{display:inline-block;background:var(--orange);color:#fff;font-size:0.65rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;padding:0.2rem 0.6rem;border-radius:50px;margin-left:0.5rem;vertical-align:middle;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.6}}

/* ── PRICE ── */
.price{background:var(--yellow);border-top:2.5px solid var(--black);border-bottom:2.5px solid var(--black);padding:3rem}
.price-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.price-col{display:flex;align-items:baseline;gap:0.8rem}
.price-big{font-weight:900;font-size:clamp(2.5rem,5vw,3.8rem);letter-spacing:-0.04em;line-height:1}
.price-per{font-size:0.95rem;font-weight:500;color:var(--black70)}
.price-center{font-size:0.95rem;max-width:320px;color:var(--black70);line-height:1.6}

/* ══════════════════════════════════════
   PRODUCTS SCROLL
══════════════════════════════════════ */
.products{background:var(--bg)}
.prod-scroll{display:flex;gap:1rem;overflow-x:auto;padding:0.5rem 0 2rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.prod-scroll::-webkit-scrollbar{display:none}
.prod-chip{flex-shrink:0;scroll-snap-align:start;background:#fff;border:2.5px solid var(--black);border-radius:var(--r);padding:1.2rem;min-width:180px;box-shadow:var(--sh);transition:all var(--ease);text-align:center}
.prod-chip:hover{transform:translate(-2px,-2px);box-shadow:var(--sh-lg)}
.prod-chip.is-drink{background:var(--yellow-pale)}
.prod-emoji{font-size:2.2rem;margin-bottom:0.6rem;display:block}
.prod-name{font-weight:800;font-size:0.9rem;margin-bottom:0.2rem}
.prod-type{font-size:0.75rem;color:var(--black45);text-transform:uppercase;letter-spacing:0.05em}

/* ══════════════════════════════════════
   DOWNLOAD BLOCK
══════════════════════════════════════ */
.download{background:var(--cream);border-top:2.5px solid var(--black);border-bottom:2.5px solid var(--black)}
.dl-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.dl-preview{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.dl-card{background:#fff;border:2.5px solid var(--black);border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--sh);transition:all var(--ease);cursor:pointer}
.dl-card:hover{transform:translate(-2px,-2px);box-shadow:var(--sh-lg)}
.dl-card-img{aspect-ratio:3/4;overflow:hidden}
.dl-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.dl-card:hover .dl-card-img img{transform:scale(1.05)}
.dl-card-label{padding:0.8rem;font-weight:700;font-size:0.82rem;text-align:center;border-top:2px solid var(--black)}
.dl-text h2{margin-bottom:1rem}
.dl-text p{color:var(--black70);font-size:1rem;line-height:1.75;margin-bottom:1rem}
.dl-form{display:flex;gap:0.5rem;margin-top:1.5rem;flex-wrap:wrap}
.dl-input{flex:1;min-width:200px;padding:0.85rem 1.2rem;border:2.5px solid var(--black);border-radius:50px;font-family:'Outfit',sans-serif;font-size:0.9rem;background:#fff;outline:none;transition:border-color 0.2s}
.dl-input:focus{border-color:var(--orange)}
.dl-input::placeholder{color:var(--black45)}

/* ══════════════════════════════════════
   ABOUT
══════════════════════════════════════ */
.about{background:var(--bg-alt);border-top:2.5px solid var(--black)}
.about-grid{display:grid;grid-template-columns:320px 1fr;gap:4rem;align-items:center}
.about-photo{border:2.5px solid var(--black);border-radius:var(--r);box-shadow:var(--sh-xl);overflow:hidden;position:relative}
.about-photo img{display:block;width:100%;aspect-ratio:3/4;object-fit:cover}
.about-photo-tag{position:absolute;top:-10px;right:-10px;background:var(--yellow);border:2px solid var(--black);border-radius:50%;width:65px;height:65px;display:flex;align-items:center;justify-content:center;font-size:0.6rem;font-weight:800;text-transform:uppercase;text-align:center;line-height:1.2;transform:rotate(12deg);box-shadow:3px 3px 0 var(--black)}
.about-text h2{font-weight:900;font-size:2.5rem;letter-spacing:-0.03em;margin-bottom:1.5rem}
.about-text p{font-size:1.05rem;color:var(--black70);line-height:1.8;margin-bottom:1.2rem}
.about-text p strong{color:var(--orange);font-weight:600}

/* ══════════════════════════════════════
   FAQ
══════════════════════════════════════ */
.faq{background:#fff;border-top:2.5px solid var(--black)}
.faq-list{max-width:700px}
.faq-item{border-bottom:2px solid var(--black10)}
.faq-q{width:100%;background:none;border:none;padding:1.3rem 0;font-family:'Outfit',sans-serif;font-weight:700;font-size:1.05rem;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--black);transition:color 0.2s;gap:1rem}
.faq-q:hover{color:var(--orange)}
.faq-icon{width:28px;height:28px;background:var(--yellow-pale);border:2px solid var(--black);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;transition:all 0.3s;font-weight:400}
.faq-item.open .faq-icon{background:var(--orange);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.faq-item.open .faq-a{max-height:250px}
.faq-a p{color:var(--black70);font-size:0.93rem;line-height:1.7;padding-bottom:1.3rem}

/* ══════════════════════════════════════
   CTA FINAL
══════════════════════════════════════ */
.cta-final{background:var(--orange);border-top:2.5px solid var(--black);text-align:center;padding:8rem 3rem;position:relative;overflow:hidden}
.cta-shapes{position:absolute;inset:0;pointer-events:none}
.cta-shape{position:absolute;border-radius:50%;border:3px solid rgba(255,255,255,0.12)}
.cta-shape-1{width:300px;height:300px;top:-80px;right:-60px}
.cta-shape-2{width:200px;height:200px;bottom:-50px;left:-40px}
.cta-final h2{font-weight:900;font-size:clamp(2.5rem,5vw,4rem);color:#fff;line-height:1.08;letter-spacing:-0.03em;margin-bottom:1rem;position:relative}
.cta-final p{color:rgba(255,255,255,0.85);font-size:1.1rem;max-width:460px;margin:0 auto 2.5rem;line-height:1.6;position:relative}
.cta-final .btn{position:relative}

/* TALLY FORM EMBED */
.cta-form{max-width:560px;margin:0 auto;position:relative;z-index:2}
.cta-form iframe{width:100%;border:none;border-radius:var(--r);min-height:200px}

/* ══════════════════════════════════════
   ALCOHOL WARNING
══════════════════════════════════════ */
.alcohol-warning{background:var(--black);color:rgba(255,255,255,0.6);text-align:center;padding:1rem 2rem;font-size:0.78rem;line-height:1.5;border-top:2.5px solid var(--black)}
.alcohol-warning strong{color:rgba(255,255,255,0.85);font-weight:600}

/* ── FOOTER ── */
.site-footer{padding:2rem 3rem;border-top:2.5px solid var(--black);display:flex;justify-content:space-between;align-items:center;font-size:0.8rem;color:var(--black45);background:var(--bg)}
.site-footer a{color:var(--black45);text-decoration:none;transition:color 0.2s}
.site-footer a:hover{color:var(--orange)}
.footer-links{display:flex;gap:2rem;list-style:none}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(30px);transition:all 0.7s cubic-bezier(0.16,1,0.3,1)}
.rv.vis{opacity:1;transform:translateY(0)}
.stg.vis>*{opacity:1!important;transform:translateY(0)!important}
.stg>*{opacity:0;transform:translateY(25px);transition:all 0.6s cubic-bezier(0.16,1,0.3,1)}
.stg.vis>*:nth-child(1){transition-delay:0s}
.stg.vis>*:nth-child(2){transition-delay:0.08s}
.stg.vis>*:nth-child(3){transition-delay:0.16s}
.stg.vis>*:nth-child(4){transition-delay:0.24s}

/* ══════════════════════════════════════
   BLOG
══════════════════════════════════════ */
/* BLOG HERO */
.blog-hero{background:var(--bg-alt);border-bottom:2.5px solid var(--black);padding:8rem 3rem 4rem}
.blog-hero .ctn{text-align:center}
.blog-hero h1{font-size:clamp(2.5rem,5vw,4rem);margin-bottom:0.5rem}
.blog-hero p{color:var(--black70);font-size:1.1rem;max-width:500px;margin:0.8rem auto 0}

/* BLOG GRID */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem;padding:4rem 3rem;max-width:1200px;margin:0 auto}

/* BLOG CARD */
.blog-card{background:#fff;border:2.5px solid var(--black);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);transition:all var(--ease);text-decoration:none;color:var(--black);display:flex;flex-direction:column;height:100%}
.blog-card:hover{transform:translate(-3px,-3px);box-shadow:var(--sh-xl)}
.blog-card-img{aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--cream)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}

/* Placeholder quand pas d'image à la une */
.blog-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--cream) 0%,var(--yellow-pale) 100%);position:absolute;inset:0}
.blog-card-placeholder span{font-size:3.5rem;opacity:0.5}

.blog-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.blog-card-meta{font-size:0.75rem;color:var(--black45);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:0.6rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.blog-card-cat{background:var(--yellow-pale);border:1.5px solid var(--black);border-radius:50px;padding:0.15rem 0.6rem;font-weight:700;font-size:0.7rem}
.blog-card-body h2{font-weight:800;font-size:1.15rem;line-height:1.3;margin-bottom:0.6rem;letter-spacing:-0.02em}
.blog-card-body p{color:var(--black70);font-size:0.88rem;line-height:1.6;flex:1}
.blog-card-link{display:inline-flex;align-items:center;gap:0.3rem;font-weight:700;font-size:0.85rem;color:var(--orange);margin-top:1rem;text-decoration:none;transition:gap 0.2s}
.blog-card-link:hover{gap:0.6rem}

/* SINGLE POST */
.single-hero{background:var(--bg-alt);border-bottom:2.5px solid var(--black);padding:8rem 3rem 3rem}
.single-hero .ctn{max-width:800px}
.single-hero .blog-card-meta{margin-bottom:1rem}
.single-hero h1{font-size:clamp(2rem,4vw,3rem);line-height:1.12;letter-spacing:-0.03em}

.single-content{max-width:760px;margin:0 auto;padding:3rem 3rem 5rem}
.single-content p{font-size:1.05rem;line-height:1.85;color:var(--black70);margin-bottom:1.5rem}
.single-content h2{font-weight:800;font-size:1.6rem;margin:2.5rem 0 1rem;letter-spacing:-0.02em;color:var(--black)}
.single-content h3{font-weight:700;font-size:1.25rem;margin:2rem 0 0.8rem;color:var(--black)}
.single-content img{border:2.5px solid var(--black);border-radius:var(--r);box-shadow:var(--sh);margin:2rem 0;max-width:100%;height:auto}
.single-content blockquote{border-left:4px solid var(--orange);padding:1rem 1.5rem;margin:2rem 0;background:var(--yellow-pale);border-radius:0 var(--r-sm) var(--r-sm) 0;font-style:italic}
.single-content blockquote p{margin-bottom:0;color:var(--black)}
.single-content ul,.single-content ol{margin:1rem 0 1.5rem 1.5rem;color:var(--black70)}
.single-content li{margin-bottom:0.5rem;line-height:1.7}
.single-content a{color:var(--orange);font-weight:600;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:2px}
.single-content a:hover{color:var(--orange-h)}

/* PAGINATION */
.pagination{display:flex;justify-content:center;gap:0.5rem;padding:0 3rem 4rem;flex-wrap:wrap}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:2px solid var(--black);border-radius:50%;font-weight:700;font-size:0.85rem;text-decoration:none;color:var(--black);transition:all var(--ease)}
.pagination a:hover{background:var(--yellow);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--black)}
.pagination .current{background:var(--orange);color:#fff;box-shadow:var(--sh)}
.pagination .prev,.pagination .next{width:auto;padding:0 1.2rem;border-radius:50px}

/* PAGE TEMPLATE */
.page-hero{background:var(--bg-alt);border-bottom:2.5px solid var(--black);padding:8rem 3rem 4rem;text-align:center}
.page-hero h1{font-size:clamp(2rem,4vw,3.2rem)}
.page-content{max-width:800px;margin:0 auto;padding:3rem 3rem 5rem}
.page-content p{font-size:1.05rem;line-height:1.85;color:var(--black70);margin-bottom:1.5rem}
.page-content h2{font-weight:800;font-size:1.6rem;margin:2.5rem 0 1rem;letter-spacing:-0.02em}
.page-content img{border:2.5px solid var(--black);border-radius:var(--r);box-shadow:var(--sh);margin:2rem 0;max-width:100%;height:auto}

/* 404 */
.page-404{text-align:center;padding:10rem 3rem;min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center}
.page-404 h1{font-size:clamp(4rem,10vw,8rem);color:var(--orange)}
.page-404 p{font-size:1.2rem;color:var(--black70);margin:1rem 0 2rem;max-width:400px}

/* COMMENTS */
.comments-area{border-top:2px solid var(--black10);margin-top:2rem;padding-top:2rem}
.comment-list .comment{padding:1.5rem;margin-bottom:1rem;background:var(--bg-alt);border:2px solid var(--black10);border-radius:var(--r-sm)}
.comment-list .comment-author{font-weight:700;font-size:0.9rem;margin-bottom:0.3rem}
.comment-list .comment-author img{border-radius:50%;margin-right:0.5rem;vertical-align:middle;border:2px solid var(--black)}
.comment-list .comment-meta{font-size:0.75rem;color:var(--black45);margin-bottom:0.8rem}
.comment-list .comment-content p{font-size:0.93rem;color:var(--black70);line-height:1.7;margin-bottom:0}
.comment-list .reply a{font-size:0.8rem;color:var(--orange);font-weight:600;text-decoration:none}
.comment-respond label{display:block;font-weight:600;font-size:0.85rem;margin-bottom:0.3rem;margin-top:1rem}
.comment-respond input[type="text"],.comment-respond input[type="email"],.comment-respond input[type="url"],.comment-respond textarea{width:100%;padding:0.75rem 1rem;border:2.5px solid var(--black);border-radius:var(--r-sm);font-family:'Outfit',sans-serif;font-size:0.9rem;background:#fff;outline:none;transition:border-color 0.2s}
.comment-respond input:focus,.comment-respond textarea:focus{border-color:var(--orange)}
.comment-respond textarea{min-height:120px;resize:vertical}
.comment-respond .submit{margin-top:1rem}

/* POST NAVIGATION */
.post-navigation{display:flex;justify-content:space-between;gap:2rem;padding-top:2rem;border-top:2px solid var(--black10)}
.post-navigation .nav-links{display:flex;justify-content:space-between;width:100%;gap:2rem}
.post-navigation .nav-previous,.post-navigation .nav-next{max-width:48%}
.post-navigation a{text-decoration:none;color:var(--black);transition:color 0.2s}
.post-navigation a:hover{color:var(--orange)}
.post-navigation a strong{font-size:0.9rem;display:block;margin-top:0.3rem}

/* WP PAGINATION (.nav-links from WP core) */
.pagination .nav-links{display:flex;justify-content:center;gap:0.5rem;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:2px solid var(--black);border-radius:50%;font-weight:700;font-size:0.85rem;text-decoration:none;color:var(--black);transition:all var(--ease)}
.pagination .page-numbers:hover{background:var(--yellow);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--black)}
.pagination .page-numbers.current{background:var(--orange);color:#fff;box-shadow:var(--sh)}
.pagination .page-numbers.prev,.pagination .page-numbers.next{width:auto;padding:0 1.2rem;border-radius:50px}

/* NAV SHRINK TRANSITION */
nav.site-nav{transition:padding 0.3s ease}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:6.5rem}
  .hero-visual{max-width:400px;margin:2rem auto 0}
  .offer-grid{grid-template-columns:1fr;gap:2.5rem}
  .offer-grid.rev{direction:ltr}
  .dl-grid{grid-template-columns:1fr}
  .dl-preview{order:-1}
}
@media(max-width:900px){
  nav.site-nav{padding:0.7rem 1.2rem}
  .nav-links{display:none}
  .nav-toggle{display:flex;align-items:center;justify-content:center}
  .mcta{display:block}
  section{padding:4rem 1.5rem}
  .hero{padding:6rem 1.5rem 3rem;gap:2rem}
  .hero h1{font-size:clamp(2.6rem,10vw,4rem)}
  .hero-float{display:none}
  .how-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .escape-steps{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-photo{max-width:260px;margin:0 auto}
  .price-inner{flex-direction:column;text-align:center}
  .price-center{max-width:none}
  .dl-form{flex-direction:column}
  .dl-input{min-width:auto}
  .site-footer{flex-direction:column;gap:1rem;text-align:center;padding:2rem 1.5rem 5.5rem}
  .footer-links{justify-content:center;flex-wrap:wrap;gap:1rem}
  .cta-final{padding:5rem 1.5rem 6rem}
  .s-head{margin-bottom:2.5rem}
  .blog-grid{grid-template-columns:1fr;padding:3rem 1.5rem;gap:1.5rem}
  .single-content,.page-content{padding:2rem 1.5rem 4rem}
  .blog-hero,.single-hero,.page-hero{padding:7rem 1.5rem 3rem}
  .cta-form{max-width:100%;padding:0 0.5rem}
}
@media(max-width:500px){
  .how-grid{grid-template-columns:1fr}
  .dl-preview{grid-template-columns:1fr 1fr}
}
