/* BOUTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--ff-ui);font-weight:500;font-size:1rem;
  padding:14px 22px;border-radius:999px;
  border:1px solid transparent;
  text-decoration:none;
  cursor:pointer;
  transition:transform .18s ease, background .2s, color .2s, border-color .2s;
  white-space:nowrap;
  line-height:1;
}
.btn:hover{transform:translateY(-1px);text-decoration:none}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--primary);color:#fff}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--text)}
.btn-ghost:hover{background:var(--text);color:var(--bg)}
.btn-ghost-inverse{background:transparent;color:#fff;border-color:rgba(255,255,255,0.5)}
.btn-ghost-inverse:hover{background:#fff;color:var(--primary)}
.btn-wa{background:var(--wa-green);color:#fff}
.btn-wa:hover{background:var(--wa-green-dark);color:#fff}
.btn-light{background:#fff;color:var(--text)}
.btn-light:hover{background:var(--bg-alt);color:var(--text)}

/* CHIPS / TAGS */
.chip{
  display:inline-flex;align-items:center;
  font-family:var(--ff-ui);font-size:0.82rem;
  padding:7px 14px;border-radius:999px;
  background:color-mix(in srgb, var(--text) 5%, var(--bg));
  color:var(--text-2);
  border:1px solid var(--border);
}
.chip--solid{background:var(--accent);color:#fff;border-color:var(--accent)}
.chip--accent{background:var(--accent-soft);color:var(--accent);border-color:transparent}

.tag-pill{
  display:inline-flex;
  font-family:var(--ff-ui);
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-size:0.66rem;
  font-weight:600;
  padding:5px 10px;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--accent);
}

/* CARDS LAY-2: card = plain (fond doux) */
.c-plain{
  background:color-mix(in srgb, var(--text) 4%, var(--bg));
  border-radius:var(--r-lg);
  padding:24px;
}
.c-plain h3{margin-bottom:8px}

/* FORM */
.form-row{display:flex;flex-direction:column;gap:14px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:560px){.form-row-2{grid-template-columns:1fr}}
.field{min-width:0;display:flex;flex-direction:column;gap:6px}
.field label{
  font-family:var(--ff-ui);font-size:0.78rem;
  text-transform:uppercase;letter-spacing:0.14em;
  color:var(--text-mute);font-weight:600;
}
.field input,
.field select,
.field textarea{
  font-family:var(--ff-body);
  font-size:1rem;
  padding:12px 14px;
  border-radius:var(--r-md);
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  width:100%;
  min-width:0;
  line-height:1.4;
}
.field textarea{min-height:96px;resize:vertical}
.field input:focus,
.field select:focus,
.field textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* MODAL (mentions legales) */
.modal{
  position:fixed;inset:0;
  z-index:var(--z-modal);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.55);cursor:pointer}
.modal-box{
  position:relative;
  background:var(--bg);
  color:var(--text);
  max-width:520px;width:100%;
  border-radius:var(--r-lg);
  padding:28px 24px 24px;
  max-height:90vh;overflow-y:auto;
  box-shadow:0 24px 60px rgba(0,0,0,0.30);
}
.modal-close{
  position:absolute;top:10px;right:10px;
  width:36px;height:36px;
  display:grid;place-items:center;
  font-size:1.3rem;color:var(--text);
}
.modal-box h2{font-size:1.4rem;margin-bottom:14px}
.modal-box p{margin-bottom:10px;font-size:0.92rem;line-height:1.55}
.modal-box p strong{color:var(--text)}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;
  z-index:var(--z-modal);
  background:rgba(15,12,8,0.92);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.lightbox .lb-image{
  max-width:90vw;max-height:88vh;
  object-fit:contain;
  border-radius:var(--r-md);
  box-shadow:0 20px 50px rgba(0,0,0,0.5);
}
.lightbox button{
  position:absolute;
  color:#fff;background:rgba(255,255,255,0.10);
  width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;
  font-size:1.5rem;
  backdrop-filter:blur(8px);
  cursor:pointer;
  transition:background .2s;
}
.lightbox button:hover{background:rgba(255,255,255,0.20)}
.lb-close{top:20px;right:20px}
.lb-prev{left:14px;top:50%;transform:translateY(-50%)}
.lb-next{right:14px;top:50%;transform:translateY(-50%)}

/* AVIS BADGE GOOGLE */
.badge-google{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--ff-ui);font-size:0.78rem;
  color:var(--text-2);
}
.badge-google svg{width:14px;height:14px;flex-shrink:0}

/* STATUS PILL (Ouvert / Ferme) */
.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-ui);font-size:0.82rem;
  padding:6px 12px;border-radius:999px;
  background:color-mix(in srgb, var(--text) 5%, var(--bg));
}
.status-pill .dot{width:8px;height:8px;border-radius:50%;background:#bbb}
.status-pill.is-open .dot{background:#3ea355;box-shadow:0 0 0 0 rgba(62,163,85,0.6);animation:dot-pulse 1.8s infinite}
.status-pill.is-closed .dot{background:#c04848}
@keyframes dot-pulse{
  0%{box-shadow:0 0 0 0 rgba(62,163,85,0.6)}
  70%{box-shadow:0 0 0 8px rgba(62,163,85,0)}
  100%{box-shadow:0 0 0 0 rgba(62,163,85,0)}
}
@media (prefers-reduced-motion:reduce){
  .status-pill.is-open .dot{animation:none}
}

/* HERO RATING BADGE (utilisé si note >= 4 ET nb_avis >= 5 ; ici nb_avis=3 donc NON utilisé) */
.hero-rating{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(6px);
  padding:8px 14px;border-radius:999px;
  font-family:var(--ff-ui);font-size:0.86rem;
  color:var(--text);
  margin-bottom:18px;
  text-decoration:none;
}
.hero-rating strong{color:var(--text);font-weight:600}
