/*
Theme Name: Divi Child
Template: Divi
Description: Divi Child Theme - Design 2026 Mairie Saint-Pierre-es-Champs
Author: Neo Activity
*/

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* ── VARIABLES PASTEL ────────────────────────────────────── */
:root {
  --c-primary:     #5B876A;
  --c-primary-lt:  #6D9E7C;
  --c-primary-dk:  #3D6152;
  --c-accent:      #E07B42;
  --c-accent-dk:   #C86830;
  --c-accent-lt:   #F09060;
  --c-text:        #2A2A2A;
  --c-text-lt:     #626262;
  --c-bg:          #FAFAF7;
  --c-bg-section:  #F2F6F2;
  --c-border:      #DDE8DA;
  --c-white:       #FFFFFF;
  --radius-sm:     8px;
  --radius:        14px;
  --shadow:        0 2px 14px rgba(91,135,106,.10);
  --shadow-md:     0 6px 24px rgba(91,135,106,.16);
  --transition:    .25s ease;
  --font:          'Plus Jakarta Sans', system-ui, sans-serif;
}

/* ── BASE ────────────────────────────────────────────────── */
body {
  font-family: var(--font) !important;
  background-color: var(--c-bg) !important;
  color: var(--c-text) !important;
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4,h5,h6 { font-family: var(--font) !important; color: var(--c-text) !important; }
a { color: var(--c-primary) !important; transition: color var(--transition); }
a:hover { color: var(--c-accent-dk) !important; }

/* ── HEADER ──────────────────────────────────────────────── */
#main-header,
#main-header.et-fixed-header {
  background-color: var(--c-white) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,.09) !important;
  border-bottom: 3px solid var(--c-primary) !important;
}
#logo {
  max-height: 90px !important;
  padding: 6px 0 !important;
}
#main-header .nav li a,
#main-header .nav > ul > li > a {
  color: var(--c-text) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  letter-spacing: .01em;
  padding: 0 14px !important;
  transition: color var(--transition) !important;
}
#main-header .nav li a:hover { color: var(--c-primary) !important; }
#main-header .nav li.current-menu-item > a,
#main-header .nav li.current_page_item > a { color: var(--c-accent) !important; font-weight: 700 !important; }
#main-header .nav li ul {
  background-color: var(--c-white) !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: var(--shadow-md) !important;
  border: 1px solid var(--c-border) !important;
  overflow: hidden;
}
#main-header .nav li ul li a { color: var(--c-text) !important; padding: 10px 18px !important; }
#main-header .nav li ul li a:hover { background-color: var(--c-bg-section) !important; color: var(--c-primary) !important; }
.et_search_icon:before { color: var(--c-primary) !important; }

/* ── ESPACEMENT HEADER → CONTENU ─────────────────────────── */
/* Divi fixe la hauteur du header sticky via JS dans #page-container.
   On force un minimum pour que rien ne se cache sous le header. */
#page-container { padding-top: 100px !important; }
/* Sur la homepage, le hero ne doit pas coller au header */
.mairie-hero { margin-top: 24px; }
/* Retirer le margin-top sur les sections Divi des pages intérieures */
.et_d4_element.et_pb_section:first-child { margin-top: 0 !important; }

/* ── BANNIÈRES DE PAGE ───────────────────────────────────── */
.et_d4_element.et_pb_section.et_pb_with_background {
  background-color: var(--c-primary) !important;
}
/* Sections de contenu avec fond clair : ne pas les rendre vertes */
.et_d4_element.et_pb_section.et_pb_section_1,
.et_d4_element.et_pb_section.et_pb_section_2,
.et_d4_element.et_pb_section.et_pb_section_3,
.et_d4_element.et_pb_section.et_pb_section_4 {
  background-color: unset !important;
}
.et_d4_element.et_pb_section .et_pb_text_inner h1 {
  font-family: var(--font) !important;
  font-weight: 800 !important;
}

