/* ===== IFSIGO-BMSP INTELLIGENT COLOR STYLING ===== */

:root{
  --accent:#2b8a3e;
  --accent-red:#c62828;
  --text-dark:#0f172a;
  --text-light:#555;
  --bg-light:#f7f9fb;
  --card:#ffffff;
  --border-radius:8px;
  --radius:8px;
  --muted:#666;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Poppins',Arial,sans-serif;line-height:1.6;color:var(--text-dark);background:var(--bg-light);overflow-x:hidden}

/* Prevent iOS zoom on input focus */
input,select,textarea{font-size:16px;font-family:inherit}

/* Global image responsiveness */
img{max-width:100%;height:auto;display:block}

/* ===== BASE ELEMENTS - NEUTRAL COLORS ===== */
h1,h2,h3,h4,h5,h6{margin:0;color:var(--text-dark);line-height:1.3}
p{color:var(--text-dark);margin:0 0 1rem}
a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-red)}
button{font-family:inherit;cursor:pointer}

/* ===== HERO SECTIONS - DARK BACKGROUND ===== */
.hero,.admission-hero,.formation-hero{
  position:relative;
  min-height:220px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-grid{width:100%;display:flex;justify-content:center}

.hero-content{
  text-align:center;
  max-width:780px;
  width:100%;
  padding:2.5rem 1rem;
}

.hero-content h1{font-size:2.2rem;margin:0 0 0.2rem}
.hero-content .tagline-hero{font-size:1rem;color:rgba(255,255,255,0.9);font-weight:600;margin:0 0 0.4rem;display:block}
.hero-content h2{font-size:1.05rem;font-weight:500;margin:0 0 0.4rem}
.hero-content .lead{font-size:0.9rem;color:rgba(255,255,255,0.85);margin:0 0 0.25rem}
.hero-content .hero-ctas{margin-top:1rem}

@media(max-width:600px){
  .hero-content h1{font-size:1.5rem}
  .hero-content h2{font-size:0.95rem}
}

.hero::before,.admission-hero::before,.formation-hero::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:url('1.jpg') center/cover;
  z-index:-1;
}

.hero::after,.admission-hero::after,.formation-hero::after{
  content:'';
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,0.3);
  z-index:0;
}

/* Hero TEXT - WHITE with shadow on dark backgrounds */
.hero h1,.hero h2,.hero h3,.hero h4,.hero h5,.hero h6,.hero p,.hero-content h1,.hero-content h2,.hero-content h3,.hero-content h4,.hero-content h5,.hero-content h6,.hero-content p,
.admission-hero h1,.admission-hero h2,.admission-hero h3,.admission-hero h4,.admission-hero h5,.admission-hero h6,.admission-hero p,
.formation-hero h1,.formation-hero h2,.formation-hero h3,.formation-hero h4,.formation-hero h5,.formation-hero h6,.formation-hero p{
  color:white;
  text-shadow:1px 1px 3px rgba(0,0,0,0.7);
  position:relative;
  z-index:1;
}

/* ===== LIGHT SECTIONS - DARK TEXT ===== */
.pca-card,.pca-card h1,.pca-card h2,.pca-card h3,.pca-card h4,.pca-card h5,.pca-card h6,.pca-card p{
  color:var(--text-dark);
  text-shadow:none;
}

/* PCA image & role */
.pca-card.centered{display:flex;flex-direction:column;gap:1.25rem;align-items:center;text-align:center;max-width:860px;margin:0 auto}
.pca-card.centered img{width:200px;height:200px;object-fit:cover;border-radius:50%;flex-shrink:0}
.pca-info{display:flex;flex-direction:column;align-items:center;gap:0.5rem;text-align:center}
.pca-info p{max-width:720px}
.pca-info{max-width:760px}
.pca-role{color:var(--accent);font-weight:700;margin:0.25rem 0}
.pca-section{margin-bottom:1.75rem}

/* Nos valeurs - remove bullets */
.values{list-style:none}
.values li{display:inline-block;padding:0.5rem 0.75rem;margin:0.25rem;background:rgba(43,138,62,0.08);border-radius:20px;font-size:0.95rem}

/* Card-paired layout for about/mission/chiffres */
.paired-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:1.25rem}
.paired-grid .card{background:var(--card);padding:1.25rem;border-radius:12px;box-shadow:0 8px 24px rgba(2,6,23,0.04);border-left:4px solid rgba(43,138,62,0.06)}
.paired-grid .card h4{color:var(--accent);margin-bottom:0.5rem}
.paired-stats{display:flex;gap:1rem;align-items:center;justify-content:center}
.paired-stats .stat{flex:1;padding:0.75rem}

