/*
Theme Name: PFG Brodard
Theme URI: https://example.com/pfg-brodard
Author: Thème généré sur mesure
Author URI: https://example.com
Description: Thème WordPress sobre et digne pour pompes funèbres / services funéraires, inspiré du site de PFG Brodard SA. Hero plein écran, section à propos avec compteurs, services, forfaits et contact. Entièrement configurable via l'outil de personnalisation.
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pfg-brodard
Tags: funeral, business, services, full-site-editing-ready, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --ink:        #0E1E33;   /* bleu marine profond : header, hero, footer */
  --ink-soft:   #16304F;   /* surfaces bleu foncé secondaires */
  --ivory:      #F2F6FB;   /* fond bleu très clair principal */
  --paper:      #FFFFFF;   /* cartes */
  --sand:       #E2EAF4;   /* surfaces bleu pâle */
  --accent:     #2F6DB0;   /* bleu accent */
  --accent-dk:  #235488;   /* bleu accent survol */
  --stone:      #586A7E;   /* texte secondaire bleu-gris */
  --line:       #D2DEEC;   /* filets fins clairs */
  --line-dk:    rgba(255,255,255,.14); /* filets sur fond sombre */

  --font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --wrap: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 5px;
  --shadow: 0 24px 60px -28px rgba(14,30,51,.45);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-dk);text-decoration:none;transition:color .25s var(--ease)}
a:hover{color:var(--ink)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.08;margin:0 0 .4em;letter-spacing:.005em}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}
p{margin:0 0 1.1em}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--ink{background:var(--ink);color:var(--ivory)}
.section--sand{background:var(--sand)}
.eyebrow{
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent-dk);
  margin:0 0 1rem;
  display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent)}
