/* ================================================================
   THÈME : MÉDICAL ÉPURÉ — Production (v2, sélecteurs exacts)
   Basé sur l'analyse des vrais templates Twig.
   Police : "DM Serif Display" (titres) + "DM Sans" (corps)
================================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

/* ── VARIABLES ──────────────────────────────────────────────── */
:root {
  --navy:      #0A2540;
  --teal:      #00A99D;
  --teal-dk:   #007D74;
  --teal-lt:   #E6F7F6;
  --teal-lt2:  #F0FAFA;
  --gray-1:    #F8FAFB;
  --gray-2:    #EEF1F4;
  --gray-3:    #9CA3AF;
  --gray-4:    #6B7280;
  --white:     #FFFFFF;
  --star:      #F59E0B;
  --r-sm:      6px;
  --r-md:      12px;
  --r-lg:      20px;
  --sh-sm:     0 1px 4px rgba(10,37,64,.06);
  --sh-md:     0 4px 20px rgba(10,37,64,.10);
  --sh-lg:     0 12px 40px rgba(10,37,64,.14);
  --font-h:    'DM Serif Display', Georgia, serif;
  --font-b:    'DM Sans', system-ui, sans-serif;
  --tr:        all .2s ease;
}

/* ── BASE ───────────────────────────────────────────────────── */
body {
  font-family: var(--font-b) !important;
  font-size: 15px !important;
  color: var(--navy) !important;
  background: var(--gray-1) !important;
  -webkit-font-smoothing: antialiased;
}
.main-wrapper { background: var(--gray-1) !important; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-h); color: var(--navy); }
a { color: var(--teal) !important; transition: var(--tr); }
a:hover { color: var(--teal-dk) !important; }

/* ── HEADER ─────────────────────────────────────────────────── */
.header {
  background: var(--white) !important;
  border-bottom: 1px solid var(--gray-2) !important;
  box-shadow: var(--sh-sm) !important;
}

/* Logo texte */
.header .navbar-brand span {
  font-family: var(--font-h) !important;
  font-size: 1.25rem !important;
  color: var(--navy) !important;
  margin-left: 10px !important;
}

/* Nav principale (gauche) */
.header .main-nav { margin: 0 !important; }
.header .main-nav > li > a {
  font-family: var(--font-b) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--navy) !important;
  padding: 8px 14px !important;
  border-radius: var(--r-sm) !important;
  transition: var(--tr) !important;
}
.header .main-nav > li > a:hover { color: var(--teal) !important; }
.header .main-nav li.active > a { color: var(--teal) !important; }

/* Login link (dans main-nav) */
.header .main-nav .login-link a {
  color: var(--gray-4) !important;
  font-size: 13px !important;
}
.header .main-nav .login-link a:hover { color: var(--teal) !important; }

/* Contact (droite) */
.header .header-navbar-rht { gap: 12px !important; }
.header .contact-item { display: flex !important; align-items: center !important; gap: 10px !important; }
.header .header-contact-img {
  width: 38px !important; height: 38px !important;
  background: var(--teal-lt) !important;
  border-radius: 50% !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: var(--teal) !important;
  font-size: 16px !important;
}
.header .header-contact-detail .contact-header {
  font-size: 11px !important;
  color: var(--gray-3) !important;
  margin: 0 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.header .header-contact-detail .contact-info-header {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--navy) !important;
  margin: 0 !important;
}

/* Bouton SE CONNECTER */
.header-navbar-rht li a.header-login,
.header .header-login {
  background: var(--navy) !important;
  color: var(--white) !important;
  border: 2px solid var(--navy) !important;
  border-radius: 100px !important;
  padding: 8px 20px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  transition: var(--tr) !important;
  white-space: nowrap !important;
}
.header-navbar-rht li a.header-login:hover,
.header .header-login:hover {
  background: var(--teal) !important;
  border-color: var(--teal) !important;
  color: var(--white) !important;
  transform: translateY(-1px) !important;
}