@media (max-width:900px){
  .paired-grid{grid-template-columns:1fr}
  .pca-card.centered{flex-direction:column;align-items:center;text-align:center}
  .pca-card.centered img{flex:0}
}

.testimonial,.testimonial h1,.testimonial h2,.testimonial h3,.testimonial h4,.testimonial h5,.testimonial h6,.testimonial p,.stat,.stat h1,.stat h2,.stat h3,.stat h4,.stat h5,.stat h6,.stat p{
  color:var(--text-dark);
  text-shadow:none;
}

/* White card sections */
.section{padding:2rem 0}
.container{max-width:1200px;margin:0 auto;padding:0 1rem}

/* ===== HEADER/NAV ===== */
.site-header,.site-header a{color:var(--text-dark)}
header{background:white;box-shadow:0 2px 8px rgba(0,0,0,0.06)}

.header-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 0}
.brand{flex:0 0 auto;display:flex;align-items:center;gap:0.5rem}
.logo-img{width:50px;height:50px;object-fit:cover;border-radius:8px;flex-shrink:0}
.brand-text{display:flex;flex-direction:column}
.site-title{font-size:1.5rem;color:var(--accent);margin:0}
.tagline{font-size:0.85rem;color:var(--muted);margin:0.25rem 0 0}

.main-nav{flex:1;display:flex;justify-content:flex-end;align-items:center}
.nav-toggle{display:none}

.nav-list{display:flex;list-style:none;gap:0.5rem;margin:0;padding:0;flex-wrap:nowrap;justify-content:flex-end;overflow-x:auto}
.nav-list li{margin:0;flex-shrink:0}
.nav-list a{background:var(--accent);color:white;padding:0.6rem 1rem;border-radius:6px;font-size:0.95rem;font-weight:600;transition:all .2s;box-shadow:0 2px 6px rgba(43,138,62,0.2);display:inline-block}
.nav-list a:hover{background:var(--accent-red);transform:translateY(-2px);box-shadow:0 4px 12px rgba(198,40,40,0.3)}

/* Mobile menu */
@media (max-width:900px){
  .nav-toggle{display:flex;align-items:center;justify-content:center;background:var(--accent);color:white;border:none;border-radius:6px;font-size:1.5rem;line-height:1;cursor:pointer;padding:0.35rem 0.7rem;min-width:42px}
  .nav-list{position:absolute;top:calc(100% + 0.5rem);right:0;left:auto;background:white;flex-direction:column;gap:0.3rem;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,0.15);padding:0.75rem;display:none;width:220px;z-index:999}
  .nav-list.open{display:flex}
  .nav-list a{width:100%;text-align:left;padding:0.6rem 0.8rem;font-size:0.9rem}
  .header-inner{flex-wrap:nowrap;gap:0.5rem;padding:0.75rem 0}
  .main-nav{position:relative;width:auto;flex:0 0 auto}
  .brand{align-items:center}
  .logo-img{width:40px;height:40px}
  .site-title{font-size:1.2rem}
  .tagline{font-size:0.75rem}
}

@media (max-width:480px){
  .site-title{font-size:1.05rem}
  .tagline{display:none}
}

  /* ===== ALIGNEMENT GÉNÉRAL: centrer titres et contenus principaux ===== */
  /* Centre les titres et paragraphes des sections, mais laisse les colonnes en texte gauche */
  .hero-content, .pca-card.centered, .section, .section .section-title, .section h3, .section h4, .section p { text-align: center; }

  /* Exceptions: garder lecture en colonnes alignée à gauche pour les contenus long texte */
  .two-col, .two-col > div, .about-grid, .about-grid > * { text-align: left; }

  /* Ajuste l'affichage de la marque pour être sur une seule ligne */
  .brand{display:flex;flex-direction:row;align-items:center}
  .site-title{white-space:nowrap}
  .tagline{white-space:nowrap}

  /* Sur mobile, centrer la marque */
  @media (max-width:900px){
    .brand{align-items:center}
    .site-title,.tagline{text-align:center}
  }