/* ── HERO HOMEPAGE ───────────────────────────────────────── */
.mairie-hero {
  position: relative;
  min-height: 500px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border-radius: 0 0 var(--radius) var(--radius);
}
.mairie-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
  transition: transform 8s ease;
}
.mairie-hero:hover .mairie-hero-bg { transform: scale(1); }
.mairie-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(40,65,48,.80) 0%, rgba(40,65,48,.25) 55%, transparent 100%);
}
.mairie-hero-content {
  position: relative;
  z-index: 2;
  padding: 50px 60px 60px;
  max-width: 860px;
}
.mairie-hero-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-accent-lt);
  margin-bottom: 10px;
  display: block;
}
.mairie-hero-title {
  font-size: clamp(28px, 4.5vw, 52px);
  font-weight: 800;
  color: #fff !important;
  line-height: 1.1;
  margin-bottom: 14px;
  text-shadow: 0 2px 10px rgba(0,0,0,.25);
}
.mairie-hero-sub {
  font-size: 16px;
  color: rgba(255,255,255,.80);
  margin-bottom: 28px;
}
.mairie-hero-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--c-accent);
  color: #fff !important;
  font-weight: 700;
  font-size: 15px;
  padding: 13px 26px;
  border-radius: 50px;
  text-decoration: none !important;
  transition: all var(--transition);
  box-shadow: 0 4px 14px rgba(224,123,66,.40);
}
.mairie-hero-btn:hover {
  background: var(--c-accent-dk) !important;
  color: #fff !important;
  transform: translateY(-2px);
}

/* ── ACCÈS RAPIDE ────────────────────────────────────────── */
.mairie-quick-access {
  background: var(--c-primary-dk);
  padding: 36px 20px;
}
.mairie-quick-access-inner {
  max-width: 860px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}
.mairie-qa-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 9px;
  text-decoration: none !important;
  transition: transform var(--transition);
  min-width: 80px;
}
.mairie-qa-item:hover { transform: translateY(-4px); }
.mairie-qa-circle {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255,255,255,.10);
  border: 2px solid rgba(255,255,255,.20);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--c-accent-lt) !important;
  transition: all var(--transition);
}
.mairie-qa-item:hover .mairie-qa-circle {
  background: var(--c-accent);
  border-color: var(--c-accent);
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(224,123,66,.40);
}
.mairie-qa-label {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,.80) !important;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .07em;
  line-height: 1.3;
}

/* ── SECTION TITRES ──────────────────────────────────────── */
.mairie-section { padding: 60px 30px; max-width: 1200px; margin: 0 auto; }
.mairie-section-title { font-size: 26px; font-weight: 800; color: var(--c-primary) !important; margin-bottom: 8px; padding-bottom: 0; }
.mairie-section-subtitle { font-size: 14px; color: var(--c-text-lt); margin-bottom: 36px; }
.mairie-section-title-bar { width: 44px; height: 4px; background: var(--c-accent); border-radius: 4px; margin-bottom: 36px; display: block; }

