/* =========================================================
 * Mama Baby Paris - Custom child theme styles
 * Design System: Editorial Frieze Art
 * Headings: Vollkorn (serif) | Body: Work Sans (sans)
 * Palette: #0F0F0F primary / #FF4E20 accent / #FFFFFF bg
 * ========================================================= */

:root{
  --d60-primary:#0F0F0F;
  --d60-accent:#FF4E20;
  --d60-text:#0F0F0F;
  --d60-text-soft:#4A4A4A;
  --d60-bg:#FFFFFF;
  --d60-surface:#F1F1F1;
  --d60-line:#D5D5D5;
  --d60-font-heading:"Vollkorn",Georgia,serif;
  --d60-font-body:"Work Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --d60-container:1280px;
  --d60-radius:0;
  --d60-shadow:0 12px 38px rgba(15,15,15,.08);
  --d60-shadow-card:0 6px 22px rgba(15,15,15,.06);
}

/* ===== Base ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body.d60-body{
  margin:0;padding:0;
  font-family:var(--d60-font-body);
  font-size:16px;line-height:1.65;
  color:var(--d60-text);
  background:var(--d60-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--d60-text);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--d60-accent)}
h1,h2,h3,h4,h5{font-family:var(--d60-font-heading);font-weight:700;line-height:1.18;color:var(--d60-text);margin:0 0 .6em}
h1{font-size:clamp(2rem,4.2vw,3.6rem);letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,2.6vw,2.4rem);letter-spacing:-.01em}
h3{font-size:clamp(1.25rem,1.8vw,1.6rem)}
h4{font-size:1.15rem}
p{margin:0 0 1em}
ul,ol{margin:0 0 1em;padding-left:1.4em}

main,.d60-main{padding-top:0!important;margin-top:0!important}

/* Container utility */
.d60-container{max-width:var(--d60-container);margin:0 auto;padding:0 24px}
@media(max-width:640px){.d60-container{padding:0 18px}}

/* ===== Header (logo-left-menu-right) ===== */
.d60-header{
  position:sticky;top:0;z-index:1000;
  background:var(--d60-bg);
  border-bottom:1px solid var(--d60-line);
  transition:box-shadow .25s ease;
}
.d60-header.is-scrolled{box-shadow:0 4px 18px rgba(15,15,15,.06)}
.d60-header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;
  max-width:var(--d60-container);
  margin:0 auto;padding:14px 24px;
}
.d60-brand-link{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--d60-text)}
.d60-brand-logo{height:46px;width:auto}
.d60-brand-name{
  font-family:var(--d60-font-heading);
  font-size:1.4rem;font-weight:700;
  letter-spacing:0;
}

.d60-nav-desktop{display:none}
.d60-nav-desktop-list{
  display:flex;gap:1.6rem;list-style:none;margin:0;padding:0;align-items:center;
}
.d60-nav-desktop-list a{
  color:var(--d60-text);text-decoration:none;
  font-weight:500;font-size:.94rem;
  padding:.4rem .2rem;
  border-bottom:2px solid transparent;
  transition:border-color .2s ease,color .2s ease;
  letter-spacing:.01em;
}
.d60-nav-desktop-list a:hover,.d60-nav-desktop-list a:focus-visible{
  color:var(--d60-accent);border-bottom-color:var(--d60-accent);
}

.d60-burger{
  display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;
  border:1px solid var(--d60-line);
  background:var(--d60-bg);
  cursor:pointer;color:var(--d60-text);
  padding:0;
}
.d60-burger svg{width:24px;height:24px}
.d60-burger:hover{background:var(--d60-surface)}

/* Mobile drawer */
.d60-nav-mobile{display:none}
@media(max-width:1023px){
  .d60-nav-mobile.is-open{
    display:flex;flex-direction:column;
    position:fixed;top:0;right:0;bottom:0;
    width:88%;max-width:380px;
    background:#fff;color:#0a0a0a;
    padding:5rem 1.6rem 2rem;
    z-index:9999;overflow-y:auto;
    box-shadow:-12px 0 36px rgba(0,0,0,.25);
    animation:d60-drawer-in .28s ease;
  }
  .d60-nav-mobile.is-open ul{list-style:none;margin:0;padding:0}
  .d60-nav-mobile.is-open li+li{border-top:1px solid #e8e8e8}
  .d60-nav-mobile.is-open a{
    display:block;padding:1rem .2rem;
    color:#0a0a0a;font-family:var(--d60-font-heading);font-size:1.2rem;font-weight:600;
    text-decoration:none;
  }
  .d60-nav-mobile.is-open a:hover{color:var(--d60-accent)}
}
@keyframes d60-drawer-in{from{transform:translateX(100%)}to{transform:translateX(0)}}

.d60-drawer-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.45);
  z-index:9998;opacity:0;pointer-events:none;transition:opacity .25s ease;
}
.d60-drawer-overlay.is-visible{opacity:1;pointer-events:auto}
.d60-drawer-close{
  position:absolute;top:1rem;right:1rem;
  width:44px;height:44px;border:none;background:transparent;
  font-size:1.6rem;cursor:pointer;color:#0a0a0a;
}