/* ===== FOOTER ===== */
.site-footer{background:#222;color:white;padding:2rem 1rem;text-align:center;border-top:1px solid #444}
.site-footer a{color:white;text-shadow:none}
.site-footer h3,.site-footer h4,.site-footer h5,.site-footer h6,.site-footer p{color:white;text-shadow:none}

/* ===== BUTTONS ===== */
.btn,.btn-primary{background:var(--accent);color:white;padding:0.75rem 1.5rem;border-radius:var(--border-radius);border:none;font-weight:600;transition:all .2s;box-shadow:0 2px 8px rgba(43,138,62,0.2);font-size:1rem;cursor:pointer;display:inline-block;text-align:center}
.btn:hover,.btn-primary:hover{background:#1e6b30;transform:translateY(-2px);box-shadow:0 4px 12px rgba(43,138,62,0.3)}

.btn-newsletter{background:var(--accent);color:white;border:none;border-radius:6px;padding:0.75rem 1rem;font-weight:600;font-size:0.9rem;cursor:pointer;transition:all .2s;width:100%}
.btn-newsletter:hover{background:#1e6b30}

/* ===== ACCORDIONS ===== */
.accordion-item h3{color:var(--text-dark);cursor:pointer;padding:1rem;background:#f0f0f0;border-radius:4px;margin:0.5rem 0;font-size:1.1rem;font-weight:600}
.accordion-item h3:hover{background:#e0e0e0}
.accordion-item ul{color:var(--text-dark);background:white;border:1px solid #ddd;border-radius:0 0 4px 4px}
.accordion-item ul li{padding:0.75rem 1rem;border-bottom:1px solid #eee}
.accordion-item ul li:last-child{border-bottom:none}

/* ===== TESTIMONIALS ===== */
.testimonial{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.08);transition:all .3s;border:1px solid #eee}
.testimonial:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,0.12)}
.testimonial-text{font-style:italic;color:var(--text-light);margin:1rem 0}
.testimonial-author{font-weight:700;color:var(--accent);margin-top:0.5rem}

/* ===== STATS ===== */
.stat{background:white;padding:1.5rem;border-radius:8px;text-align:center;box-shadow:0 4px 12px rgba(0,0,0,0.06)}
.stat-number{font-size:2.5rem;font-weight:700;color:var(--accent-red) !important;margin:0;display:block}
.stat-label{font-size:0.95rem;color:var(--text-light);margin:0.5rem 0 0;font-weight:600}

/* ===== DOCUMENTS/LISTS ===== */
.documents-list{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.06)}
.documents-list h3{color:var(--accent);margin:1rem 0 0.5rem;font-size:1.1rem}
.documents-list ul{list-style:none;margin:0.5rem 0 0}
.documents-list li{padding:0.5rem 0;color:var(--text-dark);border-bottom:1px solid #f0f0f0}
.documents-list li:last-child{border-bottom:none}

/* ===== COURSES GRID ===== */
.courses-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:1.5rem;justify-items:center;align-items:start;}
.course-card{background:white;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,0.08);transition:all .3s}
.course-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,0.12)}
.course-card h3,.course-card h4,.course-card h5{color:var(--accent);margin:0.5rem 0}
.course-card p{color:var(--text-light);font-size:0.95rem}
.course-card-content{padding:1rem}

/* ===== FILTERS ===== */
.filter-buttons{display:flex;gap:0.5rem;flex-wrap:wrap;margin:1rem 0;justify-content:center}
.filter-btn{background:#f0f0f0;color:var(--text-dark);border:1px solid #ddd;padding:0.5rem 1rem;border-radius:20px;cursor:pointer;font-weight:600;transition:all .2s}
.filter-btn:hover,.filter-btn.active{background:var(--accent);color:white;border-color:var(--accent)}

/* ===== MODAL ===== */
.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal-content{background:white;border-radius:8px;padding:2rem;max-width:500px;width:90%;position:relative;box-shadow:0 10px 40px rgba(0,0,0,0.3)}
.modal-content h2,.modal-content h3,.modal-content h4,.modal-content h5{color:var(--accent);margin-bottom:1rem}
.modal-content form input,.modal-content form textarea{width:100%;padding:0.75rem;margin:0.5rem 0 1rem;border:1px solid #ddd;border-radius:4px;font-family:inherit;color:var(--text-dark)}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-dark)}

/* ===== SEARCH INPUT ===== */
.search-input{padding:0.75rem 1rem;border:1px solid #ddd;border-radius:4px;width:100%;max-width:300px;font-size:1rem;font-family:inherit;color:var(--text-dark)}
.search-input::placeholder{color:var(--muted)}

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .courses-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
}

@media (max-width:600px){
  .courses-grid{grid-template-columns:1fr}
  .filter-buttons{justify-content:flex-start}
  .modal-content{max-width:90%;padding:1rem}
}

/* ===== ANIMATIONS ===== */
@keyframes fadeIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:none}
}

.reveal{opacity:0;transform:translateY(12px);transition:opacity .6s ease,transform .6s ease}
.reveal.in-view{opacity:1;transform:none}

/* ===== UTILITIES ===== */
.text-center{text-align:center}
.text-right{text-align:right}
.mt-2{margin-top:1rem}
.mb-2{margin-bottom:1rem}
.text-muted{color:var(--muted)}
.text-accent{color:var(--accent)}

/* ===== SCOLARITE PAGE ADDITIONS ===== */
.scolarite-hero{padding:3rem 0}
.card h4{font-size:1.05rem;margin-bottom:0.5rem}
.two-col aside .card{position:sticky;top:1rem}
.accordion-item h3{display:flex;justify-content:space-between;align-items:center}
.accordion-item h3::after{content:'+';font-weight:700}
.accordion-item ul{padding:0.75rem 1rem}

@media (max-width:900px){
  .two-col{grid-template-columns:1fr !important}
  .two-col aside{order:-1}
}

/* ===== SERVICES PAGE STYLES ===== */

/* Hero Section */
.services-hero{
  padding:4rem 0;
  background:linear-gradient(135deg, rgba(43,138,62,0.8) 0%, rgba(198,40,40,0.6) 100%), url('1.jpg') center/cover;
  color:white;
  text-align:center;
  position:relative;
}

.services-hero h1{
  font-size:3rem;
  margin-bottom:1rem;
  color:white;
  text-shadow:2px 2px 4px rgba(0,0,0,0.5);
}

.services-hero .lead{
  font-size:1.2rem;
  color:white;
  max-width:600px;
  margin:0 auto;
  text-shadow:1px 1px 3px rgba(0,0,0,0.3);
}

/* Services Menu Navigation */
.services-nav-container{
  background:#f7f9fb;
  padding:2rem 0;
  border-bottom:3px solid var(--accent);
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
}

.services-menu{
  display:flex;
  gap:1.5rem;
  justify-content:center;
  flex-wrap:wrap;
}

.service-btn{
  background:white;
  border:2px solid #ddd;
  padding:1rem 1.5rem;
  border-radius:8px;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0.5rem;
  transition:all .3s ease;
  font-size:0.95rem;
  font-weight:600;
  color:var(--text-dark);
  min-width:200px;
  position:relative;
}

.service-btn:hover{
  border-color:var(--accent);
  transform:translateY(-3px);
  box-shadow:0 6px 16px rgba(43,138,62,0.15);
}

.service-btn.active{
  background:var(--accent);
  color:white;
  border-color:var(--accent);
  box-shadow:0 6px 20px rgba(43,138,62,0.3);
}

.service-btn .icon{
  font-size:1.8rem;
  display:block;
}

.service-btn .label{
  font-size:0.9rem;
  text-align:center;
}

@media (max-width:900px){
  .services-menu{
    gap:1rem;
    padding:0 1rem;
  }
  .service-btn{
    min-width:160px;
    padding:0.75rem 1rem;
    font-size:0.85rem;
  }
  .service-btn .icon{
    font-size:1.5rem;
  }
}

/* Service Content Sections */
.service-content{
  display:none;
  padding:3rem 0;
  animation:fadeIn .3s ease;
  scroll-margin-top:110px;
}

.service-content.active{
  display:block;
}

@keyframes fadeIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:none}
}

