/*
Theme Name: Inventer Demain
Theme URI: https://inventerdemain.fr/
Author: Refonte sur mesure
Author URI: https://inventerdemain.fr/
Description: Thème WordPress natif pour le site personnel de Pierre-Marie Chapon, expert de la transition démographique. Reprend l'identité orange/rose en dégradé, fond clair, design en cartes. Conçu sans Elementor ni dépendance lourde, pour un site rapide et stable.
Version: 2.2.0
Requires at least: 6.0
Tested up to: 7.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: inventer-demain
*/

/* =================================================================
   TOKENS — identité orange -> rose
   ================================================================= */
:root{
  --orange:   #ff7f00;
  --rose:     #ff1f6e;
  --orange-l: #ff8a50;
  --gradient: linear-gradient(135deg,#ff7f00 0%,#ff1f6e 100%);
  --ink:      #1a0a05;
  --ink2:     #5c4a40;
  --bg:       #ffffff;
  --bg2:      #fff7f3;
  --border:   #f0e4dc;
  --shadow:   0 4px 28px rgba(255,127,0,.10);
  --radius:   14px;
  --font:     'Calibri','Gill Sans','Gill Sans MT','Trebuchet MS','Segoe UI',system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto;} *{animation-duration:.001ms!important;transition-duration:.001ms!important;} }
body{font-family:var(--font);background:var(--bg);color:var(--ink);overflow-x:hidden;line-height:1.6;}
h1,h2,h3,h4,h5{font-family:var(--font);font-weight:700;line-height:1.15;}
a{text-decoration:none;color:var(--orange);}
img{display:block;max-width:100%;height:auto;}
:focus-visible{outline:3px solid var(--rose);outline-offset:2px;border-radius:4px;}

.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap;border:0;padding:0;margin:-1px;}
.skip-link{position:absolute;left:-999px;top:0;z-index:2000;background:var(--ink);color:#fff;padding:.8rem 1.2rem;border-radius:0 0 8px 0;}
.skip-link:focus{left:0;}

/* ══ NAV ══ */
nav.id-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 3.5rem;background:rgba(255,255,255,.97);
  border-bottom:1px solid var(--border);box-shadow:0 2px 18px rgba(255,127,0,.07);
  transition:padding .3s;
}
body.admin-bar nav.id-nav{top:32px;}
@media screen and (max-width:782px){ body.admin-bar nav.id-nav{top:46px;} }
nav.id-nav.scrolled{padding:.6rem 3.5rem;}
.nav-logo-fb{font-weight:700;font-size:1.15rem;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.nav-logo img{max-height:46px;width:auto;}
.nav-menu{display:flex;gap:0;list-style:none;align-items:center;}
.nav-item{position:relative;}
.nav-item>a{display:flex;align-items:center;gap:.3rem;color:var(--ink);font-size:.86rem;font-weight:600;padding:.5rem .9rem;border-radius:8px;transition:color .2s,background .2s;white-space:nowrap;}
.nav-item>a:hover{color:var(--orange);background:var(--bg2);}
.nav-cta{background:var(--gradient);color:#fff!important;padding:.55rem 1.3rem;border-radius:50px;font-weight:700!important;font-size:.86rem;margin-left:.5rem;box-shadow:0 4px 16px rgba(255,31,110,.25);transition:transform .2s,box-shadow .2s;}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,31,110,.4);color:#fff;}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px;}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;display:block;}
.mob-nav{position:fixed;inset:0;background:#fff;z-index:1500;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:3rem 2.5rem;gap:0;transform:translateX(100%);transition:transform .4s cubic-bezier(.77,0,.18,1);}
.mob-nav.open{transform:none;}
.mob-close{position:absolute;top:1.4rem;right:1.5rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--ink);}
.mob-nav>a{font-size:1.25rem;font-weight:700;color:var(--ink);padding:.6rem 0;display:block;}
.mob-nav>a:hover{color:var(--orange);}
.mob-sep{width:40px;height:2px;background:var(--gradient);border:none;margin:.8rem 0;}

/* ══ HERO ══ */
#hero{min-height:100vh;min-height:100svh;position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden;background:#fff;}
.h-slides{position:absolute;inset:0;z-index:0;}
.h-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;}
.h-slide.active{opacity:1;}
.h-slide video,.h-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.h-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.75) 0%,rgba(255,255,255,.55) 50%,rgba(255,255,255,.25) 100%);}
.hero-title-area{position:relative;z-index:2;text-align:center;padding:110px 3.5rem 3rem;max-width:1100px;margin:0 auto;width:100%;}
.hero-surtitle{font-size:.8rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;margin-bottom:1.2rem;}
.hero-big-title{font-size:clamp(2.6rem,5vw,5rem);font-weight:700;line-height:1.08;color:var(--ink);}
.hero-big-title em{font-style:normal;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-cards{position:relative;z-index:2;max-width:940px;margin:0 auto;width:100%;padding:0 3.5rem 5rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;}
.hcard{background:rgba(255,255,255,.93);border:1.5px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:0 6px 28px rgba(255,127,0,.10);transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column;}
.hcard:hover{transform:translateY(-6px);box-shadow:0 16px 44px rgba(255,127,0,.17);}
.hcard-img{height:190px;overflow:hidden;flex-shrink:0;}
.hcard-img img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform .55s;}
.hcard:hover .hcard-img img{transform:scale(1.07);}
.hcard-body{padding:1.5rem 1.6rem 1.7rem;flex:1;display:flex;flex-direction:column;}
.hcard-body h3{font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:.6rem;}
.hcard-body p{font-size:.88rem;color:var(--ink2);line-height:1.68;flex:1;}
.hcard-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--orange);font-size:.84rem;font-weight:700;margin-top:1.1rem;transition:gap .2s;}
.hcard-link:hover{gap:.6rem;}
.h-dots{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);display:flex;gap:.6rem;z-index:10;}
.hdot{width:7px;height:7px;border-radius:50%;background:rgba(26,10,5,.2);cursor:pointer;transition:all .3s;border:none;padding:0;}
.hdot.active{width:22px;border-radius:3px;background:var(--gradient);}

