/*
Theme Name: PredexIA Audit IA
Theme URI: https://predexia.fr
Author: PredexIA
Author URI: https://predexia.fr
Description: Landing page verticale Audit & Diagnostic IA (édition été) — Diag Data IA cofinancé Bpifrance. Thème classique autonome (sans plugin), entièrement éditable via le Customizer : textes, images, vidéos, logo, tarif, formulaire de contact avec stockage des leads et export CSV.
Version: 1.0.0
Requires at least: 6.0
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: predexia-audit-ia
*/

/* ============================================================
   PREDEXIA — DESIGN SYSTEM (charte PredexIA — identique landing RH)
   ============================================================ */
:root{
  --px-blue:#2D7DF6;
  --px-green:#2ECC8B;
  --px-ink:#0E1B2C;
  --px-slate:#4A5A6E;
  --px-mist:#F4F7FB;
  --px-card:#FFFFFF;
  --px-line:#E2EAF4;
  --px-gradient:linear-gradient(100deg,var(--px-blue) 0%,var(--px-green) 100%);
  --px-gradient-soft:linear-gradient(135deg,rgba(45,125,246,.08),rgba(46,204,139,.08));
  /* --- Accent estival (surcouche saisonnière, ne remplace pas la marque) --- */
  --px-sun:#FF9F1C;
  --px-coral:#FF6B6B;
  --px-sun-gradient:linear-gradient(100deg,#FF9F1C 0%,#FF6B6B 100%);
  --px-sun-soft:linear-gradient(135deg,rgba(255,159,28,.12),rgba(255,107,107,.10));
  --radius-lg:24px;
  --radius-md:16px;
  --radius-pill:999px;
  --shadow-brand:0 18px 45px -18px rgba(45,125,246,.35);
  --shadow-card:0 10px 32px -14px rgba(14,27,44,.14);
  --font-display:'Poppins',sans-serif;
  --font-body:'Plus Jakarta Sans',sans-serif;
  --ease-px:cubic-bezier(.22,.9,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--px-ink);background:#fff;font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.18;letter-spacing:-.01em}
a{color:inherit}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-display);font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--px-blue);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:3px;border-radius:2px;background:var(--px-gradient)}
.grad-text{background:var(--px-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Placeholders visuels ---------- */
.ph{border:2px dashed rgba(45,125,246,.45);background:var(--px-gradient-soft);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px;text-align:center;color:var(--px-slate);font-size:.92rem;min-height:260px}
.ph strong{color:var(--px-ink);font-family:var(--font-display);font-size:.95rem}
.ph .ph-ico{font-size:1.9rem}

/* ---------- CTA ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--font-display);font-weight:600;border-radius:var(--radius-pill);text-decoration:none;cursor:pointer;border:none;transition:transform .25s var(--ease-px),box-shadow .25s var(--ease-px)}
.btn-primary{background:var(--px-gradient);color:#fff;padding:16px 32px;font-size:1.02rem;box-shadow:var(--shadow-brand)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 24px 55px -18px rgba(45,125,246,.5)}
.btn-ghost{background:#fff;color:var(--px-blue);border:2px solid var(--px-line);padding:14px 28px;font-size:.98rem}
.btn-ghost:hover{border-color:var(--px-blue)}
.btn-sm{padding:11px 22px;font-size:.92rem}
.btn-light{background:#fff;color:var(--px-ink);padding:16px 32px;font-size:1.02rem;box-shadow:var(--shadow-card)}
.btn-light:hover{transform:translateY(-2px)}
.cta-note{display:block;margin-top:12px;font-size:.85rem;color:var(--px-slate)}
.cta-note .lock{margin-right:4px}
.link-cta{font-family:var(--font-display);font-weight:600;color:var(--px-blue);text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.link-cta::after{content:"→";transition:transform .2s var(--ease-px)}
.link-cta:hover::after{transform:translateX(4px)}

/* ---------- Badge partenaire BPI ---------- */
.bpi-badge{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--px-line);border-radius:var(--radius-pill);padding:8px 16px 8px 8px;font-size:.84rem;font-weight:600;color:var(--px-ink);box-shadow:var(--shadow-card)}
.bpi-badge .bpi-logo{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--px-gradient-soft);border:1px dashed rgba(45,125,246,.5);font-size:.62rem;color:var(--px-slate);text-align:center;line-height:1}

