/*
Theme Name: ORCA
Theme URI: https://orcadrinks.com
Description: Thème sur-mesure premium pour ORCA — boisson énergisante naturelle à base de cascara. Léger, rapide, SEO-ready. Réalisé par l'Agence PTL.
Author: Agence PTL
Author URI: https://agenceptl.fr
Version: 1.0.0
Requires at least: 6.4
Requires PHP: 8.0
Text Domain: orca
Tags: custom-theme, food-and-drink, premium
*/

/* =====================================================================
   ORCA — Design system
   Palette officielle : orange #E67143 · vert #73AF78 · ink #17120E
   Typo : Fraunces (display, serif optique) + Hanken Grotesk (corps)
   ===================================================================== */

:root{
  /* Couleurs marque */
  --orange:        #E67143;
  --orange-600:    #D85F30;
  --orange-700:    #BE4F26;
  --orange-050:    #FBEDE4;
  --green:         #73AF78;
  --green-600:     #5E9A64;
  --green-050:     #EBF2EC;

  /* Neutres chauds */
  --ink:           #17120E;
  --ink-2:         #221A14;
  --ink-3:         #30251D;
  --cream:         #FBF6EF;
  --sand:          #F2E9DC;
  --sand-2:        #E8D9C7;
  --text:          #2A211B;
  --text-soft:     #61554C;
  --line:          rgba(23,18,14,.12);
  --line-soft:     rgba(23,18,14,.07);
  --on-dark:       #F4ECE2;
  --on-dark-soft:  rgba(244,236,226,.66);

  /* Dégradés (rappel canette) */
  --grad-can:  linear-gradient(158deg,#E0622E 0%,#E8894E 52%,#EEC07C 100%);
  --grad-mate: linear-gradient(165deg,#E0622E 0%,#CE8A4A 42%,#73AF78 100%);
  --grad-ink:  radial-gradient(120% 80% at 50% -10%, #2C2118 0%, var(--ink) 60%);

  /* Typo */
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body:    "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Rayons / ombres */
  --r-sm: 10px;
  --r:    18px;
  --r-lg: 28px;
  --r-xl: 40px;
  --pill: 999px;
  --shadow-sm: 0 2px 10px rgba(23,18,14,.06);
  --shadow:    0 18px 50px -22px rgba(23,18,14,.30);
  --shadow-lg: 0 40px 90px -40px rgba(23,18,14,.45);

  /* Layout */
  --container: 1200px;
  --container-narrow: 760px;
  --gutter: clamp(1.15rem, 4vw, 2.5rem);
  --section-y: clamp(3.5rem, 8vw, 7rem);
}

/* ---------- Polices self-hosted (RGPD-friendly) ---------- */
@font-face{
  font-family:"Fraunces";
  src:url("assets/fonts/fraunces-var.woff2") format("woff2");
  font-weight:100 900; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Fraunces";
  src:url("assets/fonts/fraunces-italic-var.woff2") format("woff2");
  font-weight:100 900; font-style:italic; font-display:swap;
}
@font-face{
  font-family:"Hanken Grotesk";
  src:url("assets/fonts/hanken-var.woff2") format("woff2");
  font-weight:100 900; font-style:normal; font-display:swap;
}

/* ---------- Reset léger ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.7;
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:4px}

/* ---------- Typographie ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.04;
  letter-spacing:-.015em;
  margin:0 0 .4em;
  color:var(--ink);
  font-variation-settings:"opsz" 144,"SOFT" 0,"WONK" 0;
  text-wrap:balance;
}
h1{font-size:clamp(2.6rem,1.6rem + 4.4vw,5rem);font-weight:600}
h2{font-size:clamp(2rem,1.4rem + 2.7vw,3.3rem)}
h3{font-size:clamp(1.3rem,1.05rem + 1.1vw,1.8rem);letter-spacing:-.01em}
h4{font-size:1.15rem;letter-spacing:0}
p{margin:0 0 1.1em}
strong{font-weight:700}
em{font-style:italic}
.lead{font-size:clamp(1.12rem,1rem + .7vw,1.4rem);line-height:1.6;color:var(--text-soft)}
a.link{color:var(--orange-700);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
a.link:hover{color:var(--orange-600)}

.display{font-family:var(--font-display)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-body);
  font-weight:600;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--orange-700);margin:0 0 1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--orange);border-radius:2px}
.eyebrow--center{justify-content:center}
.eyebrow--light{color:var(--orange)}
.eyebrow--on-dark{color:var(--orange)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.section--cream{background:var(--cream)}
.section--sand{background:var(--sand)}
.section--ink{background:var(--grad-ink);color:var(--on-dark)}
.section--ink h1,.section--ink h2,.section--ink h3,.section--ink h4{color:#fff}
.section--ink .lead{color:var(--on-dark-soft)}
.section--green{background:var(--green-050)}
.center{text-align:center}
.measure{max-width:62ch}
.measure-center{max-width:62ch;margin-inline:auto}

.grid{display:grid;gap:clamp(1.5rem,3vw,2.5rem)}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:repeat(2,1fr)}
@media(min-width:720px){
  .grid-2{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
}
.split{display:grid;gap:clamp(2rem,5vw,4.5rem);align-items:center}
@media(min-width:900px){
  .split{grid-template-columns:1fr 1fr}
  .split--media-left .split__media{order:-1}
  .split--40-60{grid-template-columns:42% 1fr}
  .split--60-40{grid-template-columns:1fr 42%}
}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:.95em 1.7em;border-radius:var(--pill);
  font-family:var(--font-body);font-weight:600;font-size:1rem;letter-spacing:.01em;
  border:1.5px solid transparent;transition:transform .25s ease,background .25s ease,color .25s,border-color .25s,box-shadow .25s;
  will-change:transform;line-height:1.1;text-align:center;
}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--orange);color:#fff;box-shadow:0 12px 28px -12px rgba(214,95,48,.7)}
.btn--primary:hover{background:var(--orange-600);transform:translateY(-2px)}
.btn--ink{background:var(--ink);color:#fff}
.btn--ink:hover{background:var(--ink-3);transform:translateY(-2px)}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--on-dark{background:#fff;color:var(--ink)}
.btn--on-dark:hover{background:var(--cream);transform:translateY(-2px)}
.btn--ghost-light{background:transparent;border-color:rgba(244,236,226,.35);color:var(--on-dark)}
.btn--ghost-light:hover{border-color:#fff;transform:translateY(-2px)}
.btn--lg{padding:1.1em 2.1em;font-size:1.06rem}
@media(prefers-reduced-motion:reduce){.btn:hover{transform:none}}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem}
.btn-row--center{justify-content:center}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(251,246,239,.82);backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line-soft);transition:background .3s,box-shadow .3s;
}
.site-header.is-scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:74px}
.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--ink)}
.brand__logo{width:46px;height:46px;color:var(--orange);flex:none}
.brand__word{font-family:var(--font-display);font-weight:600;font-size:1.35rem;letter-spacing:.02em;line-height:1}
.brand__sub{display:block;font-family:var(--font-body);font-weight:600;font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text-soft)}
.primary-nav{display:none}
@media(min-width:1024px){
  .primary-nav{display:flex;align-items:center;gap:.1rem}
}
@media(min-width:1260px){
  .header-actions{display:flex;align-items:center;gap:.8rem}
}
.primary-nav a{
  position:relative;padding:.5rem .62rem;border-radius:var(--pill);white-space:nowrap;
  font-weight:500;font-size:.93rem;color:var(--text);transition:color .2s,background .2s;
}
.primary-nav a:hover,.primary-nav .current-menu-item>a,.primary-nav .current_page_item>a{color:var(--orange-700);background:var(--orange-050)}
.header-actions{display:none}
.nav-toggle{
  display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:transparent;padding:0 11px;
}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-toggle span{height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s}
.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)}

/* Menu mobile */
.mobile-nav{
  position:fixed;inset:74px 0 0;z-index:55;background:var(--cream);
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
  padding:2rem var(--gutter) 3rem;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem;
}
.mobile-nav.is-open{transform:translateX(0)}
@media(min-width:1000px){.mobile-nav{display:none}}
.mobile-nav a{font-family:var(--font-display);font-size:1.6rem;font-weight:600;padding:.6rem 0;border-bottom:1px solid var(--line-soft);color:var(--ink)}
.mobile-nav a:hover{color:var(--orange-700)}
.mobile-nav .btn{margin-top:1.5rem;font-family:var(--font-body)}
body.nav-open{overflow:hidden}

/* ---------- Hero ---------- */
.hero{position:relative;color:var(--on-dark);overflow:hidden;background:var(--ink)}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,11,8,.55) 0%,rgba(15,11,8,.35) 40%,rgba(15,11,8,.82) 100%)}
.hero__inner{position:relative;z-index:1;padding-block:clamp(5rem,16vh,9rem)}
.hero__content{max-width:46rem}
.hero h1{color:#fff;font-weight:600;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 0}
.hero .lead{color:rgba(244,236,226,.85);max-width:34rem}
.hero__badges{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.6rem}

/* Pastilles / chips */
.chip{display:inline-flex;align-items:center;gap:.45em;padding:.5em 1em;border-radius:var(--pill);
  font-size:.82rem;font-weight:600;letter-spacing:.01em;background:var(--orange-050);color:var(--orange-700)}
.chip--on-dark{background:rgba(255,255,255,.12);color:#fff;backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.18)}
.chip--green{background:var(--green-050);color:var(--green-600)}
.chip svg{width:1em;height:1em}

/* ---------- Cartes ---------- */
.card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.2rem);box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.card--hover:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card__icon{width:52px;height:52px;display:grid;place-items:center;border-radius:14px;background:var(--orange-050);color:var(--orange-700);margin-bottom:1.1rem}
.card__icon svg{width:26px;height:26px}
.card h3{margin-bottom:.4rem}
.card p:last-child{margin-bottom:0}
.card--green .card__icon{background:var(--green-050);color:var(--green-600)}

/* Liste à puces custom */
.ticks{display:grid;gap:.8rem;margin:1.4rem 0}
.ticks li{position:relative;padding-left:2.1rem;font-weight:500}
.ticks li::before{content:"";position:absolute;left:0;top:.05em;width:1.45rem;height:1.45rem;border-radius:50%;
  background:var(--orange) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/.9rem no-repeat}
.ticks--green li::before{background-color:var(--green)}
.ticks--on-dark li{color:var(--on-dark)}

/* Stat / chiffres */
.stat{}
.stat__num{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.6rem);font-weight:600;line-height:1;color:var(--orange);font-variation-settings:"opsz" 144,"SOFT" 20}
.section--ink .stat__num{color:var(--orange)}
.stat__label{font-size:.95rem;color:var(--text-soft);margin-top:.4rem}
.section--ink .stat__label{color:var(--on-dark-soft)}