/* ══ SECTIONS ══ */
.sw{max-width:1360px;margin:0 auto;padding:6rem 3.5rem;}
.s-tag{display:inline-block;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;font-size:.77rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.8rem;}
.s-title{font-size:clamp(1.8rem,3vw,2.7rem);font-weight:700;color:var(--ink);line-height:1.1;margin-bottom:1rem;}
.s-title em{font-style:normal;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.s-lead{font-size:1rem;color:var(--ink2);line-height:1.75;max-width:660px;}
.btn-primary{background:var(--gradient);color:#fff;padding:.85rem 1.9rem;border-radius:50px;font-weight:700;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 6px 22px rgba(255,31,110,.27);transition:transform .2s,box-shadow .3s;}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 10px 34px rgba(255,31,110,.4);color:#fff;}

/* ══ À PROPOS — tabs ══ */
#about{background:#fff;}
.about-tabs{display:flex;gap:0;margin-bottom:2.5rem;border-bottom:2px solid var(--border);}
.about-tab{padding:.7rem 1.8rem;font-size:.9rem;font-weight:700;color:var(--ink2);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font);}
.about-tab.active{color:var(--orange);border-bottom-color:var(--orange);}
.about-tab:hover{color:var(--orange);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.about-imgs{position:relative;height:500px;}
.ab-main{position:absolute;top:0;left:0;right:10%;bottom:12%;border-radius:20px;overflow:hidden;box-shadow:0 16px 48px rgba(255,127,0,.12);}
.ab-main img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.ab-sec{position:absolute;right:0;bottom:0;width:46%;height:52%;border-radius:16px;overflow:hidden;border:4px solid #fff;box-shadow:0 12px 40px rgba(0,0,0,.12);}
.ab-sec img{width:100%;height:100%;object-fit:cover;}
.ab-badge{position:absolute;top:1.5rem;right:8%;background:var(--gradient);border-radius:14px;padding:1rem 1.3rem;text-align:center;box-shadow:0 8px 28px rgba(255,31,110,.35);}
.ab-num{font-size:1.9rem;font-weight:700;color:#fff;line-height:1;}
.ab-lab{font-size:.72rem;color:rgba(255,255,255,.85);margin-top:.2rem;}
.ab-body p{font-size:.97rem;color:var(--ink2);line-height:1.78;margin-bottom:1.2rem;}
.ab-dna{background:var(--bg2);border-left:3px solid var(--orange);border-radius:0 12px 12px 0;padding:1.2rem 1.4rem;font-size:.93rem;color:var(--ink2);line-height:1.7;font-style:italic;margin:1.5rem 0 1.8rem;}

/* Publications */
.publi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:2rem;}
.publi-card{background:var(--bg2);border:1.5px solid var(--border);border-radius:16px;overflow:hidden;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column;}
.publi-card:hover{transform:translateY(-5px);box-shadow:0 14px 38px rgba(255,127,0,.14);}
.publi-img{height:160px;overflow:hidden;background:#ede6de;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.publi-img img{width:100%;height:100%;object-fit:contain;padding:.7rem;transition:transform .4s;}
.publi-card:hover .publi-img img{transform:scale(1.05);}
.publi-info{padding:1rem 1.1rem 1.2rem;flex:1;display:flex;flex-direction:column;}
.publi-info h4{font-size:.85rem;font-weight:700;color:var(--ink);line-height:1.35;flex:1;}
.publi-source{font-size:.74rem;color:var(--orange);font-weight:600;margin-top:.4rem;}
.publi-link{font-size:.8rem;font-weight:700;color:var(--orange);margin-top:.7rem;display:inline-flex;align-items:center;gap:.3rem;transition:gap .2s;}
.publi-link:hover{gap:.55rem;}

/* ══ EXPERTISE ══ */
#poles{background:var(--bg2);}
.poles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:3.5rem;}
.pole-card{background:#fff;border:1.5px solid var(--border);border-radius:20px;overflow:hidden;transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column;}
.pole-card:hover{transform:translateY(-7px);box-shadow:0 18px 50px rgba(255,127,0,.15);}
.pole-card-top{position:relative;height:200px;overflow:hidden;flex-shrink:0;}
.pole-card-top img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s;}
.pole-card:hover .pole-card-top img{transform:scale(1.06);}
.pole-card-top::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(26,10,5,.1) 0%,rgba(26,10,5,.55) 100%);}
.pole-body{padding:1.7rem 1.8rem 2rem;flex:1;display:flex;flex-direction:column;}
.pole-body h3{font-size:1.15rem;font-weight:700;color:var(--ink);margin-bottom:.9rem;line-height:1.2;}
.pole-body p{font-size:.9rem;color:var(--ink2);line-height:1.72;flex:1;}
.pole-link{display:inline-flex;align-items:center;gap:.45rem;color:var(--orange);font-size:.86rem;font-weight:700;margin-top:1.4rem;transition:gap .2s;}
.pole-link:hover{gap:.7rem;}

/* ══ FRANCE 5 ══ */
#france5{background:#fff;}
.f5-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.f5-visual{border-radius:20px;overflow:hidden;box-shadow:0 16px 48px rgba(255,127,0,.14);aspect-ratio:16/9;}
.f5-visual iframe{width:100%;height:100%;display:block;border-radius:20px;}
.f5-text h2{font-size:clamp(1.7rem,2.8vw,2.4rem);font-weight:700;color:var(--ink);line-height:1.15;margin-bottom:1rem;}
.f5-text h2 em{font-style:normal;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.f5-text p{font-size:.97rem;color:var(--ink2);line-height:1.78;margin-bottom:1.4rem;}
.f5-infos{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.8rem;}
.f5-info{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:var(--ink2);}
.f5-info-dot{width:7px;height:7px;border-radius:50%;background:var(--gradient);flex-shrink:0;}
.btn-f5{background:var(--gradient);color:#fff;padding:.85rem 1.9rem;border-radius:50px;font-weight:700;font-size:.9rem;display:inline-flex;align-items:center;gap:.6rem;box-shadow:0 6px 20px rgba(255,31,110,.3);transition:transform .2s,box-shadow .3s;}
.btn-f5:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(255,31,110,.45);color:#fff;}

/* ══ MÉDIAS ══ */
#medias{background:var(--bg2);}
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:3rem;}
.media-card{background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:2rem 1.8rem;transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column;}
.media-card:hover{transform:translateY(-6px);box-shadow:0 16px 44px rgba(255,127,0,.15);}
.media-logo-img{height:52px;margin-bottom:1.3rem;display:flex;align-items:center;}
.media-logo-img img{height:46px;width:auto;object-fit:contain;max-width:160px;}
.media-card h3{font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:.4rem;}
.media-tag{font-size:.78rem;font-weight:700;color:var(--orange);margin-bottom:.8rem;}
.media-card p{font-size:.88rem;color:var(--ink2);line-height:1.68;flex:1;}
.media-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--orange);font-size:.84rem;font-weight:700;margin-top:1.1rem;transition:gap .2s;}
.media-link:hover{gap:.6rem;}
.media-feature{margin-top:2rem;background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:2rem 2.2rem;display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:center;}
.media-feature .e1{min-width:120px;display:flex;align-items:center;justify-content:center;}
.media-feature .e1 img{max-height:60px;width:auto;object-fit:contain;}
.media-numeros{margin-top:4rem;}
.numeros-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;}
.numero{background:var(--bg2);border:1.5px solid var(--border);border-radius:16px;padding:1.5rem;}
.numero .tag{font-size:.74rem;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.6rem;}
.numero h4{font-size:.97rem;font-weight:700;color:var(--ink);margin-bottom:.5rem;}
.numero p{font-size:.85rem;color:var(--ink2);line-height:1.65;}

