/* ============================================================
   DESIGN MAQUETTE — Centre Agnès Muggéo
   Inspiré du style : Playfair Display + DM Sans
   Palette : Navy #1a2744 | Or #c9a227 | Bleu #2563eb | Violet #7c3aed | Blanc #fff
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700;800&family=DM+Sans:wght@300;400;500;600;700&display=swap');

/* ---- VARIABLES ---- */
:root {
  --navy:      #1a2744;
  --navy-dark: #0f1a30;
  --or:        #c9a227;
  --or-clair:  #fef9ec;
  --bleu:      #2563eb;
  --bleu-clair:#eff6ff;
  --violet:    #7c3aed;
  --blanc:     #ffffff;
  --fond:      #f8f9fb;
  --texte:     #1e293b;
  --texte-doux:#64748b;
  --radius:    12px;
  --shadow:    0 4px 24px rgba(26,39,68,0.10);
  --shadow-lg: 0 10px 48px rgba(26,39,68,0.18);
}

/* ---- NO TEXT-TRANSFORM ---- */
*, h1, h2, h3, h4, h5, h6,
.wp-block-heading, .wp-block-button__link,
.site-title, .ast-nav-menu a, button, label {
  text-transform: none !important;
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}

/* ---- BASE TYPOGRAPHIE ---- */
body {
  font-family: 'DM Sans', 'Inter', sans-serif !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  color: var(--texte) !important;
  background: var(--blanc) !important;
}

h1, h2, h3, h4 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: var(--navy) !important;
}

h5, h6, p, a, span, li, button, label {
  font-family: 'DM Sans', sans-serif !important;
}

p { color: var(--texte) !important; line-height: 1.75 !important; }
a { color: var(--bleu) !important; text-decoration: none !important; transition: color 0.2s; }
a:hover { color: var(--or) !important; }

/* ---- EN-TÊTE NAVIGATION ---- */
#masthead, .site-header, header.site-header {
  background: var(--navy) !important;
  border-bottom: 3px solid var(--or) !important;
  box-shadow: 0 2px 20px rgba(10,20,50,0.25) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
  overflow: visible !important;
}

/* Logo / titre du site en blanc */
.site-title, .site-title a, .ast-site-name, .ast-logo-name {
  color: var(--blanc) !important;
  font-family: 'Playfair Display', serif !important;
  font-size: 1.1rem !important;
}

/* Liens du menu en blanc */
.main-navigation a,
#ast-desktop-header .ast-primary-header-bar a,
.ast-header-custom-widget a {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  color: rgba(255,255,255,0.88) !important;
  padding: 6px 12px !important;
  border-radius: 6px !important;
  transition: all 0.2s !important;
}
.main-navigation a:hover,
#ast-desktop-header a:hover {
  color: var(--or) !important;
  background: rgba(201,162,39,0.12) !important;
}

/* Icônes réseaux sociaux header */
.ast-header-custom-widget svg,
.ast-header-custom-widget img {
  filter: brightness(0) invert(1) !important;
  opacity: 0.85 !important;
}

/* ---- HERO SECTION ---- */
.wp-block-cover {
  min-height: 88vh !important;
  position: relative !important;
}

.wp-block-cover__background {
  background: linear-gradient(135deg,
    rgba(26,39,68,0.85) 0%,
    rgba(37,99,235,0.50) 100%) !important;
}

.wp-block-cover__inner-container {
  animation: heroFadeIn 0.9s ease-out both !important;
  padding: 48px 24px !important;
  max-width: 820px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

@keyframes heroFadeIn {
  from { opacity: 0; transform: translateY(32px); }
  to   { opacity: 1; transform: translateY(0); }
}

.wp-block-cover h1.wp-block-heading,
.wp-block-cover h2.wp-block-heading,
.wp-block-cover__inner-container h1,
.wp-block-cover__inner-container h2 {
  font-family: 'Playfair Display', serif !important;
  color: #ffffff !important;
  font-size: clamp(2rem, 4.5vw, 3.4rem) !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  text-shadow: 0 2px 16px rgba(0,0,0,0.4) !important;
  margin-bottom: 20px !important;
}

.wp-block-cover p,
.wp-block-cover__inner-container p {
  font-family: 'DM Sans', sans-serif !important;
  color: rgba(255,255,255,0.92) !important;
  font-size: clamp(1rem, 2vw, 1.2rem) !important;
  max-width: 620px !important;
  margin: 0 auto 32px !important;
  font-weight: 300 !important;
}

/* ---- BOUTONS ---- */
.wp-block-button__link,
.wp-block-button__link.wp-element-button {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  padding: 13px 30px !important;
  border-radius: var(--radius) !important;
  border: none !important;
  cursor: pointer !important;
  transition: all 0.28s ease !important;
  letter-spacing: 0.3px !important;
  text-transform: none !important;
}

/* Bouton principal — bleu */
.wp-block-button__link {
  background: var(--bleu) !important;
  color: #fff !important;
  box-shadow: 0 4px 18px rgba(37,99,235,0.35) !important;
}
.wp-block-button__link:hover {
  background: var(--or) !important;
  color: var(--navy) !important;
  box-shadow: 0 6px 24px rgba(201,162,39,0.45) !important;
  transform: translateY(-2px) !important;
}

/* Bouton outline */
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,0.7) !important;
  box-shadow: none !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--or) !important;
  color: var(--navy) !important;
  border-color: var(--or) !important;
}

