/* =================================================================== */
/* FEUILLE DE STYLE FINALE - VERSION DIAGONALE                         */
/* =================================================================== */

/* =================== IMPORTATION DES POLICES =================== */
@import url('https://fonts.googleapis.com/css2?family=Exo+2:wght@700&family=Poppins:wght@400;600;700&display=swap');

/* =================== VARIABLES & RESET =================== */
:root {
  --primary-color: #0a2540;
  --secondary-color: #f6b519;
  --light-gray: #f7f7f7;
  --dark-gray: #333;
  --text-color: #555;
  --white: #fff;
  --font-family: 'Poppins', sans-serif;
  --font-hero-title: 'Exo 2', sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-family); color: var(--text-color); line-height: 1.6; background-color: var(--white); }
img { max-width: 100%; height: auto; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
h1,h2,h3,h4 { color: var(--primary-color); margin-bottom: 20px; line-height: 1.2; }
h1 { font-size: 3rem; }
h2 { font-size: 2.2rem; text-align: center; position: relative; padding-bottom: 15px; }
h3 { font-size: 1.5rem; }
section { padding: 80px 0; }
.hp { display: none !important; }

/* Accent de couleur sous les titres H2 */
h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 4px;
  background-color: var(--secondary-color);
  border-radius: 2px;
}

