/* =========================================================
   SMILE ACT — Cabinet dentaire | Feuille de style principale
   Deux ambiances : "clair" (blanc/beige/or rosé) & "sombre" (or & noir)
   ========================================================= */

:root{
  /* Thème clair par défaut */
  --bg:#FBF8F4;
  --bg-alt:#F4EEE5;
  --surface:#FFFFFF;
  --text:#2A2521;
  --muted:#6E665C;
  --gold:#B0894F;
  --gold-soft:#C9A98F;     /* or rosé */
  --gold-deep:#9A7536;
  --line:#E8DFD2;
  --shadow:0 18px 50px -20px rgba(70,52,30,.25);
  --shadow-sm:0 8px 24px -12px rgba(70,52,30,.20);
  --hero-grad:linear-gradient(135deg,#FBF8F4 0%,#F3E9DC 48%,#EFE0D2 100%);
  --eyebrow:#A98A57;
}

html[data-theme="sombre"]{
  --bg:#0E0D0B;
  --bg-alt:#15130F;
  --surface:#1A1713;
  --text:#F1EADD;
  --muted:#B6AB97;
  --gold:#D2AC61;
  --gold-soft:#E2C79C;
  --gold-deep:#B98F3F;
  --line:#2B2620;
  --shadow:0 24px 60px -22px rgba(0,0,0,.75);
  --shadow-sm:0 10px 30px -14px rgba(0,0,0,.65);
  --hero-grad:radial-gradient(120% 120% at 80% 0%,#1d1812 0%,#100e0b 60%,#0b0a08 100%);
  --eyebrow:#D2AC61;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Jost',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  transition:background .4s ease,color .4s ease;
}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;line-height:1.12;margin:0 0 .5em;letter-spacing:.2px}
h1{font-size:clamp(2.6rem,5.5vw,4.4rem)}
h2{font-size:clamp(2rem,3.8vw,3rem)}
h3{font-size:1.5rem}
p{margin:0 0 1.1em}
a{color:var(--gold-deep);text-decoration:none;transition:color .25s}
a:hover{color:var(--gold)}
img{max-width:100%;display:block}
.container{width:min(1180px,92vw);margin-inline:auto}
section{padding:clamp(3.5rem,7vw,6.5rem) 0}

/* Eyebrow / labels */
.eyebrow{
  display:inline-block;font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--eyebrow);font-weight:600;margin-bottom:1rem;
}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);
  vertical-align:middle;margin-right:.8rem;transform:translateY(-3px)}
.lead{font-size:1.18rem;color:var(--muted);max-width:62ch}
.center{text-align:center}
.center .lead{margin-inline:auto}
.muted{color:var(--muted)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:.86rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.95rem 1.9rem;border-radius:2px;border:1px solid var(--gold);
  transition:all .3s ease;font-weight:500;
}
.btn-primary{background:var(--gold);color:#fff;border-color:var(--gold)}
html[data-theme="sombre"] .btn-primary{color:#14110c}
.btn-primary:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent;color:var(--text)}
.btn-ghost:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
html[data-theme="sombre"] .btn-ghost:hover{color:#14110c}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.85rem 0}
.brand{display:flex;align-items:center;gap:.7rem;font-family:'Cormorant Garamond',serif}
.brand svg{width:38px;height:38px;flex:none}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-size:1.5rem;font-weight:600;letter-spacing:.5px;color:var(--text)}
.brand-sub{font-family:'Jost',sans-serif;font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none;margin:0;padding:0}
.nav-links a{
  font-size:.82rem;letter-spacing:.06em;color:var(--text);text-transform:uppercase;font-weight:400;
  position:relative;padding:.3rem 0;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-links a:hover{color:var(--gold-deep)}
.nav-actions{display:flex;align-items:center;gap:.9rem}
.theme-toggle{
  width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--surface);
  display:grid;place-items:center;cursor:pointer;color:var(--text);transition:all .3s;
}
.theme-toggle:hover{border-color:var(--gold);color:var(--gold)}
.theme-toggle svg{width:18px;height:18px}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--text);padding:6px}
.menu-btn svg{width:26px;height:26px}