.wp-block-buttons {
  gap: 14px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}

/* ---- TITRES DE SECTION h2 ---- */
h2.wp-block-heading {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(1.7rem, 3.5vw, 2.4rem) !important;
  color: var(--navy) !important;
  font-weight: 700 !important;
  margin-bottom: 12px !important;
  position: relative !important;
  padding-bottom: 16px !important;
}
h2.wp-block-heading::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important; left: 0 !important;
  width: 52px !important; height: 4px !important;
  background: var(--or) !important;
  border-radius: 2px !important;
}
h2.has-text-align-center.wp-block-heading::after {
  left: 50% !important;
  transform: translateX(-50%) !important;
}

h3.wp-block-heading {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(1.1rem, 2.5vw, 1.4rem) !important;
  color: var(--navy) !important;
  margin-bottom: 8px !important;
}

/* ---- TITRES PROFIL (mark avec fond) ---- */
h2.wp-block-heading mark,
h3.wp-block-heading mark {
  background: var(--navy) !important;
  color: #fff !important;
  padding: 6px 18px !important;
  border-radius: 8px 8px 0 0 !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
  display: inline-block !important;
  text-transform: none !important;
}

/* ---- CARTES CHIFFRES CLÉS (STAT CARDS) ---- */
/* Cibles les paragraphes avec chiffres forts dans la section indicateurs */
.entry-content p:has(strong:first-child),
.wp-block-group p:has(strong:first-child) {
  background: var(--blanc) !important;
  border: 1px solid #e2e8f0 !important;
  border-top: 4px solid var(--or) !important;
  border-radius: var(--radius) !important;
  padding: 20px 20px !important;
  box-shadow: var(--shadow) !important;
  transition: all 0.25s ease !important;
  margin-bottom: 16px !important;
}
.entry-content p:has(strong:first-child):hover,
.wp-block-group p:has(strong:first-child):hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-top-color: var(--bleu) !important;
}

/* Chiffres en gras → couleur navy + grande taille */
.entry-content p strong:first-child,
.wp-block-group p strong:first-child {
  color: var(--navy) !important;
  font-size: 1.3em !important;
  font-family: 'Playfair Display', serif !important;
}

/* ---- BANDEAU SIGNATURE ---- */
.entry-content > .wp-block-group > p.has-text-align-center,
p.has-text-align-center[style*="italic"] {
  font-style: italic !important;
  font-family: 'DM Sans', sans-serif !important;
  color: var(--texte-doux) !important;
  background: var(--bleu-clair) !important;
  border-left: 4px solid var(--bleu) !important;
  border-radius: 0 var(--radius) var(--radius) 0 !important;
  padding: 14px 20px !important;
  font-size: 1.02rem !important;
}

/* ---- SECTION TITRE FOND NAVY (Pourquoi nous choisir, Prêt à faire le pas...) ---- */
h2.wp-block-heading[style*="background"],
h3.wp-block-heading[style*="background"] {
  background: var(--navy) !important;
  color: #fff !important;
  padding: 12px 22px !important;
  border-radius: 10px !important;
  display: inline-block !important;
}

/* ---- BLOCS CARTES (profil jeune/adulte) ---- */
.wp-block-group:has(> h2.wp-block-heading:first-child),
.wp-block-group:has(> h3.wp-block-heading:first-child) {
  background: var(--blanc) !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  overflow: hidden !important;
  transition: box-shadow 0.25s, transform 0.25s !important;
}
.wp-block-group:has(> h2.wp-block-heading:first-child):hover {
  box-shadow: var(--shadow-lg) !important;
  transform: translateY(-3px) !important;
}

