/*
Theme Name: Association Humanitaire Afrique Togo
Theme URI: https://asso-afritogo.org/
Author: 3Vision Group
Description: Thème WordPress custom pour Association Humanitaire Afrique Togo (AHAT), mobile-first, SEO-friendly, photos validées et charte bleue/verte issue du logo.
Version: 1.2.1
Text Domain: olf-foundation
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Tags: custom, blog, one-column, two-columns, translation-ready
*/

:root{
  /* Brand AHAT — couleurs du logo */
  --olf-blue:#15378C;
  --olf-blue-dark:#0E2762;
  --olf-green:#038C03;
  --olf-pink:#038C03;
  --olf-pink-hover:#027302;

  /* UI */
  --olf-bg:#FFFFFF;
  --olf-surface:#F7F8FC;
  --olf-ink:#0B1321;
  --olf-muted:#475569;
  --olf-line:rgba(2, 6, 23, .10);
  --olf-radius:18px;
  --olf-shadow:0 16px 45px rgba(2, 6, 23, .12);

  --olf-wrap:1180px;
  --olf-g:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:auto}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--olf-ink);
  background:var(--olf-bg);
  line-height:1.55;
}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:hover{color:var(--olf-blue)}

.olf-wrap{max-width:var(--olf-wrap);margin:0 auto;padding:0 var(--olf-g)}
.olf-skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.olf-skip:focus{left:12px;top:12px;width:auto;height:auto;padding:10px 12px;background:#fff;border:1px solid var(--olf-line);border-radius:12px;z-index:999999}

/* Header */
.olf-site-header{position:sticky;top:0;z-index:9999;background:rgba(255,255,255,.9);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--olf-line)}
.olf-header{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:74px}
.olf-brand{display:flex;align-items:center;gap:12px;min-width:180px}
.olf-brand img{display:block;width:auto;height:44px}
.olf-brand .olf-site-title{font-weight:800;letter-spacing:-.02em}

.olf-nav{display:flex;align-items:center;gap:18px}
.olf-menu{display:flex;align-items:center;gap:18px;list-style:none;margin:0;padding:0}
.olf-menu > li{position:relative}
.olf-menu > li > a{display:inline-flex;align-items:center;gap:8px;padding:10px 8px;border-radius:12px;color:var(--olf-ink);font-weight:650}
.olf-menu > li > a:hover{background:var(--olf-surface);color:var(--olf-blue)}