/* Hero */
.hero{background:var(--hero-grad);position:relative;overflow:hidden;padding:clamp(4rem,9vw,8rem) 0 clamp(3.5rem,7vw,6rem)}
.hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--gold) 30%,transparent) 1px,transparent 0);background-size:38px 38px;opacity:.25;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;position:relative;z-index:1}
.hero h1{margin-bottom:.3em}
.hero .lead{margin-bottom:2rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-card{
  background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:2rem;box-shadow:var(--shadow);
}
.hero-card h3{color:var(--gold-deep);margin-bottom:1rem}
.hero-facts{list-style:none;margin:0;padding:0;display:grid;gap:1rem}
.hero-facts li{display:flex;gap:.8rem;align-items:flex-start;font-size:.96rem}
.hero-facts svg{width:20px;height:20px;color:var(--gold);flex:none;margin-top:3px}

/* Generic grids */
.grid{display:grid;gap:1.6rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:2rem;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--gold) 45%,var(--line))}
.card .ic{width:46px;height:46px;color:var(--gold);margin-bottom:1.1rem}
.card h3{margin-bottom:.5rem}
.card p{font-size:.96rem;color:var(--muted);margin-bottom:1rem}
.card a.more{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500}

/* Section helpers */
.section-alt{background:var(--bg-alt)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.divider{width:60px;height:2px;background:var(--gold);margin:1.4rem 0}
.check-list{list-style:none;padding:0;margin:1.4rem 0;display:grid;gap:.8rem}
.check-list li{display:flex;gap:.7rem;align-items:flex-start}
.check-list svg{width:19px;height:19px;color:var(--gold);flex:none;margin-top:5px}

/* Team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.member{background:var(--surface);border:1px solid var(--line);border-radius:6px;overflow:hidden;text-align:center;padding-bottom:1.6rem;transition:transform .3s,box-shadow .3s}
.member:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.member .avatar{height:150px;background:var(--hero-grad);display:grid;place-items:center;border-bottom:1px solid var(--line)}
.member .avatar svg{width:62px;height:62px;color:var(--gold)}
.member h3{margin:1.2rem 0 .1rem;font-size:1.35rem}
.member .role{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:500}
.member .meta{font-size:.85rem;color:var(--muted);padding:0 1.2rem;margin-top:.6rem}

/* Steps */
.steps{counter-reset:step;display:grid;gap:1.4rem}
.step{display:flex;gap:1.3rem;align-items:flex-start}
.step .num{counter-increment:step;flex:none;width:46px;height:46px;border:1px solid var(--gold);border-radius:50%;display:grid;place-items:center;font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--gold-deep)}
.step .num::before{content:counter(step,decimal-leading-zero)}
.step h4{font-family:'Jost',sans-serif;font-weight:600;font-size:1.02rem;margin:.4rem 0 .3rem;text-transform:uppercase;letter-spacing:.05em}

/* FAQ */
.faq{display:grid;gap:0;max-width:820px;margin-inline:auto}
.faq details{border-bottom:1px solid var(--line);padding:1.2rem 0}
.faq summary{cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:1.35rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--text)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:1.6rem;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:1rem;color:var(--muted);font-size:.98rem}

/* CTA band */
.cta-band{background:var(--hero-grad);border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.cta-band h2{margin-bottom:.4rem}

/* Page hero (interior) */
.page-hero{background:var(--bg-alt);border-bottom:1px solid var(--line);padding:clamp(3rem,6vw,5rem) 0 clamp(2.4rem,4vw,3.4rem)}
.breadcrumb{font-size:.78rem;letter-spacing:.04em;color:var(--muted);margin-bottom:1rem;text-transform:uppercase}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--gold)}

/* Article / prose */
.prose{max-width:760px;margin-inline:auto}
.prose h2{margin-top:2.2rem}
.prose h3{margin-top:1.8rem;color:var(--gold-deep)}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:.5rem}
.prose blockquote{border-left:3px solid var(--gold);margin:1.6rem 0;padding:.4rem 0 .4rem 1.4rem;font-style:italic;color:var(--muted)}
.meta-line{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}