/* ---- BANDEAU NOUVEAUTÉ ---- */
.wp-block-group[style*="background-color:#f0a500"],
.wp-block-group[style*="background-color: #f0a500"],
[style*="background-color:#fcb900"],
[style*="background-color: #fcb900"] {
  background: linear-gradient(135deg, var(--or), #e5b40a) !important;
  color: var(--navy) !important;
  border-radius: 10px !important;
  padding: 14px 24px !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 16px rgba(201,162,39,0.35) !important;
  font-family: 'DM Sans', sans-serif !important;
}
.wp-block-group[style*="background-color:#f0a500"] p,
.wp-block-group[style*="background-color:#f0a500"] strong {
  color: var(--navy) !important;
}

/* ---- SÉPARATEURS ---- */
hr.wp-block-separator, .wp-block-separator {
  border: none !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--or), var(--bleu)) !important;
  border-radius: 2px !important;
  max-width: 64px !important;
  margin: 32px auto !important;
  opacity: 1 !important;
}

/* ---- IMAGES ---- */
.wp-block-image img, figure.wp-block-image img {
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  transition: transform 0.35s, box-shadow 0.35s !important;
}
.wp-block-image img:hover {
  transform: scale(1.025) !important;
  box-shadow: var(--shadow-lg) !important;
}
img.wp-image-295, img.wp-image-297,
img.wp-image-298, img.wp-image-1351 {
  width: 280px !important; height: 280px !important;
  object-fit: cover !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
}

/* ---- MEDIA + TEXTE ---- */
.wp-block-media-text {
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: var(--shadow) !important;
  border: 1px solid #e2e8f0 !important;
}

/* ---- TÉMOIGNAGES ---- */
.testimonials-section {
  background: var(--fond) !important;
  border-radius: 16px !important;
  padding: 40px 32px !important;
}
.testimonial {
  background: var(--blanc) !important;
  border-left: 4px solid var(--or) !important;
  border-radius: var(--radius) !important;
  padding: 24px !important;
  box-shadow: var(--shadow) !important;
  font-style: italic !important;
  font-family: 'DM Sans', sans-serif !important;
  transition: transform 0.25s !important;
}
.testimonial:hover { transform: translateX(4px) !important; }
.testimonial-author {
  font-style: normal !important;
  font-weight: 600 !important;
  color: var(--navy) !important;
  margin-top: 10px !important;
}

/* ---- FAQ ---- */
h2.wp-block-heading:not([style]) {
  font-size: clamp(1.2rem, 2.8vw, 1.8rem) !important;
}

/* ---- CARTES COORDONNÉES ---- */
.wp-block-group.is-style-default,
.entry-content .wp-block-columns .wp-block-column > .wp-block-group {
  background: var(--blanc) !important;
  border: 1px solid #e2e8f0 !important;
  border-top: 3px solid var(--bleu) !important;
  border-radius: var(--radius) !important;
  padding: 24px !important;
  box-shadow: var(--shadow) !important;
}

/* ---- PIED DE PAGE ---- */
.site-footer, #colophon, footer.site-footer {
  background: var(--navy-dark) !important;
  color: #94a3b8 !important;
  padding: 48px 24px 28px !important;
  border-top: 3px solid var(--or) !important;
}
.site-footer a, #colophon a {
  color: #93c5fd !important;
  transition: color 0.2s !important;
}
.site-footer a:hover { color: var(--or) !important; }
.site-footer p, #colophon p { color: #94a3b8 !important; }

/* ---- LIENS TEL / MAIL ---- */
a[href^="tel:"], a[href^="mailto:"] {
  color: var(--navy) !important;
  font-weight: 600 !important;
  border-bottom: 1px solid var(--or) !important;
  padding-bottom: 1px !important;
  font-family: 'DM Sans', sans-serif !important;
}
a[href^="tel:"]:hover, a[href^="mailto:"]:hover {
  color: var(--bleu) !important;
}