/* Intro Card */
.card-section{
  margin-bottom:3rem;
}

.intro-card{
  background:white;
  padding:2rem;
  border-radius:12px;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  border-left:5px solid var(--accent);
}

.intro-card h2{
  color:var(--accent);
  margin-bottom:1rem;
  font-size:2rem;
}

.intro-text{
  font-size:1.05rem;
  line-height:1.8;
  color:var(--text-dark);
  margin-bottom:1.5rem;
}

.highlight-box{
  background:rgba(43,138,62,0.08);
  border-left:4px solid var(--accent);
  padding:1rem;
  border-radius:6px;
  margin-top:1rem;
}

.highlight-box.highlight-info{
  background:rgba(59,130,246,0.08);
  border-left-color:#3b82f6;
}

.highlight-box.highlight-success{
  background:rgba(34,197,94,0.08);
  border-left-color:#22c55e;
}

/* Formation Categories Grid */
.formation-grid{
  margin:3rem 0;
}

.formation-grid .section-title{
  text-align:center;
  color:var(--accent);
  margin-bottom:2rem;
  font-size:1.8rem;
}

.formation-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:2rem;
  margin-top:2rem;
}

.category-card{
  background:white;
  padding:2rem;
  border-radius:10px;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  transition:all .3s ease;
  border-top:4px solid var(--accent);
}

