/* =========================================================
   Cabinet de Kinésithérapie — Annecy
   Feuille de style partagée
   Palette : alpine douce (teal lac + sable chaud)
   Signature : cadres en arche (rappel des fenêtres du cabinet)
   ========================================================= */

:root{
  --bg:#F4F7F6;
  --surface:#FFFFFF;
  --surface-2:#EAF1EE;
  --ink:#1B2B28;
  --muted:#5E726E;
  --primary:#1C5A55;
  --primary-700:#143F3B;
  --accent:#4F9B8C;
  --aqua:#C2E4DB;
  --warm:#E7D4C1;
  --warm-deep:#C89B79;
  --line:#DCE6E2;
  --shadow:0 18px 50px -28px rgba(20,63,59,.45);
  --shadow-sm:0 8px 24px -16px rgba(20,63,59,.35);
  --radius:18px;
  --maxw:1180px;
  --arch:140px 140px 20px 20px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:clamp(16px,1rem + .15vw,17.5px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}

h1,h2,h3,h4{
  font-family:"Newsreader",Georgia,serif;
  font-weight:500;
  line-height:1.12;
  letter-spacing:-.01em;
  margin:0 0 .4em;
  color:var(--ink);
}
h1{font-size:clamp(2.4rem,5.2vw,3.9rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}
h3{font-size:clamp(1.2rem,2vw,1.45rem)}
p{margin:0 0 1rem}
.serif-it{font-family:"Newsreader",serif;font-style:italic;font-weight:400}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px)}
.section{padding:clamp(56px,8vw,104px) 0}
.section--tight{padding:clamp(40px,5vw,64px) 0}

.eyebrow{
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:.6em;
  margin:0 0 1rem;
}
.eyebrow::before{
  content:"";width:26px;height:1.5px;background:var(--accent);display:inline-block;
}

.lead{font-size:1.15rem;color:var(--muted);max-width:60ch}
.muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-weight:600;font-size:.98rem;
  padding:.85em 1.5em;border-radius:999px;
  text-decoration:none;border:1.5px solid transparent;
  transition:transform .18s ease,background .18s ease,color .18s ease,box-shadow .18s ease;
  cursor:pointer;
}
.btn--primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--primary-700);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--primary);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--primary);transform:translateY(-2px)}
.btn svg{width:18px;height:18px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(244,247,246,.82);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.7em;text-decoration:none;color:var(--ink)}
.brand__mark{width:38px;height:38px;flex:none}
.brand__txt{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:"Newsreader",serif;font-size:1.18rem;font-weight:500}
.brand__sub{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.nav__links{display:flex;align-items:center;gap:.4rem;list-style:none;margin:0;padding:0}
.nav__links a{
  text-decoration:none;color:var(--ink);font-weight:500;font-size:.97rem;
  padding:.5em .9em;border-radius:999px;transition:background .15s,color .15s;
}
.nav__links a:hover{background:var(--surface-2)}
.nav__links a.active{color:var(--primary);background:var(--surface-2)}
.nav__cta{margin-left:.5rem}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--ink)}
.nav__toggle svg{width:26px;height:26px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden}
.hero__contour{
  position:absolute;inset:0;pointer-events:none;opacity:.5;
}
.hero__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,68px);
  align-items:center;padding:clamp(40px,6vw,76px) 0 clamp(48px,7vw,90px);
  position:relative;
}
.hero h1{margin-bottom:.25em}
.hero__loc{display:inline-flex;align-items:center;gap:.5em;color:var(--accent);font-weight:600;font-size:.95rem;margin-bottom:1.2rem}
.hero__loc svg{width:17px;height:17px}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.hero__media{position:relative}
.arch{
  border-radius:var(--arch);
  overflow:hidden;background:var(--surface-2);
  box-shadow:var(--shadow);
  aspect-ratio:4/5;
}
.arch img{width:100%;height:100%;object-fit:cover}
.hero__media .badge{
  position:absolute;left:-22px;bottom:34px;
  background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:.85rem 1.1rem;box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:.7rem;max-width:230px;
}
.hero__media .badge .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);flex:none;box-shadow:0 0 0 4px var(--aqua)}
.hero__media .badge span{font-size:.86rem;line-height:1.3;color:var(--muted)}
.hero__media .badge strong{color:var(--ink);font-weight:700;display:block}

