/* ============================================================
   ALLO SANTÉ — Feuille de styles globale
   WinoSoft © 2025
   ============================================================ */

:root {
  --blue:    #1d6fa4;
  --blue-dk: #155e8a;
  --blue-lt: #e8f4fc;
  --ink:     #0d1b2a;
  --ink2:    #1e3a5f;
  --sky:     #38bdf8;
  --mint:    #10b981;
  --mint-lt: #ecfdf5;
  --rose:    #f43f5e;
  --amber:   #f59e0b;
  --violet:  #7c3aed;
  --gbg:     #f4f7fb;
  --gbd:     #dde4ee;
  --muted:   #64748b;
  --r:       16px;
  --rsm:     10px;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body { font-family: 'Outfit', sans-serif; color: var(--ink); background: #fff; overflow-x: hidden; }
img  { max-width: 100%; height: auto; }
a    { color: var(--blue); }

/* ── Topbar ── */
.topbar { background: var(--blue); padding: .5rem 0; font-size: .88rem; color: rgba(255,255,255,.8); }
.topbar a { color: rgba(255,255,255,.8); text-decoration: none; transition: color .18s; }
.topbar a:hover { color: #fff; }

/* ── Navbar ── */
.navbar { background: #fff; border-bottom: 1px solid var(--gbd); padding: .9rem 0; position: sticky; top: 0; z-index: 1000; box-shadow: 0 2px 16px rgba(0,0,0,.06); }
.nav-link { font-size: .96rem; font-weight: 500; color: var(--muted) !important; padding: .45rem .8rem !important; border-radius: 8px; transition: all .18s; }
.nav-link:hover, .nav-link.active { color: var(--ink) !important; background: var(--gbg); }
.btn-nav-rdv  { background: var(--blue); color: #fff !important; border-radius: 50px; padding: .5rem 1.2rem !important; font-weight: 600; font-size: .93rem; transition: background .18s; }
.btn-nav-rdv:hover { background: var(--blue-dk) !important; }
.btn-nav-pro  { border: 1.5px solid var(--blue); color: var(--blue) !important; border-radius: 50px; padding: .45rem 1.1rem !important; font-size: .93rem; font-weight: 600; transition: all .18s; }
.btn-nav-pro:hover { background: var(--blue-lt) !important; }

/* ── Section helpers ── */
.eyebrow { font-size: .8rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; margin-bottom: .4rem; }
.stitle  { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; color: var(--ink); letter-spacing: -.5px; line-height: 1.2; }
.ssub    { color: var(--muted); font-size: .96rem; line-height: 1.65; }

/* ── Cards générique ── */
.card-base { background: #fff; border: 1.5px solid var(--gbd); border-radius: var(--r); padding: 1.35rem; transition: box-shadow .2s, transform .2s; }
.card-base:hover { box-shadow: 0 10px 32px rgba(0,0,0,.09); transform: translateY(-2px); }

/* ── Boutons principaux ── */
.btn-blue  { background: var(--blue);  color: #fff; border: none; border-radius: var(--rsm); padding: .75rem 1.5rem; font-size: .96rem; font-weight: 700; cursor: pointer; font-family: 'Outfit', sans-serif; transition: background .18s; display: inline-flex; align-items: center; gap: 7px; }
.btn-blue:hover  { background: var(--blue-dk); }
.btn-mint  { background: var(--mint);  color: #fff; border: none; border-radius: var(--rsm); padding: .75rem 1.5rem; font-size: .96rem; font-weight: 700; cursor: pointer; font-family: 'Outfit', sans-serif; transition: background .18s; display: inline-flex; align-items: center; gap: 7px; }
.btn-mint:hover  { background: #059669; }
.btn-outline { background: transparent; color: var(--blue); border: 1.5px solid var(--blue); border-radius: var(--rsm); padding: .72rem 1.4rem; font-size: .96rem; font-weight: 600; cursor: pointer; font-family: 'Outfit', sans-serif; transition: all .18s; display: inline-flex; align-items: center; gap: 7px; }
.btn-outline:hover { background: var(--blue); color: #fff; }

/* ── Badges statut ── */
.badge-publie   { background: #dcfce7; color: #166534; border-radius: 50px; padding: 3px 11px; font-size: .75rem; font-weight: 700; }
.badge-attente  { background: #fef9c3; color: #713f12; border-radius: 50px; padding: 3px 11px; font-size: .75rem; font-weight: 700; }
.badge-suspendu { background: #fee2e2; color: #991b1b; border-radius: 50px; padding: 3px 11px; font-size: .75rem; font-weight: 700; }
.badge-premium  { background: #fffbeb; color: #92400e; border-radius: 50px; padding: 3px 11px; font-size: .75rem; font-weight: 700; }
.badge-rdv      { background: var(--mint-lt); color: #065f46; border-radius: 50px; padding: 3px 11px; font-size: .75rem; font-weight: 700; }

/* ── Chips filtre ── */
.chip { background: var(--gbg); border: 1.5px solid var(--gbd); border-radius: 50px; padding: .4rem 1rem; font-size: .88rem; font-weight: 500; color: var(--muted); cursor: pointer; transition: all .18s; white-space: nowrap; font-family: 'Outfit', sans-serif; }
.chip:hover, .chip.on { background: var(--blue); border-color: var(--blue); color: #fff; }
.chip.on-mint { background: var(--mint); border-color: var(--mint); color: #fff; }

/* ── Stars ── */
.stars-out { color: #f59e0b; font-size: .9rem; }
.stars-out .empty { color: #e2e8f0; }

/* ── Inputs ── */
.finp {
  width: 100%; border: 1.5px solid var(--gbd); border-radius: var(--rsm);
  padding: .75rem 1rem; font-family: 'Outfit', sans-serif; font-size: .96rem;
  color: var(--ink); outline: none; transition: border-color .18s; background: var(--gbg);
}
.finp:focus { border-color: var(--blue); background: #fff; }
.finp-icon { position: relative; }
.finp-icon i { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: 1rem; pointer-events: none; }
.finp-icon .finp { padding-left: 2.45rem; }

/* ── Footer ── */
footer { background: #060e1a; padding: 3.5rem 0 1.75rem; }
.fdesc { color: rgba(255,255,255,.38); font-size: .88rem; line-height: 1.65; margin-top: .6rem; max-width: 230px; }
.fcol h6 { font-size: .78rem; font-weight: 700; color: rgba(255,255,255,.35); letter-spacing: 2px; text-transform: uppercase; margin-bottom: .9rem; }
.fcol a  { display: block; color: rgba(255,255,255,.55); font-size: .9rem; text-decoration: none; margin-bottom: .45rem; transition: color .18s; }
.fcol a:hover { color: #fff; }
footer hr { border-color: rgba(255,255,255,.07); margin: 2rem 0 1.25rem; }
.copy { font-size: .8rem; color: rgba(255,255,255,.28); }
.soc-btn { width: 36px; height: 36px; border-radius: 8px; background: rgba(255,255,255,.09); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.5); font-size: .9rem; transition: all .18s; text-decoration: none; }
.soc-btn:hover { background: var(--blue); color: #fff; }

/* ── Flash messages ── */
.alert { border-radius: var(--rsm); padding: .85rem 1rem; font-size: .92rem; }

/* ── Responsive helpers ── */
@media (max-width: 767px) {
  .topbar { display: none; }
  .hide-mobile { display: none !important; }
  .stitle { font-size: 1.65rem; }
}

/* ── Pages listing médecins/pharmacies/cliniques/labos ─── */
/* Force layout horizontal des cards — doit battre Bootstrap  */

/* Cards médecins */
article.doc-card { display:flex !important; flex-direction:row !important; flex-wrap:nowrap !important; }
article.doc-card .doc-av-col { flex-shrink:0 !important; align-self:stretch !important; }
article.doc-card .doc-body   { flex:1 !important; min-width:0 !important; display:flex !important; flex-direction:column !important; }

/* Cards pharmacies */
article.ph-card { display:flex !important; flex-direction:row !important; flex-wrap:nowrap !important; }
article.ph-card .ph-av   { flex-shrink:0 !important; align-self:stretch !important; }
article.ph-card .ph-body { flex:1 !important; min-width:0 !important; display:flex !important; flex-direction:column !important; }

/* Cards cliniques */
article.cl-card { display:flex !important; flex-direction:row !important; flex-wrap:nowrap !important; }
article.cl-card .cl-av   { flex-shrink:0 !important; align-self:stretch !important; }
article.cl-card .cl-body { flex:1 !important; min-width:0 !important; display:flex !important; flex-direction:column !important; }

/* Cards laboratoires */
article.lab-card { display:flex !important; flex-direction:row !important; flex-wrap:nowrap !important; }
article.lab-card .lab-av   { flex-shrink:0 !important; align-self:stretch !important; }
article.lab-card .lab-body { flex:1 !important; min-width:0 !important; display:flex !important; flex-direction:column !important; }

/* Hero 2 colonnes */
.hero-grid-2col { display:grid !important; grid-template-columns:5fr 7fr !important; gap:2rem !important; align-items:start !important; }
@media(max-width:991px) { .hero-grid-2col { grid-template-columns:1fr !important; } }