.section--ink .eyebrow{color:var(--accent)}
.lead{font-size:1.12rem;color:var(--stone);max-width:62ch}
.section--ink .lead{color:rgba(246,243,236,.78)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  --bg:var(--accent);--fg:#fff;--bd:var(--accent);
  display:inline-flex;align-items:center;gap:.6rem;
  font-weight:600;font-size:.92rem;letter-spacing:.04em;
  padding:.95rem 1.8rem;border-radius:var(--radius);
  background:var(--bg);color:var(--fg);border:1px solid var(--bd);
  cursor:pointer;transition:all .28s var(--ease);text-transform:uppercase;
}
.btn:hover{background:var(--accent-dk);border-color:var(--accent-dk);color:#fff;transform:translateY(-2px)}
.btn--ghost{--bg:transparent;--fg:var(--ivory);--bd:rgba(246,243,236,.4)}
.btn--ghost:hover{--bg:rgba(246,243,236,.08);color:var(--ivory);border-color:var(--ivory)}
.btn--urgent{--bg:#7c2d2d;--bd:#7c2d2d}
.btn--urgent:hover{background:#612121;border-color:#612121}
.btn--dark{--bg:var(--ink);--bd:var(--ink)}
.btn--dark:hover{background:#000;border-color:#000}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;padding:1.1rem var(--gutter);
  transition:background .35s var(--ease),padding .35s var(--ease),box-shadow .35s var(--ease);
}
.site-header.is-scrolled{
  background:rgba(14,30,51,.96);
  backdrop-filter:saturate(140%) blur(8px);
  padding-block:.7rem;
  box-shadow:0 10px 30px -20px rgba(0,0,0,.8);
}
.brand{display:flex;align-items:center;gap:.85rem;color:#fff}
.brand:hover{color:#fff}
.brand__mark{
  width:46px;height:46px;border:1px solid var(--accent);border-radius:50%;
  display:grid;place-items:center;flex:0 0 auto;
  font-family:var(--font-display);font-size:1.25rem;color:var(--accent);font-weight:600;
}
.brand__name{font-family:var(--font-display);font-size:1.35rem;line-height:1;color:#fff;letter-spacing:.02em}
.brand__name small{display:block;font-family:var(--font-body);font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-top:.3rem}
.site-nav{display:flex;align-items:center;gap:2.2rem}
.menu{display:flex;align-items:center;gap:1.7rem;list-style:none;margin:0;padding:0}
.menu a{
  color:rgba(246,243,236,.86);font-size:.92rem;font-weight:500;letter-spacing:.02em;
  position:relative;padding-block:.4rem;
}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);transition:width .3s var(--ease)}
.menu a:hover,.menu .current-menu-item>a{color:#fff}
.menu a:hover::after,.menu .current-menu-item>a::after{width:100%}
.header-phone{
  display:inline-flex;align-items:center;gap:.5rem;color:#fff;font-weight:600;font-size:.95rem;
  border:1px solid var(--accent);padding:.55rem 1rem;border-radius:var(--radius);
}
.header-phone:hover{background:var(--accent);color:#fff}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px}
.nav-toggle span{display:block;width:24px;height:2px;background:#fff;margin:5px auto;transition:.3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  color:var(--ivory);overflow:hidden;
}
.hero__bg{position:absolute;left:0;right:0;top:-8%;height:116%;z-index:0;will-change:transform}
.hero__bg img{width:100%;height:100%;object-fit:cover;animation:kenburns 26s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.14)}}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,30,51,.55) 0%,rgba(14,30,51,.5) 40%,rgba(14,30,51,.88) 100%);
}
.hero__inner{position:relative;z-index:1;width:100%;padding-top:120px;padding-bottom:60px}
.hero__avail{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  color:var(--accent);margin-bottom:1.4rem;
}
.hero__avail .dot{width:8px;height:8px;border-radius:50%;background:#5fa376;box-shadow:0 0 0 0 rgba(95,163,118,.7);animation:pulse 2.2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 12px rgba(95,163,118,0)}100%{box-shadow:0 0 0 0 rgba(95,163,118,0)}}
.hero h1{margin:0;max-width:16ch}
.hero h1 em{font-style:normal;color:var(--accent);display:block}
.hero__text{margin:1.6rem 0 2.4rem;max-width:54ch;font-size:1.12rem;color:rgba(246,243,236,.85)}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem}
.hero__year{
  position:absolute;right:var(--gutter);bottom:48px;z-index:1;
  writing-mode:vertical-rl;text-orientation:mixed;
  font-family:var(--font-display);font-size:1rem;letter-spacing:.5em;
  color:rgba(246,243,236,.5);text-transform:uppercase;
}
.hero__year strong{color:var(--accent);font-weight:600}
@media (max-width:760px){.hero__year{display:none}}

/* Entrée du hero en cascade au chargement */
.hero__avail,.hero h1,.hero__text,.hero__cta{opacity:0;animation:heroIn .9s var(--ease) forwards}
.hero__avail{animation-delay:.15s}
.hero h1{animation-delay:.30s}
.hero__text{animation-delay:.55s}
.hero__cta{animation-delay:.75s}
@keyframes heroIn{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* Indicateur de défilement */
.hero__scroll{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:1;display:flex;flex-direction:column;align-items:center;gap:.7rem;color:rgba(246,243,236,.55);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;opacity:0;animation:heroIn 1s var(--ease) 1s forwards}
.hero__scroll .line{width:1px;height:46px;background:rgba(246,243,236,.18);position:relative;overflow:hidden}
.hero__scroll .line::after{content:"";position:absolute;left:0;top:-60%;width:100%;height:60%;background:linear-gradient(var(--accent),transparent);animation:scrollDot 2.1s var(--ease) infinite}
@keyframes scrollDot{0%{top:-60%}60%,100%{top:110%}}
@media (max-width:760px){.hero__scroll{display:none}}

/* ============================================================
   ABOUT
   ============================================================ */
.about{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,80px);align-items:center}
.about__media{position:relative}
.about__media img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}
.about__badge{
  position:absolute;left:-22px;bottom:-22px;background:var(--ink);color:var(--ivory);
  padding:1.4rem 1.6rem;border-radius:var(--radius);text-align:center;border:1px solid var(--line-dk);
}
.about__badge b{font-family:var(--font-display);font-size:2.6rem;color:var(--accent);display:block;line-height:1}
.about__badge span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(246,243,236,.7)}
.stats{display:flex;gap:2.5rem;margin:2rem 0;flex-wrap:wrap}
.stat b{font-family:var(--font-display);font-size:2.8rem;color:var(--accent);display:block;line-height:1}
.stat span{font-size:.85rem;color:var(--stone);letter-spacing:.04em}
.director{display:flex;align-items:center;gap:1rem;margin-top:1.6rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.director img{width:64px;height:64px;border-radius:50%;object-fit:cover}
.director b{font-family:var(--font-display);font-size:1.25rem;display:block;line-height:1.1}
.director span{font-size:.85rem;color:var(--stone);letter-spacing:.04em}

/* ============================================================
   SERVICES
   ============================================================ */
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,64px)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card__media{aspect-ratio:4/3;overflow:hidden;background:var(--sand)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card__media img{transform:scale(1.06)}
.card__body{padding:1.6rem 1.5rem 1.8rem}
.card__body h3{margin-bottom:.5rem}
.card__body p{color:var(--stone);font-size:.97rem;margin-bottom:1.1rem}
.card__more{font-weight:600;font-size:.86rem;letter-spacing:.06em;text-transform:uppercase;display:inline-flex;gap:.4rem;align-items:center}

/* ============================================================
   PACKAGES
   ============================================================ */
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;align-items:stretch}
.pack{
  background:var(--ink-soft);border:1px solid var(--line-dk);border-radius:var(--radius);
  padding:2.2rem 1.9rem;display:flex;flex-direction:column;
}
.pack--featured{border-color:var(--accent);background:#262a31;position:relative}
.pack--featured::before{
  content:"Le plus choisi";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  font-weight:600;padding:.35rem .9rem;border-radius:100px;
}
.pack h3{color:var(--ivory);margin-bottom:.2rem}
.pack__tag{color:var(--accent);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.4rem}
.pack ul{list-style:none;margin:0 0 1.8rem;padding:0;flex:1}
.pack li{padding:.55rem 0;border-bottom:1px solid var(--line-dk);color:rgba(246,243,236,.85);font-size:.95rem;display:flex;gap:.7rem}
.pack li::before{content:"";flex:0 0 auto;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-top:.6rem}
.packages-note{text-align:center;color:rgba(246,243,236,.55);font-size:.88rem;margin-top:2rem}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta{display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:center}
.cta h2{margin:0}
.cta__actions{display:flex;flex-direction:column;gap:1rem}
.cta__line{display:flex;align-items:center;gap:.8rem;font-size:1.05rem}
.cta__line .ic{width:42px;height:42px;border-radius:50%;border:1px solid var(--accent);display:grid;place-items:center;color:var(--accent);flex:0 0 auto}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:rgba(246,243,236,.72);padding-block:clamp(56px,7vw,88px) 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem}
.footer-grid h4{color:var(--ivory);font-family:var(--font-body);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.2rem}
.footer-grid ul{list-style:none;margin:0;padding:0}
.footer-grid li{margin-bottom:.6rem}
.footer-grid a{color:rgba(246,243,236,.72)}
.footer-grid a:hover{color:var(--accent)}
.footer-brand .brand__name{font-size:1.5rem}
.footer-brand p{margin-top:1rem;font-size:.95rem;max-width:34ch}
.socials{display:flex;gap:.7rem;margin-top:1.4rem}
.socials a{width:40px;height:40px;border:1px solid var(--line-dk);border-radius:50%;display:grid;place-items:center;color:var(--ivory)}
.socials a:hover{background:var(--accent);border-color:var(--accent)}
.footer-bottom{margin-top:clamp(40px,6vw,72px);border-top:1px solid var(--line-dk);padding-block:1.5rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem}
.footer-bottom a{color:rgba(246,243,236,.6)}