/* ---------- Trust strip ---------- */
.strip{background:var(--primary);color:#fff}
.strip__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,4vw,48px);padding:clamp(32px,4vw,46px) 0}
.strip__item{display:flex;gap:.9rem;align-items:flex-start}
.strip__item svg{width:26px;height:26px;flex:none;color:var(--aqua);margin-top:3px}
.strip__item h3{color:#fff;font-size:1.08rem;margin-bottom:.15em}
.strip__item p{color:rgba(255,255,255,.78);font-size:.92rem;margin:0}

/* ---------- Generic section head ---------- */
.head{max-width:62ch;margin-bottom:clamp(34px,4vw,52px)}
.head--center{margin-left:auto;margin-right:auto;text-align:center}
.head--center .eyebrow{justify-content:center}

/* ---------- Cards (soins) ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(16px,2vw,24px)}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(22px,3vw,30px);transition:transform .2s ease,box-shadow .2s ease,border-color .2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:transparent}
.card__ico{
  width:50px;height:50px;border-radius:14px;display:grid;place-items:center;
  background:var(--surface-2);color:var(--primary);margin-bottom:1.1rem;
}
.card__ico svg{width:26px;height:26px}
.card h3{margin-bottom:.35em}
.card p{color:var(--muted);font-size:.95rem;margin:0}

/* ---------- Split (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,68px);align-items:center}
.split--rev .split__media{order:2}
.split__media .arch{aspect-ratio:5/6}
.split ul{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:.7rem}
.split li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink)}
.split li svg{width:20px;height:20px;color:var(--accent);flex:none;margin-top:4px}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,34px)}
.member{text-align:center}
.member .arch{aspect-ratio:3/4;margin-bottom:1.1rem}
.member__ph{width:100%;height:100%;display:grid;place-items:center;background:linear-gradient(160deg,var(--surface-2),var(--aqua))}
.member__ph svg{width:46%;height:46%;color:var(--accent);opacity:.55}
.member h3{margin-bottom:.1em}
.member__role{color:var(--accent);font-weight:600;font-size:.9rem;letter-spacing:.02em;margin-bottom:.6rem}
.member p{color:var(--muted);font-size:.93rem;margin:0}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery a{border-radius:14px;overflow:hidden;display:block;background:var(--surface-2);box-shadow:var(--shadow-sm)}
.gallery img{width:100%;height:100%;object-fit:cover;aspect-ratio:1;transition:transform .4s ease}
.gallery a:hover img{transform:scale(1.05)}
.gallery a:nth-child(1){grid-row:span 2;aspect-ratio:auto}
.gallery a:nth-child(1) img{aspect-ratio:3/4}

/* ---------- Timeline (parcours / formations) ---------- */
.timeline{position:relative;max-width:780px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-item{position:relative;padding:0 0 1.6rem 42px}
.tl-item::before{content:"";position:absolute;left:0;top:6px;width:20px;height:20px;border-radius:50%;background:var(--surface);border:2px solid var(--accent)}
.tl-item:last-child{padding-bottom:0}
.tl-year{font-weight:700;color:var(--primary);font-size:.95rem}
.tl-item p{margin:.1rem 0 0;color:var(--muted);font-size:.95rem}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(135deg,var(--primary),var(--primary-700));
  color:#fff;border-radius:26px;overflow:hidden;position:relative;
  padding:clamp(38px,5vw,64px);text-align:center;
}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.82);max-width:52ch;margin:0 auto 1.6rem}
.cta-band .btn--primary{background:#fff;color:var(--primary)}
.cta-band .btn--primary:hover{background:var(--aqua)}
.cta-band__deco{position:absolute;inset:0;opacity:.18;pointer-events:none}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,4vw,52px);align-items:start}
.info-list{list-style:none;margin:0;padding:0;display:grid;gap:1.3rem}
.info-list li{display:flex;gap:1rem;align-items:flex-start}
.info-list .ico{width:46px;height:46px;border-radius:13px;background:var(--surface-2);color:var(--primary);display:grid;place-items:center;flex:none}
.info-list .ico svg{width:22px;height:22px}
.info-list .label{font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:.15rem}
.info-list a{color:var(--primary);font-weight:600;text-decoration:none}
.info-list a:hover{text-decoration:underline}
.map-frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);min-height:380px}
.map-frame iframe{width:100%;height:100%;min-height:380px;border:0;display:block}
.hours{list-style:none;margin:.4rem 0 0;padding:0}
.hours li{display:flex;justify-content:space-between;padding:.45rem 0;border-bottom:1px dashed var(--line);font-size:.95rem}
.hours li:last-child{border-bottom:0}
.hours span:last-child{color:var(--muted)}

