/* Force TOUT au maximum */
body .elementor-section {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body .elementor-container {
  max-width: none !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body .elementor-widget-html {
  width: 100% !important;
  max-width: 100% !important;
}

body .elementor-widget-html .elementor-widget-container {
  width: 100% !important;
  max-width: 100% !important;
}

/* Contenu */
.etude-biblique {
  width: 100% !important;
  max-width: 100% !important;
  padding: 2rem 1.75rem;
  background: #fdfbf7;
  border-radius: 12px;
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.04);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Reste du CSS (idem que avant) */
.etude-hero { display: flex; flex-wrap: wrap; gap: 1.5rem; align-items: center; margin-bottom: 2.5rem; padding: 1.5rem; background: linear-gradient(135deg, #f7efe3, #eef4fb); border-radius: 16px; }
.etude-hero-text h1 { margin: 0 0 0.5rem; font-size: 2rem; color: #243b53; }
.etude-sous-titre { margin: 0; color: #52606d; font-style: italic; }
.etude-hero-image { flex: 1 1 260px; min-height: 160px; }
.etude-section { margin: 2.5rem 0; }
.etude-intro { margin-bottom: 2.5rem; }
.etude-section h2 { font-size: 1.6rem; color: #243b53; margin-bottom: 1rem; }
.etude-section h3 { font-size: 1.3rem; color: #334e68; margin-bottom: 0.75rem; }
.etude-section h4 { font-size: 1.1rem; color: #52606d; }
.etude-biblique p { line-height: 1.7; color: #243b53; margin-bottom: 0.9rem; }
.etude-biblique ul, .etude-biblique ol { padding-left: 1.2rem; color: #334e68; margin-bottom: 0.9rem; }
.etude-biblique li { margin-bottom: 0.25rem; }
.etude-grid-2 { display: grid; grid-template-columns: 2fr 1.3fr; gap: 1.5rem; }
@media (max-width: 900px) { .etude-grid-2 { grid-template-columns: 1fr; } }
.etude-image-slot { min-height: 190px; background: #f7fafc; border-radius: 12px; border: 1px dashed #d0dae7; }
.encadre-soft { padding: 1rem 1.25rem; border-radius: 10px; background: #f7f4ff; border: 1px solid #ddd6fe; }
.encadre-verse { margin-top: 1.2rem; padding: 1rem 1.25rem; border-left: 4px solid #9f7aea; border-radius: 10px; background: #f8f5ff; }
.highlight-box { padding: 1.25rem 1.5rem; border-radius: 14px; background: #fff7e6; border: 1px solid #ffe0b2; }
.etude-biblique blockquote { margin: 0.75rem 0; padding-left: 1rem; border-left: 3px solid #9fb3c8; color: #475569; font-style: italic; }
.table-wrapper { margin: 1.2rem 0; overflow-x: auto; }
.table-soft { width: 100%; border-collapse: collapse; background: #ffffff; border-radius: 10px; overflow: hidden; box-shadow: 0 2px 4px rgba(15, 23, 42, 0.06); font-size: 0.95rem; }
.table-soft thead { background: linear-gradient(90deg, #e3f2fd, #ede7f6); }
.table-soft th, .table-soft td { padding: 0.65rem 0.9rem; text-align: left; }
.table-soft th { font-weight: 600; color: #1f2933; }
.table-soft td { color: #334e68; }
.table-soft tbody tr:nth-child(odd) { background: #f8fafc; }
.table-soft tbody tr:nth-child(even) { background: #ffffff; }
.table-soft tbody tr:hover { background: #fff3e0; }
.etude-biblique hr { border: none; border-top: 1px solid #e1e7f0; margin: 2.5rem 0; }
.etude-biblique a { color: #2563eb; text-decoration: none; }
.etude-biblique a:hover { text-decoration: underline; }


/* Neutralisation définitive des menus Astra */
.ast-primary-header,
.ast-header-break-point .ast-mobile-header-wrap,
.main-header-menu,
.ast-nav-menu {
  display: none !important;
}

/* ===== FIX MENU ASTRA + ELEMENTOR ===== */

/* Le header Astra doit laisser passer les menus */
.ast-primary-header,
.ast-main-header-wrap,
.ast-desktop-header,
.site-header {
  overflow: visible !important;
}

/* Sections Elementor */
.elementor-section,
.elementor-section-wrap,
.elementor-container,
.elementor-widget,
.elementor-widget-wrap {
  overflow: visible !important;
}

/* Conteneur principal du menu */
.main-menu {
  position: relative;
  z-index: 999999;
}

/* Sous-menus standards */
.main-menu .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 999999;
}

/* Mega-menu */
.main-menu .mega-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 999999;
}

/* Animation visible */
.sub-menu,
.mega-menu {
  opacity: 0;
  transform: translateY(25px);
  pointer-events: none;
  transition: all 0.35s ease;
}

/* Hover actif */
.has-sub:hover > .sub-menu,
.has-mega:hover > .mega-menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}


.main-menu > ul > li > a::after {
  content: '';
  display: block;
  height: 2px;
  width: 0;
  background: linear-gradient(90deg, #f5c97a, #fff);
  transition: width 0.3s ease;
}

.main-menu > ul > li:hover > a::after {
  width: 100%;
}