/* Blog list */
.post-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.post-card .thumb{height:170px;background:var(--hero-grad);display:grid;place-items:center;border-bottom:1px solid var(--line)}
.post-card .thumb svg{width:54px;height:54px;color:var(--gold)}
.post-card .body{padding:1.6rem}
.post-card .tag{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.post-card h3{margin:.5rem 0;font-size:1.45rem}
.post-card p{font-size:.92rem;color:var(--muted)}

/* Contact */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.info-card{background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:1.8rem;text-align:center}
.info-card svg{width:30px;height:30px;color:var(--gold);margin-bottom:.8rem}
.info-card h4{font-family:'Jost',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;font-weight:600;margin:0 0 .4rem}
.map-wrap{border:1px solid var(--line);border-radius:6px;overflow:hidden;min-height:340px;background:var(--bg-alt)}
.map-wrap iframe{width:100%;height:100%;min-height:340px;border:0;filter:grayscale(.2)}

/* Footer */
.site-footer{background:var(--bg-alt);border-top:1px solid var(--line);padding:3.5rem 0 1.6rem}
html[data-theme="sombre"] .site-footer{background:#0a0907}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.2rem;margin-bottom:2.4rem}
.footer-grid h4{font-family:'Jost',sans-serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:1rem}
.footer-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer-grid a{color:var(--muted);font-size:.9rem}
.footer-grid a:hover{color:var(--gold)}
.footer-grid p{font-size:.9rem;color:var(--muted)}
.footer-bottom{border-top:1px solid var(--line);padding-top:1.4rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.78rem;color:var(--muted)}
.footer-disclaimer{font-size:.76rem;color:var(--muted);max-width:80ch;margin-top:1rem;line-height:1.6}

/* Responsive */
@media(max-width:900px){
  .hero-grid,.split{grid-template-columns:1fr;gap:2.2rem}
  .grid-3,.team-grid,.info-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(320px,82vw);flex-direction:column;align-items:flex-start;
    background:var(--surface);padding:5rem 2rem;gap:1.4rem;transform:translateX(100%);transition:transform .35s ease;
    box-shadow:var(--shadow);border-left:1px solid var(--line);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1rem}
  .menu-btn{display:block}
}
@media(max-width:560px){
  .grid-3,.team-grid,.info-grid,.grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  body{font-size:16px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}

/* --- Hero vidéo dynamique (accueil) --- */
.hero{position:relative}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-video{width:100%;height:100%;object-fit:cover;display:block}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(115deg,color-mix(in srgb,var(--bg) 88%,transparent) 0%,color-mix(in srgb,var(--bg) 62%,transparent) 60%,color-mix(in srgb,var(--bg) 42%,transparent) 100%)}
.hero>.container{position:relative;z-index:2}

/* --- Photos de profil équipe --- */
.member .avatar{height:248px;padding:0}
.member .avatar-img{width:100%;height:100%;object-fit:cover;object-position:center 18%;display:block}

/* --- Lisibilité des noms de l'équipe (contraste renforcé) --- */
.member h3{color:var(--text);font-weight:600;font-size:1.45rem;margin-top:1.1rem;opacity:1}
html[data-theme="sombre"] .member h3{color:#F8F2E7}
.member .role{color:var(--gold-deep)}
html[data-theme="sombre"] .member .role{color:var(--gold-soft)}
.member .meta{color:var(--muted)}

/* --- Prise de RDV par praticien (Doctolib) --- */
.rdv-dd{position:relative}
.rdv-toggle{cursor:pointer}
.rdv-menu{position:absolute;right:0;top:calc(100% + 10px);min-width:266px;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:.5rem;list-style:none;margin:0;display:none;z-index:60}
.rdv-dd.open .rdv-menu{display:block}
.rdv-menu .rdv-head{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:.5rem .7rem .3rem}
.rdv-menu li a{display:block;padding:.62rem .7rem;border-radius:6px;color:var(--text);font-size:.93rem;text-transform:none;letter-spacing:0}
.rdv-menu li a:hover{background:var(--bg-alt);color:var(--gold-deep)}
.rdv-menu .rdv-foot{border-top:1px solid var(--line);margin-top:.3rem}
.rdv-menu .rdv-foot a{font-size:.8rem;color:var(--muted)}
.rdv-card-btn{margin-top:1.1rem;font-size:.72rem;padding:.6rem 1.2rem}
.rdv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1.4rem;max-width:920px;margin-inline:auto}
.rdv-card{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:1.7rem 1.4rem;text-align:center;transition:transform .3s,box-shadow .3s}
.rdv-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--gold) 45%,var(--line))}
.rdv-name{font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:var(--text)}
.rdv-role{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);margin:.35rem 0 1.2rem}
@media(max-width:900px){.rdv-dd{width:100%}.rdv-menu{position:static;display:block;box-shadow:none;border:1px solid var(--line);min-width:0;margin-top:.6rem}}

/* Descendre un peu les noms de l'équipe sous la photo */
.member h3{margin-top:2rem}
.member .avatar{margin-bottom:.2rem}

/* Réseaux sociaux (footer) */
.footer-social{display:flex;gap:.7rem;margin-top:1rem}
.footer-social a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--muted);transition:all .25s}
.footer-social a:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.footer-social svg{width:18px;height:18px}