/* ---------- Carte produit (canette) ---------- */
.product-card{position:relative;display:flex;flex-direction:column;border-radius:var(--r-xl);overflow:hidden;background:#fff;border:1px solid var(--line-soft);box-shadow:var(--shadow);transition:transform .35s,box-shadow .35s}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.product-card__media{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--grad-can)}
.product-card--mate .product-card__media{background:var(--grad-mate)}
.product-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.product-card:hover .product-card__media img{transform:scale(1.04)}
.product-card__caf{position:absolute;top:1rem;right:1rem;z-index:2;background:rgba(23,18,14,.78);color:#fff;border-radius:var(--pill);padding:.5em .95em;font-weight:700;font-size:.85rem;backdrop-filter:blur(4px)}
.product-card__body{padding:clamp(1.4rem,3vw,2rem);display:flex;flex-direction:column;gap:.5rem;flex:1}
.product-card__body h3{margin:0}
.product-card__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin:.3rem 0 .6rem}
.product-card__foot{margin-top:auto;padding-top:1rem}

/* ---------- Image décorée ---------- */
.media-frame{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow)}
.media-frame img{width:100%;height:100%;object-fit:cover}
.media-frame--tall{aspect-ratio:4/5}
.media-frame--wide{aspect-ratio:16/10}
.media-frame--square{aspect-ratio:1/1}
.media-badge{position:absolute;z-index:2;bottom:1.1rem;left:1.1rem;background:rgba(251,246,239,.92);backdrop-filter:blur(6px);border-radius:var(--r);padding:.8rem 1.1rem;box-shadow:var(--shadow-sm);max-width:75%}
.media-badge strong{display:block;font-family:var(--font-display);font-size:1.05rem}
.media-badge span{font-size:.82rem;color:var(--text-soft)}