/* ---------- Habillage estival ---------- */
.season-bar{background:var(--px-sun-gradient);color:#fff;text-align:center;font-family:var(--font-display);font-weight:600;font-size:.9rem;padding:9px 16px;letter-spacing:.01em}
.season-bar span{opacity:.95}
.sun-badge{display:inline-flex;align-items:center;gap:8px;background:var(--px-sun-soft);border:1.5px solid rgba(255,159,28,.4);border-radius:var(--radius-pill);padding:7px 16px;font-size:.82rem;font-weight:700;color:#C2410C;font-family:var(--font-display);letter-spacing:.02em}
.grad-sun{background:var(--px-sun-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.btn-sun{background:var(--px-sun-gradient);color:#fff;padding:16px 32px;font-size:1.02rem;box-shadow:0 18px 45px -18px rgba(255,107,107,.45)}
.btn-sun:hover{transform:translateY(-2px);box-shadow:0 24px 55px -18px rgba(255,107,107,.55)}
.btn-sun.btn-sm{padding:11px 22px;font-size:.92rem}
/* Frise planning été → rentrée */
.timeline-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:0;max-width:880px;margin:0 auto;counter-reset:tl}
.tl-step{flex:1;min-width:200px;position:relative;padding:22px 18px;text-align:center}
.tl-step .tl-emoji{font-size:1.8rem;display:block;margin-bottom:8px}
.tl-step b{font-family:var(--font-display);display:block;font-size:1.02rem;margin-bottom:4px}
.tl-step span{font-size:.9rem;color:var(--px-slate)}
.tl-step:not(:last-child)::after{content:"→";position:absolute;right:-9px;top:34px;color:var(--px-sun);font-size:1.4rem;font-weight:700}
@media(max-width:680px){.tl-step:not(:last-child)::after{display:none}}

/* ============================================================
   1. HEADER MINIMAL
   ============================================================ */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--px-line)}
.header .container{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-family:var(--font-display);font-weight:800;font-size:1.45rem;text-decoration:none;color:var(--px-ink)}
.logo span{background:var(--px-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.header-right{display:flex;align-items:center;gap:18px}
.header-phone{font-size:.9rem;color:var(--px-slate);text-decoration:none}
@media(max-width:760px){.header-phone{display:none}}

/* ============================================================
   2. HERO
   ============================================================ */
.hero{padding:84px 0 60px;background:
  radial-gradient(60% 50% at 85% 0%,rgba(46,204,139,.10),transparent 60%),
  radial-gradient(55% 45% at 5% 10%,rgba(45,125,246,.10),transparent 60%),#fff}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.2rem,4.6vw,3.45rem);font-weight:800;margin:18px 0 22px}
.rotator{display:inline-grid;vertical-align:bottom;text-align:left}
.rotator span{grid-area:1/1;background:var(--px-gradient);-webkit-background-clip:text;background-clip:text;color:transparent;opacity:0;transform:translateY(12px);transition:opacity .45s var(--ease-px),transform .45s var(--ease-px);white-space:nowrap}
.rotator span.on{opacity:1;transform:translateY(0)}
.hero p.sub{font-size:1.16rem;color:var(--px-slate);max-width:560px;margin-bottom:30px}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.trust-row{display:flex;flex-wrap:wrap;gap:14px 26px;margin-top:26px;font-size:.92rem;color:var(--px-slate)}
.trust-row span{display:inline-flex;align-items:center;gap:7px;font-weight:600}
.hero-rating{display:flex;align-items:center;gap:10px;margin-top:22px;font-size:.9rem;color:var(--px-slate)}
.stars{color:#F6B73C;letter-spacing:2px}
.hero-visual .ph{min-height:420px}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr}.hero-visual .ph{min-height:300px}}

/* ============================================================
   3. BANDE LOGOS / RÉASSURANCE
   ============================================================ */
.logos{padding:46px 0 56px;text-align:center}
.logos h2{font-size:1.18rem;font-weight:600;color:var(--px-slate);margin-bottom:30px;font-family:var(--font-body)}
.logo-track{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.logo-chip{border:1.5px dashed rgba(45,125,246,.4);background:var(--px-gradient-soft);border-radius:var(--radius-md);padding:14px 22px;font-size:.85rem;color:var(--px-slate);min-width:150px}

/* ============================================================
   4. TROIS PILIERS
   ============================================================ */
.pillars{padding:70px 0;background:var(--px-mist)}
.pillar{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:52px 0}
.pillar+.pillar{border-top:1px solid var(--px-line)}
.pillar:nth-child(even) .pillar-txt{order:2}
.pillar h3{font-size:clamp(1.5rem,2.6vw,2.05rem);font-weight:700;margin:14px 0 16px}
.pillar p{color:var(--px-slate);margin-bottom:20px;max-width:520px}
.pillar .ph{min-height:320px}
@media(max-width:920px){.pillar{grid-template-columns:1fr;gap:28px}.pillar:nth-child(even) .pillar-txt{order:0}}

/* ============================================================
   5. PILLS CAS D'USAGE
   ============================================================ */
.usecases{padding:80px 0;text-align:center}
.usecases h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:700;margin-bottom:14px}
.usecases .lead{color:var(--px-slate);max-width:640px;margin:0 auto 38px}
.pill-track{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;max-width:900px;margin:0 auto}
.pill{font-family:var(--font-display);font-weight:600;font-size:.95rem;padding:13px 24px;border-radius:var(--radius-pill);border:1.5px solid var(--px-line);background:#fff;color:var(--px-ink);transition:all .2s var(--ease-px);cursor:default}
.pill:hover{border-color:transparent;background:var(--px-gradient);color:#fff;box-shadow:var(--shadow-brand)}

/* ============================================================
   6. DÉROULÉ DU DIAGNOSTIC (cards façon "Aura AI" sur fond sombre)
   ============================================================ */
.agents{padding:80px 0;background:var(--px-ink);color:#fff}
.agents .eyebrow{color:var(--px-green)}
.agents h2{font-size:clamp(1.8rem,3.4vw,2.55rem);font-weight:700;margin:14px 0 12px;max-width:760px}
.agents .lead{color:#B9C6D8;max-width:640px;margin-bottom:46px}
.agent-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.agent-card{background:#16273D;border:1px solid #233A57;border-radius:var(--radius-lg);padding:30px;display:flex;flex-direction:column;gap:16px;transition:transform .3s var(--ease-px),border-color .3s var(--ease-px)}
.agent-card:hover{transform:translateY(-4px);border-color:var(--px-green)}
.agent-card .step-num{font-family:var(--font-display);font-size:.8rem;font-weight:700;letter-spacing:.1em;color:var(--px-green)}
.agent-card .ph{min-height:160px;border-color:rgba(46,204,139,.5);background:rgba(46,204,139,.06);color:#B9C6D8}
.agent-card .ph strong{color:#fff}
.agent-card h3{font-size:1.22rem;font-weight:700}
.agent-card p{color:#B9C6D8;font-size:.97rem;flex-grow:1}
@media(max-width:820px){.agent-grid{grid-template-columns:1fr}}

/* ============================================================
   7. SECTION TARIF / BPI (le pivot de cette landing)
   ============================================================ */
.pricing{padding:88px 0;background:
  radial-gradient(60% 60% at 15% 0%,rgba(45,125,246,.10),transparent 60%),
  radial-gradient(55% 55% at 90% 100%,rgba(46,204,139,.10),transparent 60%),#fff}
.pricing .head{text-align:center;max-width:680px;margin:0 auto 46px}
.pricing h2{font-size:clamp(1.8rem,3.4vw,2.5rem);font-weight:800;margin:14px 0 14px}
.pricing .head p{color:var(--px-slate)}
.price-card{max-width:720px;margin:0 auto;background:#fff;border:1px solid var(--px-line);border-radius:var(--radius-lg);box-shadow:var(--shadow-brand);overflow:hidden}
.price-top{background:var(--px-ink);color:#fff;padding:34px 40px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px}
.price-top .title b{font-family:var(--font-display);font-size:1.3rem;font-weight:700;display:block}
.price-top .title span{color:#B9C6D8;font-size:.92rem}
.price-tag{text-align:right}
.price-tag .old{font-size:1.05rem;color:#8FA2BC;text-decoration:line-through;margin-right:8px}
.price-tag .now{font-family:var(--font-display);font-size:2.4rem;font-weight:800;color:#fff}
.price-tag .now .grad-text{background:linear-gradient(100deg,#6FB0FF,#5DE0AB);-webkit-background-clip:text;background-clip:text;color:transparent}
.price-tag .unit{display:block;font-size:.8rem;color:#8FA2BC;margin-top:2px}
.price-body{padding:34px 40px}
.price-body ul{list-style:none}
.price-body li{padding-left:32px;position:relative;margin-bottom:14px;color:var(--px-ink)}
.price-body li::before{content:"✓";position:absolute;left:0;top:1px;width:22px;height:22px;border-radius:50%;background:var(--px-gradient);color:#fff;font-size:.78rem;display:flex;align-items:center;justify-content:center;font-weight:700}
.price-cta{margin-top:26px;text-align:center}
.price-legal{font-size:.78rem;color:var(--px-slate);margin-top:18px;line-height:1.5;background:var(--px-mist);border:1px solid var(--px-line);border-radius:var(--radius-md);padding:14px 16px}
.price-legal mark{background:rgba(246,183,60,.25);padding:1px 5px;border-radius:4px;font-weight:600}

/* ============================================================
   8. ÉLIGIBILITÉ (onglets profils)
   ============================================================ */
.audiences{padding:84px 0}
.audiences h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:700;text-align:center;margin-bottom:36px}
.tabs{display:flex;justify-content:center;gap:10px;margin-bottom:42px;flex-wrap:wrap}
.tab-btn{font-family:var(--font-display);font-weight:600;font-size:.97rem;padding:12px 28px;border-radius:var(--radius-pill);border:1.5px solid var(--px-line);background:#fff;cursor:pointer;transition:all .2s var(--ease-px)}
.tab-btn.active{background:var(--px-gradient);color:#fff;border-color:transparent;box-shadow:var(--shadow-brand)}
.tab-panel{display:none;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.tab-panel.active{display:grid}
.tab-panel .kicker{font-size:.86rem;font-weight:600;color:var(--px-green);text-transform:uppercase;letter-spacing:.1em}
.tab-panel h3{font-size:clamp(1.4rem,2.4vw,1.9rem);font-weight:700;margin:10px 0 12px}
.tab-panel p{color:var(--px-slate);margin-bottom:18px}
.checks{list-style:none;margin:0 0 26px}
.checks li{padding-left:32px;position:relative;margin-bottom:12px;color:var(--px-ink)}
.checks li::before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;background:var(--px-gradient);color:#fff;font-size:.78rem;display:flex;align-items:center;justify-content:center;font-weight:700}
.tab-panel .ph{min-height:330px}
@media(max-width:920px){.tab-panel.active{grid-template-columns:1fr}}

/* ============================================================
   9. CONFORMITÉ / CONFIANCE
   ============================================================ */
.compliance{padding:80px 0;background:var(--px-mist)}
.comp-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.compliance h2{font-size:clamp(1.7rem,3.2vw,2.35rem);font-weight:700;margin:14px 0 14px}
.compliance .lead{color:var(--px-slate);margin-bottom:24px}
.comp-list{list-style:none}
.comp-list li{display:flex;gap:14px;margin-bottom:18px}
.comp-list .ico{flex:0 0 44px;height:44px;border-radius:14px;background:#fff;border:1px solid var(--px-line);display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:var(--shadow-card)}
.comp-list b{display:block;font-family:var(--font-display)}
.comp-list span{color:var(--px-slate);font-size:.95rem}
.compliance .ph{min-height:340px}
@media(max-width:920px){.comp-grid{grid-template-columns:1fr}}

/* ============================================================
   10. CHIFFRES
   ============================================================ */
.proof{padding:74px 0;text-align:center}
.proof h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;margin-bottom:44px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.stat{background:#fff;border:1px solid var(--px-line);border-radius:var(--radius-lg);padding:34px 20px;box-shadow:var(--shadow-card)}
.stat .num{font-family:var(--font-display);font-size:2.5rem;font-weight:800;background:var(--px-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{font-size:.92rem;color:var(--px-slate);margin-top:6px}
@media(max-width:820px){.stat-grid{grid-template-columns:repeat(2,1fr)}}

/* ============================================================
   11. ÉTUDE DE CAS
   ============================================================ */
.casestudy{padding:80px 0;background:var(--px-mist)}
.case-card{display:grid;grid-template-columns:.9fr 1.1fr;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);border:1px solid var(--px-line)}
.case-card .ph{border-radius:0;border:none;border-right:2px dashed rgba(45,125,246,.4);min-height:100%}
.case-body{padding:44px}
.case-body .tag{font-size:.74rem;font-weight:700;letter-spacing:.12em;color:var(--px-green);text-transform:uppercase}
.case-body h3{font-size:clamp(1.35rem,2.4vw,1.8rem);font-weight:700;margin:12px 0 14px}
.case-body p{color:var(--px-slate);margin-bottom:20px}
.case-kpis{display:flex;gap:30px;margin:22px 0 26px;flex-wrap:wrap}
.case-kpis .k{font-family:var(--font-display)}
.case-kpis .k b{font-size:1.65rem;font-weight:800;background:var(--px-gradient);-webkit-background-clip:text;background-clip:text;color:transparent;display:block}
.case-kpis .k span{font-size:.85rem;color:var(--px-slate)}
blockquote.case-quote{border-left:3px solid var(--px-green);padding-left:18px;font-style:italic;color:var(--px-ink);margin-bottom:14px}
.case-author{font-size:.9rem;color:var(--px-slate)}
@media(max-width:920px){.case-card{grid-template-columns:1fr}.case-card .ph{min-height:240px;border-right:none;border-bottom:2px dashed rgba(45,125,246,.4)}}

/* ============================================================
   12. FAQ
   ============================================================ */
.faq{padding:84px 0}
.faq h2{font-size:clamp(1.7rem,3.2vw,2.35rem);font-weight:700;text-align:center;margin-bottom:42px}
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border:1px solid var(--px-line);border-radius:var(--radius-md);margin-bottom:14px;background:#fff;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;font-family:var(--font-display);font-weight:600;font-size:1.04rem;padding:20px 54px 20px 22px;cursor:pointer;position:relative;color:var(--px-ink)}
.faq-q::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--px-blue);transition:transform .25s var(--ease-px)}
.faq-item.open .faq-q::after{transform:translateY(-50%) rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease-px)}
.faq-a p{padding:0 22px 22px;color:var(--px-slate);font-size:.97rem}

/* ============================================================
   13. CTA FINAL + FORMULAIRE
   ============================================================ */
.finalcta{padding:90px 0;background:
  radial-gradient(70% 60% at 20% 0%,rgba(45,125,246,.18),transparent 60%),
  radial-gradient(60% 55% at 90% 100%,rgba(46,204,139,.18),transparent 60%),var(--px-ink);color:#fff}
.final-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.finalcta h2{font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:800;margin-bottom:16px}
.finalcta .lead{color:#B9C6D8;margin-bottom:26px}
.final-points{list-style:none;margin-bottom:10px}
.final-points li{padding-left:30px;position:relative;margin-bottom:12px;color:#DCE6F2}
.final-points li::before{content:"✓";position:absolute;left:0;color:var(--px-green);font-weight:700}
.form-card{background:#fff;color:var(--px-ink);border-radius:var(--radius-lg);padding:36px;box-shadow:0 30px 80px -20px rgba(0,0,0,.45)}
.form-card h3{font-size:1.3rem;font-weight:700;margin-bottom:6px}
.form-card .form-sub{font-size:.9rem;color:var(--px-slate);margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-display);font-weight:600;font-size:.86rem;margin-bottom:6px}
.field input,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--px-line);border-radius:12px;font-family:var(--font-body);font-size:.97rem;background:#fff;transition:border-color .2s}
.field input:focus,.field select:focus{outline:none;border-color:var(--px-blue)}
.form-card .btn-primary{width:100%;margin-top:8px}
.form-trust{margin-top:14px;font-size:.8rem;color:var(--px-slate);text-align:center}
@media(max-width:920px){.final-grid{grid-template-columns:1fr}}

/* ============================================================
   14. FOOTER
   ============================================================ */
.footer{padding:34px 0;border-top:1px solid var(--px-line);background:#fff}
.footer .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:.86rem;color:var(--px-slate)}
.footer a{color:var(--px-slate);text-decoration:none;margin-left:18px}
.footer a:hover{color:var(--px-blue)}

/* ---------- Sticky CTA mobile ---------- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:60;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-top:1px solid var(--px-line);display:none}
.sticky-cta .btn{width:100%}
@media(max-width:640px){.sticky-cta.show{display:block}}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease-px),transform .6s var(--ease-px)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .rotator span{transition:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   AJOUTS THÈME — médias éditables, formulaire, pages légales
   ============================================================ */

/* Quand un média est défini dans le Customizer, .ph devient un cadre média plein */
.ph.has-media{border:none;background:none;padding:0;overflow:hidden;display:block;min-height:0}
.ph.has-media img,.ph.has-media video{display:block;width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}
/* Étude de cas : média sans arrondi (le cadre gère l'overflow) */
.case-card .ph.has-media img{border-radius:0;box-shadow:none;height:100%}

/* Logo image dans l'en-tête */
.logo img{max-height:48px;width:auto;display:block}

/* Logos clients / réassurance en média */
.logo-chip.has-media{border:none;background:none;padding:0;min-width:0}
.logo-chip.has-media img{max-height:46px;width:auto;display:block}

/* Barre d'admin WordPress : décale le header sticky et le bandeau saison */
body.admin-bar .season-bar{position:relative}
body.admin-bar .header{top:32px}
@media(max-width:782px){body.admin-bar .header{top:46px}}

/* Honeypot anti-spam : invisible pour les humains */
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* Messages du formulaire (succès / erreur) */
.form-msg{display:none;margin-top:16px;padding:14px 16px;border-radius:12px;font-size:.93rem;font-weight:600}
.form-msg.show{display:block}
.form-msg.success{background:rgba(46,204,139,.12);color:#1B7A55;border:1px solid rgba(46,204,139,.4)}
.form-msg.error{background:rgba(220,60,60,.08);color:#B23B3B;border:1px solid rgba(220,60,60,.3)}
.btn-primary[disabled],.btn-sun[disabled]{opacity:.65;cursor:wait;transform:none}

/* ============================================================
   PAGES STANDARD & LÉGALES (page.php)
   ============================================================ */
.page-shell{padding:70px 0 90px;background:#fff}
.page-shell .entry{max-width:820px;margin:0 auto}
.page-shell h1.entry-title{font-size:clamp(1.9rem,3.6vw,2.6rem);font-weight:800;margin-bottom:8px}
.page-shell .entry-updated{font-size:.88rem;color:var(--px-slate);margin-bottom:36px}
.entry-content h2{font-size:1.45rem;font-weight:700;margin:38px 0 14px;padding-bottom:8px;border-bottom:2px solid var(--px-line)}
.entry-content h3{font-size:1.12rem;font-weight:700;margin:26px 0 10px}
.entry-content p{margin-bottom:16px;color:var(--px-slate)}
.entry-content ul,.entry-content ol{margin:0 0 16px 22px;color:var(--px-slate)}
.entry-content li{margin-bottom:8px}
.entry-content a{color:var(--px-blue)}
.entry-content table{width:100%;border-collapse:collapse;margin:0 0 20px;font-size:.93rem}
.entry-content th,.entry-content td{border:1px solid var(--px-line);padding:10px 12px;text-align:left;vertical-align:top}
.entry-content th{background:var(--px-mist);font-family:var(--font-display);font-weight:600}
.entry-content mark{background:rgba(246,183,60,.25);padding:1px 5px;border-radius:4px;font-weight:600}