/* ---------- Placeholder marker (contenu à fournir) ---------- */
.todo{
  background:repeating-linear-gradient(45deg,#FFF7E8,#FFF7E8 10px,#FFF1D6 10px,#FFF1D6 20px);
  border:1px dashed var(--warm-deep);border-radius:8px;
  padding:.1em .5em;font-size:.82em;color:#8a6a3f;font-weight:600;white-space:nowrap;
}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:var(--surface-2);border-bottom:1px solid var(--line)}
.page-hero .wrap{padding-top:clamp(46px,6vw,76px);padding-bottom:clamp(46px,6vw,76px)}
.page-hero h1{margin-bottom:.2em}
.page-hero p{color:var(--muted);max-width:58ch;margin:0}

/* ---------- Prose (legal pages) ---------- */
.prose{max-width:780px}
.prose h2{margin-top:2.2rem;font-size:1.5rem}
.prose h3{margin-top:1.6rem}
.prose p,.prose li{color:var(--muted)}
.prose ul{padding-left:1.2rem;display:grid;gap:.4rem}
.prose a{color:var(--primary)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#cfdad7;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(28px,4vw,56px);padding:clamp(48px,6vw,72px) 0 clamp(28px,3vw,40px)}
.site-footer .brand__name{color:#fff}
.site-footer .brand__sub{color:#8fa6a1}
.footer-col h4{font-family:"Hanken Grotesk",sans-serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#8fa6a1;margin:0 0 1rem;font-weight:700}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.footer-col a{color:#cfdad7;text-decoration:none;font-size:.95rem}
.footer-col a:hover{color:#fff}
.footer-col p{color:#a9bbb7;font-size:.92rem;margin:.3rem 0 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.4rem 0;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#8fa6a1}
.footer-bottom a{color:#8fa6a1;text-decoration:none}
.footer-bottom a:hover{color:#fff}

/* ---------- Reveal animation (only when JS is active) ---------- */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero__grid,.split,.contact-grid{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .hero__media{max-width:440px;margin:0 auto}
  .strip__grid{grid-template-columns:1fr;gap:18px}
  .team{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery a:nth-child(1){grid-row:auto}
  .gallery a:nth-child(1) img{aspect-ratio:1}
}
@media (max-width:680px){
  .nav__links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--surface);padding:14px 20px 22px;gap:.2rem;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .3s ease;
  }
  .nav__links.open{transform:translateY(0)}
  .nav__links a{padding:.8em .6em}
  .nav__cta{margin:.4rem 0 0}
  .nav__toggle{display:inline-flex}
  .team{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero__media .badge{left:0}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js .reveal{opacity:1;transform:none}
}

:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}