/* Badge sceau rond (trust) */
.seal{width:clamp(120px,18vw,168px);height:auto;color:var(--orange);animation:spin 32s linear infinite}
@media(prefers-reduced-motion:reduce){.seal{animation:none}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Bandeau marquee ---------- */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;padding:.85rem 0;border-block:1px solid rgba(255,255,255,.08)}
.marquee__track{display:flex;gap:2.5rem;width:max-content;animation:marquee 28s linear infinite}
.marquee__track span{display:inline-flex;align-items:center;gap:1rem;font-family:var(--font-display);font-size:1.05rem;letter-spacing:.01em;white-space:nowrap;color:var(--on-dark-soft)}
.marquee__track span::after{content:"✦";color:var(--orange)}
@media(prefers-reduced-motion:reduce){.marquee__track{animation:none}}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Steps / process ---------- */
.steps{counter-reset:s;display:grid;gap:1.5rem}
.step{position:relative;padding-left:3.6rem}
.step::before{counter-increment:s;content:counter(s);position:absolute;left:0;top:-.1rem;width:2.6rem;height:2.6rem;border-radius:50%;display:grid;place-items:center;background:var(--orange);color:#fff;font-family:var(--font-display);font-weight:600;font-size:1.15rem}
.step h3{margin-bottom:.2rem;font-size:1.2rem}

/* ---------- FAQ accordéon ---------- */
.faq{display:grid;gap:.85rem;max-width:780px;margin-inline:auto}
.faq__item{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;transition:box-shadow .25s}
.faq__item[open]{box-shadow:var(--shadow-sm)}
.faq__q{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.4rem;font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--ink);cursor:pointer;list-style:none}
.faq__q::-webkit-details-marker{display:none}
.faq__q::after{content:"";flex:none;width:1.4rem;height:1.4rem;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E67143' stroke-width='2.4' stroke-linecap='round'%3E%3Cline x1='12' y1='5' x2='12' y2='19'/%3E%3Cline x1='5' y1='12' x2='19' y2='12'/%3E%3C/svg%3E") center/contain no-repeat;transition:transform .3s}
.faq__item[open] .faq__q::after{transform:rotate(135deg)}
.faq__a{padding:0 1.4rem 1.3rem;color:var(--text-soft)}
.faq__a p:last-child{margin-bottom:0}

/* ---------- CTA bande ---------- */
.cta-band{position:relative;border-radius:var(--r-xl);overflow:hidden;background:var(--grad-can);color:#fff;padding:clamp(2.5rem,5vw,4rem);text-align:center}
.cta-band--mate{background:var(--grad-mate)}
.cta-band h2{color:#fff}
.cta-band .lead{color:rgba(255,255,255,.9)}
.cta-band__inner{position:relative;z-index:1;max-width:640px;margin-inline:auto}

/* ---------- Journal / articles ---------- */
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);overflow:hidden;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post-card__media{aspect-ratio:16/10;overflow:hidden;background:var(--sand)}
.post-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.post-card:hover .post-card__media img{transform:scale(1.05)}
.post-card__body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.post-card__cluster{font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--orange-700)}
.post-card h3{font-size:1.25rem;margin:0}
.post-card__excerpt{color:var(--text-soft);font-size:.96rem;flex:1}
.post-card__more{font-weight:600;color:var(--orange-700);display:inline-flex;align-items:center;gap:.4rem;margin-top:.3rem}

/* Article (single) */
.article{max-width:var(--container-narrow);margin-inline:auto}
.article__hero{aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;margin-bottom:2.2rem;box-shadow:var(--shadow)}
.article__hero img{width:100%;height:100%;object-fit:cover}
.prose{font-size:1.08rem;line-height:1.78}
.prose h2{margin-top:2.2em}
.prose h3{margin-top:1.6em}
.prose ul{margin:1.2em 0;display:grid;gap:.6rem}
.prose ul li{position:relative;padding-left:1.5rem}
.prose ul li::before{content:"";position:absolute;left:0;top:.65em;width:.5rem;height:.5rem;border-radius:50%;background:var(--orange)}
.prose a{color:var(--orange-700);text-decoration:underline;text-underline-offset:3px}
.prose blockquote{margin:1.8em 0;padding:.4em 0 .4em 1.4em;border-left:3px solid var(--orange);font-family:var(--font-display);font-size:1.25rem;font-style:italic;color:var(--ink)}
.author{display:flex;align-items:center;gap:.9rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.author__avatar{width:52px;height:52px;border-radius:50%;background:var(--orange-050);color:var(--orange-700);display:grid;place-items:center;font-family:var(--font-display);font-weight:600;font-size:1.3rem;flex:none}
.author__name{font-weight:700}
.author__role{font-size:.88rem;color:var(--text-soft)}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-size:.85rem;color:var(--text-soft);padding-top:1.5rem}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}
.breadcrumb li{display:flex;gap:.45rem;align-items:center}
.breadcrumb li:not(:last-child)::after{content:"›";color:var(--orange)}
.breadcrumb a:hover{color:var(--orange-700)}