@media(min-width:1024px){
  .d60-nav-desktop{display:flex;flex:0 1 auto;justify-content:flex-end}
  .d60-burger{display:none!important}
}

/* ===== Hero (split-50-50) ===== */
.d60-hero{
  position:relative;
  background:var(--d60-bg);
  overflow:hidden;
}
.d60-hero--split-50-50{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:62vh;
  border-bottom:1px solid var(--d60-line);
}
.d60-hero-media{
  position:relative;
  overflow:hidden;
  background:var(--d60-surface);
}
.d60-hero-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
}
.d60-hero-content{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(2rem,5vw,4.5rem);
  background:var(--d60-bg);
}
.d60-hero-eyebrow{
  font-family:var(--d60-font-body);
  font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--d60-accent);font-weight:600;
  margin:0 0 1rem;
}
.d60-hero-title{
  font-family:var(--d60-font-heading);
  font-size:clamp(2rem,4vw,3.6rem);
  line-height:1.1;letter-spacing:-.025em;
  color:var(--d60-text);
  margin:0 0 1.2rem;
}
.d60-hero-title em{color:var(--d60-accent);font-style:italic}
.d60-hero-subtitle{
  font-size:clamp(1rem,1.4vw,1.15rem);
  color:var(--d60-text-soft);
  margin:0 0 2rem;
  max-width:38ch;
}
.d60-hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

@media(max-width:900px){
  .d60-hero--split-50-50{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .d60-hero-media{aspect-ratio:4/3;order:-1}
  .d60-hero-content{padding:2.2rem 1.4rem}
}

/* ===== Buttons (orange_squared_bold) ===== */
.d60-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.95rem 1.8rem;
  font-family:var(--d60-font-body);
  font-size:.88rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  border:2px solid var(--d60-primary);
  background:var(--d60-bg);color:var(--d60-primary);
  cursor:pointer;text-decoration:none;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
  border-radius:0;
}
.d60-btn:hover{background:var(--d60-primary);color:#fff}
.d60-btn--cta{background:var(--d60-accent);color:#fff;border-color:var(--d60-accent)}
.d60-btn--cta:hover{background:var(--d60-primary);border-color:var(--d60-primary);color:#fff}
.d60-btn--ghost{background:transparent;color:var(--d60-text);border-color:var(--d60-line)}
.d60-btn--ghost:hover{background:var(--d60-surface);color:var(--d60-text)}

/* ===== Editorial intro block (after hero) ===== */
.d60-editorial{
  padding:clamp(3rem,6vw,5.5rem) 0;
  background:var(--d60-bg);
  border-bottom:1px solid var(--d60-line);
}
.d60-editorial-grid{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:3rem;
  align-items:start;
}
.d60-editorial-eyebrow{
  font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--d60-accent);font-weight:600;margin-bottom:1.2rem;
}
.d60-editorial-title{
  font-family:var(--d60-font-heading);
  font-size:clamp(1.7rem,2.8vw,2.4rem);
  line-height:1.15;letter-spacing:-.02em;
  margin:0 0 .8rem;
  color:var(--d60-text);
}
.d60-editorial-lead{
  font-size:1.05rem;color:var(--d60-text-soft);
  border-left:3px solid var(--d60-accent);
  padding-left:1rem;margin:1.2rem 0 0;
}
.d60-editorial-body p{
  font-size:1.02rem;color:var(--d60-text);
  margin:0 0 1.1em;line-height:1.75;
}
.d60-editorial-body h3{
  font-family:var(--d60-font-heading);
  font-size:1.35rem;margin:1.6rem 0 .6rem;
  color:var(--d60-text);
}
.d60-editorial-body a{
  color:var(--d60-primary);
  border-bottom:1px solid var(--d60-accent);
  font-weight:500;
}
.d60-editorial-body a:hover{color:var(--d60-accent)}
.d60-editorial-pull{
  background:var(--d60-surface);
  padding:1.4rem 1.6rem;
  border-left:4px solid var(--d60-accent);
  margin:1.6rem 0;
}
.d60-editorial-pull strong{font-family:var(--d60-font-heading);font-size:1.1rem;display:block;margin-bottom:.4rem}

@media(max-width:900px){
  .d60-editorial-grid{grid-template-columns:1fr;gap:1.6rem}
}

/* ===== Sections heading common ===== */
.d60-section{padding:clamp(3.2rem,5vw,5rem) 0}
.d60-section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:2rem;margin-bottom:2.4rem;flex-wrap:wrap;
  border-bottom:2px solid var(--d60-primary);
  padding-bottom:1rem;
}
.d60-section-eyebrow{
  font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--d60-accent);font-weight:600;display:block;margin-bottom:.5rem;
}
.d60-section-title{
  font-family:var(--d60-font-heading);
  font-size:clamp(1.6rem,2.4vw,2.2rem);
  margin:0;letter-spacing:-.02em;
}
.d60-section-link{
  font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--d60-text);font-weight:600;
  border-bottom:2px solid var(--d60-accent);
  padding-bottom:.2rem;
}
.d60-section-link:hover{color:var(--d60-accent)}

