/* =========================================================
   LE ROI PELLET — Charte "Forêt moderne"
   Feuille de style principale du site vitrine
   ========================================================= */

:root{
  /* Couleurs */
  --bg:#F2F6F2;            /* fond de page (vert très clair)   */
  --surface:#FFFFFF;       /* cartes / surfaces                */
  --border:#DCE7DE;        /* bordures douces                  */
  --text:#2C3A33;          /* texte courant                    */
  --heading:#10302A;       /* titres (vert forêt foncé)        */
  --muted:#6E7E74;         /* texte secondaire                 */
  --accent:#1E7A52;        /* vert frais : boutons, liens      */
  --accent-hover:#176343;  /* survol bouton                    */
  --gold:#D4A017;          /* touche dorée (accents, étoiles)  */
  --dark:#10302A;          /* sections foncées / pied de page  */
  --on-accent:#FFFFFF;     /* texte sur fond vert/accent       */

  /* Typo */
  --font-titre:'Poppins', system-ui, 'Segoe UI', sans-serif;
  --font-texte:'Inter', system-ui, 'Segoe UI', sans-serif;

  /* Divers */
  --radius:14px;
  --radius-lg:20px;
  --maxw:1140px;
  --shadow:0 10px 30px rgba(16,48,42,.08);
  --shadow-hover:0 16px 40px rgba(16,48,42,.14);
}

/* ---------- Base ---------- */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:90px;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-texte);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-titre);color:var(--heading);line-height:1.18;font-weight:700;}
a{color:var(--accent);}
img{max-width:100%;display:block;}

.container{width:90%;max-width:var(--maxw);margin:0 auto;}
.section{padding:72px 0;}
.section--tight{padding:48px 0;}
.center{text-align:center;}
.eyebrow{display:inline-block;color:var(--accent);font-family:var(--font-titre);font-weight:600;
  font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;}
.section h2{font-size:clamp(1.7rem,3.5vw,2.3rem);margin-bottom:12px;}
.lead{color:var(--muted);max-width:680px;font-size:1.05rem;}
.center .lead{margin-left:auto;margin-right:auto;}

/* ---------- Boutons ---------- */
.btn{display:inline-block;padding:13px 28px;border-radius:30px;font-family:var(--font-titre);
  font-weight:600;font-size:.98rem;text-decoration:none;cursor:pointer;border:2px solid transparent;
  transition:all .2s ease;text-align:center;}
.btn-primary{background:var(--accent);color:var(--on-accent);}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 10px 24px rgba(30,122,82,.30);}
.btn-ghost{background:transparent;color:var(--accent);border-color:var(--border);}
.btn-ghost:hover{border-color:var(--accent);background:rgba(30,122,82,.06);}
.btn-light{background:#fff;color:var(--accent);}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.18);}

/* ---------- En-tête ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(242,246,242,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--border);transition:box-shadow .2s ease;}
.header.scrolled{box-shadow:0 4px 18px rgba(16,48,42,.08);}
.header .container{display:flex;align-items:center;justify-content:space-between;padding:12px 0;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;}
.brand .mark{width:38px;height:38px;color:var(--accent);flex:0 0 auto;}
.brand .word{font-family:var(--font-titre);font-weight:700;font-size:1.2rem;color:var(--heading);line-height:1;}
.brand .word b{color:var(--accent);}
.nav{display:flex;align-items:center;gap:6px;}
.nav a{color:var(--text);text-decoration:none;font-weight:500;font-size:.95rem;padding:8px 12px;border-radius:8px;transition:color .2s,background .2s;}
.nav a:hover{color:var(--accent);background:rgba(30,122,82,.07);}
.nav .btn{margin-left:8px;padding:10px 20px;}
.nav a.btn-primary,.nav a.btn-primary:hover{color:var(--on-accent);background:var(--accent);}
.nav a.btn-primary:hover{background:var(--accent-hover);}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.burger span{width:26px;height:3px;background:var(--heading);border-radius:3px;transition:.3s;}

/* ---------- Hero ---------- */
.hero{position:relative;padding:150px 0 90px;
  background:linear-gradient(rgba(16,38,32,.66), rgba(16,38,32,.74)), url('../img/hero-fond.jpg');
  background-size:cover;background-position:center;}
.hero .container{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;}
.hero-text{max-width:760px;}
.hero .tag{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.12);backdrop-filter:blur(2px);
  border-radius:30px;padding:6px 16px;font-size:.82rem;color:#fff;font-weight:600;
  font-family:var(--font-titre);margin-bottom:22px;}