/* Dropdown utilisateur connecté */
.header .dropdown-menu {
  border: 1px solid var(--gray-2) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--sh-md) !important;
  padding: 8px !important;
}
.header .dropdown-item {
  border-radius: var(--r-sm) !important;
  font-size: 14px !important;
  color: var(--navy) !important;
  padding: 8px 14px !important;
}
.header .dropdown-item:hover {
  background: var(--teal-lt2) !important;
  color: var(--teal) !important;
}
.header .user-header {
  padding: 8px 14px 12px !important;
  border-bottom: 1px solid var(--gray-2) !important;
  margin-bottom: 6px !important;
}
.header .user-header h6 { color: var(--navy) !important; font-weight: 700 !important; margin: 0 !important; }
/* Avatar initiales */
.header .bg-success-light {
  background: var(--teal-lt) !important;
  color: var(--teal-dk) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
}

/* ── BREADCRUMB BAR ─────────────────────────────────────────── */
.breadcrumb-bar {
  background: var(--white) !important;
  border-bottom: 1px solid var(--gray-2) !important;
  padding: 20px 0 24px !important;
}
.breadcrumb { background: transparent !important; padding: 0 !important; font-size: 13px !important; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--gray-3) !important; }
.breadcrumb-item a { color: var(--teal) !important; }
.breadcrumb-item.active { color: var(--gray-4) !important; }
.breadcrumb-bar h2,
.breadcrumb-bar h1 {
  font-family: var(--font-h) !important;
  font-size: clamp(1.4rem, 2.5vw, 2rem) !important;
  color: var(--navy) !important;
  margin-bottom: 4px !important;
}

/* ── HERO / SECTION SEARCH ──────────────────────────────────── */
.section.section-search {
  background: var(--navy) !important;
  padding: 80px 0 72px !important;
  position: relative !important;
  overflow: hidden !important;
}
.section.section-search::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(ellipse 60% 80% at 80% 50%, rgba(0,169,157,.18) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 20% 80%, rgba(0,169,157,.10) 0%, transparent 70%) !important;
  pointer-events: none !important;
}
.section.section-search .container-fluid { position: relative !important; }

/* Titre hero */
.section-search .banner-header h1 {
  font-family: var(--font-h) !important;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  color: var(--white) !important;
  margin-bottom: 14px !important;
  letter-spacing: -.01em !important;
}
.section-search .banner-header p {
  font-size: 17px !important;
  color: rgba(255,255,255,.72) !important;
  font-weight: 300 !important;
  margin-bottom: 36px !important;
}

/* Search box */
.section-search .search-box {
  background: var(--white) !important;
  border-radius: var(--r-lg) !important;
  padding: 16px !important;
  box-shadow: var(--sh-lg) !important;
  max-width: 820px !important;
  margin: 0 auto !important;
  display: flex !important;
  gap: 12px !important;
  align-items: flex-end !important;
}
.section-search .search-box .form-group {
  flex: 1 !important;
  margin-bottom: 0 !important;
  position: relative !important;
}
.section-search .search-box .form-text {
  display: block !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  color: var(--gray-3) !important;
  margin-bottom: 6px !important;
}
.section-search .search-box .form-control {
  height: 48px !important;
  border: 1.5px solid var(--gray-2) !important;
  border-radius: var(--r-md) !important;
  font-size: 14px !important;
  color: var(--navy) !important;
  background: var(--gray-1) !important;
  box-shadow: none !important;
  transition: var(--tr) !important;
  padding: 0 14px !important;
}
.section-search .search-box .form-control:focus {
  border-color: var(--teal) !important;
  background: var(--white) !important;
  box-shadow: 0 0 0 3px rgba(0,169,157,.15) !important;
  outline: none !important;
}
.section-search .search-box .form-control::placeholder { color: var(--gray-3) !important; }
.section-search .search-box > div { flex-shrink: 0 !important; }
.section-search .search-box > div span { display: block !important; height: 17px !important; } /* spacer label */