/* ============================================================
   GENERIC PAGE / POSTS
   ============================================================ */
.page-hero{background:var(--ink);color:var(--ivory);padding:160px var(--gutter) 80px;text-align:center}
.page-hero h1{margin:0}
.page-body{padding-block:clamp(48px,7vw,96px)}
.content-narrow{max-width:760px;margin-inline:auto}
.content-narrow img{border-radius:var(--radius);margin-block:1.5rem}
.content-narrow blockquote{border-left:3px solid var(--accent);margin:1.5rem 0;padding:.5rem 0 .5rem 1.5rem;font-family:var(--font-display);font-size:1.4rem;font-style:italic;color:var(--ink)}
.post-meta{color:var(--stone);font-size:.9rem;margin-bottom:1.5rem;letter-spacing:.03em}
.post-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:2rem}
.post-card .card__body h2{font-size:1.6rem}
.pagination{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:2rem}
.pagination .page-numbers{padding:.5rem .9rem;border:1px solid var(--line);border-radius:var(--radius);color:var(--ink)}
.pagination .current{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.widget{margin-bottom:2rem}
.comment-list{list-style:none;padding:0}

/* ============================================================
   REVEAL ON SCROLL
   ============================================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:var(--d,0s);will-change:opacity,transform}
.reveal--left{transform:translateX(-40px)}
.reveal--right{transform:translateX(40px)}
.reveal--scale{transform:scale(.93)}
.reveal.is-in{opacity:1;transform:none}

/* Décalage en chaîne des grilles */
.cards .card.reveal:nth-child(2),.packages .pack.reveal:nth-child(2){--d:.13s}
.cards .card.reveal:nth-child(3),.packages .pack.reveal:nth-child(3){--d:.26s}
.stats .stat:nth-child(2){transition-delay:.12s}

/* Filet de l'eyebrow qui se trace à la révélation */
.reveal .eyebrow::before{width:0;transition:width .7s var(--ease) .25s}
.reveal.is-in .eyebrow::before{width:30px}

/* Soulignement du titre de section qui se trace */
.section-head.reveal h2{position:relative}
.section-head.reveal h2::after{content:"";position:absolute;left:0;bottom:-.35rem;height:2px;width:0;background:var(--accent);transition:width .8s var(--ease) .35s}
.section-head.reveal.is-in h2::after{width:64px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .cards,.packages{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .about{grid-template-columns:1fr}
  .about__media{order:-1}
  .cta{grid-template-columns:1fr}
}
@media (max-width:760px){
  .site-nav{
    position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:var(--ink);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;
    padding:6rem 2rem 2rem;gap:1.4rem;transform:translateX(100%);
    transition:transform .35s var(--ease);box-shadow:-20px 0 60px -30px rgba(0,0,0,.9);
  }
  .site-nav.is-open{transform:none}
  .menu{flex-direction:column;align-items:flex-start;gap:1.1rem;width:100%}
  .menu a{font-size:1.1rem}
  .header-phone{margin-top:.5rem}
  .nav-toggle{display:block;z-index:101}
  .cards,.packages,.footer-grid{grid-template-columns:1fr}
  body{font-size:16px}
}

/* ============================================================
   PAGE D'ACCUEIL — basée sur des blocs natifs (éditable)
   ============================================================ */
.home-content > *{margin-block:0}

/* Conteneur centré réutilisable */
.wrap.wp-block-group{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}

/* Sections */
.pfg-section{padding-block:clamp(64px,9vw,128px)}
.pfg-section--mist{background:var(--sand)}
.pfg-section--ink{background:var(--ink);color:var(--ivory)}
.pfg-section--ink :is(h2,h3){color:var(--ivory)}
.pfg-section--ink .lead{color:rgba(242,246,251,.78)}

/* ---- HERO (groupe pleine largeur, image via CSS pour le zoom lent) ---- */
.pfg-hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;color:var(--ivory);padding-block:120px 90px}
.pfg-hero::before{content:"";position:absolute;inset:-8% 0;background:var(--ink) url(assets/images/hero.jpg) center/cover no-repeat;animation:kenburns 26s ease-in-out infinite alternate;z-index:0}
.pfg-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,30,51,.55),rgba(14,30,51,.5) 40%,rgba(14,30,51,.9));z-index:0}
.pfg-hero__inner{position:relative;z-index:1;max-width:var(--wrap);margin-inline:auto;width:100%;padding-inline:var(--gutter)}
.pfg-hero__inner > *{opacity:0;animation:heroIn .9s var(--ease) forwards}
.pfg-hero__inner > *:nth-child(1){animation-delay:.15s}
.pfg-hero__inner > *:nth-child(2){animation-delay:.30s}
.pfg-hero__inner > *:nth-child(3){animation-delay:.55s}
.pfg-hero__inner > *:nth-child(4){animation-delay:.75s}
.pfg-hero__inner h1{font-size:clamp(2.6rem,6vw,4.6rem);max-width:18ch;margin:0}
.pfg-hero__inner .pfg-hero__text{font-size:1.12rem;color:rgba(242,246,251,.85);max-width:54ch;margin:1.4rem 0 2.2rem}
.pfg-hero .eyebrow{color:var(--accent)}

