/* BOUTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 22px;
  font-family:var(--ff-body);
  font-size:.95rem;font-weight:500;
  line-height:1;
  border-radius:999px;
  border:1px solid transparent;
  text-decoration:none;
  cursor:pointer;
  transition:background .2s, color .2s, border-color .2s, transform .15s;
  white-space:nowrap;
  min-height:46px;
}
.btn svg{width:16px;height:16px;flex-shrink:0;}

.btn--primary{
  background:var(--text);
  color:var(--bg);
}
.btn--primary:hover{background:var(--accent);color:var(--bg);}

.btn--accent{
  background:var(--accent);
  color:var(--bg);
}
.btn--accent:hover{background:var(--text);color:var(--bg);}

.btn--wa{
  background:var(--wa-green);
  color:#fff;
}
.btn--wa:hover{background:var(--wa-green-d);color:#fff;}

.btn--ghost{
  background:transparent;
  color:var(--text);
  border-color:var(--text);
}
.btn--ghost:hover{background:var(--text);color:var(--bg);}

.btn--ghost-light{
  background:transparent;
  color:#E7DCC9;
  border-color:rgba(231,220,201,.4);
}
.btn--ghost-light:hover{background:rgba(231,220,201,.1);}

.btn--sm{padding:9px 16px;font-size:.85rem;min-height:38px;}
.btn--lg{padding:15px 28px;font-size:1rem;min-height:52px;}

/* PILLS / TAGS */
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;
  background:color-mix(in srgb,var(--accent) 12%, var(--bg));
  color:var(--accent);
  border-radius:999px;
  font-size:.78rem;
  font-weight:500;
  font-family:var(--ff-body);
  letter-spacing:.02em;
}
.pill svg{width:11px;height:11px;}
.pill--dark{background:var(--text);color:var(--bg);}

/* CARDS plain (LAY-2 card=plain) */
.c-plain{
  background:color-mix(in srgb,var(--text) 4%, var(--bg));
  border-radius:var(--r-lg);
  padding:24px;
}
@media (min-width:768px){.c-plain{padding:28px;}}

/* FORM */
.form-grid{display:grid;grid-template-columns:1fr;gap:14px;}
@media (min-width:640px){.form-grid{grid-template-columns:1fr 1fr;}}
.form-grid .field{min-width:0;}
.form-grid .field.full{grid-column:1/-1;}
.field label{
  display:block;font-size:.82rem;color:var(--text-2);
  margin-bottom:6px;font-family:var(--ff-body);font-weight:500;
}
.field input,
.field textarea,
.field select{
  width:100%;min-width:0;
  padding:12px 14px;
  font-family:var(--ff-body);font-size:.95rem;
  color:var(--text);
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:border-color .2s, box-shadow .2s;
}
.field textarea{resize:vertical;min-height:120px;line-height:1.5;}
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 14%, transparent);
}
.form-note{font-size:.82rem;color:var(--text-mute);margin-top:8px;}
.form-status{
  margin-top:14px;padding:12px 14px;border-radius:var(--r-md);
  font-size:.92rem;display:none;
}
.form-status.ok{display:block;background:color-mix(in srgb,var(--wa-green) 14%, var(--bg));color:#0F6B2C;border:1px solid rgba(37,211,102,.4);}
.form-status.err{display:block;background:#FBEAEA;color:#7A1E1E;border:1px solid #E2B6B6;}

/* MENTIONS LEGALES MODAL */
.ml-modal{
  position:fixed;inset:0;z-index:var(--z-modal);
  background:rgba(20,16,12,.6);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  animation:fade-in .2s ease;
}
@keyframes fade-in{from{opacity:0;}to{opacity:1;}}
.ml-modal[hidden]{display:none !important;}
.ml-box{
  background:var(--bg);
  border-radius:var(--r-xl);
  max-width:520px;width:100%;
  max-height:84vh;overflow-y:auto;
  padding:28px;
  position:relative;
  box-shadow:0 24px 48px rgba(0,0,0,.25);
}
.ml-box h2{font-size:1.3rem;margin:0 0 18px;}
.ml-box h3{font-family:var(--ff-body);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin:18px 0 6px;font-weight:500;}
.ml-box p{font-size:.92rem;line-height:1.5;color:var(--text-2);margin:0 0 8px;}
.ml-close{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;
  background:transparent;border:none;
  font-size:1.6rem;line-height:1;
  cursor:pointer;color:var(--text);
  border-radius:50%;
}
.ml-close:hover{background:var(--accent-soft);}

/* LIGHTBOX (au cas ou photos) */
.lightbox{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(20,16,12,.92);display:flex;align-items:center;justify-content:center;}
.lightbox[hidden]{display:none !important;}
.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:8px;}
.lb-close,.lb-prev,.lb-next{
  position:absolute;background:rgba(255,255,255,.1);
  color:#fff;border:none;font-size:1.4rem;
  width:48px;height:48px;border-radius:50%;cursor:pointer;
}
.lb-close{top:18px;right:18px;}
.lb-prev{left:14px;top:50%;transform:translateY(-50%);}
.lb-next{right:14px;top:50%;transform:translateY(-50%);}