/* ===== Categories grid (home) ===== */
.d60-categories{padding:clamp(3rem,5vw,5rem) 0;background:var(--d60-bg)}
.d60-categories-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.6rem;
}
.d60-cat-card{
  position:relative;
  display:block;
  overflow:hidden;
  background:var(--d60-surface);
  text-decoration:none;
  color:var(--d60-text);
  aspect-ratio:4/5;
  transition:transform .35s ease;
}
.d60-cat-card:hover{transform:translateY(-4px)}
.d60-cat-card-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform .6s ease;
}
.d60-cat-card:hover .d60-cat-card-img{transform:scale(1.05)}
.d60-cat-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,15,15,0) 35%,rgba(15,15,15,.82) 100%);
}
.d60-cat-card-text{
  position:absolute;left:1.4rem;right:1.4rem;bottom:1.4rem;
  z-index:2;color:#fff;
}
.d60-cat-card-eyebrow{
  display:inline-block;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  background:var(--d60-accent);color:#fff;
  padding:.25rem .55rem;margin-bottom:.7rem;font-weight:600;
}
.d60-cat-card-title{
  font-family:var(--d60-font-heading);
  font-size:1.7rem;font-weight:700;
  margin:0;line-height:1.1;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.4);
}
.d60-cat-card-fallback{
  position:absolute;inset:0;
  background:var(--d60-primary);
}

@media(max-width:900px){
  .d60-categories-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
}
@media(max-width:540px){
  .d60-categories-grid{grid-template-columns:1fr}
  .d60-cat-card{aspect-ratio:16/10}
}

/* ===== Latest articles grid (home) ===== */
.d60-latest{padding:clamp(3rem,5vw,5rem) 0;background:var(--d60-surface)}
.d60-latest-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}
.d60-article-card{
  background:#fff;
  display:flex;flex-direction:column;
  border:1px solid var(--d60-line);
  transition:transform .25s ease,box-shadow .25s ease;
}
.d60-article-card:hover{transform:translateY(-3px);box-shadow:var(--d60-shadow-card)}
.d60-article-card-thumb{
  display:block;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--d60-surface);
}
.d60-article-card-thumb img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s ease;
}
.d60-article-card:hover .d60-article-card-thumb img{transform:scale(1.04)}
.d60-article-card-body{padding:1.4rem;flex-grow:1;display:flex;flex-direction:column}
.d60-article-card-cat{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--d60-accent);font-weight:600;margin-bottom:.5rem;
}
.d60-article-card-title{
  font-family:var(--d60-font-heading);
  font-size:1.2rem;line-height:1.25;
  margin:0 0 .6rem;color:var(--d60-text);
}
.d60-article-card-title a{color:inherit;text-decoration:none}
.d60-article-card-title a:hover{color:var(--d60-accent)}
.d60-article-card-excerpt{
  font-size:.92rem;color:var(--d60-text-soft);
  margin:0 0 1rem;line-height:1.55;flex-grow:1;
}
.d60-article-card-meta{
  font-size:.78rem;color:var(--d60-text-soft);
  border-top:1px solid var(--d60-line);
  padding-top:.7rem;
}
.d60-no-posts{
  grid-column:1/-1;
  padding:2.5rem;text-align:center;
  background:#fff;border:1px dashed var(--d60-line);
  color:var(--d60-text-soft);
}