.hero h1{font-size:clamp(2.1rem,5vw,3.3rem);margin-bottom:18px;color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.35);}
.hero h1 span{color:var(--gold);}
.hero p{color:rgba(255,255,255,.92);font-size:1.12rem;margin:0 auto 30px;max-width:620px;
  text-shadow:0 1px 10px rgba(0,0,0,.35);}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}
/* Pastille avis Google */
.hero-avis{display:inline-flex;align-items:center;gap:14px;margin-top:32px;background:#fff;
  border:1px solid var(--border);border-radius:40px;padding:10px 22px 10px 18px;box-shadow:var(--shadow);
  text-decoration:none;color:inherit;transition:.2s;}
.hero-avis:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 22px rgba(30,122,82,.12);}
.hero-avis .hero-avis-note{font-family:var(--font-titre);font-weight:700;font-size:1.9rem;color:var(--accent);line-height:1;}
.hero-avis .hero-avis-right{display:flex;flex-direction:column;align-items:flex-start;gap:2px;}
.hero-avis .stars{color:var(--gold);letter-spacing:2px;font-size:1.02rem;line-height:1;}
.hero-avis .hero-avis-meta{font-size:.82rem;color:var(--muted);}
.hero-avis .hero-avis-meta b{color:var(--heading);font-weight:600;}

/* ---------- Bandeau marques ---------- */
.brands{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:22px 0;overflow:hidden;}
.brands .row{display:flex;gap:48px;align-items:center;width:max-content;animation:scrollX 55s linear infinite;}
.brands img{height:46px;width:auto;opacity:.55;filter:grayscale(1);transition:.2s;}
.brands img:hover{opacity:1;filter:none;}
@keyframes scrollX{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Cartes services ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px;}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:30px 26px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:var(--accent);}
.card h3{font-size:1.2rem;margin-bottom:6px;}
.card .desc{color:var(--muted);font-size:.95rem;flex:1;}
.card .price{font-family:var(--font-titre);font-weight:700;color:var(--accent);font-size:2.7rem;margin:16px 0 6px;}
.card .price small{font-size:1rem;color:var(--muted);font-weight:500;}
.card .btn{margin-top:18px;}
.card.featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset, var(--shadow);position:relative;}
.badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);
  color:#fff;font-family:var(--font-titre);font-weight:600;font-size:.72rem;letter-spacing:.04em;
  text-transform:uppercase;padding:5px 14px;border-radius:20px;white-space:nowrap;}
.note{color:var(--muted);font-size:.85rem;margin-top:22px;}
/* Paliers « Hors zone » */
.zone-tiers{display:flex;flex-direction:column;gap:8px;margin:16px 0 6px;}
.zone-tier{display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:9px 14px;}
.zone-tier span{color:var(--muted);font-size:.9rem;}
.zone-tier strong{font-family:var(--font-titre);font-weight:700;color:var(--accent);font-size:1.2rem;white-space:nowrap;}