/* ── CARTES ACTUALITÉS ───────────────────────────────────── */
.mairie-news-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 36px; }
@media (max-width: 900px) { .mairie-news-grid { grid-template-columns: 1fr; } }
.mairie-news-card { background: var(--c-white); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); transition: all var(--transition); border: 1px solid var(--c-border); }
.mairie-news-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.mairie-news-card-body { padding: 22px; }
.mairie-news-card-date { font-size: 11px; font-weight: 700; color: var(--c-accent); text-transform: uppercase; letter-spacing: .09em; margin-bottom: 9px; }
.mairie-news-card-title { font-size: 15px; font-weight: 700; color: var(--c-primary) !important; line-height: 1.4; margin-bottom: 10px; padding-bottom: 0; }
.mairie-news-card-title a { color: var(--c-primary) !important; text-decoration: none; }
.mairie-news-card-title a:hover { color: var(--c-accent-dk) !important; }
.mairie-news-card-excerpt { font-size: 13px; color: var(--c-text-lt); line-height: 1.65; }
.mairie-news-card-footer { padding: 12px 22px; border-top: 1px solid var(--c-border); text-align: right; }
.mairie-news-card-footer a { font-size: 12px; font-weight: 600; color: var(--c-primary) !important; }
.mairie-news-more { text-align: center; margin-top: 32px; }
.mairie-btn-outline { display: inline-flex; align-items: center; gap: 8px; border: 2px solid var(--c-primary); color: var(--c-primary) !important; font-weight: 700; font-size: 14px; padding: 11px 26px; border-radius: 50px; text-decoration: none !important; transition: all var(--transition); }
.mairie-btn-outline:hover { background: var(--c-primary); color: #fff !important; }

/* ── CARTES NAVIGATION ───────────────────────────────────── */
.mairie-nav-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; max-width: 1100px; margin: 0 auto; padding: 50px 30px; box-sizing: border-box; }
@media (max-width: 768px) { .mairie-nav-cards { grid-template-columns: 1fr; } }
@media (min-width: 769px) and (max-width: 1024px) { .mairie-nav-cards { grid-template-columns: repeat(2,1fr); } }
.mairie-card { background: var(--c-white); border: 1px solid var(--c-border); border-radius: var(--radius); padding: 30px 18px 22px; text-align: center; transition: box-shadow var(--transition), transform var(--transition); }
.mairie-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.mairie-card .mairie-icon { font-size: 40px; color: var(--c-accent); display: block; margin-bottom: 14px; }
.mairie-card h4 { color: var(--c-primary) !important; font-size: 15px; font-weight: 700; margin-bottom: 8px; padding-bottom: 0; line-height: 1.3; }
.mairie-card h4 a { color: var(--c-primary) !important; text-decoration: none; }
.mairie-card h4 a:hover { color: var(--c-accent-dk) !important; }
.mairie-card p { color: var(--c-text-lt); font-size: 13.5px; line-height: 1.6; margin: 0; padding: 0; }

/* ── CARTES INFO ─────────────────────────────────────────── */
.mairie-info-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; max-width: 1100px; margin: 0 auto; padding: 50px 30px; }
@media (max-width: 768px) { .mairie-info-cards { grid-template-columns: 1fr; } }
.mairie-info-card { background: var(--c-bg-section); border-top: 4px solid var(--c-primary); border-radius: var(--radius-sm); padding: 28px 22px; text-align: center; }
.mairie-info-card .mairie-icon { font-size: 32px; color: var(--c-primary); display: block; margin-bottom: 12px; }
.mairie-info-card h4 { color: var(--c-primary) !important; font-size: 16px; font-weight: 700; margin-bottom: 10px; padding-bottom: 0; }
.mairie-info-card p { color: var(--c-text-lt); font-size: 14px; line-height: 1.8; margin: 0; padding: 0; }
.mairie-info-card a { color: var(--c-primary) !important; }

/* ── PERSONNEL ───────────────────────────────────────────── */
.mairie-personnel { max-width: 680px; margin: 48px auto; padding: 36px 28px; background: var(--c-white); border: 1px solid var(--c-border); border-radius: var(--radius); display: flex; gap: 28px; align-items: flex-start; }
.mairie-personnel .mairie-icon { font-size: 44px; color: var(--c-accent); flex-shrink: 0; margin-top: 4px; }
.mairie-personnel h4 { color: var(--c-primary) !important; font-size: 18px; font-weight: 700; margin-bottom: 10px; padding-bottom: 0; }
.mairie-personnel p { color: var(--c-text-lt); font-size: 14px; line-height: 1.8; margin: 0; padding: 0; }
.mairie-personnel a { color: var(--c-primary) !important; }
@media (max-width: 600px) { .mairie-personnel { flex-direction: column; } }