@media(max-width:900px){.d60-latest-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem}}
@media(max-width:600px){.d60-latest-grid{grid-template-columns:1fr;gap:1.2rem}}

/* ===== Metrics links block ===== */
.d60-metrics{
  padding:2.4rem 0;
  background:var(--d60-bg);
  border-top:1px solid var(--d60-line);
  border-bottom:1px solid var(--d60-line);
}
.d60-metrics-title{
  font-family:var(--d60-font-heading);
  font-size:1.1rem;margin:0 0 1rem;
  letter-spacing:.05em;text-transform:uppercase;
  color:var(--d60-text-soft);
}
.d60-metrics-list{
  display:flex;flex-wrap:wrap;gap:1rem 1.4rem;
  list-style:none;margin:0;padding:0;
}
.d60-metrics-list a{
  color:var(--d60-text);font-size:.92rem;
  border-bottom:1px solid var(--d60-line);padding-bottom:1px;
}
.d60-metrics-list a:hover{color:var(--d60-accent);border-bottom-color:var(--d60-accent)}

/* ===== Home tool embed ===== */
.d60-home-tool{
  padding:clamp(3rem,5vw,5rem) 0;
  background:var(--d60-bg);
  border-top:1px solid var(--d60-line);
}
.d60-home-tool-intro{max-width:680px;margin:0 auto 2.4rem;text-align:center}
.d60-home-tool-intro p{font-size:1.05rem;color:var(--d60-text-soft)}

/* ===== Category page ===== */
.d60-cat-hero{
  position:relative;
  height:320px;max-height:350px;
  overflow:hidden;
  background:var(--d60-primary);
}
.d60-cat-hero-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;z-index:1;
}
.d60-cat-hero-overlay{
  position:relative;z-index:2;
  height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(1.5rem,3vw,3rem) 24px;
  background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.75) 100%);
  max-width:var(--d60-container);margin:0 auto;
}
.d60-cat-hero-title{
  color:#fff;font-family:var(--d60-font-heading);
  font-size:clamp(2rem,4vw,3.4rem);
  margin:0;text-shadow:0 2px 14px rgba(0,0,0,.7);
  line-height:1.1;
}
.d60-cat-intro{
  padding:clamp(2.4rem,4vw,3.6rem) 0;
  max-width:780px;margin:0 auto;
}
.d60-cat-intro p{font-size:1.08rem;color:var(--d60-text);line-height:1.75}
.d60-cat-posts{padding:0 0 4rem}
.d60-cat-posts-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}
@media(max-width:900px){.d60-cat-posts-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem}}
@media(max-width:600px){.d60-cat-posts-grid{grid-template-columns:1fr}}

/* ===== Persona photo on a-propos ===== */
.d60-persona-photo{
  display:block;
  width:280px;max-width:60%;
  margin:2rem auto;
  border:2px solid var(--d60-primary);
}

/* ===== Contact form wrap ===== */
.d60-contact-form{margin:2.5rem 0;background:var(--d60-surface);padding:1.5rem}
.d60-contact-form iframe{width:100%;border:0}