/* ---- Boutons (blocs natifs) ---- */
.wp-block-button__link{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);padding:.95rem 1.8rem;font-weight:600;font-size:.92rem;letter-spacing:.04em;text-transform:uppercase;transition:all .28s var(--ease)}
.wp-block-button__link:hover{background:var(--accent-dk);border-color:var(--accent-dk);color:#fff;transform:translateY(-2px)}
.wp-block-button.is-style-outline .wp-block-button__link{background:transparent;border-color:rgba(242,246,251,.45);color:var(--ivory)}
.wp-block-button.is-style-outline .wp-block-button__link:hover{background:rgba(242,246,251,.1);border-color:var(--ivory)}
.pfg-btn-urgent .wp-block-button__link{background:#7c2d2d;border-color:#7c2d2d}
.pfg-btn-urgent .wp-block-button__link:hover{background:#612121;border-color:#612121}

/* ---- ABOUT ---- */
.pfg-about{align-items:center;gap:clamp(32px,5vw,72px)}
.pfg-about .wp-block-column:first-child{position:relative}
.pfg-about__img img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);display:block}
.pfg-stats{gap:2.5rem;margin-block:1.8rem}
.pfg-stats .count{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,2.8rem);color:var(--accent);line-height:1;margin:0}
.pfg-stats p:not(.count){font-size:.85rem;color:var(--stone);margin:.2rem 0 0}
.pfg-section--ink .pfg-stats p:not(.count){color:rgba(242,246,251,.7)}
.pfg-director{display:flex;align-items:center;gap:1rem;margin-top:1.6rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.pfg-director img{width:64px;height:64px;border-radius:50%;object-fit:cover}
.pfg-director .pfg-director__name{font-family:var(--font-display);font-size:1.25rem;margin:0;line-height:1.1}
.pfg-director p:not(.pfg-director__name){font-size:.85rem;color:var(--stone);margin:.1rem 0 0}

/* ---- Section head ---- */
.pfg-head{max-width:760px}
.pfg-head h2::after{content:"";display:block;height:2px;width:0;background:var(--accent);margin-top:.5rem;transition:width .8s var(--ease) .35s}
.pfg-head.is-in h2::after{width:64px}

/* ---- SERVICES (cartes) ---- */
.pfg-cards{gap:1.6rem;align-items:stretch}
.pfg-cards .wp-block-column{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;padding:0;transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.pfg-cards .wp-block-column:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pfg-cards img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.pfg-cards h3{margin:1.4rem 1.4rem .4rem}
.pfg-cards p{color:var(--stone);font-size:.97rem;margin:0 1.4rem 1rem}
.pfg-cards .wp-block-buttons{margin:0 1.4rem 1.6rem}
.pfg-cards .wp-block-button__link{background:transparent;color:var(--accent-dk);border:0;padding:0;text-transform:uppercase;letter-spacing:.06em;font-size:.84rem}
.pfg-cards .wp-block-button__link:hover{color:var(--ink);transform:none}

/* ---- FORFAITS ---- */
.pfg-packs{gap:1.6rem;align-items:stretch}
.pfg-packs .wp-block-column{background:var(--ink-soft);border:1px solid var(--line-dk);border-radius:var(--radius);padding:2.2rem 1.9rem;display:flex;flex-direction:column}
.pfg-packs .pfg-pack--featured{border-color:var(--accent);background:#1c3a5e;position:relative}
.pfg-packs h3{margin:0 0 .2rem}
.pfg-packs .pfg-pack__tag{color:var(--accent);font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;margin:0 0 1.2rem}
.pfg-packs ul{list-style:none;margin:0 0 1.6rem;padding:0;flex:1}
.pfg-packs li{padding:.55rem 0;border-bottom:1px solid var(--line-dk);color:rgba(242,246,251,.85);font-size:.95rem;display:flex;gap:.7rem;align-items:flex-start}
.pfg-packs li::before{content:"";flex:0 0 auto;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-top:.55rem}

/* ---- CONTACT ---- */
.pfg-cta{align-items:center;gap:3rem}
.pfg-cta .pfg-cta__line{display:flex;align-items:center;gap:.8rem;font-size:1.05rem;margin:0 0 1rem}
.pfg-cta__line::before{content:"";flex:0 0 auto;width:42px;height:42px;border-radius:50%;border:1px solid var(--accent)}

/* Réduction d'animations : forcer l'affichage */
@media (prefers-reduced-motion: reduce){
  .pfg-hero__inner > *{opacity:1}
  .pfg-hero::before{animation:none}
}
/* Décalage en chaîne des colonnes de blocs */
.pfg-cards .wp-block-column.reveal:nth-child(2),.pfg-packs .wp-block-column.reveal:nth-child(2){--d:.13s}
.pfg-cards .wp-block-column.reveal:nth-child(3),.pfg-packs .wp-block-column.reveal:nth-child(3){--d:.26s}

/* Secours de mise en page des blocs natifs (cohérent avec le cœur de WP) */
.wp-block-buttons{display:flex;flex-wrap:wrap;gap:1rem}
.wp-block-columns{display:flex;gap:1.6rem;margin-block:0}
.wp-block-column{flex:1 1 0;min-width:0}
.wp-block-image{margin:0}
.wp-block-image img{height:auto;display:block}
.pfg-director .wp-block-image img{width:64px;height:64px;border-radius:50%;object-fit:cover}
@media (max-width:781px){
  .wp-block-columns{flex-wrap:wrap}
  .wp-block-column{flex-basis:100% !important}
}