.category-card:hover{
  transform:translateY(-6px);
  box-shadow:0 8px 24px rgba(0,0,0,0.12);
}

.category-icon{
  font-size:2.5rem;
  margin-bottom:1rem;
  display:block;
}

.category-card h4{
  color:var(--accent);
  margin:1rem 0;
  font-size:1.2rem;
}

.formation-list{
  list-style:none;
  padding:0;
}

.formation-list li{
  padding:0.75rem 0 0.75rem 1.5rem;
  position:relative;
  color:var(--text-dark);
  border-bottom:1px solid #f0f0f0;
}

.formation-list li:before{
  content:'✓';
  position:absolute;
  left:0;
  color:var(--accent);
  font-weight:700;
}

.formation-list li:last-child{
  border-bottom:none;
}

/* Courses Section */
.courses-section{
  margin:3rem 0;
}

.courses-section .section-title{
  text-align:center;
  color:var(--accent);
  margin-bottom:2rem;
  font-size:1.8rem;
}

.courses-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
  gap:2rem;
  margin-top:2rem;
}

.course-card{
  background:white;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  transition:all .3s ease;
  display:flex;
  flex-direction:column;
  position:relative;
}

.course-card:hover{
  transform:translateY(-8px);
  box-shadow:0 12px 28px rgba(0,0,0,0.15);
}

.course-card h4{
  color:var(--accent);
  margin:1rem 0;
  font-size:1.15rem;
}

.course-badge{
  position:absolute;
  top:1rem;
  right:1rem;
  background:var(--accent-red);
  color:white;
  padding:0.4rem 0.8rem;
  border-radius:20px;
  font-size:0.8rem;
  font-weight:700;
}

.course-card-content{
  padding:1.5rem;
  flex:1;
  display:flex;
  flex-direction:column;
}

.course-description{
  color:var(--text-light);
  font-size:0.95rem;
  margin:0.5rem 0 1rem;
  flex:1;
}

.course-details{
  display:flex;
  flex-direction:column;
  gap:0.5rem;
  margin:1rem 0;
  background:#f7f9fb;
  padding:1rem;
  border-radius:6px;
}

.detail{
  font-size:0.9rem;
  color:var(--text-dark);
}

.detail strong{
  color:var(--accent);
}

.btn-request{
  background:var(--accent);
  color:white;
  border:none;
  padding:0.75rem 1.5rem;
  border-radius:6px;
  cursor:pointer;
  font-weight:600;
  transition:all .2s ease;
  margin-top:auto;
  width:100%;
}

.btn-request:hover{
  background:#1e6b30;
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(43,138,62,0.3);
}

/* Dispensaire Cards */
.dispensaire-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:2rem;
  margin:2rem 0;
}

.dispensaire-grid .section-title{
  grid-column:1 / -1;
  text-align:center;
  color:var(--accent);
  margin-bottom:1rem;
  font-size:1.8rem;
}

.service-card{
  background:white;
  padding:2rem;
  border-radius:10px;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  transition:all .3s ease;
  border-top:4px solid var(--accent);
  text-align:center;
}

.service-card:hover{
  transform:translateY(-6px);
  box-shadow:0 8px 24px rgba(0,0,0,0.12);
}

.service-icon{
  font-size:3rem;
  margin-bottom:1rem;
  display:block;
}

.service-card h4{
  color:var(--accent);
  margin:0.5rem 0;
  font-size:1.2rem;
}

.service-card p{
  color:var(--text-light);
  margin:0.5rem 0 1rem;
}

.service-card ul{
  list-style:none;
  text-align:left;
  padding:0;
}

.service-card li{
  padding:0.5rem 0;
  color:var(--text-dark);
  position:relative;
  padding-left:1.5rem;
}

.service-card li:before{
  content:'◆';
  position:absolute;
  left:0;
  color:var(--accent);
}