/* Bouton recherche */
.section-search .btn.search-btn,
.section-search .search-btn {
  height: 48px !important;
  background: var(--teal) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--r-md) !important;
  padding: 0 24px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
  transition: var(--tr) !important;
  box-shadow: none !important;
}
.section-search .btn.search-btn:hover,
.section-search .search-btn:hover {
  background: var(--teal-dk) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(0,169,157,.3) !important;
}

/* ── SECTION DOCTOR (homepage — slider) ─────────────────────── */
.section.section-doctor {
  background: var(--white) !important;
  padding: 64px 0 !important;
}
.section-doctor .section-header h2 {
  font-family: var(--font-h) !important;
  font-size: clamp(1.5rem, 2.5vw, 2rem) !important;
  color: var(--navy) !important;
}
.section-doctor .section-header p { color: var(--gray-4) !important; }
.section-doctor .about-content p { font-size: 15px !important; color: var(--gray-4) !important; line-height: 1.7 !important; }

/* Cards praticiens homepage */
.profile-widget {
  background: var(--white) !important;
  border-radius: var(--r-lg) !important;
  border: 1.5px solid var(--gray-2) !important;
  overflow: hidden !important;
  box-shadow: none !important;
  transition: var(--tr) !important;
  margin: 8px !important;
}
.profile-widget:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--sh-lg) !important;
  border-color: transparent !important;
}
.profile-widget .doc-img { overflow: hidden !important; background: var(--gray-1) !important; }
.profile-widget .doc-img img {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform .4s ease !important;
}
.profile-widget:hover .doc-img img { transform: scale(1.04) !important; }
/* Placeholder icône praticien */
.profile-widget .doc-img .square {
  height: 180px !important;
  background: var(--teal-lt) !important;
  color: var(--teal) !important;
}
.profile-widget .pro-content { padding: 18px !important; }
.profile-widget .title {
  font-family: var(--font-h) !important;
  font-size: 1.05rem !important;
  margin-bottom: 3px !important;
}
.profile-widget .title a { color: var(--navy) !important; }
.profile-widget .title a:hover { color: var(--teal) !important; }
.profile-widget .speciality {
  font-size: 13px !important;
  color: var(--teal) !important;
  font-weight: 500 !important;
  margin-bottom: 8px !important;
}
.profile-widget .available-info {
  list-style: none !important;
  padding: 0 !important;
  margin: 10px 0 14px !important;
}
.profile-widget .available-info li { font-size: 13px !important; color: var(--gray-4) !important; margin-bottom: 4px !important; }
.profile-widget .available-info i { color: var(--teal) !important; margin-right: 5px !important; }

/* Boutons homepage cards : "Profil" et "Rendez-vous" */
.profile-widget .view-btn {
  background: transparent !important;
  color: var(--navy) !important;
  border: 1.5px solid var(--gray-2) !important;
  border-radius: 100px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  padding: 7px 16px !important;
  transition: var(--tr) !important;
  text-align: center !important;
  display: block !important;
}
.profile-widget .view-btn:hover { border-color: var(--teal) !important; color: var(--teal) !important; }
.profile-widget .book-btn {
  background: var(--teal) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: 100px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  padding: 7px 16px !important;
  transition: var(--tr) !important;
  text-align: center !important;
  display: block !important;
}
.profile-widget .book-btn:hover {
  background: var(--teal-dk) !important;
  color: var(--white) !important;
}

/* Icône vérifié */
.profile-widget .verified { color: var(--teal) !important; font-size: .8em !important; }

/* ── RATING ─────────────────────────────────────────────────── */
.rating { display: flex !important; align-items: center !important; gap: 2px !important; margin: 6px 0 !important; }
.rating .fa-star { font-size: 12px !important; color: var(--gray-2) !important; }
.rating .fa-star.filled { color: var(--star) !important; }
.rating .fal.fa-star { font-size: 12px !important; color: var(--gray-2) !important; }
.rating .average-rating { font-size: 12px !important; color: var(--gray-3) !important; margin-left: 4px !important; }