/* ===== Footer ===== */
.d60-footer{
  background:var(--d60-primary);
  color:#f5f5f5;
  padding:clamp(3.4rem,5vw,5rem) 0 2rem;
  margin-top:4rem;
}
.d60-footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:3rem;
  max-width:var(--d60-container);
  margin:0 auto;padding:0 24px;
}
.d60-footer-col h3,.d60-footer-title{
  font-family:var(--d60-font-heading);
  font-size:1rem;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;
  margin:0 0 1.2rem;
  border-bottom:1px solid rgba(255,255,255,.25);
  padding-bottom:.6rem;
}
.d60-footer-logo{
  display:block;
  width:120px;height:auto;
  margin-bottom:1rem;
  filter:invert(1) brightness(2);
}
.d60-footer-brand-pitch{
  color:#dcdcdc;font-size:.95rem;line-height:1.65;
  margin:0 0 1.2rem;
}
.d60-footer-brand-cta{
  display:inline-block;
  color:var(--d60-accent);font-weight:600;
  border-bottom:1px solid var(--d60-accent);
  padding-bottom:1px;font-size:.92rem;
}
.d60-footer-brand-cta:hover{color:#fff;border-bottom-color:#fff}
.d60-footer-links{list-style:none;margin:0;padding:0}
.d60-footer-links li{margin-bottom:.7rem}
.d60-footer-links a{
  color:#dcdcdc;font-size:.94rem;
  text-decoration:none;transition:color .2s ease;
}
.d60-footer-links a:hover{color:var(--d60-accent)}
.d60-footer-social{display:flex;gap:.8rem;margin-top:1rem}
.d60-footer-social a{
  width:38px;height:38px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.35);
  color:#dcdcdc;transition:all .2s ease;
}
.d60-footer-social a:hover{background:var(--d60-accent);border-color:var(--d60-accent);color:#fff}
.d60-footer-social svg{width:18px;height:18px}

.d60-footer-bottom{
  max-width:var(--d60-container);margin:0 auto;
  padding:1.6rem 24px 0;
  margin-top:2.5rem;
  border-top:1px solid rgba(255,255,255,.18);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
  color:#bdbdbd;font-size:.85rem;
}
.d60-footer-bottom a{color:#dcdcdc}
.d60-footer-bottom a:hover{color:var(--d60-accent)}
.d60-footer-legal{display:flex;flex-wrap:wrap;gap:1.2rem}

@media(max-width:980px){
  .d60-footer-grid{grid-template-columns:1fr 1fr;gap:2.4rem}
}
@media(max-width:560px){
  .d60-footer-grid{grid-template-columns:1fr;gap:2rem}
  .d60-footer-bottom{flex-direction:column;align-items:flex-start}
}

/* ===== Animations ===== */
@keyframes d60-cta-sticky-pulse{
  0%,100%{transform:translateY(0);box-shadow:0 4px 18px rgba(255,78,32,.35)}
  50%{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,78,32,.55)}
}
.d60-btn--cta,.d60-cta-sticky{animation:d60-cta-sticky-pulse 2.4s ease-in-out infinite}
.d60-cta-sticky{
  position:fixed;bottom:24px;right:24px;
  background:var(--d60-accent);color:#fff;
  padding:14px 22px;font-weight:700;text-decoration:none;
  letter-spacing:.04em;text-transform:uppercase;
  z-index:9990;font-size:.85rem;display:none;
}
@media(max-width:980px){.d60-cta-sticky{display:inline-block}}

@keyframes d60-ctr-fade-up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.d60-ctr-reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.d60-ctr-reveal.is-visible{opacity:1;transform:translateY(0)}
@keyframes d60-ctr-timeline-mark{from{height:0}to{height:100%}}
.d60-ctr-timeline{position:relative;padding-left:32px}
.d60-ctr-timeline::before{
  content:"";position:absolute;left:8px;top:0;
  width:2px;background:var(--d60-accent);height:0;
  animation:d60-ctr-timeline-mark 1.5s ease forwards;
}

@keyframes d60-cto-slidein{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes d60-cto-slideout{to{transform:translateX(110%);opacity:0}}
.d60-cto-popup{
  position:fixed;bottom:24px;left:24px;
  max-width:340px;background:#fff;
  border-left:4px solid var(--d60-accent);
  box-shadow:0 12px 40px rgba(0,0,0,.16);
  padding:16px 20px;z-index:9990;
  font-size:.9rem;color:var(--d60-text);
  animation:d60-cto-slidein .5s ease;
}
.d60-cto-popup.is-closing{animation:d60-cto-slideout .35s ease forwards}
.d60-cto-popup-close{
  position:absolute;top:6px;right:8px;
  background:none;border:none;color:var(--d60-text-soft);
  cursor:pointer;font-size:1.1rem;line-height:1;
}
.d60-cto-popup-title{font-weight:700;font-family:var(--d60-font-heading);margin-bottom:4px}
.d60-cto-popup small{color:var(--d60-text-soft);display:block;margin-top:6px;font-size:.78rem}

/* ===== Page tool template ===== */
.d60-tool-page{padding:clamp(2.4rem,4vw,4rem) 0}
.d60-tool-page-head{max-width:780px;margin:0 auto 2.6rem;text-align:center}
.d60-tool-page-head h1{margin-bottom:1rem}
.d60-tool-page-head p{color:var(--d60-text-soft);font-size:1.05rem}
.d60-tool-wrapper{max-width:880px;margin:0 auto;padding:0 1rem}
.d60-tool-faq{max-width:780px;margin:3rem auto;padding:0 1rem}
.d60-tool-faq h2{font-family:var(--d60-font-heading);font-size:1.6rem;margin-bottom:1.4rem}
.d60-tool-faq details{
  border-top:1px solid var(--d60-line);padding:1rem 0;
}
.d60-tool-faq summary{
  font-family:var(--d60-font-heading);font-weight:600;font-size:1.05rem;
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;
}
.d60-tool-faq summary::after{content:"+";font-size:1.4rem;color:var(--d60-accent)}
.d60-tool-faq details[open] summary::after{content:"−"}
.d60-tool-faq details p{color:var(--d60-text-soft);margin:.8rem 0 0;line-height:1.65}

/* ===== Cookie strip (anti footprint placeholder) ===== */
.d60-cookie-strip{display:none}

/* ===== Accessibility ===== */
.d60-sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
:focus-visible{outline:2px solid var(--d60-accent);outline-offset:3px}

/* ===== Print ===== */
@media print{
  .d60-header,.d60-footer,.d60-cta-sticky,.d60-cto-popup,.d60-burger,.d60-nav-mobile{display:none!important}
  body{background:#fff;color:#000}
}

/* Validator: cap hauteur hero cat v2 */
body section[class*="cat-hero"], body div[class*="cat-hero"], body section[class*="category-hero"], body div[class*="category-hero"] { position: relative !important; height: 320px !important; max-height: 320px !important; min-height: 200px !important; padding: 0 !important; overflow: hidden !important; display: flex !important; align-items: center !important; border: none !important; box-shadow: none !important; }
body [class*="cat-hero"] > img, body [class*="cat-hero-bg"], body [class*="cat-hero"] img, body [class*="category-hero"] img { position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; max-height: 320px !important; object-fit: cover !important; z-index: 0 !important; border: none !important; }
body [class*="cat-hero"] > [class*="container"], body [class*="cat-hero"] > [class*="wrap"], body [class*="cat-hero"] > [class*="inner"], body [class*="cat-hero"] > div { position: relative !important; z-index: 2 !important; max-width: 900px !important; margin: 0 auto !important; padding: 1.5rem 2rem !important; background: transparent !important; }
body [class*="cat-hero"] h1, body [class*="category-hero"] h1 { color: #ffffff !important; font-size: clamp(2rem, 5vw, 3.5rem) !important; margin: 0 !important; font-weight: 800 !important; text-shadow: 0 3px 12px rgba(0,0,0,.85), 0 0 30px rgba(0,0,0,.5) !important; }
body [class*="cat-hero"][style*="background-image"] { background-size: cover !important; background-position: center !important; }
body [class*="cat-hero"] [class*="breadcrumb"], body [class*="cat-hero"] nav[aria-label*="riane"], body [class*="cat-hero"] nav[aria-label*="readcrumb"] { display: none !important; }

/* Validator: nav-mobile drawer hidden by default v2 */
/* Drawer/burger menu mobile : hidden par defaut, visible mobile+is-open */
[class*="-nav-mobile"]:not(.is-open), [id*="-nav-mobile"]:not(.is-open), [class*="-drawer"]:not(.is-open), [class*="-burger-menu"]:not(.is-open), [class*="-mobile-menu"]:not(.is-open) { display: none !important; }
@media (max-width: 980px) {
  [class*="-nav-mobile"].is-open, [id*="-nav-mobile"].is-open, [class*="-drawer"].is-open, [class*="-burger-menu"].is-open, [class*="-mobile-menu"].is-open { display: flex !important; flex-direction: column !important; position: fixed !important; top: 0 !important; right: 0 !important; bottom: 0 !important; width: 86% !important; max-width: 380px !important; background: #fff !important; padding: 4.5rem 1.5rem 2rem !important; z-index: 9999 !important; overflow-y: auto !important; box-shadow: -10px 0 30px rgba(0,0,0,0.3) !important; }
}

/* Validator: drawer-mobile height fix v1 */
/* Force height:100vh sur le drawer ouvert : top:0;bottom:0 sans !important peut etre overrides par Claude → on impose 100vh. */
/* [2026-06-06] Broadening : ajout patterns supplementaires (X-nav sans 'mobile', X-side, X-menu-drawer, etc.) sinon le validator manque les sites comme artois-moto.com qui utilise fe8-nav (sans 'mobile' dans le nom). */
@media (max-width: 1023px) {
  [class*="-nav-mobile"].is-open, [id*="-nav-mobile"].is-open, [class*="-drawer"].is-open, [class*="-burger-menu"].is-open, [class*="-mobile-menu"].is-open, [class*="-side-nav"].is-open, [class*="-side-menu"].is-open, [class*="-offcanvas"].is-open, nav[aria-label*="mobile" i].is-open, nav[aria-label*="Menu mobile" i].is-open, nav[id*="nav"].is-open[class*="-nav"]:not([class*="desktop"]) { height: 100vh !important; min-height: 100vh !important; max-height: 100vh !important; }
}

/* Validator: footer logo no-filter v1 */
footer img, [class*="-footer"] img, [role="contentinfo"] img, footer [class*="logo"], [class*="-footer"] [class*="logo"] { filter: none !important; mix-blend-mode: normal !important; opacity: 1 !important; }
footer[class*="dark"] img, footer[class*="black"] img, [class*="-footer"][class*="dark"] img, [class*="-footer"][class*="black"] img { filter: brightness(0) invert(1) !important; }

/* Validator: header-hero gap fix v1 */
/* Bug recurrent : <main class="X-main"> a padding-top:30px qui creait un
 * gap entre header sticky et hero/cat-hero. Force padding-top:0 sur le
 * wrapper <main> + margin-top:0 sur le 1er hero enfant. */
body > main, body > [role="main"], main[class*="-main"], [id="main"] { padding-top: 0 !important; }
main > [class*="-hero"]:first-child, main > [class*="-cat-hero"]:first-child, main > [class*="-category-hero"]:first-child { margin-top: 0 !important; }
/* Fallback : si sibling direct du header */
header + section, header + [class*="-hero"], header + [class*="-cat-hero"], header + [class*="-category-hero"], [class*="-header"] + section, [class*="-header"] + [class*="-hero"], [class*="-header"] + [class*="-cat-hero"], [class*="-header"] + [class*="-category-hero"] { margin-top: 0 !important; padding-top: 0 !important; }
section[class*="-hero"]:first-of-type, section[class*="-cat-hero"]:first-of-type, section[class*="-category-hero"]:first-of-type { margin-top: 0 !important; }

/* Validator: contraste lisible header+menu-mobile+footer v2 */
[class*="-nav-mobile"], [id*="-nav-mobile"], [class*="-drawer"], [class*="-burger-menu"], [class*="-mobile-menu"], [class*="-side-nav"] { background: #ffffff !important; }
[class*="-nav-mobile"] *, [id*="-nav-mobile"] *, [class*="-drawer"] *, [class*="-burger-menu"] *, [class*="-mobile-menu"] *, [class*="-side-nav"] * { color: #0a0a0a !important; }
[class*="-nav-mobile"] a, [id*="-nav-mobile"] a, [class*="-drawer"] a, [class*="-burger-menu"] a, [class*="-mobile-menu"] a { color: #0a0a0a !important; font-weight: 600 !important; }
[class*="-nav-mobile"] a:hover, [class*="-drawer"] a:hover, [class*="-burger-menu"] a:hover, [class*="-mobile-menu"] a:hover { color: #000 !important; opacity: 0.7 !important; }
footer *, [class*="-footer"] *, [role="contentinfo"] * { color: #1a1a1a !important; }
footer a, [class*="-footer"] a, [role="contentinfo"] a { color: #1a1a1a !important; text-decoration: underline !important; text-decoration-color: currentColor !important; text-underline-offset: 3px !important; font-weight: 600 !important; }
footer a:hover, [class*="-footer"] a:hover, [role="contentinfo"] a:hover { color: #000 !important; opacity: 1 !important; }
footer h1, footer h2, footer h3, footer h4, footer h5, [class*="-footer"] h1, [class*="-footer"] h2, [class*="-footer"] h3, [class*="-footer"] h4, [class*="-footer"] h5 { color: #0a0a0a !important; font-weight: 700 !important; }
footer p, footer span, footer li, [class*="-footer"] p, [class*="-footer"] span, [class*="-footer"] li { color: #2a2a2a !important; }
footer[class*="dark"] *, footer[class*="black"] *, [class*="-footer"][class*="dark"] *, [class*="-footer"][class*="black"] *, footer[style*="background:#0"] *, footer[style*="background: #0"] *, footer[style*="background:#1"] *, footer[style*="background: #1"] *, footer[style*="background:#2"] *, footer[style*="background: #2"] * { color: #f5f5f5 !important; }
footer[class*="dark"] a, [class*="-footer"][class*="dark"] a, footer[style*="background:#0"] a, footer[style*="background:#1"] a { color: #ffffff !important; }
header a, [class*="-header"] a, [role="banner"] a { text-shadow: none !important; }
header a:hover, [class*="-header"] a:hover { opacity: 0.7 !important; }
[class*="-nav-mobile"] [class*="-btn"], [class*="-footer"] [class*="-btn"] { border: 1.5px solid currentColor !important; }

/* Validator: burger button always visible+clickable v2 */
/* === Burger button : VISIBLE + CLIQUABLE garanti === */
[class*="-burger"], [class*="burger-menu"], [class*="menu-toggle"], button[aria-controls*="nav"], button[aria-label*="menu" i] { color: #1a1a1a !important; pointer-events: auto !important; cursor: pointer !important; z-index: 100 !important; position: relative !important; user-select: none !important; -webkit-tap-highlight-color: transparent !important; background: rgba(255,255,255,0.92) !important; border-radius: 8px !important; border: 1.5px solid rgba(0,0,0,0.15) !important; box-shadow: 0 1px 3px rgba(0,0,0,0.12) !important; padding: 8px !important; }
[class*="-burger"] svg, [class*="burger-menu"] svg, [class*="menu-toggle"] svg, button[aria-controls*="nav"] svg { stroke: #1a1a1a !important; fill: none !important; pointer-events: none !important; stroke-width: 2.5 !important; width: 22px !important; height: 22px !important; }
[class*="-burger"] svg path, [class*="-burger"] svg line, [class*="-burger"] svg rect, [class*="-burger"] svg polyline { stroke: #1a1a1a !important; stroke-width: 2.5 !important; fill: none !important; }
[class*="-burger"]:hover, [class*="-burger"]:focus { background: rgba(255,255,255,1) !important; border-color: rgba(0,0,0,0.3) !important; outline: 2px solid rgba(0,0,0,0.15) !important; outline-offset: 1px !important; }
/* Si le header est sombre : inverse en clair (detection elargie) */
[class*="-header"][style*="background:#0"] [class*="-burger"], [class*="-header"][style*="background:#1"] [class*="-burger"], [class*="-header"][style*="background:#2"] [class*="-burger"], [class*="-header"][style*="background-color:#0"] [class*="-burger"], [class*="-header"][style*="background-color:#1"] [class*="-burger"], [class*="-header"][style*="background-color:#2"] [class*="-burger"], [class*="-header"][class*="dark"] [class*="-burger"], [class*="-header"][class*="black"] [class*="-burger"], [class*="-header"][class*="--dark"] [class*="-burger"], [class*="-header"][class*="-night"] [class*="-burger"] { color: #f5f5f5 !important; background: rgba(0,0,0,0.55) !important; border-color: rgba(255,255,255,0.4) !important; box-shadow: 0 1px 3px rgba(0,0,0,0.4) !important; }
[class*="-header"][style*="background:#0"] [class*="-burger"] svg, [class*="-header"][style*="background:#1"] [class*="-burger"] svg, [class*="-header"][class*="dark"] [class*="-burger"] svg, [class*="-header"][class*="black"] [class*="-burger"] svg { stroke: #f5f5f5 !important; }
@media (max-width: 1023px) {
  [class*="-burger"], button[aria-controls*="nav"] { display: inline-flex !important; align-items: center !important; justify-content: center !important; min-width: 44px !important; min-height: 44px !important; }
}
@media (min-width: 1024px) {
  [class*="-burger"], button[aria-controls*="nav"] { display: none !important; }
}

/* Validator: nav-mobile-list visible inside open drawer v1 */
/* Burger drawer ouvert : la UL des liens DOIT etre visible. */
[class*="-nav-mobile"].is-open ul, [id*="-nav-mobile"].is-open ul, [class*="-nav-mobile"].is-open [class*="-nav-mobile-list"], [class*="-drawer"].is-open ul, [class*="-burger-menu"].is-open ul { display: block !important; visibility: visible !important; height: auto !important; max-height: none !important; overflow: visible !important; padding: 0 !important; margin: 0 !important; list-style: none !important; }
[class*="-nav-mobile"].is-open ul li, [id*="-nav-mobile"].is-open ul li, [class*="-drawer"].is-open ul li, [class*="-burger-menu"].is-open ul li { display: list-item !important; height: auto !important; padding: 0 !important; margin: 0 !important; list-style: none !important; }
[class*="-nav-mobile"].is-open ul li a, [id*="-nav-mobile"].is-open ul li a, [class*="-drawer"].is-open ul li a, [class*="-burger-menu"].is-open ul li a { display: block !important; padding: 0.9rem 0 !important; text-decoration: none !important; border-bottom: 1px solid rgba(0,0,0,0.08) !important; font-size: 1rem !important; }