/* Gallery */
.dispensaire-gallery{
  margin:3rem 0;
}

.dispensaire-gallery .section-title{
  text-align:center;
  color:var(--accent);
  margin-bottom:2rem;
  font-size:1.8rem;
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(250px, 1fr));
  gap:1.5rem;
  margin-top:2rem;
}

.gallery-item{
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
  transition:all .3s ease;
  cursor:pointer;
}

.gallery-item:hover{
  transform:scale(1.05);
  box-shadow:0 8px 20px rgba(0,0,0,0.15);
}

.gallery-item img{
  width:100%;
  height:250px;
  object-fit:cover;
  display:block;
}

.gallery-item p{
  padding:1rem;
  background:white;
  margin:0;
  color:var(--text-dark);
  font-weight:600;
  text-align:center;
}

/* Location Cards */
.location-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(350px, 1fr));
  gap:2rem;
  margin:2rem 0;
}

.location-grid .section-title{
  grid-column:1 / -1;
  text-align:center;
  color:var(--accent);
  margin-bottom:1rem;
  font-size:1.8rem;
}

.hall-card{
  background:white;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  transition:all .3s ease;
  border-top:4px solid var(--accent);
}

.hall-card.featured{
  border-top:5px solid var(--accent-red);
  box-shadow:0 8px 24px rgba(198,40,40,0.15);
}

.hall-card:hover{
  transform:translateY(-6px);
  box-shadow:0 8px 24px rgba(0,0,0,0.12);
}

.hall-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  padding:1.5rem;
  border-bottom:2px solid #f0f0f0;
}

.hall-header h4{
  color:var(--accent);
  margin:0;
  flex:1;
}

.capacity-badge{
  background:var(--accent);
  color:white;
  padding:0.5rem 1rem;
  border-radius:20px;
  font-size:0.85rem;
  font-weight:700;
  white-space:nowrap;
}

.hall-image{
  width:100%;
  height:250px;
  overflow:hidden;
}

.hall-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .3s ease;
}

.hall-card:hover .hall-image img{
  transform:scale(1.05);
}

.hall-content{
  padding:1.5rem;
}

.hall-content p{
  color:var(--text-light);
  margin:0 0 1rem;
}

.hall-content h5{
  color:var(--accent);
  margin:1rem 0 0.5rem;
  font-size:1rem;
}

.amenities-list{
  list-style:none;
  padding:0;
}

.amenities-list li{
  padding:0.4rem 0 0.4rem 1.5rem;
  color:var(--text-dark);
  position:relative;
  font-size:0.95rem;
}

.amenities-list li:before{
  content:'';
  position:absolute;
  left:0;
  color:var(--accent);
}

.hall-info{
  display:flex;
  flex-direction:column;
  gap:0.5rem;
  padding:1rem 1.5rem;
  background:#f7f9fb;
  border-top:2px solid #e8e8e8;
}

.info-item{
  font-size:0.9rem;
  color:var(--text-dark);
}

.info-item strong{
  color:var(--accent);
}

/* Additional Services */
.additional-services{
  margin:3rem 0;
}

.additional-services .section-title{
  text-align:center;
  color:var(--accent);
  margin-bottom:2rem;
  font-size:1.8rem;
}

.services-feature-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:2rem;
}

.feature{
  background:white;
  padding:2rem;
  border-radius:10px;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  text-align:center;
  transition:all .3s ease;
  border:2px solid transparent;
}

.feature:hover{
  border-color:var(--accent);
  transform:translateY(-4px);
  box-shadow:0 8px 20px rgba(0,0,0,0.12);
}

.feature-icon{
  font-size:2.5rem;
  margin-bottom:1rem;
  display:block;
}

.feature h5{
  color:var(--accent);
  margin:0.5rem 0;
  font-size:1.1rem;
}

.feature p{
  color:var(--text-light);
  font-size:0.9rem;
}

/* Pricing Table */
.pricing-section{
  margin:3rem 0;
}

.pricing-section .section-title{
  text-align:center;
  color:var(--accent);
  margin-bottom:2rem;
  font-size:1.8rem;
}

.pricing-table{
  overflow-x:auto;
}

.pricing-table table{
  width:100%;
  border-collapse:collapse;
  background:white;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
}

.pricing-table thead{
  background:var(--accent);
  color:white;
}

.pricing-table th{
  padding:1rem;
  text-align:left;
  font-weight:600;
  border-bottom:2px solid rgba(0,0,0,0.1);
}