/* ── SECTION FEATURES (recherches récentes) ─────────────────── */
.section.section-features {
  background: var(--gray-1) !important;
  padding: 64px 0 !important;
}
.section-features .section-header h2 {
  font-family: var(--font-h) !important;
  font-size: clamp(1.5rem, 2.5vw, 2rem) !important;
  color: var(--navy) !important;
}
.section-features .section-header p { font-size: 15px !important; color: var(--gray-4) !important; }
/* Tags "Médecin à Ville" */
.section-features .btn.btn-outline-primary {
  border: 1.5px solid var(--gray-2) !important;
  background: var(--white) !important;
  color: var(--navy) !important;
  border-radius: 100px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 7px 16px !important;
  transition: var(--tr) !important;
  box-shadow: none !important;
}
.section-features .btn.btn-outline-primary:hover {
  background: var(--teal-lt) !important;
  border-color: var(--teal) !important;
  color: var(--teal) !important;
  transform: translateY(-1px) !important;
}

/* ── CONTENU PAGES INTÉRIEURES ──────────────────────────────── */
.content {
  background: var(--gray-1) !important;
  padding: 32px 0 64px !important;
}

/* ── FILTRE LISTING ─────────────────────────────────────────── */
.card.search-filter {
  background: var(--white) !important;
  border: 1.5px solid var(--gray-2) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--sh-sm) !important;
}
.card.search-filter .card-header {
  background: transparent !important;
  border-bottom: 1px solid var(--gray-2) !important;
  padding: 14px 18px !important;
  border-radius: var(--r-md) var(--r-md) 0 0 !important;
}
.card.search-filter .card-title {
  font-family: var(--font-b) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
}
.card.search-filter .card-body { padding: 18px !important; }

.filter-widget { margin-bottom: 22px !important; }
.filter-widget:last-child { margin-bottom: 0 !important; }
.filter-widget h4 {
  font-family: var(--font-b) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .07em !important;
  color: var(--gray-3) !important;
  margin-bottom: 10px !important;
}

/* Checkboxes personnalisées */
.custom_check {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 8px !important;
  cursor: pointer !important;
  font-size: 14px !important;
  color: var(--navy) !important;
  user-select: none !important;
}
.custom_check input[type="checkbox"] { display: none !important; }
.custom_check .checkmark {
  width: 17px !important; height: 17px !important;
  border: 1.5px solid var(--gray-2) !important;
  border-radius: 4px !important;
  background: var(--white) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  transition: var(--tr) !important;
}
.custom_check input:checked ~ .checkmark {
  background: var(--teal) !important;
  border-color: var(--teal) !important;
}
.custom_check input:checked ~ .checkmark::after {
  content: '' !important;
  display: block !important;
  width: 5px !important; height: 9px !important;
  border: 2px solid #fff !important;
  border-top: none !important; border-left: none !important;
  transform: rotate(45deg) !important;
  margin-top: -2px !important;
}
.custom_check:hover .checkmark { border-color: var(--teal) !important; }

/* Lien "voir plus" spécialisations */
.show-more-specialist a {
  font-size: 13px !important;
  color: var(--teal) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}

/* ── CARDS LISTING PRATICIENS ───────────────────────────────── */
#all-doctors .card,
#doctor-listing .card {
  background: var(--white) !important;
  border: 1.5px solid var(--gray-2) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--sh-sm) !important;
  transition: var(--tr) !important;
  margin-bottom: 16px !important;
}
#all-doctors .card:hover,
#doctor-listing .card:hover {
  border-color: transparent !important;
  box-shadow: var(--sh-md) !important;
  transform: translateY(-2px) !important;
}
#all-doctors .card .card-body,
#doctor-listing .card .card-body { padding: 20px !important; }

/* Image praticien listing */
#all-doctors .card img.img-fluid,
#all-doctors .card .square.border {
  border-radius: var(--r-sm) !important;
  border: 2px solid var(--gray-2) !important;
  transition: var(--tr) !important;
}
#all-doctors .card:hover img.img-fluid { border-color: var(--teal) !important; }
#all-doctors .card .square {
  aspect-ratio: 1 !important;
  background: var(--teal-lt) !important;
  color: var(--teal) !important;
}