/* =================== BOUTONS & MODAL =================== */
.cta-button, .cta-button-secondary {
  display: inline-block;
  text-decoration: none;
  cursor: pointer;
  border: none;
}
.cta-button {
  background: linear-gradient(45deg, #f6b519, #f9c74f);
  color: var(--primary-color);
  font-weight: 700;
  border-radius: 8px;
  padding: 12px 24px;
  font-size: 0.9rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
}
.cta-button:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}
.hero .cta-button, .cta-section .cta-button {
  padding: 14px 28px;
  font-size: 1rem;
}
.cta-button-secondary {
  background: transparent;
  color: var(--primary-color);
  border: 2px solid var(--primary-color);
  padding: 12px 25px;
  border-radius: 5px;
  font-weight: 600;
  transition: all .3s ease;
}
.cta-button-secondary:hover {
  background: var(--primary-color);
  color: var(--white);
}
.hero .cta-button-secondary {
  color: var(--white);
  border-color: rgba(255, 255, 255, 0.8);
}
.hero .cta-button-secondary:hover {
  background-color: var(--white);
  color: var(--primary-color);
  border-color: var(--white);
}
.modal { display: none; position: fixed; z-index: 2000; inset: 0; background: rgba(0,0,0,.5); }
.modal-content {
  background:var(--white);margin:8vh auto;padding:30px;border:1px solid #888;width:92%;
  max-width:500px;border-radius:10px;position:relative;text-align:center;
}
.close-button { color:#666;position:absolute;top:8px;right:12px;font-size:28px;font-weight:bold;cursor:pointer;background:none;border:0; }
.modal-content form { display:flex;flex-direction:column;gap:15px;margin-top:20px; }
.modal-content input { padding:12px;border:1px solid #ccc;border-radius:5px; }
.form-msg { margin-top:6px;font-size:.95rem; }

/* =================== HEADER =================== */
.main-header { background:var(--white);box-shadow:0 2px 5px rgba(0,0,0,.08);position:sticky;top:0;z-index:1000; }
.main-header .container { display:flex;justify-content:space-between;align-items:center;height:72px; }
.logo { font-size:1.6rem;font-weight:700;text-decoration:none;color:var(--primary-color); }
.logo-tech { color:var(--secondary-color); }
#mobileMenuToggle { display:none;background:none;border:0;font-size:1.8rem;color:var(--primary-color);cursor:pointer; }
.main-nav .nav-links { list-style:none;display:flex;margin-bottom:0; }
.main-nav a {
  text-decoration:none;color:var(--primary-color);padding:10px 12px;font-weight:600;position:relative;
  text-transform: uppercase; letter-spacing: 0.5px; font-size: 0.85rem;
  transition: all 0.3s ease;
}
.main-nav a:hover { color: var(--secondary-color); transform: translateY(-2px); }
.main-nav a::after { display: none; }

/* =================== FOOTER =================== */
.main-footer { background:var(--primary-color);color:var(--white);padding:60px 0 20px; }
.footer-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-bottom:40px; }
.footer-column h4 { color:var(--white);margin-bottom:10px; }
.main-footer a { color:var(--white);text-decoration:none; }
.main-footer a:hover { color:var(--secondary-color); }
.footer-column ul { list-style:none;padding-left:0; }
.footer-column li { margin-bottom:8px; }
.footer-bottom { text-align:center;border-top:1px solid #2a4a6d;padding-top:20px;font-size:.9rem; }
.footer-bottom p { margin:0; }

/* =================== HERO =================== */
.hero {
  color:var(--white);
  min-height: 80vh;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  text-align:center;
  position:relative;
  padding:100px 20px;
  overflow:hidden;
  background:radial-gradient(circle at center,#0d2c4a,#0a2540 80%),var(--primary-color);
  clip-path: polygon(0 0, 100% 0, 100% 90%, 0 100%);
}
.hero::after {
  content:'';position:absolute;inset:0;
  width:100%;height:100%;
  background-image:url('/img/background_webini.webp');
  background-size:cover;background-position:center;background-repeat:no-repeat;
  opacity:.15;z-index:1;
}
.hero .container { position:relative;z-index:2;width:55%;padding-right:5%; }
.hero h1 {
  color:var(--white);margin-bottom:15px;
  font-family:var(--font-hero-title);
  text-shadow: 0 0 15px rgba(255, 255, 255, 0.3);
}
.hero h1::after { display:none; }
.hero .subtitle { font-size:1.2rem;max-width:700px;margin:0 auto 28px;color:rgba(255,255,255,.85); }
.hero-ctas { display:flex;gap:12px;justify-content:center; }
.scroll-cue { margin-top:22px;opacity:.6;animation:floatY 1.8s ease-in-out infinite; }
@keyframes floatY { 0%,100%{transform:translateY(0)} 50%{transform:translateY(6px)} }

/* =================== TRUST LOGOS =================== */
.trust-logos {
  padding: 100px 0 80px 0;
  text-align: center;
  background-color: white;
  margin-top: -8vh;
  position: relative;
  z-index: 5;
}
.trust-logos h2 {
  margin-bottom: 40px;
}
.trust-logos .logos {
  list-style:none;display:flex;gap:32px;justify-content:center;align-items:center;padding:0;margin:0;flex-wrap:wrap;
}
.trust-logos img { height:34px;filter:grayscale(1) contrast(1.05);opacity:.9; transition: all 0.3s ease; }
.trust-logos img:hover {
  filter: grayscale(0);
  transform: scale(1.1);
}

/* =================== ENGAGEMENTS =================== */
.engagements { background:var(--light-gray); border-top: 1px solid #eef2f7; }
.engagements-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:30px;margin-top:40px; }
.engagement-item { text-align:center; padding: 20px; }
.engagement-item img { width:60px;height:60px;object-fit:cover;margin-bottom:15px;border-radius:50%; }
.engagement-item h3 { font-size:1.2rem; }

/* =================== SOLUTIONS =================== */
.solutions-overview { padding:80px 0; border-top: 1px solid #eef2f7; }
.solutions-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px; }
.solution-card {
  background:var(--white);padding:30px;border-radius:8px;box-shadow:0 5px 15px rgba(0,0,0,.05);
  transition:transform .3s ease,box-shadow .3s ease;
}
.solution-card:hover { transform:translateY(-5px);box-shadow:0 8px 25px rgba(0,0,0,.1); }
.solution-card a { color:var(--primary-color);font-weight:600;text-decoration:none; }

/* =================== SOCIAL PROOF / CASES =================== */
.social-proof { background:var(--light-gray);text-align:center; border-top: 1px solid #eef2f7; }
.testimonial blockquote { font-size:1.3rem;font-style:italic;max-width:800px;margin:0 auto;position:relative; }
.testimonial cite { display:block;margin-top:15px;font-weight:600;color:var(--primary-color); }
.case-studies-highlights { display:flex;justify-content:space-around;margin:60px 0;text-align:center;gap:20px;flex-wrap:wrap; }
.case-study-highlight h4 { font-size:2.5rem;color:var(--secondary-color); }
.case-study-highlight p { max-width:200px;margin:0 auto; }
.case-study-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:30px; }
.case-study-card {
  background:var(--white);border-radius:8px;box-shadow:0 5px 15px rgba(0,0,0,.05);padding:30px;display:flex;flex-direction:column;
  border-left:5px solid var(--secondary-color);transition:transform .3s ease,box-shadow .3s ease;
}
.case-study-card:hover { transform:translateY(-5px);box-shadow:0 8px 25px rgba(0,0,0,.1); }
.card-icon { margin-bottom:20px;width:60px; }
.case-study-result { margin-top:auto;padding:10px 15px;background:#f0f4f8;border-radius:5px;font-size:1rem;color:var(--primary-color);text-align:center; }

/* =================== ABOUT =================== */
.about-us { border-top: 1px solid #eef2f7; }
.about-us .about-us-content { display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center; }

/* =================== REVEAL / COUNTS =================== */
.reveal { opacity:0;transform:translateY(12px);transition:opacity .6s ease,transform .6s ease; }
.reveal.in-view { opacity:1;transform:none; }
.count { font-variant-numeric:tabular-nums; }

/* =================== RESPONSIVE =================== */
@media (max-width:991px) {
  .hero {
    justify-content:center;min-height:60vh;
    clip-path: polygon(0 0, 100% 0, 100% 95%, 0 100%);
  }
  .trust-logos { margin-top: -5vh; }
  .hero .container { width:100%;padding-right:0; }
  .hero::after { display: none; }
  .solutions-grid { grid-template-columns:1fr; }
  .about-us .about-us-content { grid-template-columns:1fr;text-align:center; }
  #mobileMenuToggle { display:block; }
  .main-nav { display:none;position:absolute;top:72px;left:0;width:100%;background:var(--white);box-shadow:0 4px 8px rgba(0,0,0,.1); }
  .main-nav.active { display:block; }
  .main-nav .nav-links { flex-direction:column; }
  .main-nav li { text-align:center;border-bottom:1px solid #f0f0f0; }
  .case-studies-highlights { flex-direction:column;gap:40px; }
  .footer-grid { text-align:center; }
}

@media (prefers-reduced-motion:reduce) {
  .scroll-cue,.reveal,.cta-button,.solution-card,.case-study-card,.main-nav a {
    animation:none;
    transition:none;
  }
}

/* =================================================================== */
/* STYLES DES PAGES INTERNES                                         */
/* =================================================================== */

.page-header{
  background-color: var(--primary-color);
  color: var(--white);
  padding: 60px 0;
  text-align: center;
}
.page-header h1{ color: var(--white); font-size: 2.6rem; margin-bottom:10px }
.page-header .subtitle{ font-size:1.05rem; max-width:780px; margin:0 auto; opacity:.92 }

.page-nav{
  background-color: var(--light-gray);
  position: sticky;
  top: 72px;
  z-index: 900;
  border-bottom: 1px solid #e0e0e0;
}
.page-nav .container ul{
  list-style:none; display:flex; justify-content:center; gap:8px; padding:0; margin:0
}
.page-nav a{
  display:block; padding:14px 20px; text-decoration:none;
  color: var(--text-color); font-weight:600; border-radius:8px;
  transition: color .25s ease, background-color .25s ease;
}
.page-nav a:hover{ color: var(--primary-color); background:#e9e9e9 }
.page-nav a.active{ color:var(--primary-color); background:#e9f2ff; border:1px solid #cfe3ff }

.solution-category{ padding:80px 0 }
.solution-category.alt-bg{ background-color: var(--light-gray) }

.category-intro{ text-align:center; max-width:860px; margin:0 auto 50px }
.category-intro h2{ font-size:2.2rem; margin-bottom:10px }
.category-problem{ font-size:1.05rem; font-style:italic; color:var(--text-color) }

.service-detail-grid{ display:grid; grid-template-columns:1fr; gap:28px }
.service-item{
  display:flex; align-items:flex-start; gap:22px;
  background:var(--white); padding:26px; border-radius:10px;
  box-shadow:0 5px 15px rgba(0,0,0,.05)
}
.solution-category.alt-bg .service-item{ background:#fdfdfd }
.service-icon img{ border-radius:8px; display:block }
.service-content h3{ margin-top:0; font-size:1.5rem }
.service-content p{ margin:10px 0 14px }
.benefits-list{ list-style:none; padding-left:0; margin:0 }
.benefits-list li{ padding-left:24px; position:relative; margin-bottom:6px }
.benefits-list li::before{
  content:'✓'; color:#28a745; font-weight:700; position:absolute; left:0; top:0
}

@media (max-width: 768px){
  .page-header h1{ font-size:2.1rem }
  .page-nav{ top:72px }
  .service-item{ flex-direction:column; text-align:center; align-items:center }
}

.filters-bar{
  display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px;flex-wrap:wrap
}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chips .chip{
  padding:8px 12px;border:1px solid #e2e8f0;border-radius:999px;font-weight:600;
  background:#fff;color:#334155;cursor:pointer;transition:all .2s
}
.chips .chip:hover{border-color:#cbd5e1;background:#f8fafc}
.chips .chip.active{background:#e9f2ff;border-color:#cfe3ff;color:#0a2540}
.chips.small .chip{padding:6px 10px;font-size:.9rem}

.filters-right{display:flex;gap:12px;align-items:center}
.search-wrap{position:relative}
.search-wrap input{
  padding:10px 34px 10px 12px;border:1px solid #e2e8f0;border-radius:8px;min-width:260px;font-size:0.95rem
}
.search-wrap .search-ico{position:absolute;right:10px;top:50%;transform:translateY(-50%);opacity:.6}
.sort-wrap select{
  padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-weight:600
}
.cases-count{margin:8px 0 22px 0;color:#475569}

.case-study-card{
  position:relative;overflow:hidden;border-left:0;border:1px solid #eef2f7
}
.case-study-card::before{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,37,64,0.03),transparent 40%,rgba(246,181,25,0.05));
  opacity:0;transition:opacity .25s
}
.case-study-card:hover::before{opacity:1}
.case-study-card h3{margin-top:0}
.case-study-card p{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}

.case-study-card .pill{
  display:inline-block;padding:6px 10px;border-radius:999px;background:#f0f4f8;font-weight:600;font-size:.9rem;color:#0a2540
}
.case-study-card .pill.result{background:#fff6db;border:1px solid #ffe9a3;color:#8a6200}

.card-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.card-btn{border:1px solid #e2e8f0;border-radius:8px;padding:8px 12px;background:#fff;font-weight:600;cursor:pointer}
.card-btn:hover{background:#f8fafc}

.card-skel{
  height:200px;border-radius:8px;background:
  linear-gradient(90deg,#f2f5f9 25%,#e9edf3 37%,#f2f5f9 63%);
  background-size:400% 100%;animation:shimmer 1.4s ease-in-out infinite
}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:0 0}}

.center{text-align:center}
.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}

.case-modal .case-modal-content{max-width:960px;width:92%}
.case-modal-hero{margin:0 0 14px 0;border-radius:8px;overflow:hidden}
.case-modal-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}
.case-modal-body p{margin:10px 0}
.case-modal-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap}
.case-modal-footer .pill.result{background:#fff6db;border:1px solid #ffe9a3;color:#8a6200}

@media (max-width: 991px){
  .search-wrap input{min-width:180px}
}

.page-header.with-bg-image {
    position: relative;
    background-image: linear-gradient(rgba(10, 37, 64, 0.85), rgba(10, 37, 64, 0.85)), url('https://via.placeholder.com/1920x400/cccccc/000000?text=Industrie');
    background-size: cover;
    background-position: center;
    padding: 100px 0;
}
.timeline-section {
    padding: 80px 0;
    background: var(--white);
}
.timeline-section .subtitle { color: var(--text-color); }
.timeline {
    position: relative;
    max-width: 800px;
    margin: 60px auto 0;
    padding: 0 20px;
}
.timeline::after {
    content: '';
    position: absolute;
    width: 3px;
    background-color: var(--secondary-color);
    top: 0;
    bottom: 0;
    left: 50%;
    margin-left: -1.5px;
}
.timeline-item {
    padding: 10px 40px;
    position: relative;
    width: 50%;
}
.timeline-item:nth-child(odd) { left: 0; }
.timeline-item:nth-child(even) { left: 50%; }
.timeline-item::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    right: -8px;
    background-color: var(--white);
    border: 3px solid var(--secondary-color);
    top: 22px;
    border-radius: 50%;
    z-index: 1;
}
.timeline-item:nth-child(even)::after { left: -8px; }
.timeline-content {
    padding: 20px 30px;
    background-color: var(--light-gray);
    position: relative;
    border-radius: 6px;
    border-left: 4px solid var(--primary-color);
}
.timeline-content h3 { margin-top: 0; }
.values-section .values-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 30px;
    margin-top: 40px;
}
.values-section .value-card {
    background: var(--white);
    padding: 30px;
    border-radius: 8px;
    text-align: center;
    box-shadow: 0 5px 25px rgba(0,0,0,0.07);
    border-top: 4px solid var(--secondary-color);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.values-section .value-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.1);
}
.values-section .value-icon {
    margin-bottom: 20px;
}
.values-section .value-icon img {
    height: 50px;
    width: auto;
}
.values-section .value-card h3 {
    color: var(--primary-color);
    margin-bottom: 10px;
}
.meet-the-team-section {
    padding: 80px 0;
    background: var(--white);
}
.team-grid {
    display: flex;
    justify-content: center;
    gap: 30px;
    margin-top: 40px;
    flex-wrap: wrap;
}
.team-member-card {
    background: var(--white);
    text-align: center;
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 5px 25px rgba(0,0,0,0.07);
    max-width: 350px;
}
.team-photo {
    width: 140px;
    height: 140px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 20px;
    border: 4px solid var(--light-gray);
}
.team-member-card h3 { margin-bottom: 5px; }
.team-member-card h4 {
    margin-bottom: 15px;
    font-size: 1rem;
    color: var(--secondary-color);
    font-weight: 600;
}
.team-quote { font-style: italic; color: var(--text-color); }
.cta-section { padding: 80px 0; text-align: center; }
.cta-section h2 { font-size: 2.5rem; }
.cta-section p {
    font-size: 1.2rem;
    max-width: 600px;
    margin: 0 auto 30px;
    color: var(--text-color);
}

@media (max-width: 768px) {
    .timeline::after { left: 20px; }
    .timeline-item { width: 100%; padding-left: 50px; padding-right: 0; left: 0 !important; }
    .timeline-item::after { left: 12px; }
}



/* =================================================================== */
/* PAGE CONTACT                                                      */
/* =================================================================== */

.contact-page-section {
    background-color: #fcfdff;
    padding: 100px 0;
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr; /* 2 colonnes avec des proportions équilibrées */
    gap: 50px;
    background-color: var(--white);
    box-shadow: 0 10px 40px rgba(10, 37, 64, 0.1);
    border-radius: 12px;
    overflow: hidden; /* Pour que les coins arrondis s'appliquent bien */
}

/* --- PARTIE GAUCHE : INFOS DIRECTES (LE BLOC SOMBRE) --- */
.contact-info {
    background: var(--primary-color);
    color: rgba(255, 255, 255, 0.9);
    padding: 50px 40px;
    display: flex;
    flex-direction: column;
    gap: 25px;
}
.contact-info h3 {
    color: var(--white);
    font-size: 1.8rem;
}
.contact-info h4 {
    color: var(--secondary-color);
    margin-bottom: 5px;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.contact-info a {
    color: var(--white);
    text-decoration: none;
    transition: color 0.3s ease;
}
.contact-info a:hover {
    color: var(--secondary-color);
}
.contact-info address {
    font-style: normal;
    line-height: 1.6;
}

.info-item {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

/* --- ICÔNES SVG DIRECTEMENT EN CSS --- */
.contact-icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    margin-top: 5px;
}
.phone-icon {
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f6b519' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.63A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'%3E%3C/path%3E%3C/svg%3E");
}
.email-icon {
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f6b519' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'%3E%3C/path%3E%3Cpolyline points='22,6 12,13 2,6'%3E%3C/polyline%3E%3C/svg%3E");
}
.address-icon {
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f6b519' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'%3E%3C/path%3E%3Ccircle cx='12' cy='10' r='3'%3E%3C/circle%3E%3C/svg%3E");
}
.hours-icon {
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f6b519' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E");
}

/* --- PARTIE DROITE : FORMULAIRE DE CONTACT --- */
.contact-form {
    padding: 50px 40px;
}
.contact-form h3 {
    font-size: 1.8rem;
    margin-bottom: 30px;
}
.form-group {
    margin-bottom: 20px;
}
.form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: var(--primary-color);
}
.form-group input,
.form-group textarea {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background-color: #fcfdff;
    font-family: var(--font-family);
    font-size: 1rem;
    transition: all 0.3s ease;
}
.form-group input:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--secondary-color);
    background-color: var(--white);
    box-shadow: 0 0 0 3px rgba(246, 181, 25, 0.2);
}
.form-group textarea {
    resize: vertical;
    min-height: 120px;
}
.contact-form .cta-button {
    width: 100%;
    padding: 15px;
    font-size: 1.1rem;
    margin-top: 10px;
}

/* --- SECTION CARTE GEOGRAPHIQUE --- */
.map-section {
    padding: 0; /* Pas de padding pour que la carte prenne toute la largeur */
    line-height: 0; /* Supprime l'espace sous l'iframe */
}
.map-section iframe {
    filter: grayscale(1);
    transition: filter 0.4s ease;
}
.map-section iframe:hover {
    filter: grayscale(0);
}

/* --- Responsive pour la page contact --- */
@media (max-width: 991px) {
    .contact-grid {
        grid-template-columns: 1fr; /* Passe à une seule colonne sur mobile */
    }
}

/* =================== AMÉLIORATION PAGE HEADER =================== */
.page-header {
  padding: 80px 0; /* Plus d'espace vertical */
  background-color: var(--primary-color);
  color: var(--white);
  text-align: center;
}
.page-header h1 {
  color: var(--white);
  font-size: 3.2rem; /* Titre plus grand et percutant */
  margin-bottom: 15px;
  text-shadow: 0 2px 5px rgba(0,0,0,0.2);
}
/* On retire l'accent jaune pour les titres sur fond sombre */
.page-header h1::after {
    display: none;
}
.page-header .subtitle {
  font-size: 1.2rem;
  max-width: 700px; /* Assure une lisibilité optimale */
  margin: 0 auto;
  opacity: 0.85; /* Crée une hiérarchie avec le titre principal */
  line-height: 1.6;
}

/* =================== AMÉLIORATIONS FOOTER =================== */

/* Classe pour masquer les labels visuellement mais les garder pour les lecteurs d'écran */
.visually-hidden {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap; /* Ajout pour la robustesse */
}

/* Style de la liste de contact dans le footer */
.footer-contact-list {
  list-style: none;
  padding-left: 0;
  color: rgba(255, 255, 255, 0.8);
}
.footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.footer-contact-list i {
  margin-top: 5px;
  color: var(--secondary-color);
  font-size: 1rem;
}
.footer-contact-list address {
  font-style: normal;
}
.footer-contact-list a {
  color: rgba(255, 255, 255, 0.8);
}
.footer-contact-list a:hover {
  color: var(--white);
}

/* Style des icônes de réseaux sociaux */
.footer-social {
  margin-top: 20px;
  display: flex;
  gap: 10px;
}
.footer-social a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--white);
  font-size: 1.1rem;
  transition: background-color 0.3s, transform 0.3s;
}
.footer-social a:hover {
  background-color: var(--secondary-color);
  color: var(--primary-color);
  transform: translateY(-3px);
}

/* S'assurer que les champs du formulaire de la modale sont espacés */
#recallForm div {
    margin-bottom: 10px;
}
#recallForm div:last-of-type {
    margin-bottom: 0;
}