.pricing-table td{
  padding:1rem;
  border-bottom:1px solid #f0f0f0;
  color:var(--text-dark);
}

.pricing-table tbody tr:hover{
  background:#f7f9fb;
}

.pricing-table tbody tr:last-child td{
  border-bottom:none;
}

.pricing-note{
  text-align:center;
  color:var(--text-light);
  margin-top:1rem;
  font-size:0.9rem;
}

/* CTA Sections */
.cta-section{
  background:white;
  border-radius:10px;
  padding:3rem;
  margin:3rem 0;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  border-left:5px solid var(--accent);
  text-align:center;
}

.cta-content h3{
  color:var(--accent);
  font-size:1.8rem;
  margin-bottom:1rem;
}

.cta-content p{
  color:var(--text-light);
  font-size:1.05rem;
  margin-bottom:2rem;
  max-width:600px;
  margin-left:auto;
  margin-right:auto;
}

.cta-buttons{
  display:flex;
  gap:1rem;
  justify-content:center;
  flex-wrap:wrap;
}

.btn-secondary{
  background:#e8e8e8;
  color:var(--text-dark);
  padding:0.75rem 1.5rem;
  border-radius:6px;
  font-weight:600;
  transition:all .2s ease;
  display:inline-block;
  border:2px solid #ddd;
}

.btn-secondary:hover{
  background:var(--accent);
  color:white;
  border-color:var(--accent);
  transform:translateY(-2px);
}

/* Modals */
.modal-overlay{
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,0.6);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:2000;
  opacity:0;
  visibility:hidden;
  transition:opacity .3s, visibility .3s;
}

.modal-overlay.open{
  opacity:1;
  visibility:visible;
}

.modal-content{
  background:white;
  border-radius:10px;
  padding:2rem;
  max-width:500px;
  width:90%;
  box-shadow:0 10px 40px rgba(0,0,0,0.3);
  position:relative;
  animation:slideUp .3s ease;
}