/* ---------- Détails prestation (cadres) ---------- */
.frame{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:36px;box-shadow:var(--shadow);}
.frame.dark{background:var(--dark);border-color:var(--dark);color:#D6E4DC;}
.frame.dark h2,.frame.dark h3{color:#fff;}
.frame ul{list-style:none;margin:18px 0;}
.frame li{position:relative;padding-left:30px;margin:11px 0;}
.frame li::before{content:"";position:absolute;left:0;top:9px;width:14px;height:14px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px rgba(30,122,82,.15);}
.frame.dark li::before{background:var(--gold);box-shadow:0 0 0 4px rgba(212,160,23,.18);}
.frame .duree{font-style:italic;color:var(--muted);}
.frame.dark .duree{color:#9DB6AB;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;}

/* ---------- Réglementation ---------- */
.reglementation{background:var(--dark);color:#D6E4DC;}
.reglementation h2,.reglementation h3{color:#fff;}
.reglementation a{color:var(--gold);}
.reglementation .alert{background:rgba(212,160,23,.12);border-left:4px solid var(--gold);
  padding:16px 20px;border-radius:8px;margin-top:24px;color:#fff;font-weight:500;}
.reg-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:26px;}
.reglementation ul{list-style:none;}
.reglementation li{position:relative;padding-left:26px;margin:10px 0;}
.reglementation li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700;}

/* ---------- Zone géographique ---------- */
.zones{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px;}
.zone-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;}
.zone-card .dept{font-family:var(--font-titre);font-weight:700;color:var(--accent);font-size:1.05rem;margin-bottom:6px;}
.zone-card .secteurs{color:var(--muted);font-size:.92rem;}

/* ---------- Étoiles (note) ---------- */
.stars{color:var(--gold);letter-spacing:2px;}

/* ---------- Contact / RDV ---------- */
.cta{background:var(--accent);color:#fff;border-radius:var(--radius-lg);padding:54px;text-align:center;}
.cta h2{color:#fff;}
.cta p{color:rgba(255,255,255,.9);max-width:560px;margin:10px auto 26px;}
.cta .tel{font-family:var(--font-titre);font-weight:700;font-size:2.2rem;color:#fff;text-decoration:none;display:inline-block;margin-bottom:8px;}
.cta .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:10px;}
.cta .mail{color:#fff;text-decoration:underline;}

/* ---------- Pied de page ---------- */
.footer{background:var(--dark);color:#9DB6AB;padding:48px 0 28px;}
.footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:30px;}
.footer h4{color:#fff;font-size:1rem;margin-bottom:12px;}
.footer a{color:#9DB6AB;text-decoration:none;display:block;margin:6px 0;}
.footer a:hover{color:var(--gold);}
.footer .brand .word{color:#fff;}
.footer .legal{border-top:1px solid rgba(255,255,255,.12);padding-top:18px;text-align:center;font-size:.85rem;}
.footer .legal a{display:inline;color:var(--gold);}

/* ---------- Modale CGV / mentions ---------- */
.modal{display:none;position:fixed;inset:0;z-index:2000;background:rgba(16,48,42,.55);padding:5vh 16px;}
.modal.open{display:block;}
.modal-box{background:#fff;max-width:860px;margin:0 auto;border-radius:var(--radius-lg);
  max-height:90vh;overflow:auto;padding:40px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.3);}
.modal-close{position:absolute;top:16px;right:20px;font-size:1.8rem;background:none;border:none;cursor:pointer;color:var(--muted);}
.modal-close:hover{color:var(--heading);}

/* ---------- Animations au scroll ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;}
.reveal.visible{opacity:1;transform:none;}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:900px){
  .two-col,.reg-grid{grid-template-columns:1fr;}
  .zones{grid-template-columns:1fr 1fr;}
}
@media(max-width:760px){
  .nav{position:fixed;top:63px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);
    flex-direction:column;align-items:stretch;padding:12px 18px 18px;gap:2px;
    transform:translateY(-130%);transition:transform .28s ease;box-shadow:var(--shadow);}
  .nav.open{transform:translateY(0);}
  .nav a{padding:12px;border-radius:8px;}
  .nav .btn{margin:8px 0 0;}
  .burger{display:flex;}
  .grid-3{grid-template-columns:1fr;}
  .frame{padding:24px;}
  .cta{padding:36px 22px;}
  .footer .cols{grid-template-columns:1fr;}
  .section{padding:56px 0;}
}
@media(max-width:460px){
  .zones{grid-template-columns:1fr;}
}

/* =========================================================
   PAGES INTERNES + FORMULAIRE DE RDV
   ========================================================= */
.page-head{padding:120px 0 24px;text-align:center;
  background:radial-gradient(800px 360px at 50% -10%, rgba(30,122,82,.12), transparent 70%);}
.page-head h1{font-size:clamp(1.8rem,4.5vw,2.7rem);}
.page-head p{color:var(--muted);max-width:600px;margin:10px auto 0;}
.back-link{display:inline-block;margin-bottom:8px;color:var(--accent);text-decoration:none;font-weight:600;font-size:.9rem;}
.back-link:hover{text-decoration:underline;}

.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:34px;box-shadow:var(--shadow);max-width:800px;margin:0 auto 40px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field.full{grid-column:1 / -1;}
.field label{font-family:var(--font-titre);font-weight:600;font-size:.9rem;color:var(--heading);}
.field .req{color:var(--accent);}
.field input,.field select,.field textarea{font-family:var(--font-texte);font-size:1rem;
  padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);
  width:100%;transition:border-color .15s,box-shadow .15s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(30,122,82,.15);}
.field textarea{resize:vertical;min-height:96px;}
.field .hint{font-size:.8rem;color:var(--muted);}
.field .err{color:#c0392b;font-size:.8rem;display:none;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#c0392b;}
.field.invalid .err{display:block;}
.form-section-title{font-family:var(--font-titre);font-weight:600;color:var(--heading);
  grid-column:1 / -1;margin-top:10px;padding-top:14px;border-top:1px solid var(--border);}

.radio-row{display:flex;gap:12px;}
.radio-opt{flex:1;border:1px solid var(--border);border-radius:10px;padding:12px 14px;cursor:pointer;
  display:flex;align-items:center;gap:8px;font-weight:500;transition:.15s;}
.radio-opt:hover{border-color:var(--accent);}
.radio-opt input{accent-color:var(--accent);}
.radio-opt.checked{border-color:var(--accent);background:rgba(30,122,82,.06);}

.zone-msg{border-radius:10px;padding:12px 14px;font-size:.9rem;margin-top:8px;display:none;}
.zone-msg.show{display:block;}
.zone-msg.in{background:rgba(30,122,82,.10);color:var(--accent-hover);border:1px solid rgba(30,122,82,.3);}
.zone-msg.sup{background:rgba(212,160,23,.14);color:#8a6d0f;border:1px solid rgba(212,160,23,.45);}
.zone-msg.out{background:rgba(192,57,43,.08);color:#a5331f;border:1px solid rgba(192,57,43,.3);}

.price-tag{font-family:var(--font-titre);font-weight:700;color:var(--accent);}

.consent{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--muted);grid-column:1 / -1;}
.consent input{margin-top:4px;accent-color:var(--accent);flex:0 0 auto;}
.consent a{color:var(--accent);}

.form-actions{grid-column:1 / -1;margin-top:8px;}
.form-actions .btn{width:100%;padding:15px;font-size:1.05rem;}
.demo-flag{grid-column:1 / -1;background:rgba(212,160,23,.12);border:1px dashed var(--gold);
  border-radius:10px;padding:10px 14px;font-size:.82rem;color:#8a6d0f;text-align:center;}
.form-error{grid-column:1 / -1;display:none;background:rgba(192,57,43,.08);
  border:1px solid rgba(192,57,43,.35);color:#a5331f;border-radius:10px;padding:12px 14px;font-size:.9rem;}
.form-error.show{display:block;}

.form-success{display:none;text-align:center;padding:30px 10px;}
.form-success.show{display:block;}
.form-success .ico{width:74px;height:74px;border-radius:50%;background:rgba(30,122,82,.12);
  color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:2.4rem;margin:0 auto 18px;}

@media(max-width:640px){
  .form-grid{grid-template-columns:1fr;}
  .form-card{padding:24px;}
  .radio-row{flex-direction:column;}
}

/* Champs masqués (calendrier / moment) */
.field[hidden]{display:none;}

/* ---------- Calendrier de disponibilités ---------- */
.calendar{border:1px solid var(--border);border-radius:14px;padding:16px;background:#fff;max-width:380px;}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.cal-title{font-family:var(--font-titre);font-weight:600;color:var(--heading);text-transform:capitalize;}
.cal-nav{border:1px solid var(--border);background:#fff;border-radius:8px;width:36px;height:36px;
  cursor:pointer;font-size:1.2rem;line-height:1;color:var(--accent);transition:.15s;}
.cal-nav:hover:not(:disabled){border-color:var(--accent);background:rgba(30,122,82,.06);}
.cal-nav:disabled{opacity:.3;cursor:default;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.cal-dow{text-align:center;font-size:.72rem;font-weight:600;color:var(--muted);
  font-family:var(--font-titre);padding-bottom:4px;}
.cal-cell{border:1px solid transparent;background:transparent;border-radius:9px;height:40px;
  font-size:.92rem;color:var(--muted);font-family:var(--font-texte);cursor:default;padding:0;}
.cal-cell.empty{border:none;}
.cal-cell.ok{background:rgba(30,122,82,.10);color:var(--accent-hover);
  border-color:rgba(30,122,82,.25);cursor:pointer;font-weight:600;}
.cal-cell.ok:hover{background:var(--accent);color:#fff;}
.cal-cell.no{color:#c4ccc7;text-decoration:line-through;}
.cal-legend{margin:12px 0 0;font-size:.78rem;color:var(--muted);display:flex;align-items:center;}
.cal-legend .dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:5px;vertical-align:middle;}
.cal-legend .dot.ok{background:rgba(30,122,82,.45);}
.cal-legend .dot.no{background:#d8e0db;}

/* ---------- Étapes du formulaire ---------- */
.step[hidden]{display:none;}
.step-back{background:none;border:none;color:var(--accent);cursor:pointer;font-weight:600;
  font-family:var(--font-titre);padding:0;margin-bottom:14px;font-size:.92rem;}
.step-back:hover{text-decoration:underline;}
.creneau-mode{background:rgba(30,122,82,.08);border:1px solid rgba(30,122,82,.25);border-radius:10px;
  padding:10px 14px;color:var(--accent-hover);font-size:.92rem;margin:6px 0 18px;}

/* ---------- Appareils (générateurs) ---------- */
.generateur{border:1px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:16px;background:#fbfdfb;}
.gen-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.gen-head h3{font-size:1.05rem;}
.gen-remove{background:none;border:1px solid #e4cccc;color:#a5331f;border-radius:8px;padding:5px 12px;
  font-size:.8rem;cursor:pointer;font-family:var(--font-titre);}
.gen-remove:hover{background:rgba(192,57,43,.07);}
.btn-add-gen{background:transparent;border:1.5px dashed var(--accent);color:var(--accent);border-radius:10px;
  padding:13px;width:100%;cursor:pointer;font-family:var(--font-titre);font-weight:600;transition:.15s;}
.btn-add-gen:hover{background:rgba(30,122,82,.06);}
.btn-add-gen[hidden]{display:none;}
.gen-error{color:#c0392b;font-size:.85rem;margin-top:8px;display:none;}
.gen-error.show{display:block;}

/* ---------- Bande de la semaine ---------- */
.week-strip[hidden]{display:none;}
.week-strip{margin-top:18px;border:1px solid var(--border);border-radius:14px;padding:16px;background:#fff;}
.week-title{text-align:center;font-family:var(--font-titre);font-weight:600;color:var(--heading);margin-bottom:14px;}
.week-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;}
.week-day{text-align:center;}
.week-day .dlabel{font-size:.78rem;color:var(--muted);font-family:var(--font-titre);}
.week-day .dnum{font-weight:600;color:var(--heading);margin-bottom:8px;}
.slot-btn{display:block;width:100%;margin:5px 0;padding:9px 4px;border-radius:8px;border:1px solid var(--border);
  background:#fff;font-size:.76rem;font-family:var(--font-titre);font-weight:600;color:var(--muted);cursor:default;transition:.15s;}
.slot-btn.free{border-color:rgba(30,122,82,.4);background:rgba(30,122,82,.10);color:var(--accent-hover);cursor:pointer;}
.slot-btn.free:hover{background:var(--accent);color:#fff;}
.slot-btn.sel{background:var(--accent);color:#fff;border-color:var(--accent);}
.slot-btn.taken{opacity:.45;text-decoration:line-through;}
@media(max-width:640px){
  .week-grid{grid-template-columns:1fr;}
  .week-day{display:flex;align-items:center;gap:10px;text-align:left;flex-wrap:wrap;}
  .week-day .dnum{margin:0;}
  .slot-btn{width:auto;flex:1;margin:0;}
}

/* ---------- Récapitulatif (étape 3) ---------- */
.recap-block{margin-bottom:16px;}
.recap-block h4{font-family:var(--font-titre);color:var(--heading);font-size:.92rem;margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.04em;}
.recap-info{color:var(--text);font-size:.96rem;line-height:1.7;}
.recap-lines{border:1px solid var(--border);border-radius:12px;padding:2px 16px;background:#fff;}
.recap-row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--border);font-size:.95rem;}
.recap-row:last-child{border-bottom:none;}
.recap-row .lbl{color:var(--text);}
.recap-row .val{font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--heading);font-weight:600;}
.recap-row.remise .lbl,.recap-row.remise .val{color:var(--accent);}
.recap-total{display:flex;justify-content:space-between;font-family:var(--font-titre);font-weight:700;
  font-size:1.25rem;color:var(--heading);padding:14px 4px 2px;border-top:2px solid var(--heading);margin-top:10px;}
.recap-note{color:var(--muted);font-size:.82rem;margin-top:10px;}

/* Tableau type devis (prestations alignées avec leurs prix) */
.devis{width:100%;border-collapse:collapse;}
.devis td{padding:11px 0;border-bottom:1px solid var(--border);font-size:.95rem;vertical-align:top;color:var(--text);}
.devis td.p{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;font-weight:600;color:var(--heading);width:96px;padding-left:14px;}
.devis tr.remise td{color:var(--accent);}
.devis tfoot td{border-bottom:none;border-top:2px solid var(--heading);padding-top:13px;
  font-family:var(--font-titre);font-weight:700;font-size:1.2rem;color:var(--heading);}

/* =========================================================
   CRM / ESPACE ADMIN
   ========================================================= */
.admin-top{background:var(--dark);position:sticky;top:0;z-index:100;}
.admin-top .bar{display:flex;align-items:center;gap:18px;max-width:1200px;margin:0 auto;padding:12px 20px;flex-wrap:wrap;}
.admin-top .brand .word{color:#fff;}
.admin-top .brand .word b{color:var(--gold);}
.admin-nav{display:flex;gap:4px;flex:1;flex-wrap:wrap;}
.admin-nav a{color:#cfe0d7;text-decoration:none;padding:8px 14px;border-radius:8px;font-family:var(--font-titre);font-weight:500;font-size:.94rem;}
.admin-nav a:hover{background:rgba(255,255,255,.08);color:#fff;}
.admin-nav a.active{background:var(--accent);color:#fff;}
.admin-top .who{color:#9DB6AB;font-size:.85rem;}
.admin-top .logout{color:#cfe0d7;text-decoration:none;font-size:.9rem;font-weight:600;}
.admin-top .logout:hover{color:var(--gold);}
.admin-main{max-width:1200px;margin:0 auto;padding:28px 20px;}
.admin-main h1{font-size:1.7rem;margin-bottom:22px;}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:28px;}
.stat{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;}
.stat .num{font-family:var(--font-titre);font-weight:700;font-size:2.1rem;color:var(--accent);line-height:1;}
.stat .lbl{color:var(--muted);font-size:.9rem;margin-top:6px;}

.card-block{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:22px;}
.card-block h2{font-size:1.15rem;margin-bottom:14px;}

.table{width:100%;border-collapse:collapse;}
.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);font-size:.92rem;vertical-align:top;}
.table th{font-family:var(--font-titre);color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.03em;}
.table tbody tr:hover{background:var(--bg);}
.table .muted{color:var(--muted);font-size:.85rem;}

.tag-statut{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.74rem;font-weight:600;font-family:var(--font-titre);}
.st-prospect{background:#e7eef0;color:#4a6b73;}
.st-actif{background:rgba(30,122,82,.12);color:var(--accent-hover);}
.st-fidel{background:rgba(212,160,23,.18);color:#8a6d0f;}
.st-inactif{background:#f0e6da;color:#8a5a0f;}
.st-perdu{background:#f3d9d4;color:#a5331f;}
.st-nouvelle{background:#fde9c8;color:#8a5a0f;}
.st-confirmee{background:rgba(30,122,82,.12);color:var(--accent-hover);}
.st-refusee{background:#f3d9d4;color:#a5331f;}
.st-reproposee{background:#e7eef0;color:#4a6b73;}

.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap;}
.toolbar input[type=search]{flex:1;min-width:200px;padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-family:var(--font-texte);font-size:.95rem;}
.pagination{display:flex;gap:6px;margin-top:18px;flex-wrap:wrap;}
.pagination a,.pagination span{padding:7px 12px;border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text);font-size:.9rem;}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent);}

/* Connexion */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px;}
.login-box{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;max-width:380px;width:100%;box-shadow:var(--shadow);}
.login-box .brand{justify-content:center;margin-bottom:8px;}
.login-box h1{font-size:1.3rem;text-align:center;margin-bottom:22px;}
.login-box label{display:block;font-family:var(--font-titre);font-weight:600;font-size:.9rem;margin-bottom:6px;color:var(--heading);}
.login-box input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-size:1rem;margin-bottom:16px;}
.login-box .btn{width:100%;}
.login-error{background:rgba(192,57,43,.08);border:1px solid rgba(192,57,43,.35);color:#a5331f;border-radius:10px;padding:10px 14px;font-size:.9rem;margin-bottom:16px;}
.login-ok{background:rgba(30,122,82,.10);border:1px solid rgba(30,122,82,.3);color:var(--accent-hover);border-radius:10px;padding:10px 14px;font-size:.9rem;margin-bottom:16px;}