/* ---- MENU MOBILE ---- */
@media (max-width: 921px) {
  .site-header, #masthead, .ast-main-header-wrap {
    position: sticky !important; top: 0 !important;
    z-index: 99999 !important; overflow: visible !important;
    background: var(--navy) !important;
  }
  .main-header-bar-navigation {
    position: absolute !important; top: 100% !important;
    left: 0 !important; right: 0 !important; width: 100% !important;
    z-index: 99998 !important;
    background: var(--navy) !important;
    box-shadow: 0 8px 32px rgba(10,20,50,0.3) !important;
    overflow: visible !important;
  }
  #ast-mobile-site-navigation ul li a,
  #ast-hf-mobile-menu li a {
    display: block !important;
    padding: 13px 22px !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    color: rgba(255,255,255,0.88) !important;
    font-family: 'DM Sans', sans-serif !important;
    font-weight: 500 !important;
    font-size: 15px !important;
  }
  #ast-mobile-site-navigation ul li a:hover,
  #ast-hf-mobile-menu li a:hover {
    background: rgba(201,162,39,0.15) !important;
    color: var(--or) !important;
    padding-left: 30px !important;
  }
  button.menu-toggle, .ast-mobile-menu-trigger-minimal {
    color: var(--blanc) !important;
    background: transparent !important;
    border: none !important;
  }
  #ast-mobile-site-navigation .sub-menu {
    background: rgba(255,255,255,0.05) !important;
    border-left: 3px solid var(--or) !important;
  }
}

/* ---- RESPONSIVE TABLETTE ---- */
@media (max-width: 1024px) {
  .wp-block-columns { flex-wrap: wrap !important; gap: 20px !important; }
  .wp-block-column { flex-basis: calc(50% - 10px) !important; min-width: 240px !important; }
}

/* ---- RESPONSIVE MOBILE ---- */
@media (max-width: 768px) {
  .wp-block-cover { min-height: 72vh !important; }
  .wp-block-cover__inner-container h1,
  .wp-block-cover__inner-container h2 {
    font-size: clamp(1.5rem, 7vw, 2.3rem) !important;
  }
  .wp-block-buttons {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
    max-width: 320px !important;
    margin: 0 auto !important;
  }
  .wp-block-button { width: 100% !important; }
  .wp-block-button__link {
    width: 100% !important;
    padding: 14px 20px !important;
    text-align: center !important;
  }
  .wp-block-columns { flex-direction: column !important; }
  .wp-block-column { width: 100% !important; flex-basis: 100% !important; margin: 0 !important; }
  h2.wp-block-heading {
    font-size: clamp(1.2rem, 5.5vw, 1.7rem) !important;
    word-break: break-word !important;
    hyphens: auto !important;
  }
  h3.wp-block-heading {
    font-size: clamp(1rem, 4.5vw, 1.3rem) !important;
    word-break: break-word !important;
  }
  .entry-content > .wp-block-group,
  .wp-block-group.is-layout-constrained {
    padding: 32px 14px !important;
  }
  .testimonials-section { padding: 24px 14px !important; }
  .site-footer { padding: 32px 14px 20px !important; }
  img.wp-image-295, img.wp-image-297,
  img.wp-image-298, img.wp-image-1351 {
    width: 100% !important; height: 220px !important;
    max-width: 340px !important; margin: 0 auto !important;
  }
  .wp-block-media-text {
    grid-template-columns: 1fr !important;
    display: flex !important; flex-direction: column !important;
  }
}

@media (max-width: 480px) {
  .wp-block-cover { min-height: 60vh !important; }
  .wp-block-cover__inner-container { padding: 24px 12px !important; }
  body { font-size: 15px !important; }
  h2.wp-block-heading { font-size: clamp(1.1rem, 5vw, 1.5rem) !important; }
  h3.wp-block-heading { font-size: clamp(1rem, 4vw, 1.2rem) !important; }
}

/* ---- LIENS MAPS ---- */
a[href*="maps"], a[href*="google.com/maps"] {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: var(--bleu-clair) !important;
  color: var(--navy) !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  border: 1px solid var(--bleu) !important;
}

/* ---- SMOOTH SCROLL ---- */
html { scroll-behavior: smooth !important; }

/* ---- FOCUS ACCESSIBILITÉ ---- */
.wp-block-button__link:focus {
  outline: 3px solid var(--or) !important;
  outline-offset: 3px !important;
}