@keyframes slideUp{
  from{
    opacity:0;
    transform:translateY(30px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.modal-content h3{
  color:var(--accent);
  margin-bottom:1.5rem;
}

.modal-close{
  position:absolute;
  top:1rem;
  right:1rem;
  background:none;
  border:none;
  font-size:1.8rem;
  cursor:pointer;
  color:var(--text-light);
  transition:color .2s;
}

.modal-close:hover{
  color:var(--accent);
}

.form-group{
  margin-bottom:1rem;
}

.form-group label{
  display:block;
  margin-bottom:0.5rem;
  color:var(--text-dark);
  font-weight:600;
  font-size:0.95rem;
}

.form-group input,
.form-group textarea,
.form-group select{
  width:100%;
  padding:0.75rem;
  border:2px solid #ddd;
  border-radius:6px;
  font-family:inherit;
  color:var(--text-dark);
  transition:border-color .2s;
  font-size:0.95rem;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{
  outline:none;
  border-color:var(--accent);
  background:#f7f9fb;
}

.form-group textarea{
  resize:vertical;
  min-height:100px;
}

/* Notifications */
.notification{
  position:fixed;
  bottom:-100px;
  left:50%;
  transform:translateX(-50%);
  background:var(--accent);
  color:white;
  padding:1rem 1.5rem;
  border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,0.2);
  z-index:3000;
  transition:bottom .3s ease;
  max-width:90%;
  width:100%;
}

.notification.show{
  bottom:2rem;
}

.notification-content{
  display:flex;
  align-items:center;
  gap:1rem;
}

.notification-icon{
  font-size:1.5rem;
  font-weight:700;
}

.notification-text{
  flex:1;
}

@media (max-width:900px){
  .services-hero h1{
    font-size:2rem;
  }
  
  .services-hero .lead{
    font-size:1rem;
  }
  
  .courses-grid{
    grid-template-columns:1fr;
  }
  
  .dispensaire-grid{
    grid-template-columns:1fr;
  }
  
  .location-grid{
    grid-template-columns:1fr;
  }
  
  .gallery-grid{
    grid-template-columns:repeat(2, 1fr);
  }
  
  .cta-section{
    padding:2rem 1rem;
  }
  
  .cta-buttons{
    flex-direction:column;
  }
  
  .btn-primary,
  .btn-secondary{
    width:100%;
  }
  
  .modal-content{
    width:95%;
  }
  
  .pricing-table{
    font-size:0.85rem;
  }
  
  .pricing-table th,
  .pricing-table td{
    padding:0.5rem;
  }
}

@media (max-width:600px){
  .services-menu{
    flex-direction:column;
  }
  
  .service-btn{
    min-width:100%;
  }
  
  .gallery-grid{
    grid-template-columns:1fr;
  }
  
  .notification{
    bottom:1rem;
    width:calc(100% - 2rem);
    left:1rem;
    transform:none;
  }
}

/* ===== FOOTER REDESIGN ===== */
.site-footer{
  background:var(--text-dark);
  color:white;
  padding:2.5rem 0 0.75rem;
  margin-top:4rem;
}

.footer-content{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
  max-width:1200px;
  margin:0 auto;
  padding:0 1rem 1.5rem;
  border-bottom:1px solid rgba(255,255,255,0.1);
}

.footer-section h3{
  color:white;
  margin-bottom:0.75rem;
  font-size:1rem;
  font-weight:700;
}

.footer-formation ul{
  list-style:none;
}

.footer-formation li{
  margin:0.5rem 0;
}

.footer-formation a{
  color:rgba(255,255,255,0.7);
  transition:color .2s;
}

.footer-formation a:hover{
  color:white;
}

.footer-contact p{
  margin:0.5rem 0;
  color:rgba(255,255,255,0.8);
  font-size:0.9rem;
}

.footer-contact strong{
  color:white;
  display:block;
  margin-bottom:0.25rem;
}

.footer-newsletter form{
  display:flex;
  flex-direction:column;
  gap:0.75rem;
}

.footer-newsletter input{
  padding:0.75rem;
  border:none;
  border-radius:6px;
  font-family:inherit;
  font-size:0.9rem;
}

.footer-newsletter input[type="email"]{
  background:rgba(255,255,255,0.95);
  color:var(--text-dark);
}

.footer-newsletter input[type="email"]::placeholder{
  color:#bbb;
}

.footer-newsletter button{
  background:var(--accent);
  color:white;
  padding:0.75rem;
  border:none;
  border-radius:6px;
  font-weight:600;
  cursor:pointer;
  transition:all .2s;
}

.footer-newsletter button:hover{
  background:#1e6b30;
  transform:translateY(-2px);
}

.footer-newsletter .newsletter-status{
  font-size:0.85rem;
  color:rgba(255,255,255,0.7);
  margin-top:0.5rem;
}

.footer-bottom{
  text-align:center;
  padding:1rem 0;
}

.footer-social{
  margin-bottom:1rem;
}

.footer-social a{
  display:inline-block;
  width:40px;
  height:40px;
  border-radius:50%;
  background:rgba(255,255,255,0.15);
  color:white;
  text-align:center;
  line-height:40px;
  text-decoration:none;
  transition:all .3s;
  font-size:1.3rem;
}

.footer-social a:hover{
  background:var(--accent);
  transform:scale(1.15);
}

.footer-copyright{
  color:rgba(255,255,255,0.7);
  font-size:0.9rem;
}

@media (max-width:900px){
  .footer-content{
    grid-template-columns:1fr;
    gap:2rem;
  }
  .footer-newsletter form{
    flex-direction:column;
  }
}

/* ===== GLOBAL RESPONSIVE ADDITIONS ===== */
@media (max-width:900px){
  .hero h1,.admission-hero h1,.formation-hero h1{font-size:1.8rem}
  .hero h2{font-size:1.2rem}
  .hero p,.admission-hero p,.formation-hero p{font-size:0.95rem}
  .section{padding:1.5rem 0}
  .container{padding:0 1rem}
}

@media (max-width:600px){
  .hero h1,.admission-hero h1,.formation-hero h1{font-size:1.4rem}
  .hero h2{font-size:1rem}
  .paired-grid{grid-template-columns:1fr}
  .form-card .row{grid-template-columns:1fr}
  .btn,.btn-primary{width:100%;text-align:center}
  .actions{flex-direction:column;align-items:stretch}
  h2{font-size:1.3rem}
  h3{font-size:1.1rem}
}

/* Contact page responsive */
.contact-grid{display:grid;grid-template-columns:1fr 380px;gap:2rem;align-items:start}
@media (max-width:960px){
  .contact-grid{grid-template-columns:1fr}
}

/* Scolarite two-col responsive */
@media (max-width:800px){
  .two-col[style*="360px"]{grid-template-columns:1fr !important}
}