/* Nom */
.doc-name {
  font-family: var(--font-h) !important;
  font-size: 1.1rem !important;
  margin-bottom: 2px !important;
  color: var(--navy) !important;
}
.doc-name a { color: var(--navy) !important; }
.doc-name a:hover { color: var(--teal) !important; }

/* Sous-titre et spécialité */
.doc-speciality { font-size: 14px !important; color: var(--gray-4) !important; }
.doc-department {
  font-family: var(--font-b) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--teal) !important;
  margin-bottom: 4px !important;
}

/* Lieu cabinet */
.doc-location {
  font-size: 13px !important;
  color: var(--gray-4) !important;
}
.doc-location a.btn-outline-success {
  border-color: var(--teal) !important;
  color: var(--teal) !important;
  background: transparent !important;
  border-radius: 100px !important;
  font-size: 12px !important;
  padding: 3px 12px !important;
  font-weight: 500 !important;
  transition: var(--tr) !important;
}
.doc-location a.btn-outline-success:hover {
  background: var(--teal-lt) !important;
}

/* Badges spécialisations */
.clinic-services span {
  display: inline-block !important;
  background: var(--gray-1) !important;
  border: 1px solid var(--gray-2) !important;
  color: var(--gray-4) !important;
  border-radius: 100px !important;
  padding: 3px 12px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  margin: 2px !important;
  transition: var(--tr) !important;
}
.clinic-services span.bg-primary-light {
  background: var(--teal-lt) !important;
  border-color: var(--teal-lt) !important;
  color: var(--teal-dk) !important;
}

/* Infos (feedback, localisation) */
.clini-infos ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 12px !important;
}
.clini-infos li {
  font-size: 13px !important;
  color: var(--gray-4) !important;
  margin-bottom: 4px !important;
}
.clini-infos i { color: var(--teal) !important; margin-right: 5px !important; width: 14px !important; }

/* Zone disponibilité / booking dans listing */
.clinic-booking { }
.clinic-booking span.border {
  border-color: var(--teal) !important;
  border-radius: var(--r-sm) !important;
  background: var(--teal-lt2) !important;
  font-size: 13px !important;
  color: var(--gray-4) !important;
  padding: 10px 14px !important;
}
.clinic-booking .text-info,
.clinic-booking b.text-info {
  color: var(--teal-dk) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}
/* Bouton voir profil */
.view-pro-btn {
  display: block !important;
  border: 1.5px solid var(--gray-2) !important;
  background: transparent !important;
  color: var(--navy) !important;
  border-radius: var(--r-sm) !important;
  padding: 9px 14px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-align: center !important;
  transition: var(--tr) !important;
}
.view-pro-btn:hover { border-color: var(--teal) !important; color: var(--teal) !important; }

/* Bouton prendre rendez-vous listing */
.apt-btn {
  display: block !important;
  background: var(--teal) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-align: center !important;
  line-height: 1.3 !important;
  transition: var(--tr) !important;
}
.apt-btn:hover {
  background: var(--teal-dk) !important;
  color: var(--white) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(0,169,157,.3) !important;
}

/* Numéro INAMI */
#all-doctors .text-muted { font-size: 12px !important; color: var(--gray-3) !important; }
#all-doctors .fa-shield-check.text-success { color: var(--teal) !important; }

/* Card SEO texte (en haut du listing) */
#doctor-listing > article.card {
  margin-bottom: 20px !important;
  border-color: var(--gray-2) !important;
}
#doctor-listing > article.card .card-header {
  background: transparent !important;
  border-bottom: 1px solid var(--gray-2) !important;
}
#doctor-listing > article.card .card-title { color: var(--navy) !important; }
#doctor-listing > article.card p { color: var(--gray-4) !important; font-size: 15px !important; line-height: 1.7 !important; }

