/* ============================================================
   Cabinet d'Acupuncture Vétérinaire — Feuille de style commune
   Charte : Médicale / Pro (bleu, blanc)
   Polices : Spectral (titres) + Manrope (texte)
   ============================================================ */

:root{
  --bleu:#1d4e89; --bleu-fonce:#13315c; --bleu-clair:#3d77c2; --bleu-pale:#eaf1fa;
  --azur:#4cc9f0; --gris:#f5f7fa; --texte:#1a2433; --texte-doux:#5b6678; --bord:#e2e8f2;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;color:var(--texte);background:#fff;line-height:1.65}
h1,h2,h3,h4{font-family:'Spectral',serif;font-weight:600;line-height:1.15}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
section{padding:96px 0}
.eyebrow{font-weight:800;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;color:var(--bleu-clair);margin-bottom:16px}

/* ---------- NAV ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--bord)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;max-width:1180px;margin:0 auto}
.logo{font-family:'Spectral';font-weight:700;font-size:1.3rem;display:flex;align-items:center;gap:11px;color:var(--bleu-fonce)}
.logo .mk{width:34px;height:34px;border-radius:10px;background:var(--bleu);display:flex;align-items:center;justify-content:center}
.logo .mk svg{width:20px;height:20px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:.93rem;font-weight:600;color:var(--texte-doux);transition:.2s}
.nav-links a:hover{color:var(--bleu)}
.nav-links a.active{color:var(--bleu)}
.nav-links a.active:not(.btn){border-bottom:2px solid var(--bleu);padding-bottom:3px}
.btn{display:inline-block;background:var(--bleu);color:#fff;padding:13px 26px;border-radius:8px;font-weight:700;font-size:.92rem;transition:.25s;border:none;cursor:pointer}
.btn:hover{background:var(--bleu-fonce)}
.btn-ghost{background:#fff;color:var(--bleu);border:1.5px solid var(--bord)}
.btn-ghost:hover{border-color:var(--bleu);background:var(--bleu-pale)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.burger span{width:26px;height:2.5px;background:var(--bleu-fonce);border-radius:2px;transition:.2s}

/* ---------- HERO ---------- */
.hero{padding:172px 0 100px;background:linear-gradient(160deg,var(--bleu-pale) 0%,#fff 60%);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;top:-120px;right:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(76,201,240,.18),transparent 70%)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center;position:relative;z-index:2}
.pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--bord);padding:7px 16px;border-radius:30px;font-size:.82rem;font-weight:700;color:var(--bleu);margin-bottom:24px}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--azur)}
.hero h1{font-size:clamp(2.5rem,5vw,3.9rem);letter-spacing:-.02em;margin-bottom:22px;color:var(--bleu-fonce)}
.hero p.lead{font-size:1.15rem;color:var(--texte-doux);max-width:500px;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{aspect-ratio:1;border-radius:24px;background:linear-gradient(160deg,var(--bleu-clair),var(--bleu-fonce));display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.78);font-family:'Spectral';font-style:italic;text-align:center;padding:30px;box-shadow:0 30px 60px rgba(29,78,137,.25)}