/* ── ASSOCIATIONS ────────────────────────────────────────── */
.mairie-asso-cards { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; max-width: 1100px; margin: 0 auto; padding: 50px 30px; }
@media (max-width: 768px) { .mairie-asso-cards { grid-template-columns: 1fr; } }
.mairie-asso-card { background: var(--c-white); border: 1px solid var(--c-border); border-left: 5px solid var(--c-primary-lt); border-radius: var(--radius-sm); padding: 20px 22px; display: flex; gap: 14px; align-items: flex-start; transition: box-shadow var(--transition); }
.mairie-asso-card:hover { box-shadow: var(--shadow); }
.mairie-asso-card .mairie-icon { font-size: 26px; color: var(--c-primary); flex-shrink: 0; margin-top: 2px; }
.mairie-asso-card h4 { color: var(--c-primary) !important; font-size: 15px; font-weight: 700; margin-bottom: 5px; padding-bottom: 0; }
.mairie-asso-card p { color: var(--c-text-lt); font-size: 13.5px; line-height: 1.6; margin: 0; padding: 0; }

/* ── FOOTER ──────────────────────────────────────────────── */
#footer-widgets {
  background-color: var(--c-primary-dk) !important;
  padding: 56px 0 36px !important;
}
#footer-widgets .footer-widget h4.widgettitle {
  color: var(--c-accent-lt) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  border-bottom: 1px solid rgba(255,255,255,.12) !important;
  padding-bottom: 10px !important;
  margin-bottom: 16px !important;
  letter-spacing: .07em;
  text-transform: uppercase;
}
#footer-widgets .footer-widget,
#footer-widgets .footer-widget p,
#footer-widgets .footer-widget li { color: rgba(255,255,255,.72) !important; font-size: 13.5px !important; line-height: 1.9 !important; }
#footer-widgets .footer-widget a { color: rgba(255,255,255,.80) !important; transition: color var(--transition); }
#footer-widgets .footer-widget a:hover { color: var(--c-accent-lt) !important; }
#footer-widgets ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
#footer-bottom { background-color: rgba(0,0,0,.20) !important; padding: 12px 0 !important; }
#footer-bottom .footer-bottom-wrap,
#footer-bottom .footer-bottom-wrap a { color: rgba(255,255,255,.45) !important; font-size: 11px !important; }

/* ── MASQUER TITRE DE PAGE ───────────────────────────────── */
h1.entry-title.main_title { display: none !important; }
.page .et_pb_title_container { display: none !important; }

/* ── BLOG / ARTICLES ─────────────────────────────────────── */
.et_pb_post .entry-title a { color: var(--c-primary) !important; font-weight: 700; }
.et_pb_post .entry-title a:hover { color: var(--c-accent-dk) !important; }
.et_pb_post .post-meta, .et_pb_post .post-meta a { color: var(--c-accent) !important; font-weight: 600; font-size: 11px; }

/* ── TABLEAUX ────────────────────────────────────────────── */
table { border-collapse: collapse; width: 100%; margin: 20px 0; }
th { background: var(--c-primary); color: #fff; padding: 12px 16px; text-align: left; font-weight: 600; }
td { padding: 11px 16px; border-bottom: 1px solid var(--c-border); }
tr:nth-child(even) { background: var(--c-bg-section); }

/* ── FORMULAIRE CF7 ──────────────────────────────────────── */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 textarea {
  border: 2px solid var(--c-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 12px 16px !important;
  font-family: var(--font) !important;
  font-size: 15px !important;
  width: 100% !important;
  transition: border-color var(--transition) !important;
  background: var(--c-white) !important;
}
.wpcf7 input:focus, .wpcf7 textarea:focus { border-color: var(--c-primary) !important; outline: none !important; }
.wpcf7 input[type="submit"] {
  background: var(--c-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 13px 30px !important;
  font-family: var(--font) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
}
.wpcf7 input[type="submit"]:hover { background: var(--c-primary-lt) !important; }