/* ===== PAGE QUI SUIS-JE ? - TEXTES SUR FONDS SOMBRES ===== */
/* Force white headings on dark backgrounds in page 111 */
.elementor-111 .elementor-element-s1-hero h1,
.elementor-111 .elementor-element-s1-hero h2,
.elementor-111 .elementor-element-s1-hero h3,
.elementor-111 .elementor-element-hero-title .elementor-heading-title,
.elementor-111 .elementor-element-s4-gallery h1,
.elementor-111 .elementor-element-s4-gallery h2,
.elementor-111 .elementor-element-s4-gallery h3,
.elementor-111 .elementor-element-gallery-h2 .elementor-heading-title,
.elementor-111 .elementor-element-s5-cta h1,
.elementor-111 .elementor-element-s5-cta h2,
.elementor-111 .elementor-element-s5-cta h3,
.elementor-111 .elementor-element-cta-h2 .elementor-heading-title {
  color: #ffffff !important;
}

/* Gallery section captions - force white */
.elementor-111 .elementor-element-cap1 p,
.elementor-111 .elementor-element-cap2 p,
.elementor-111 .elementor-element-cap3 p,
.elementor-111 .elementor-element-s4-gallery .elementor-widget-text-editor p {
  color: #ffffff !important;
}

/* Gallery eyebrow and CTA paragraph text */
.elementor-111 .elementor-element-gallery-eyebrow p,
.elementor-111 .elementor-element-s5-cta .elementor-widget-text-editor p,
.elementor-111 .elementor-element-cta-p p {
  color: rgba(255,255,255,0.90) !important;
}

/* Fix bouton telephone - couleur visible sur fond fonce */
.btn-outline {
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
}


/* ====================================================
   RESPONSIVE - Page Bilan de compétences
   Correction des grilles et sections pleine largeur
   ==================================================== */

/* Sections pleine largeur avec width:100vw - correction overflow */
html, body {
  overflow-x: hidden !important;
}

.entry-content {
  overflow-x: hidden !important;
}

/* Conteneurs internes des sections */
.page-id-441 .entry-content div[style*="max-width: 900px"],
.page-id-441 .entry-content div[style*="max-width: 800px"],
.page-id-441 .entry-content div[style*="max-width: 700px"] {
  box-sizing: border-box !important;
}

/* Tablette (max 992px) : grilles 3 col -> 2 col */
@media (max-width: 992px) {
  .page-id-441 .entry-content div[style*="grid-template-columns: repeat(3, 1fr)"],
  [data-grid-cols="3"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .page-id-441 .entry-content div[style*="max-width: 900px"],
  .page-id-441 .entry-content div[style*="max-width: 800px"],
  .page-id-441 .entry-content div[style*="max-width: 700px"] {
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
}

/* Mobile (max 600px) : toutes les grilles en 1 colonne */
@media (max-width: 600px) {
  .page-id-441 .entry-content div[style*="grid-template-columns: repeat(3, 1fr)"],
  [data-grid-cols="3"] {
    grid-template-columns: 1fr !important;
    gap: 15px !important;
  }

  .page-id-441 .entry-content div[style*="grid-template-columns: repeat(2, 1fr)"],
  [data-grid-cols="2"] {
    grid-template-columns: 1fr !important;
    gap: 15px !important;
  }

  /* Sections hero et contenu avec padding vertical */
  .page-id-441 .entry-content div[style*="padding: 80px 20px"] {
    padding: 40px 15px !important;
  }

  .page-id-441 .entry-content div[style*="padding: 60px 20px"] {
    padding: 35px 15px !important;
  }

  /* Boutons CTA */
  .page-id-441 .entry-content a[style*="display: inline-block"][style*="#f59e0b"],
  [data-cta-button="true"] {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
    white-space: normal !important;
    word-break: break-word !important;
    box-sizing: border-box !important;
    font-size: 1rem !important;
  }

  /* Sections avec largeur 100vw - éviter le scroll horizontal */
  .page-id-441 .entry-content div[style*="width: 100vw"] {
    width: 100% !important;
    margin-left: 0 !important;
    left: 0 !important;
    overflow-x: hidden !important;
  }
}

/* Petit mobile (max 480px) */
@media (max-width: 480px) {
  .page-id-441 .entry-content div[style*="padding: 80px"] {
    padding: 30px 12px !important;
  }

  .page-id-441 .entry-content div[style*="padding: 60px"] {
    padding: 25px 12px !important;
  }

  .page-id-441 .entry-content div[style*="padding: 40px"] {
    padding: 20px 12px !important;
  }

  .page-id-441 .entry-content div[style*="padding: 30px"] {
    padding: 18px 12px !important;
  }
}
