/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;border-radius:var(--r-md);font-family:var(--ff-ui);font-weight:600;
  font-size:0.96rem;text-decoration:none;cursor:pointer;border:0;line-height:1;
  transition:transform var(--t-fast), background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
  white-space:nowrap;min-width:0;}
.btn svg{width:18px;height:18px;flex-shrink:0;}
.btn-primary{background:var(--accent);color:var(--surface);}
.btn-primary:hover{background:color-mix(in srgb, var(--accent) 88%, black);transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(31,91,78,0.22);}
.btn-wa{background:var(--wa-green);color:#fff;}
.btn-wa:hover{background:color-mix(in srgb, var(--wa-green) 88%, black);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--text);}
.btn-ghost:hover{background:var(--text);color:var(--surface);}
.btn-ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.6);}
.btn-ghost-light:hover{background:#fff;color:var(--text);border-color:#fff;}
.btn-line{background:transparent;color:var(--accent);border:1.5px solid var(--accent);}
.btn-line:hover{background:var(--accent);color:var(--surface);}
@media (prefers-reduced-motion: reduce){.btn{transition:none;}.btn:hover{transform:none;}}

/* CARDS — radius-asym (LAY-6 card style) */
.c-asym{background:color-mix(in srgb, var(--text) 4%, var(--bg));border-radius:22px 4px 22px 4px;
  padding:26px;}
.c-asym:nth-child(even){border-radius:4px 22px 4px 22px;}
.c-asym--lead{background:var(--surface-deep);color:var(--text-on-dark);}
.c-asym--lead h3,.c-asym--lead p,.c-asym--lead .svc-num,.c-asym--lead li,.c-asym--lead .svc-icon{color:var(--text-on-dark);}
.c-asym--lead p{color:color-mix(in srgb, var(--text-on-dark) 80%, transparent);}
.c-asym--lead .svc-num{color:var(--accent-on-dark);}
.c-asym--lead .svc-icon{background:color-mix(in srgb, var(--accent-on-dark) 16%, transparent);color:var(--accent-on-dark);}

/* BADGES + CHIPS */
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;
  background:color-mix(in srgb, var(--accent) 12%, var(--bg));color:var(--accent);
  font-family:var(--ff-ui);font-size:0.78rem;font-weight:600;letter-spacing:0.02em;}
.chip svg{width:14px;height:14px;}

/* RATING BADGE (hero) */
.rating-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;
  background:color-mix(in srgb, var(--surface) 92%, transparent);border:1px solid var(--border);
  text-decoration:none;color:var(--text);font-family:var(--ff-ui);font-size:0.85rem;
  box-shadow:0 4px 14px rgba(30,46,41,0.06);transition:transform var(--t-fast);}
.rating-badge:hover{transform:translateY(-2px);}
.rating-badge strong{font-weight:700;color:var(--text);font-size:0.94rem;}
.rating-badge .stars{display:inline-flex;gap:2px;color:var(--star-gold);}
.rating-badge .stars svg{width:14px;height:14px;}

/* STAR SVG (avis) */
.stars{display:inline-flex;gap:2px;color:var(--star-gold);}
.stars svg{width:16px;height:16px;}

/* MODAL (mentions legales) */
.modal{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;
  padding:20px;}
.modal[hidden]{display:none !important;}
.modal-overlay{position:absolute;inset:0;background:rgba(15,25,21,0.5);backdrop-filter:blur(4px);}
.modal-box{position:relative;background:var(--surface);border-radius:14px;padding:32px 26px;
  max-width:520px;width:100%;max-height:85vh;overflow-y:auto;
  box-shadow:0 18px 50px rgba(15,25,21,0.3);}
.modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;
  background:transparent;border:0;color:var(--text);display:grid;place-items:center;cursor:pointer;}
.modal-close:hover{background:var(--bg-alt);}
.modal-box h2{font-family:var(--ff-display);font-size:1.4rem;margin-bottom:16px;color:var(--text);}
.modal-box h3{font-family:var(--ff-display);font-size:0.92rem;text-transform:uppercase;
  letter-spacing:0.12em;color:var(--accent);margin:18px 0 6px;}
.modal-box p{font-size:0.92rem;color:var(--text-2);margin-bottom:8px;}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(15,25,21,0.95);
  display:flex;align-items:center;justify-content:center;padding:20px;}
.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,0.12);border:0;color:#fff;
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;cursor:pointer;font-size:1.6rem;
  transition:background var(--t-fast);}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,0.24);}
.lb-close{top:20px;right:20px;}
.lb-prev{left:20px;top:50%;transform:translateY(-50%);}
.lb-next{right:20px;top:50%;transform:translateY(-50%);}
@media (max-width: 640px){.lb-prev{left:10px;}.lb-next{right:10px;}}

/* FORM */
.form{display:grid;gap:14px;}
.form .field{display:flex;flex-direction:column;gap:6px;min-width:0;}
.form label{font-family:var(--ff-ui);font-size:0.82rem;font-weight:600;color:var(--text);
  letter-spacing:0.02em;}
.form input,.form select,.form textarea{font-family:var(--ff-body);font-size:0.96rem;
  padding:13px 14px;border:1.5px solid var(--border);border-radius:var(--r-md);
  background:var(--surface);color:var(--text);min-width:0;width:100%;
  transition:border-color var(--t-fast), box-shadow var(--t-fast);}
.form input:focus,.form select:focus,.form textarea:focus{outline:0;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent);}
.form textarea{resize:vertical;min-height:120px;}
.form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media (max-width: 480px){.form .form-row{grid-template-columns:1fr;}}
.form-note{font-size:0.8rem;color:var(--text-mute);margin-top:4px;}