/* ---------- Formulaire ---------- */
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field label{font-weight:600;font-size:.92rem}
.field input,.field textarea,.field select{
  width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:#fff;font:inherit;color:var(--text);transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-050)}
.field textarea{min-height:140px;resize:vertical}
.field--hp{position:absolute;left:-9999px}
.form-note{font-size:.85rem;color:var(--text-soft)}
.alert{padding:1rem 1.2rem;border-radius:var(--r-sm);margin-bottom:1.4rem;font-weight:500}
.alert--ok{background:var(--green-050);color:var(--green-600);border:1px solid var(--green)}
.alert--err{background:#fdecea;color:#b3261e;border:1px solid #f3b4ad}

/* ---------- Footer ---------- */
.site-footer{background:var(--grad-ink);color:var(--on-dark);padding-top:clamp(3.5rem,7vw,5.5rem)}
.footer-grid{display:grid;gap:2.5rem;grid-template-columns:1fr}
@media(min-width:760px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
@media(min-width:1000px){.footer-grid{grid-template-columns:1.6fr 1fr 1fr 1.2fr}}
.footer-brand__logo{width:64px;height:64px;color:var(--orange);margin-bottom:1rem}
.site-footer h4{color:#fff;font-family:var(--font-body);font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-links li{margin-bottom:.6rem}
.footer-links a{color:var(--on-dark-soft);transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-contact{color:var(--on-dark-soft);font-size:.95rem;display:grid;gap:.5rem}
.footer-contact a{display:inline-flex;align-items:center;gap:.5rem}
.footer-contact a svg{width:1.05em;height:1.05em;flex:none;color:var(--orange)}
.footer-contact a:hover{color:#fff}
.footer-bottom{margin-top:clamp(2.5rem,5vw,4rem);padding:1.6rem 0;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--on-dark-soft)}
.footer-bottom a:hover{color:#fff}
.footer-ptl{display:inline-flex;align-items:center;gap:.45rem}
.footer-ptl b{color:var(--orange)}

/* ---------- Page intro (sous-pages) ---------- */
.page-hero{background:var(--grad-ink);color:var(--on-dark);padding-block:clamp(3rem,7vw,5rem) clamp(2.5rem,5vw,4rem);position:relative;overflow:hidden}
.page-hero h1{color:#fff}
.page-hero .lead{color:var(--on-dark-soft);max-width:46rem}
.page-hero__eyebrow{color:var(--orange)}

/* ---------- Animations d'apparition ---------- */
[data-anim]{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1)}
[data-anim].is-in{opacity:1;transform:none}
[data-anim-delay="1"]{transition-delay:.08s}
[data-anim-delay="2"]{transition-delay:.16s}
[data-anim-delay="3"]{transition-delay:.24s}
[data-anim-delay="4"]{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){[data-anim]{opacity:1;transform:none;transition:none}}

/* ---------- Utilitaires ---------- */
.stack>*+*{margin-top:1.2rem}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.text-soft{color:var(--text-soft)}
.text-orange{color:var(--orange-700)}
.hide{display:none}
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ink);color:#fff;padding:.8rem 1.2rem;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.divider{height:1px;background:var(--line);border:0;margin-block:0}
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem}
hr{border:0;height:1px;background:var(--line);margin-block:2rem}

/* WP align/embed */
.wp-block-image img{border-radius:var(--r)}
.aligncenter{margin-inline:auto;text-align:center}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%)}