/* Dropdown (simple) */
.olf-menu li ul{display:none;position:absolute;left:0;top:calc(100% + 10px);min-width:220px;background:#fff;border:1px solid var(--olf-line);border-radius:14px;box-shadow:var(--olf-shadow);padding:8px;list-style:none;margin:0}
.olf-menu li:hover > ul{display:block}
.olf-menu li ul a{display:block;padding:10px 10px;border-radius:12px;color:var(--olf-ink)}
.olf-menu li ul a:hover{background:var(--olf-surface);color:var(--olf-blue)}

.olf-actions{display:flex;align-items:center;gap:10px}
.olf-btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:10px;padding:10px 14px;border-radius:999px;
  border:1px solid transparent;font-weight:750;white-space:nowrap;
}
.olf-btn-primary{background:var(--olf-pink);color:#fff;box-shadow:0 10px 30px rgba(3,140,3,.25)}
.olf-btn-primary:hover{background:var(--olf-pink-hover);color:#fff}
.olf-btn-ghost{background:transparent;border-color:var(--olf-line);color:var(--olf-ink)}
.olf-btn-ghost:hover{background:var(--olf-surface)}

/* Language switcher wrapper */
.olf-lang{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--olf-line);border-radius:999px;background:#fff}
.olf-lang a{font-weight:700;color:var(--olf-muted)}
.olf-lang a:hover{color:var(--olf-blue)}

/* Mobile */
.olf-burger{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:1px solid var(--olf-line);background:#fff}
.olf-burger:hover{background:var(--olf-surface)}
.olf-burger svg{width:20px;height:20px}

.olf-drawer-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.55);backdrop-filter:blur(2px);display:none;z-index:9998}
.olf-drawer{position:fixed;top:0;right:0;height:100%;width:min(92vw, 360px);background:#fff;border-left:1px solid var(--olf-line);transform:translateX(105%);transition:transform .22s ease;z-index:9999;display:flex;flex-direction:column}
.olf-drawer.open{transform:translateX(0)}
.olf-drawer-backdrop.open{display:block}

.olf-drawer-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 16px;border-bottom:1px solid var(--olf-line)}
.olf-drawer-title{font-weight:850}
.olf-drawer-close{width:44px;height:44px;border-radius:12px;border:1px solid var(--olf-line);background:#fff}
.olf-drawer-close:hover{background:var(--olf-surface)}

.olf-drawer-body{padding:14px 16px;overflow:auto}
.olf-mmenu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.olf-mmenu a{display:flex;align-items:center;justify-content:space-between;padding:12px 12px;border-radius:14px;font-weight:750;color:var(--olf-ink);background:var(--olf-surface)}
.olf-mmenu a:hover{background:#fff;border:1px solid var(--olf-line)}
.olf-drawer-actions{padding:14px 16px;border-top:1px solid var(--olf-line);display:grid;gap:10px}

@media (max-width: 980px){
  .olf-nav{display:none}
  .olf-burger{display:inline-flex}
  .olf-actions{gap:8px}
  .olf-brand{min-width:unset}
}

/* Content basics */
main{display:block}
.olf-section{padding:44px 0}
.olf-hero{background:linear-gradient(180deg, rgba(66,86,164,.08), rgba(255,255,255,0));border-bottom:1px solid var(--olf-line)}
.olf-hero-grid{display:grid;grid-template-columns: 1.1fr .9fr;gap:24px;align-items:center}
.olf-kicker{display:inline-flex;gap:8px;align-items:center;font-weight:800;color:var(--olf-blue)}
.olf-h1{font-size:clamp(28px, 3.4vw, 46px);line-height:1.1;margin:10px 0 10px;font-weight:900;letter-spacing:-.03em}
.olf-lead{font-size:clamp(16px, 1.3vw, 18px);color:var(--olf-muted);margin:0 0 16px}
.olf-hero-card{background:#fff;border:1px solid var(--olf-line);border-radius:var(--olf-radius);box-shadow:var(--olf-shadow);padding:18px}

@media (max-width: 980px){
  .olf-hero-grid{grid-template-columns:1fr}
}

/* Blog cards */
.olf-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:18px}
.olf-card{background:#fff;border:1px solid var(--olf-line);border-radius:var(--olf-radius);overflow:hidden;box-shadow:0 10px 30px rgba(2,6,23,.06)}
.olf-card-media{aspect-ratio:16/9;background:var(--olf-surface)}
.olf-card-media img{width:100%;height:100%;object-fit:cover;display:block}
.olf-card-body{padding:14px 14px 16px}
.olf-card-title{font-weight:900;letter-spacing:-.02em;line-height:1.2;margin:0 0 8px}
.olf-card-meta{font-size:13px;color:var(--olf-muted)}

@media (max-width: 980px){
  .olf-grid{grid-template-columns:1fr}
}

/* Footer */
.olf-site-footer{margin-top:50px;background:#0B1321;color:#E8EEF9}
.olf-footer{padding:34px 0}
.olf-footer a{color:#E8EEF9;opacity:.9}
.olf-footer a:hover{opacity:1;color:#fff}
.olf-footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:18px}
.olf-footer-title{font-weight:900;margin:0 0 10px}
.olf-footer-muted{color:rgba(232,238,249,.8)}
@media (max-width: 980px){
  .olf-footer-grid{grid-template-columns:1fr}
}

/* =========================================================
   AHAT v1.1.5 — stabilité mobile + pages intérieures premium
   Objectif : header mobile fixe, scroll fluide, pages propres
========================================================= */
html{
  scroll-padding-top:96px;
  -webkit-text-size-adjust:100%;
}
body{
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overscroll-behavior-y:auto;
}

/* Le header inline du thème arrive après style.css : on force seulement le mobile. */
@media (max-width:1180px){
  .aso-header{
    position:fixed!important;
    left:0!important;
    right:0!important;
    top:0!important;
    width:100%!important;
    z-index:100050!important;
    transform:translateZ(0);
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
    box-shadow:0 12px 34px rgba(14,39,98,.10)!important;
  }
  body.admin-bar .aso-header{top:46px!important;}
  body{padding-top:72px!important;}
  .aso-drawer__sheet{
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
  }
}
@media (max-width:520px){
  body{padding-top:68px!important;}
}

/* Pages génériques : transforme les contenus WP simples en rendu institutionnel. */
.aso-page-shell{
  --aso-page-ink:#0E2762;
  --aso-page-blue:#15378C;
  --aso-page-green:#038C03;
  --aso-page-muted:#52617f;
  --aso-page-line:rgba(21,55,140,.12);
  --aso-page-bg:#f7f9ff;
  --aso-page-shadow:0 24px 80px rgba(14,39,98,.12);
  background:
    radial-gradient(900px 420px at 14% 4%, rgba(21,55,140,.10), transparent 60%),
    radial-gradient(900px 420px at 86% 8%, rgba(3,140,3,.08), transparent 62%),
    linear-gradient(180deg,#ffffff 0%, var(--aso-page-bg) 100%);
  padding:clamp(20px,3vw,38px) 0 clamp(54px,6vw,90px);
}
.aso-page-shell__wrap{max-width:1180px;margin:0 auto;padding:0 18px;}
.aso-page-hero{
  position:relative;
  overflow:hidden;
  border-radius:clamp(24px,3vw,42px);
  min-height:clamp(230px,34vw,390px);
  display:grid;
  align-items:end;
  padding:clamp(22px,4vw,42px);
  border:1px solid var(--aso-page-line);
  box-shadow:var(--aso-page-shadow);
  background:#eaf0ff;
  isolation:isolate;
}
.aso-page-hero::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(14,39,98,.86) 0%,rgba(21,55,140,.62) 48%,rgba(3,140,3,.20) 100%);
  z-index:1;
}
.aso-page-hero::after{
  content:"";
  position:absolute;inset:auto 0 0 0;height:42%;
  background:linear-gradient(180deg,transparent,rgba(14,39,98,.34));
  z-index:2;
}
.aso-page-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 36%;z-index:0;}
.aso-page-hero__content{position:relative;z-index:3;max-width:760px;color:#fff;}
.aso-page-kicker{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);
  color:#fff;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:.06em;
  margin-bottom:12px;
}
.aso-page-h1{
  margin:0;color:#fff;font-weight:950;letter-spacing:-.035em;line-height:1.04;
  font-size:clamp(34px,5.4vw,68px);text-wrap:balance;
}
.aso-page-lead{margin:12px 0 0;color:rgba(255,255,255,.90);font-weight:700;line-height:1.55;max-width:64ch;font-size:clamp(15.5px,1.3vw,18px);}
.aso-page-card{
  margin:clamp(18px,2.6vw,28px) auto 0;
  background:rgba(255,255,255,.94);
  border:1px solid var(--aso-page-line);
  border-radius:clamp(22px,2.6vw,34px);
  box-shadow:var(--aso-page-shadow);
  padding:clamp(18px,3vw,36px);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.aso-page-content{
  color:#273653;
  font-size:clamp(16px,1.2vw,18px);
  line-height:1.78;
  overflow-wrap:anywhere;
}
.aso-page-content > *:first-child{margin-top:0!important;}
.aso-page-content > *:last-child{margin-bottom:0!important;}
.aso-page-content h2,
.aso-page-content h3,
.aso-page-content h4{
  color:var(--aso-page-ink);
  line-height:1.16;
  letter-spacing:-.02em;
  margin:1.55em 0 .65em;
  font-weight:950;
}
.aso-page-content h2{font-size:clamp(25px,3vw,40px);}
.aso-page-content h3{font-size:clamp(21px,2vw,28px);}
.aso-page-content p{margin:0 0 1em;color:#273653;}
.aso-page-content ul,
.aso-page-content ol{padding-left:1.2em;margin:0 0 1.1em;}
.aso-page-content li{margin:.38em 0;}
.aso-page-content a{color:var(--aso-page-green);font-weight:900;text-decoration:none;}
.aso-page-content a:hover{text-decoration:underline;}
.aso-page-content img{
  border-radius:22px;
  box-shadow:0 18px 52px rgba(14,39,98,.10);
}
.aso-page-content blockquote{
  margin:1.4em 0;padding:18px 20px;border-left:5px solid var(--aso-page-green);
  background:rgba(3,140,3,.06);border-radius:18px;color:var(--aso-page-ink);font-weight:800;
}
/* Nettoyage des vieux contenus importés avec bandes grises/inline styles. */
.aso-page-content [style*="background"],
.aso-page-content [style*="Background"],
.aso-page-content p[style],
.aso-page-content div[style]{
  background:transparent!important;
}
.aso-page-content .wp-block-group,
.aso-page-content .wp-block-columns,
.aso-page-content .wp-block-media-text{
  border-radius:22px;
}
.aso-page-cta{
  margin-top:clamp(18px,2.4vw,28px);
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:18px;border-radius:24px;
  background:linear-gradient(135deg,rgba(21,55,140,.10),rgba(3,140,3,.08));
  border:1px solid var(--aso-page-line);
}
.aso-page-cta strong{color:var(--aso-page-ink);font-size:18px;}
.aso-page-cta a{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:999px;
  color:#fff!important;background:linear-gradient(135deg,var(--aso-page-blue),var(--aso-page-green));
  text-decoration:none!important;font-weight:950;box-shadow:0 14px 34px rgba(14,39,98,.16);
}
@media (max-width:720px){
  .aso-page-shell__wrap{padding:0 14px;}
  .aso-page-hero{border-radius:24px;padding:22px;min-height:250px;}
  .aso-page-card{border-radius:24px;padding:18px 16px;}
  .aso-page-content{text-align:left;line-height:1.74;}
  .aso-page-content p{text-align:left!important;}
  .aso-page-cta{align-items:stretch;}
  .aso-page-cta a{width:100%;}
}

/* Blog/single/archive : meilleur confort de lecture mobile. */
.olf-single-post__content,
.olf-blog-page,
.olf-archive{scroll-margin-top:92px;}
.olf-single-post__content p{margin:0 0 1em;}
.olf-single-post__content img{border-radius:22px;box-shadow:0 18px 52px rgba(14,39,98,.10);}
.olf-single-post__content h2,.olf-single-post__content h3{color:#0E2762;letter-spacing:-.02em;line-height:1.18;}

@media (max-width:720px){
  .olf-blog-page__wrap,
  .olf-archive__wrap,
  .olf-single-post__wrap{padding-left:14px!important;padding-right:14px!important;}
  .olf-single-post__content{font-size:16.5px!important;line-height:1.75!important;}
}

/* =========================================================
   AHAT v1.1.6 — stabilité mobile + pages internes premium
   Note: front-page.php non modifié.
========================================================= */
html{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  -webkit-text-size-adjust:100%;
  scroll-padding-top:calc(var(--aso-header-fixed-h, 76px) + 18px);
}
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
img,svg,video,iframe{max-width:100%;}
:target{scroll-margin-top:calc(var(--aso-header-fixed-h, 76px) + 22px);}

@media (max-width:1180px){
  .aso-header{
    position:fixed!important;
    left:0!important;
    right:0!important;
    top:0!important;
    width:100%!important;
    z-index:100050!important;
    transform:translateZ(0)!important;
    -webkit-transform:translateZ(0)!important;
    backface-visibility:hidden!important;
    -webkit-backface-visibility:hidden!important;
    box-shadow:0 12px 34px rgba(14,39,98,.12)!important;
  }
  body{padding-top:var(--aso-header-fixed-h, 72px)!important;}
  .admin-bar .aso-header{top:46px!important;}
  body.admin-bar{padding-top:calc(var(--aso-header-fixed-h, 72px) + 46px)!important;}
  .aso-topbar{display:none!important;}
  .aso-drawer{position:fixed!important;inset:0!important;z-index:100200!important;}
  .aso-drawer__sheet{max-height:100dvh;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;}
}
@media (min-width:783px) and (max-width:1180px){
  .admin-bar .aso-header{top:32px!important;}
  body.admin-bar{padding-top:calc(var(--aso-header-fixed-h, 72px) + 32px)!important;}
}

/* Generic inner pages */
.aso-inner-page{
  --aso-ink:#0E2762;
  --aso-text:#334155;
  --aso-muted:#64748b;
  --aso-blue:#15378C;
  --aso-green:#038C03;
  --aso-soft:#F6F8FF;
  --aso-line:rgba(14,39,98,.12);
  --aso-shadow:0 26px 80px rgba(14,39,98,.10);
  background:
    radial-gradient(900px 420px at 5% 0%, rgba(21,55,140,.08), transparent 62%),
    radial-gradient(900px 420px at 95% 8%, rgba(3,140,3,.07), transparent 58%),
    linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  color:var(--aso-ink);
}
.aso-page-shell{padding:clamp(22px,4vw,56px) 0 clamp(44px,6vw,82px);}
.aso-page-shell__wrap{width:min(1160px, calc(100% - 32px));margin:0 auto;}

.aso-page-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,440px);
  gap:clamp(16px,2.4vw,28px);
  align-items:stretch;
  margin-bottom:clamp(18px,2.8vw,28px);
  padding:clamp(18px,2.6vw,30px);
  border-radius:clamp(24px,3vw,38px);
  overflow:hidden;
  background:
    linear-gradient(135deg, rgba(14,39,98,.98) 0%, rgba(21,55,140,.96) 62%, rgba(3,140,3,.88) 140%);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:var(--aso-shadow);
  position:relative;
  isolation:isolate;
}
.aso-page-hero::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(520px 260px at 18% 12%, rgba(255,255,255,.12), transparent 62%),
    radial-gradient(520px 260px at 88% 22%, rgba(3,140,3,.18), transparent 62%);
  pointer-events:none;
  z-index:-1;
}
.aso-page-hero__content{display:flex;flex-direction:column;justify-content:center;min-width:0;padding:clamp(6px,1vw,10px) 0;}
.aso-page-kicker{
  display:inline-flex;align-items:center;gap:9px;width:max-content;max-width:100%;
  padding:8px 12px;border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:900;font-size:13px;line-height:1;
  letter-spacing:.08em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.16);
}
.aso-page-kicker::before{content:"";width:8px;height:8px;border-radius:999px;background:#52d66b;box-shadow:0 0 0 4px rgba(82,214,107,.15);}
.aso-page-h1{
  color:#fff!important;
  margin:14px 0 10px!important;
  font-size:clamp(32px,5vw,58px)!important;
  line-height:1.02!important;
  letter-spacing:-.045em!important;
  font-weight:950!important;
  text-wrap:balance;
}
.aso-page-lead{color:rgba(255,255,255,.86)!important;font-size:clamp(16px,1.4vw,18px);line-height:1.7;margin:0;max-width:62ch;}
.aso-page-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.aso-page-btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:46px;padding:12px 16px;border-radius:999px;
  font-weight:900;text-decoration:none!important;
  transition:transform .16s ease,box-shadow .16s ease,background .16s ease;
}
.aso-page-btn--primary{background:#fff;color:var(--aso-blue)!important;box-shadow:0 16px 42px rgba(0,0,0,.10);}
.aso-page-btn--ghost{background:rgba(255,255,255,.10);color:#fff!important;border:1px solid rgba(255,255,255,.18);}
.aso-page-btn:hover{transform:translateY(-1px);}
.aso-page-hero__media{margin:0;border-radius:26px;overflow:hidden;min-height:300px;background:rgba(255,255,255,.12);box-shadow:0 18px 52px rgba(0,0,0,.12);}
.aso-page-hero__media img{width:100%;height:100%;display:block;object-fit:cover;object-position:center;}

.aso-page-card,
.aso-page-feature,
.aso-page-cta{
  background:rgba(255,255,255,.92);
  border:1px solid var(--aso-line);
  border-radius:clamp(22px,2.4vw,30px);
  box-shadow:0 18px 58px rgba(14,39,98,.07);
}
.aso-page-card{padding:clamp(20px,3vw,38px);margin-bottom:clamp(16px,2.4vw,24px);}
.aso-page-content{max-width:860px;margin:0 auto;color:var(--aso-text);}
.aso-page-content > *:first-child{margin-top:0!important;}
.aso-page-content > *:last-child{margin-bottom:0!important;}
.aso-page-content h1,
.aso-page-content h2,
.aso-page-content h3,
.aso-page-content h4{
  color:var(--aso-ink)!important;
  letter-spacing:-.02em;
  line-height:1.14;
  margin:1.25em 0 .55em;
  font-weight:950;
}
.aso-page-content h1{font-size:clamp(28px,3.4vw,44px);}
.aso-page-content h2{font-size:clamp(24px,2.7vw,34px);}
.aso-page-content h3{font-size:clamp(20px,2vw,26px);}
.aso-page-content p,
.aso-page-content li{
  color:var(--aso-text)!important;
  font-size:clamp(16px,1.25vw,17px);
  line-height:1.85;
}
.aso-page-content p{margin:0 0 1.05em;}
.aso-page-content ul,
.aso-page-content ol{padding-left:1.2em;margin:0 0 1.1em;}
.aso-page-content li{margin:.42em 0;}
.aso-page-content a{color:var(--aso-blue)!important;font-weight:850;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}
.aso-page-content img{border-radius:22px;box-shadow:0 18px 48px rgba(14,39,98,.10);}
.aso-page-content table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--aso-line);border-radius:18px;overflow:hidden;background:#fff;}
.aso-page-content td,.aso-page-content th{padding:12px;border-bottom:1px solid var(--aso-line);text-align:left;}
.aso-page-content blockquote{margin:22px 0;padding:18px 20px;border-left:4px solid var(--aso-green);border-radius:18px;background:rgba(3,140,3,.06);color:var(--aso-ink);}

.aso-page-feature{padding:clamp(18px,2.6vw,28px);margin-bottom:clamp(16px,2.4vw,24px);}
.aso-page-feature__head{max-width:760px;margin-bottom:16px;}
.aso-page-feature__head span{display:inline-flex;color:var(--aso-green);font-weight:950;letter-spacing:.08em;text-transform:uppercase;font-size:12px;margin-bottom:8px;}
.aso-page-feature__head h2{margin:0 0 8px;color:var(--aso-ink);font-size:clamp(24px,3vw,38px);line-height:1.12;letter-spacing:-.035em;}
.aso-page-feature__head p{margin:0;color:var(--aso-muted);line-height:1.7;font-weight:650;}
.aso-page-feature__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}
.aso-page-feature__grid > div{padding:16px;border:1px solid var(--aso-line);border-radius:20px;background:linear-gradient(180deg,#fff,rgba(246,248,255,.72));}
.aso-page-feature__grid strong{display:block;color:var(--aso-ink);font-weight:950;margin-bottom:6px;}
.aso-page-feature__grid span{display:block;color:var(--aso-muted);line-height:1.55;font-weight:650;font-size:14.5px;}

.aso-page-cta{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:clamp(18px,2.8vw,28px);background:linear-gradient(135deg,var(--aso-blue),#0E2762);color:#fff;overflow:hidden;position:relative;}
.aso-page-cta::after{content:"";position:absolute;right:-80px;top:-120px;width:260px;height:260px;border-radius:999px;background:rgba(3,140,3,.24);}
.aso-page-cta > *{position:relative;z-index:1;}
.aso-page-cta span{display:block;color:rgba(255,255,255,.72);font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;}
.aso-page-cta strong{display:block;font-size:clamp(20px,2.2vw,30px);line-height:1.18;max-width:670px;}
.aso-page-cta__links{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;}
.aso-page-cta a{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:11px 15px;border-radius:999px;background:#fff;color:var(--aso-blue)!important;font-weight:950;text-decoration:none!important;white-space:nowrap;}
.aso-page-cta a + a{background:rgba(255,255,255,.12);color:#fff!important;border:1px solid rgba(255,255,255,.18);}

.aso-reveal-block{animation:asoSoftIn .42s ease both;}
@keyframes asoSoftIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

@media (max-width:900px){
  .aso-page-shell__wrap{width:min(100% - 24px, 680px);}
  .aso-page-hero{grid-template-columns:1fr;padding:16px;border-radius:28px;}
  .aso-page-hero__media{order:-1;min-height:210px;border-radius:22px;}
  .aso-page-h1{font-size:clamp(30px,8.4vw,42px)!important;}
  .aso-page-actions{display:grid;grid-template-columns:1fr;}
  .aso-page-btn{width:100%;}
  .aso-page-card{padding:18px;border-radius:24px;}
  .aso-page-content p,.aso-page-content li{font-size:16px;line-height:1.82;}
  .aso-page-feature__grid{grid-template-columns:1fr;}
  .aso-page-cta{display:grid;text-align:left;border-radius:24px;}
  .aso-page-cta__links{justify-content:stretch;display:grid;grid-template-columns:1fr;}
}
@media (max-width:520px){
  .aso-page-shell{padding-top:16px;}
  .aso-page-shell__wrap{width:calc(100% - 20px);}
  .aso-page-hero{padding:12px;border-radius:24px;}
  .aso-page-hero__media{min-height:190px;}
  .aso-page-kicker{font-size:11.5px;padding:7px 10px;}
  .aso-page-card,.aso-page-feature,.aso-page-cta{border-radius:22px;}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto!important;}
  .aso-reveal-block,.aso-page-btn{animation:none!important;transition:none!important;}
}


/* =========================================================
   AHAT v1.1.8 — scroll natif fiable
   On ne force plus html/body en overflow auto/hidden.
   Le navigateur garde son scroll normal en desktop et mobile.
========================================================= */
html,
body{
  scroll-behavior:auto!important;
  overscroll-behavior-y:auto!important;
  touch-action:auto!important;
}
html.aso-drawer-open,
body.aso-drawer-open,
html.aso-hard-lock,
body.aso-hard-lock{
  overflow:visible!important;
  height:auto!important;
  position:static!important;
  touch-action:auto!important;
}
.aso-drawer[hidden]{display:none!important;}
.aso-drawer[aria-hidden="true"]{pointer-events:none!important;}
.aso-drawer[aria-hidden="false"]{pointer-events:auto!important;}
@media (max-width:1180px){
  .aso-drawer__sheet{
    max-height:100dvh;
    overflow-y:auto!important;
    -webkit-overflow-scrolling:touch!important;
  }
}

/* =========================================================
   AHAT v1.1.8 — performance scroll desktop/mobile
   Supprime les effets coûteux pendant le scroll sans toucher front-page.php.
========================================================= */
html,
body{
  scroll-behavior:auto!important;
  overscroll-behavior-y:auto!important;
  touch-action:auto!important;
}
body{
  text-rendering:auto!important;
}
.aso-header,
.olf-site-header,
.aso-page-card,
.aso-page-feature,
.aso-page-hero,
.aso-page-shell,
.aso-drawer__sheet,
.aso-drawer__backdrop{
  -webkit-backdrop-filter:none!important;
  backdrop-filter:none!important;
}
.aso-header,
.olf-site-header{
  will-change:auto!important;
  contain:layout paint;
}
.olf-media-card,
.olf-split-card,
.olfc-map,
.olfc-card,
.aso-page-card,
.aso-page-feature,
.aso-page-hero,
.aso-page-cta{
  will-change:auto!important;
}
@media (min-width:1181px){
  .aso-header{
    position:sticky!important;
    top:0!important;
  }
  body{padding-top:0!important;}
}


/* =========================================================
   AHAT v1.2.0 — charte logo + scroll natif stable
========================================================= */
:root{
  --olf-blue:#15378C!important;
  --olf-blue-dark:#0E2762!important;
  --olf-green:#038C03!important;
  --olf-pink:#038C03!important;
  --olf-pink-hover:#027302!important;
  --olf-ink:#0B1F52!important;
  --olf-muted:#52617F!important;
  --olf-line:rgba(21,55,140,.12)!important;
  --olf-shadow:0 16px 45px rgba(14,39,98,.12)!important;
}
html,body{
  overflow-x:hidden!important;
  overflow-y:auto!important;
  height:auto!important;
  min-height:100%!important;
  position:static!important;
  touch-action:auto!important;
  scroll-behavior:auto!important;
  overscroll-behavior-y:auto!important;
}
html.aso-drawer-open,body.aso-drawer-open,
html.olfx-open,body.olfx-open{
  overflow-y:auto!important;
  height:auto!important;
  position:static!important;
  touch-action:auto!important;
}
.aso-header,.olf-site-header{
  -webkit-backdrop-filter:none!important;
  backdrop-filter:none!important;
  will-change:auto!important;
  contain:none!important;
}
@media (max-width:1180px){
  .aso-header{position:sticky!important;top:0!important;left:auto!important;right:auto!important;width:100%!important;transform:none!important;}
  body,body.admin-bar{padding-top:0!important;}
}
.aso-page-shell{
  --aso-page-blue:#15378C;
  --aso-page-green:#038C03;
  --aso-page-ink:#0E2762;
}
.aso-page-cta{background:linear-gradient(135deg,#15378C,#0E2762)!important;}
.aso-page-cta::after{background:rgba(3,140,3,.25)!important;}