/* ── BOUTONS GÉNÉRAUX ───────────────────────────────────────── */
.btn-primary {
  background: var(--teal) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--r-sm) !important;
  font-weight: 600 !important;
  transition: var(--tr) !important;
  box-shadow: none !important;
}
.btn-primary:hover {
  background: var(--teal-dk) !important;
  color: var(--white) !important;
  box-shadow: 0 4px 12px rgba(0,169,157,.3) !important;
}

/* ── FOOTER ─────────────────────────────────────────────────── */
.footer { background: var(--navy) !important; }
.footer .footer-top { padding: 56px 0 !important; }

/* Titre widget footer (c'est un h2.footer-title) */
.footer .footer-title {
  font-family: var(--font-b) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .09em !important;
  color: var(--white) !important;
  margin-bottom: 18px !important;
}

.footer .footer-about-content p { color: rgba(255,255,255,.65) !important; font-size: 14px !important; }

/* Logo footer */
.footer .footer-logo span { color: var(--white) !important; }

/* Liens footer */
.footer .footer-menu ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.footer .footer-menu ul li { margin-bottom: 10px !important; }
.footer .footer-menu a,
.footer .footer-contact-info p,
.footer .footer-contact-info a {
  color: rgba(255,255,255,.65) !important;
  font-size: 14px !important;
  transition: var(--tr) !important;
  text-decoration: none !important;
}
.footer .footer-menu a:hover,
.footer .footer-contact-info a:hover { color: var(--teal) !important; padding-left: 2px !important; }
/* Icône >> avant les liens */
.footer .footer-menu .fa-angle-double-right { margin-right: 6px !important; color: var(--teal) !important; font-size: 12px !important; }

/* Icônes contact footer */
.footer .footer-contact-info .fa-envelope { color: var(--teal) !important; margin-right: 8px !important; }

/* Icônes sociales */
.footer .social-icon ul { list-style: none !important; padding: 0 !important; display: flex !important; gap: 8px !important; margin-top: 16px !important; }
.footer .social-icon a {
  display: inline-flex !important;
  align-items: center !important; justify-content: center !important;
  width: 36px !important; height: 36px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.1) !important;
  color: rgba(255,255,255,.75) !important;
  font-size: 14px !important;
  transition: var(--tr) !important;
  text-decoration: none !important;
}
.footer .social-icon a:hover { background: var(--teal) !important; color: var(--white) !important; }

/* Footer bottom */
.footer .footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1) !important;
  padding: 20px 0 !important;
}
/* Supprime le 2e border-top hérité de style.css sur .copyright */
.footer .footer-bottom .copyright {
  border-top: none !important;
  padding: 0 !important;
}
.footer .policy-menu {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  gap: 20px !important;
  justify-content: flex-end !important;
}
.footer .policy-menu a { color: rgba(255,255,255,.45) !important; font-size: 13px !important; }
.footer .policy-menu a:hover { color: var(--teal) !important; }

/* ── ALERTES ────────────────────────────────────────────────── */
.bg-success-light {
  background: var(--teal-lt) !important;
  color: var(--teal-dk) !important;
}

/* ================================================================
   PROFIL PRATICIEN
================================================================ */

/* Carte englobante des onglets */
.content > .container > .card {
  border: 1.5px solid var(--gray-2) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--sh-sm) !important;
  background: var(--white) !important;
  margin-top: 20px !important;
}
.content > .container > .card > .card-body {
  padding: 0 !important;
}

/* ── ONGLETS ────────────────────────────────────────────────── */
nav.user-tabs {
  border-bottom: 2px solid var(--gray-2) !important;
  margin-bottom: 0 !important;
  padding: 0 24px !important;
}
nav.user-tabs .nav-tabs {
  border-bottom: none !important;
  gap: 0 !important;
}
nav.user-tabs .nav-tabs .nav-item .nav-link {
  border: none !important;
  border-bottom: 3px solid transparent !important;
  border-radius: 0 !important;
  color: var(--gray-4) !important;
  font-family: var(--font-b) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 16px 20px !important;
  margin-bottom: -2px !important;
  background: transparent !important;
  transition: var(--tr) !important;
  letter-spacing: .01em !important;
}
nav.user-tabs .nav-tabs .nav-item .nav-link:hover {
  color: var(--navy) !important;
  background: transparent !important;
}
nav.user-tabs .nav-tabs .nav-item .nav-link.active {
  color: var(--teal) !important;
  border-bottom-color: var(--teal) !important;
  background: transparent !important;
}