/* ══ RESSOURCES / SHOP ══ */
#ressources{background:#fff;}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:3rem;}
.shop-card{background:var(--bg2);border:1.5px solid var(--border);border-radius:18px;overflow:hidden;transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column;}
.shop-card:hover{transform:translateY(-6px);box-shadow:0 16px 44px rgba(255,127,0,.15);}
.shop-card-img{height:170px;overflow:hidden;flex-shrink:0;background:#ede6de;display:flex;align-items:center;justify-content:center;}
.shop-card-img img{width:100%;height:100%;object-fit:contain;padding:.8rem;transition:transform .55s;}
.shop-card:hover .shop-card-img img{transform:scale(1.05);}
.shop-card-body{padding:1.3rem 1.5rem 1.5rem;flex:1;display:flex;flex-direction:column;}
.shop-card-body h3{font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:.5rem;line-height:1.35;}
.shop-card-body p{font-size:.83rem;color:var(--ink2);line-height:1.6;flex:1;}
.shop-price{font-size:1rem;font-weight:700;color:var(--orange);margin-top:.8rem;}
.shop-price.free{color:#16a34a;}
.shop-btn{display:inline-flex;align-items:center;gap:.35rem;color:var(--orange);font-size:.84rem;font-weight:700;margin-top:.9rem;transition:gap .2s;}
.shop-btn:hover{gap:.6rem;}
.shop-card.cta{background:var(--gradient);border-color:transparent;}
.shop-card.cta .shop-card-body{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:220px;}

/* ══ LINKEDIN ══ */
#linkedin{background:var(--bg2);}
.li-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2.5rem;align-items:start;}
.li-left h3{font-size:1.4rem;font-weight:700;color:var(--ink);margin-bottom:1rem;}
.li-left p{font-size:.95rem;color:var(--ink2);line-height:1.75;margin-bottom:1.5rem;}
.social-links{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem;}
.soc-link{display:inline-flex;align-items:center;gap:.55rem;padding:.65rem 1.3rem;border-radius:50px;font-weight:700;font-size:.87rem;transition:all .3s;}
.soc-link.li{background:#0077b5;color:#fff;box-shadow:0 4px 14px rgba(0,119,181,.25);}
.soc-link.li:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,119,181,.4);color:#fff;}
.soc-link.tw{background:#000;color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.18);}
.soc-link.tw:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3);color:#fff;}
.soc-link svg{width:16px;height:16px;fill:#fff;flex-shrink:0;}
.li-card{background:#fff;border:1.5px solid var(--border);border-radius:16px;padding:2.2rem;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:250px;}
.li-card p{font-size:.95rem;color:var(--ink2);max-width:280px;line-height:1.6;}
.li-card a{background:#0077b5;color:#fff;padding:.7rem 1.5rem;border-radius:50px;font-weight:700;font-size:.88rem;display:inline-flex;align-items:center;gap:.5rem;}

/* ══ FOOTER ══ */
footer.id-foot{background:#1a0a05;padding:3.5rem 3.5rem 1.8rem;}
.foot-in{max-width:1360px;margin:0 auto;}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem;}
.foot-brand-name{font-size:1.4rem;font-weight:700;color:#fff;}
.foot-brand-name span{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.foot-brand p{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.7;max-width:260px;margin-top:1rem;}
.foot-col h5{font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1rem;}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem;}
.foot-col ul a{color:rgba(255,255,255,.6);font-size:.88rem;transition:color .2s;}
.foot-col ul a:hover{color:var(--orange-l);}
.foot-bot{border-top:1px solid rgba(255,255,255,.08);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.foot-bot p{font-size:.78rem;color:rgba(255,255,255,.3);}
.soc-row{display:flex;gap:.6rem;}
.soc{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:transparent;color:rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;font-size:.82rem;cursor:pointer;transition:all .3s;text-decoration:none;}
.soc:hover{background:var(--gradient);border-color:transparent;color:#fff;}

/* ══ REVEAL (apparition douce, contenu visible si JS absent) ══ */
.reveal{opacity:1;transform:none;}

/* =================================================================
   PAGES INTERNES (articles, pages, archives, recherche, 404)
   — réutilisent l'identité orange/rose.
   ================================================================= */
.id-wrap{width:100%;max-width:1100px;margin-inline:auto;padding-inline:clamp(1.4rem,4vw,3.5rem);}
.id-narrow{max-width:760px;}
body:not(.home) #id-content{padding-top:100px;}
.id-page-header{padding-block:1rem clamp(1.5rem,3vw,2.5rem);}
.id-page-header h1{font-size:clamp(2rem,4vw,3rem);color:var(--ink);margin-bottom:.4rem;}
.id-eyebrow{display:inline-block;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;font-size:.77rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.6rem;}
.id-lede{font-size:1.05rem;color:var(--ink2);line-height:1.7;}
.id-meta{color:var(--ink2);font-size:.9rem;margin-bottom:1rem;}
.id-meta a{color:var(--orange);}
.id-entry{font-size:1rem;color:var(--ink);line-height:1.8;padding-bottom:3rem;}
.id-entry h2{font-size:1.6rem;margin:1.6em 0 .5em;color:var(--ink);}
.id-entry h3{font-size:1.25rem;margin:1.3em 0 .4em;color:var(--ink);}
.id-entry p{margin:0 0 1.1em;}
.id-entry a{color:var(--orange);text-decoration:underline;text-underline-offset:.15em;}
.id-entry img{border-radius:var(--radius);margin-block:1.5rem;}
.id-entry ul,.id-entry ol{padding-left:1.4rem;margin-bottom:1.1em;}
.id-entry li{margin-bottom:.4rem;}
.id-entry blockquote{margin:1.6rem 0;padding:.4rem 0 .4rem 1.4rem;border-left:4px solid var(--orange);font-size:1.15rem;color:var(--ink);font-style:italic;background:var(--bg2);border-radius:0 12px 12px 0;padding:1rem 1.4rem;}
.id-entry code{background:var(--bg2);padding:.12em .4em;border-radius:5px;font-size:.92em;}
.id-entry pre{background:var(--ink);color:#fff;padding:1.2rem;border-radius:var(--radius);overflow:auto;}
.id-btn{display:inline-flex;align-items:center;gap:.4rem;background:var(--gradient);color:#fff;padding:.7rem 1.4rem;border-radius:50px;font-weight:700;font-size:.88rem;box-shadow:0 6px 20px rgba(255,31,110,.25);transition:transform .2s,box-shadow .25s;border:none;cursor:pointer;}
.id-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,31,110,.4);color:#fff;}
.id-btn--ghost{background:#fff;color:var(--orange);border:2px solid var(--orange);box-shadow:none;}
.id-btn--ghost:hover{background:var(--bg2);color:var(--orange);}

.id-posts{display:grid;grid-template-columns:repeat(2,1fr);gap:1.8rem;}
.id-post-card{background:var(--bg2);border:1.5px solid var(--border);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s;}
.id-post-card:hover{transform:translateY(-5px);box-shadow:0 14px 38px rgba(255,127,0,.14);}
.id-post-card__thumb img{width:100%;aspect-ratio:16/9;object-fit:cover;margin:0;border-radius:0;}
.id-post-card__body{padding:1.3rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1;}
.id-post-card h2{font-size:1.25rem;margin:.3rem 0 .5rem;}
.id-post-card h2 a{color:var(--ink);text-decoration:none;}
.id-post-card h2 a:hover{color:var(--orange);}
.id-post-card p{color:var(--ink2);font-size:.92rem;}
.id-post-card .id-btn{align-self:flex-start;margin-top:auto;}

.id-pagination{margin:2.5rem 0 3rem;display:flex;justify-content:center;flex-wrap:wrap;gap:.4rem;}
.id-pagination .page-numbers{display:inline-grid;place-items:center;min-width:44px;height:44px;padding:0 .6rem;border:1.5px solid var(--border);border-radius:10px;color:var(--ink);text-decoration:none;}
.id-pagination .current{background:var(--gradient);color:#fff;border-color:transparent;}
.id-pagination a:hover{border-color:var(--orange);color:var(--orange);}

/* Widgets / commentaires basiques */
.id-comments{padding-bottom:3rem;}
.comment-list{list-style:none;padding:0;}
.comment-list .children{list-style:none;padding-left:1.5rem;}

/* Alignements WP */
.alignwide{width:min(100%,1280px);margin-inline:auto;}
.alignfull{width:100%;}
.aligncenter{margin-inline:auto;}
.wp-caption-text,.wp-element-caption{color:var(--ink2);font-size:.9rem;text-align:center;}

/* WooCommerce — petites retouches pour rester dans le ton */
.woocommerce #id-content{padding-top:110px;}
.woocommerce .button,.woocommerce a.button,.woocommerce button.button{background:var(--gradient)!important;color:#fff!important;border-radius:50px!important;border:none!important;}
.woocommerce span.price,.woocommerce .price{color:var(--orange)!important;}

/* ══ RESPONSIVE ══ */
@media(max-width:1200px){.publi-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:1100px){
  .hero-cards{grid-template-columns:1fr 1fr;}
  .poles-grid{grid-template-columns:1fr 1fr;}
  .about-grid{grid-template-columns:1fr;}
  .about-imgs{height:340px;}
  .media-grid{grid-template-columns:1fr 1fr;}
  .shop-grid{grid-template-columns:1fr 1fr;}
  .f5-inner{grid-template-columns:1fr;}
  .li-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:900px){
  .poles-grid{grid-template-columns:1fr;}
  .hero-cards{grid-template-columns:1fr;}
  .media-grid{grid-template-columns:1fr;}
  .numeros-grid{grid-template-columns:1fr;}
  .publi-grid{grid-template-columns:repeat(2,1fr);}
  .id-posts{grid-template-columns:1fr;}
}
@media(max-width:768px){
  nav.id-nav,nav.id-nav.scrolled{padding:.9rem 1.4rem;}
  .nav-menu{display:none;}
  .burger{display:flex;}
  .sw{padding:4rem 1.4rem;}
  .hero-title-area{padding:90px 1.4rem 2rem;}
  .hero-cards{padding:0 1.4rem 4rem;}
  .media-feature{grid-template-columns:1fr;}
  footer.id-foot{padding:2.5rem 1.4rem 1.4rem;}
  .foot-grid{grid-template-columns:1fr;gap:2rem;}
  .foot-bot{flex-direction:column;gap:1rem;text-align:center;}
  .shop-grid{grid-template-columns:1fr;}
}

/* =================================================================
   AJOUTS v2.1 — hero-thèse, dataviz "chiffres", médiathèque filtrable
   ================================================================= */

/* Hero : lede + invitation à scroller */
.hero-lede{max-width:680px;margin:1.4rem auto 0;font-size:clamp(1rem,1.6vw,1.2rem);color:var(--ink2);line-height:1.6;}
.hero-scroll{display:inline-block;margin-top:1.8rem;font-weight:700;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;color:var(--orange);}
.hero-scroll:hover{color:var(--rose);}

/* ── Section signature : Le défi en chiffres (fond blanc) ── */
#chiffres{background:#fff;}
.dotfigs{display:grid;grid-template-columns:repeat(4,1fr);gap:2.5rem;margin-top:3.5rem;align-items:start;}
.dotfig{margin:0;}
.dotgrid{display:grid;grid-template-columns:repeat(10,1fr);gap:5px;max-width:190px;}
.dotgrid .dot{aspect-ratio:1;border-radius:50%;background:#ece4db;}
.dotgrid .dot.is-fill{background:#ece4db;transition:background .4s ease,transform .4s ease;}
.dotgrid .dot.is-fill.on{background:var(--gradient);transform:scale(1.06);}
.dotfig figcaption{margin-top:1.2rem;display:flex;flex-wrap:wrap;align-items:baseline;gap:.1rem .25rem;}
.dotfig-num{font-size:clamp(2.4rem,4vw,3rem);font-weight:700;line-height:1;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.dotfig-unit{font-size:1.4rem;font-weight:700;color:var(--orange);}
.dotfig-lab{flex-basis:100%;color:var(--ink2);margin-top:.5rem;font-size:.9rem;line-height:1.5;}
.dotfig-lab strong{color:var(--ink);}
.chiffres-thesis{margin-top:3rem;border-left:4px solid var(--orange);background:var(--bg2);border-radius:0 14px 14px 0;padding:1.6rem 1.9rem;max-width:780px;}
.ct-quote{font-size:clamp(1.2rem,1.8vw,1.5rem);line-height:1.4;color:var(--ink);font-weight:700;margin-bottom:.8rem;}
.ct-src{color:var(--ink2);font-size:.95rem;}
.chiffres-note{margin-top:2rem;color:var(--ink2);font-size:.8rem;opacity:.8;}

/* ── Médiathèque filtrable ── */
.media-lib{margin-top:4.5rem;}
.lib-head h3{font-size:1.45rem;color:var(--ink);margin:.5rem 0 1.6rem;}
.lib-head h3 em{font-style:normal;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.lib-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem;}
.chip{border:1.5px solid var(--border);background:#fff;color:var(--ink2);padding:.5rem 1.15rem;border-radius:50px;font-weight:700;font-size:.85rem;cursor:pointer;font-family:var(--font);transition:color .2s,border-color .2s,background .2s;}
.chip:hover{border-color:var(--orange);color:var(--orange);}
.chip.is-active{background:var(--gradient);color:#fff;border-color:transparent;box-shadow:0 4px 16px rgba(255,31,110,.25);}
.lib-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.media-item{background:var(--bg2);border:1.5px solid var(--border);border-radius:16px;padding:1.5rem;transition:transform .3s,box-shadow .3s;}
.media-item:hover{transform:translateY(-4px);box-shadow:0 14px 38px rgba(255,127,0,.14);}
.media-item.is-hidden{display:none;}
.mi-src{font-size:.73rem;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem;}
.media-item h4{font-size:1rem;color:var(--ink);margin-bottom:.5rem;line-height:1.3;}
.media-item p{font-size:.85rem;color:var(--ink2);line-height:1.62;}
.lib-empty{grid-column:1/-1;color:var(--ink2);text-align:center;padding:2rem 0;}

@media(max-width:1100px){
  .dotfigs{grid-template-columns:repeat(2,1fr);gap:2rem 2.5rem;}
  .lib-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:760px){
  .dotfigs{grid-template-columns:1fr 1fr;gap:1.6rem;}
  .lib-grid{grid-template-columns:1fr;}
}
@media(max-width:460px){
  .dotfigs{grid-template-columns:1fr;}
}

/* ── Page Boutique (à venir) ── */
.boutique-soon{padding-block:clamp(2.5rem,6vw,5rem) clamp(3rem,8vw,6rem);background:linear-gradient(180deg,var(--bg2),#fff);}
.bs-badge{display:inline-block;background:var(--gradient);color:#fff;font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;padding:.5rem 1.1rem;border-radius:50px;margin-bottom:1.4rem;box-shadow:0 6px 20px rgba(255,31,110,.25);}
.boutique-soon h1{font-size:clamp(2.2rem,5vw,3.4rem);color:var(--ink);margin-bottom:1rem;}
.bs-cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin:2rem 0 1.5rem;}
.bs-note{color:var(--ink2);font-size:.9rem;opacity:.85;}