/* bandeau page secondaire */
.page-head{padding:150px 0 64px;background:linear-gradient(160deg,var(--bleu-pale) 0%,#fff 90%);text-align:center}
.page-head h1{font-size:clamp(2.2rem,4.4vw,3.2rem);color:var(--bleu-fonce);margin-bottom:14px}
.page-head p{color:var(--texte-doux);font-size:1.08rem;max-width:620px;margin:0 auto}

/* stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:52px;background:#fff;border:1px solid var(--bord);border-radius:14px;overflow:hidden}
.stats div{padding:24px;text-align:center;border-right:1px solid var(--bord)}
.stats div:last-child{border:none}
.stats strong{display:block;font-family:'Spectral';font-size:1.9rem;color:var(--bleu)}
.stats span{font-size:.82rem;color:var(--texte-doux)}

/* ---------- section heads ---------- */
.sec-head{max-width:660px;margin-bottom:50px}
.sec-head.center{margin:0 auto 50px;text-align:center}
.sec-head h2{font-size:clamp(1.85rem,3.4vw,2.7rem);letter-spacing:-.015em;margin-bottom:14px;color:var(--bleu-fonce)}
.sec-head p{color:var(--texte-doux);font-size:1.05rem}

/* features */
.bg-gris{background:var(--gris)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{background:#fff;border:1px solid var(--bord);border-radius:14px;padding:32px 28px;transition:.3s}
.feat:hover{box-shadow:0 16px 36px rgba(29,78,137,.1);transform:translateY(-4px)}
.feat .ic{width:50px;height:50px;border-radius:12px;background:var(--bleu-pale);color:var(--bleu);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:18px}
.feat h3{font-size:1.2rem;margin-bottom:9px;color:var(--bleu-fonce)}
.feat p{font-size:.94rem;color:var(--texte-doux)}

/* espèces */
.species-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.species{background:#fff;border:1px solid var(--bord);border-radius:16px;padding:34px 30px;text-align:center;transition:.3s}
.species:hover{box-shadow:0 16px 36px rgba(29,78,137,.1);transform:translateY(-4px)}
.species .em{font-size:2.6rem;margin-bottom:14px}
.species h3{font-size:1.3rem;color:var(--bleu-fonce);margin-bottom:8px}
.species p{font-size:.93rem;color:var(--texte-doux)}

/* à propos */
.about-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center}
.about-photo{aspect-ratio:4/5;border-radius:20px;background:linear-gradient(160deg,var(--bleu-pale),var(--bleu-clair));display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.85);font-family:'Spectral';font-style:italic;text-align:center;padding:24px}
.about-grid h2{font-size:clamp(1.85rem,3.4vw,2.6rem);margin-bottom:18px;color:var(--bleu-fonce)}
.about-grid p{color:var(--texte-doux);margin-bottom:16px}
.creds{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
.cred{display:flex;gap:12px;align-items:flex-start;font-size:.9rem;background:var(--gris);padding:14px 16px;border-radius:10px}
.cred .dot{flex-shrink:0;color:var(--bleu);font-weight:800}

/* indications */
.indic-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.bg-dark{background:var(--bleu-fonce);color:#fff}
.bg-dark .eyebrow{color:var(--azur)}
.bg-dark .sec-head h2{color:#fff}
.bg-dark .sec-head p{color:rgba(255,255,255,.72)}
.indic{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:26px 22px}
.indic .ic{font-size:1.8rem;margin-bottom:14px}
.indic h3{font-size:1.08rem;margin-bottom:12px;color:#fff}
.indic ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.indic li{font-size:.85rem;color:rgba(255,255,255,.78);padding-left:16px;position:relative}
.indic li::before{content:"–";position:absolute;left:0;color:var(--azur)}

/* tarifs */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.price{background:#fff;border:1px solid var(--bord);border-radius:16px;padding:36px 30px;position:relative;transition:.3s}
.price:hover{box-shadow:0 16px 36px rgba(29,78,137,.1)}
.price.hl{border:2px solid var(--bleu);box-shadow:0 20px 44px rgba(29,78,137,.16)}
.price.hl .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--bleu);color:#fff;font-size:.72rem;font-weight:800;padding:6px 16px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em}
.price h3{font-size:1.25rem;margin-bottom:6px;color:var(--bleu-fonce)}
.price .sub{font-size:.85rem;color:var(--texte-doux);margin-bottom:16px}
.price .amt{font-family:'Spectral';font-size:2.5rem;font-weight:700;color:var(--bleu);margin-bottom:18px}
.price .amt span{font-size:.95rem;font-weight:400;color:var(--texte-doux)}
.price ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:8px}
.price li{font-size:.92rem;padding-left:26px;position:relative;color:var(--texte-doux)}
.price li::before{content:"✓";position:absolute;left:0;color:var(--bleu);font-weight:800}
.note-tarif{text-align:center;margin-top:28px;font-size:.88rem;color:var(--texte-doux)}

/* FAQ */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq{background:#fff;border:1px solid var(--bord);border-radius:12px;overflow:hidden;transition:.2s}
.faq[open]{box-shadow:0 12px 30px rgba(29,78,137,.08)}
.faq summary{cursor:pointer;list-style:none;padding:22px 26px;font-family:'Spectral';font-size:1.12rem;font-weight:600;color:var(--bleu-fonce);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.6rem;color:var(--bleu-clair);flex-shrink:0;transition:.2s}
.faq[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 26px 24px;color:var(--texte-doux);font-size:.97rem}

/* CTA bandeau */
.cta-band{background:var(--bleu);color:#fff;border-radius:20px;padding:54px 48px;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:14px}
.cta-band p{color:rgba(255,255,255,.82);max-width:520px;margin:0 auto 28px}
.cta-band .btn{background:#fff;color:var(--bleu)}
.cta-band .btn:hover{background:var(--bleu-pale)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px}
.infos-card{background:var(--bleu-fonce);color:#fff;border-radius:18px;padding:38px;height:100%}
.infos-card h3{color:#fff;font-size:1.4rem;margin-bottom:24px}
.info-item{display:flex;gap:15px;align-items:flex-start;margin-bottom:22px}
.info-item .ic{flex-shrink:0;width:44px;height:44px;border-radius:11px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.info-item strong{display:block;font-size:.95rem;font-family:'Manrope';font-weight:700}
.info-item span{font-size:.9rem;color:rgba(255,255,255,.72)}
.info-item a{color:rgba(255,255,255,.72)}
.info-item a:hover{color:#fff}
.map{aspect-ratio:16/7;border-radius:12px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-style:italic;margin-top:8px}
.social-row{display:flex;gap:12px;margin-top:26px}
.social{width:42px;height:42px;border-radius:10px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;cursor:default;transition:.2s}
.social:hover{background:rgba(255,255,255,.2)}
.social svg{width:20px;height:20px}

form{background:#fff;border:1px solid var(--bord);border-radius:18px;padding:38px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.85rem;font-weight:700;margin-bottom:7px}
.req{color:#c0392b}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--bord);border-radius:9px;font-family:inherit;font-size:.94rem;transition:.2s;background:#fff}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--bleu)}
.field textarea{resize:vertical;min-height:120px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
form .btn{width:100%}
.hp{position:absolute;left:-9999px;top:-9999px}
.form-note{font-size:.82rem;color:var(--texte-doux);margin-top:14px;text-align:center}
.alert{padding:14px 18px;border-radius:10px;margin-bottom:22px;font-size:.92rem;font-weight:600}
.alert.ok{background:#e6f6ec;color:#1c7a3e;border:1px solid #b9e3c6}
.alert.err{background:#fdecea;color:#b5302a;border:1px solid #f3c4c0}

/* footer */
footer{background:#0d1f3c;color:rgba(255,255,255,.65);padding:58px 0 28px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:38px}
footer .logo{color:#fff;margin-bottom:14px}
footer h4{color:#fff;font-family:'Manrope';font-weight:700;margin-bottom:15px;font-size:.92rem}
footer a{display:block;margin-bottom:9px;font-size:.88rem;transition:.2s}
footer a:hover{color:#fff}
.foot-social{display:flex;gap:10px;margin-top:6px}
.foot-social .social{width:38px;height:38px}
.foot-bot{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;font-size:.8rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- responsive ---------- */
@media(max-width:880px){
  .nav-links{position:fixed;top:67px;left:0;right:0;background:#fff;flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--bord);box-shadow:0 16px 30px rgba(0,0,0,.08);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 28px;width:100%}
  .nav-links a.active:not(.btn){border-bottom:none}
  .nav-links .btn{margin:10px 28px;text-align:center}
  .burger{display:flex}
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .feat-grid,.price-grid,.indic-grid,.creds,.species-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  section{padding:70px 0}
  .cta-band{padding:42px 28px}
}