/* Contenu des onglets */
.tab-content { padding: 28px 24px !important; }

/* ── TITRE DE WIDGET ────────────────────────────────────────── */
.widget .widget-title,
h4.widget-title {
  font-family: var(--font-h) !important;
  font-size: 1.15rem !important;
  color: var(--navy) !important;
  margin-bottom: 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--gray-2) !important;
  font-weight: 400 !important;
}

/* Espacement entre widgets */
.widget { margin-bottom: 32px !important; }
.widget:last-child { margin-bottom: 0 !important; }

/* ── À PROPOS ───────────────────────────────────────────────── */
.about-widget p {
  font-size: 15px !important;
  color: var(--gray-4) !important;
  line-height: 1.75 !important;
}

/* ── TIMELINE (formations & expériences) ────────────────────── */
.experience-box { position: relative !important; }

/* Ligne verticale */
.experience-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  position: relative !important;
}
.experience-list::before {
  content: '' !important;
  position: absolute !important;
  left: 5px !important;
  top: 6px !important;
  bottom: 6px !important;
  width: 2px !important;
  background: var(--gray-2) !important;
}

.experience-list li {
  display: flex !important;
  gap: 18px !important;
  margin-bottom: 24px !important;
  position: relative !important;
}
.experience-list li:last-child { margin-bottom: 0 !important; }

/* Point sur la timeline */
.experience-user { flex-shrink: 0 !important; padding-top: 2px !important; }
.before-circle {
  width: 12px !important;
  height: 12px !important;
  border-radius: 50% !important;
  background: var(--teal) !important;
  border: 2px solid var(--white) !important;
  box-shadow: 0 0 0 2px var(--teal) !important;
  position: relative !important;
  z-index: 1 !important;
}

/* Contenu timeline */
.experience-content { flex: 1 !important; }
.timeline-content {
  background: var(--gray-1) !important;
  border: 1px solid var(--gray-2) !important;
  border-radius: var(--r-md) !important;
  padding: 14px 16px !important;
}
.timeline-content .name {
  display: block !important;
  font-family: var(--font-b) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--navy) !important;
  margin-bottom: 4px !important;
}
.timeline-content .time {
  display: block !important;
  font-size: 13px !important;
  color: var(--gray-3) !important;
}

/* ── LISTE PRESTATIONS ──────────────────────────────────────── */
.service-list { margin-bottom: 32px !important; }
.service-list h4 {
  font-family: var(--font-h) !important;
  font-size: 1.15rem !important;
  color: var(--navy) !important;
  margin-bottom: 14px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--gray-2) !important;
  font-weight: 400 !important;
}
.service-list ul.clearfix {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
.service-list ul.clearfix li {
  background: var(--teal-lt) !important;
  color: var(--teal-dk) !important;
  border-radius: 100px !important;
  padding: 6px 16px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  border: 1px solid rgba(0,169,157,.15) !important;
  float: none !important;
  position: static !important;
  width: auto !important;
}
.service-list ul.clearfix li::before {
  content: none !important;
  display: none !important;
}

/* ── CARTE MAP ──────────────────────────────────────────────── */
#map {
  height: 340px !important;
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  border: 1px solid var(--gray-2) !important;
}

/* ── AVIS PATIENTS ──────────────────────────────────────────── */
.review-listing { }

/* Liste des avis (chargée via HTMX) */
ul.comments-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 32px !important;
}
ul.comments-list li {
  padding: 18px 0 !important;
  border-bottom: 1px solid var(--gray-2) !important;
}
ul.comments-list li:first-child { padding-top: 0 !important; }
ul.comments-list li:last-child { border-bottom: none !important; }

/* Étoiles dans les avis */
.star-rating { display: flex !important; gap: 3px !important; margin-bottom: 8px !important; }
.star-rating input[type="radio"] { display: none !important; }
.star-rating label { cursor: pointer !important; font-size: 0 !important; }
.star-rating label i {
  font-size: 20px !important;
  color: var(--gray-2) !important;
  transition: var(--tr) !important;
}
.star-rating label:has(i.active) i { color: var(--star) !important; }
/* Comportement interactif */
.star-rating:hover label i { color: var(--star) !important; }
.star-rating label:hover ~ label i { color: var(--gray-2) !important; }
.star-rating input:checked ~ label i { color: var(--gray-2) !important; }
.star-rating input:checked + label i,
.star-rating input:checked + label ~ label i { color: var(--star) !important; }

/* ── FORMULAIRE AVIS ────────────────────────────────────────── */
.write-review {
  border-top: 2px solid var(--gray-2) !important;
  padding-top: 28px !important;
  margin-top: 28px !important;
}
.write-review > h4 {
  font-family: var(--font-h) !important;
  font-size: 1.15rem !important;
  color: var(--navy) !important;
  margin-bottom: 20px !important;
  font-weight: 400 !important;
}
.write-review > h4 strong { font-weight: 700 !important; color: var(--teal-dk) !important; }

/* Champs du formulaire */
.write-review .form-group { margin-bottom: 18px !important; }
.write-review label {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--navy) !important;
  margin-bottom: 6px !important;
  display: block !important;
  letter-spacing: .01em !important;
}
.write-review .form-control {
  border: 1.5px solid var(--gray-2) !important;
  border-radius: var(--r-sm) !important;
  font-size: 14px !important;
  color: var(--navy) !important;
  background: var(--white) !important;
  height: 44px !important;
  box-shadow: none !important;
  transition: var(--tr) !important;
}
.write-review textarea.form-control {
  height: auto !important;
  min-height: 110px !important;
  resize: vertical !important;
  padding: 10px 14px !important;
}
.write-review .form-control:focus {
  border-color: var(--teal) !important;
  box-shadow: 0 0 0 3px rgba(0,169,157,.12) !important;
  outline: none !important;
}
.write-review .form-control::placeholder { color: var(--gray-3) !important; }

/* Compteur de caractères */
.write-review .text-muted { color: var(--gray-3) !important; font-size: 13px !important; }

/* Checkbox CGU */
.write-review .terms-accept { margin: 4px 0 !important; }
.write-review .custom-checkbox {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.write-review .custom-checkbox input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  accent-color: var(--teal) !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
}
.write-review .custom-checkbox label {
  font-size: 14px !important;
  font-weight: 400 !important;
  color: var(--gray-4) !important;
  cursor: pointer !important;
  margin: 0 !important;
}
.write-review .custom-checkbox a { color: var(--teal) !important; font-weight: 600 !important; }

/* Bouton soumettre l'avis */
.write-review .submit-section { margin-top: 20px !important; }
.write-review .btn.submit-btn {
  background: var(--navy) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--r-sm) !important;
  padding: 11px 28px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: .01em !important;
  transition: var(--tr) !important;
}
.write-review .btn.submit-btn:hover {
  background: var(--teal) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 14px rgba(0,169,157,.3) !important;
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 991px) {
  .section.section-search { padding: 52px 0 48px !important; }
  .section.section-search .search-box { flex-wrap: wrap !important; }
  .content { padding: 20px 0 40px !important; }
  .section.section-doctor,
  .section.section-features { padding: 40px 0 !important; }
  nav.user-tabs { padding: 0 14px !important; }
  .tab-content { padding: 20px 14px !important; }
}

@media (max-width: 767px) {
  nav.user-tabs .nav-tabs .nav-item .nav-link {
    padding: 12px 10px !important;
    font-size: 13px !important;
  }
}
