/*
Theme Name: Beaudition
Theme URI: https://www.beaudition.fr
Author: Beaudition - GrandAudition Boulogne-Billancourt
Author URI: https://www.beaudition.fr
Description: Thème vitrine premium pour Beaudition, audioprothésiste GrandAudition à Boulogne-Billancourt. Couleurs GrandAudition (anthracite + vert anis), prise de rendez-vous Doctolib et formulaire de contact intégré.
Version: 1.2.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: beaudition
*/

/* ===== Variables ===== */
:root{
  --bg-base:#F3F2EF;
  --bg-surface:#FFFFFF;
  --charcoal:#1F2022;
  --charcoal-light:#2D2E32;
  --orange:#EF7D00;
  --orange-hover:#D96E00;
  --orange-tint:rgba(239,125,0,.12);
  --grad:linear-gradient(270deg,#EF7D00,#F6920A 52%,#FFB11A);
  --grad-hover:linear-gradient(270deg,#D96E00,#E5850A 52%,#F39E12);
  /* legacy aliases */
  --lime:#EF7D00;
  --lime-hover:#D96E00;
  --text-main:#1F2022;
  --text-muted:#5C5E62;
  --border-light:#E6E2DB;
  --radius:1rem;
  --maxw:1200px;
}

/* ===== Reset / base ===== */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Work Sans",-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg-base);
  color:var(--text-main);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Outfit",sans-serif;color:var(--charcoal);margin:0;line-height:1.1;}
p{margin:0;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--lime);color:var(--charcoal);}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.section{padding:96px 0;}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.8rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:18px;}
.eyebrow .bar{width:32px;height:1px;background:var(--lime);}
.lead{font-size:1.15rem;color:var(--text-muted);max-width:620px;}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:56px;padding:0 30px;border-radius:999px;font-weight:600;font-size:1.05rem;cursor:pointer;border:none;transition:background-color .25s ease,box-shadow .25s ease,color .25s ease,transform .25s ease;}
.btn svg{width:20px;height:20px;}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 2px 8px rgba(239,125,0,.25);}
.btn-primary:hover{background:var(--grad-hover);box-shadow:0 10px 24px rgba(239,125,0,.3);}
.btn-dark{background:var(--charcoal);color:#fff;}
.btn-dark:hover{background:var(--charcoal-light);}
.btn-outline{background:transparent;color:var(--charcoal);border:2px solid var(--charcoal);}
.btn-outline:hover{background:var(--charcoal);color:#fff;}
.btn-sm{height:48px;padding:0 24px;font-size:1rem;}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background-color .3s ease,box-shadow .3s ease,border-color .3s ease;border-bottom:1px solid transparent;}
.site-header.is-scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(16px);box-shadow:0 2px 12px rgba(0,0,0,.05);border-bottom-color:var(--border-light);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:80px;}
.brand{display:flex;flex-direction:column;line-height:1;}
.brand .custom-logo,.brand img{max-height:56px;width:auto;display:block;}
.brand .name{font-family:"Outfit",sans-serif;font-size:1.55rem;font-weight:600;letter-spacing:-.01em;color:var(--charcoal);}
.brand .sub{font-size:.62rem;text-transform:uppercase;letter-spacing:.25em;color:var(--text-muted);margin-top:4px;}
.nav{display:flex;align-items:center;gap:34px;}
.nav a{font-size:.95rem;font-weight:500;color:rgba(31,32,34,.8);}
.nav a:hover{color:var(--charcoal);}
.header-cta{display:flex;align-items:center;gap:14px;}
.header-phone{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--charcoal);white-space:nowrap;}
.header-phone:hover{color:var(--lime-hover);}
.menu-toggle{display:none;background:none;border:none;color:var(--charcoal);cursor:pointer;padding:6px;}
.mobile-menu{display:none;background:#fff;border-top:1px solid var(--border-light);padding:24px;}
.mobile-menu.open{display:block;}
.mobile-menu a{display:block;font-size:1.1rem;font-weight:500;padding:8px 0;color:var(--charcoal);}
.mobile-menu .btn{width:100%;margin-top:10px;}

/* ===== Hero ===== */
.hero{padding:150px 0 80px;background:var(--bg-base);}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.hero h1{font-size:3.5rem;font-weight:300;letter-spacing:-.02em;}
.hero h1 strong{font-weight:600;}
.hero .lead{margin-top:26px;font-size:1.25rem;}
.hero-actions{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap;}
.hero-trust{margin-top:38px;display:flex;align-items:center;gap:16px;}
.stars{display:flex;gap:2px;color:var(--lime);}
.hero-trust p{font-size:.9rem;color:var(--text-muted);}
.hero-media{position:relative;}
.hero-media img{width:100%;height:520px;object-fit:cover;border-radius:24px;box-shadow:0 30px 60px rgba(0,0,0,.18);}
.hero-badge{position:absolute;bottom:-24px;left:24px;background:var(--charcoal);color:#fff;border-radius:18px;padding:20px 28px;box-shadow:0 20px 40px rgba(0,0,0,.2);}
.hero-badge .big{font-family:"Outfit",sans-serif;font-size:2rem;font-weight:600;color:var(--lime);}
.hero-badge .small{font-size:.85rem;color:rgba(255,255,255,.8);margin-top:4px;}

/* ===== Services ===== */
.services{background:#fff;}
.section-head{max-width:640px;margin-bottom:56px;}
.section-head h2{font-size:2.4rem;font-weight:400;letter-spacing:-.01em;margin-top:14px;}
.section-head p{margin-top:16px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.card{background:var(--bg-base);border:1px solid var(--border-light);border-radius:var(--radius);padding:32px;height:100%;transition:transform .3s ease,box-shadow .3s ease;}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(0,0,0,.07);}
.icon-box{width:56px;height:56px;border-radius:16px;background:var(--orange-tint);display:flex;align-items:center;justify-content:center;margin-bottom:22px;color:var(--orange);}
.icon-box svg{width:28px;height:28px;}
.card h3{font-size:1.25rem;font-weight:600;}
.card p{margin-top:12px;color:var(--text-muted);}

/* ===== Why / dark ===== */
.why{background:var(--charcoal);color:#fff;}
.why .eyebrow{color:var(--lime);}
.why .section-head h2{color:#fff;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.card-dark{background:var(--charcoal-light);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:32px;height:100%;}
.card-dark .icon-box{background:var(--orange);color:#fff;}
.card-dark h3{color:#fff;font-size:1.25rem;font-weight:600;}
.card-dark p{margin-top:12px;color:rgba(255,255,255,.7);}
.brands{margin-top:64px;text-align:center;}
.brands .label{font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;color:rgba(255,255,255,.5);margin-bottom:22px;}
.brands-list{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;}
.brands-list span{font-family:"Outfit",sans-serif;font-size:1.5rem;font-weight:500;color:rgba(255,255,255,.4);transition:color .25s ease;}
.brands-list span:hover{color:#fff;}

/* ===== About ===== */
.about{background:var(--bg-base);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.about ul{list-style:none;padding:0;margin:30px 0 0;}
.about li{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;font-size:1.1rem;}
.tick{width:24px;height:24px;border-radius:50%;background:var(--lime);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:3px;}
.tick svg{width:14px;height:14px;color:var(--charcoal);}
.about-photos{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.about-photos img{height:320px;object-fit:cover;border-radius:18px;box-shadow:0 14px 30px rgba(0,0,0,.12);}
.about-photos img:nth-child(2){margin-top:32px;}

/* ===== Gallery ===== */
.gallery{background:#fff;}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.gallery-grid figure{margin:0;overflow:hidden;border-radius:18px;}
.gallery-grid img{width:100%;height:220px;object-fit:cover;transition:transform .5s ease;}
.gallery-grid figure:hover img{transform:scale(1.06);}
.gallery-grid .tall{grid-row:span 2;}
.gallery-grid .tall img{height:100%;min-height:300px;}

/* ===== Contact ===== */
.contact{background:var(--bg-base);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.contact-card{background:#fff;border:1px solid var(--border-light);border-radius:24px;padding:40px;box-shadow:0 2px 10px rgba(0,0,0,.03);}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px;}
.info-row{display:flex;align-items:flex-start;gap:12px;min-width:0;}
.info-ico{width:40px;height:40px;border-radius:12px;background:rgba(196,214,0,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--charcoal);}
.info-ico svg{width:20px;height:20px;}
.info-row .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);}
.info-row .val{font-weight:500;color:var(--charcoal);word-break:break-word;line-height:1.3;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.field{width:100%;padding:14px 16px;border:1px solid var(--border-light);border-radius:12px;background:#fff;font-family:inherit;font-size:1rem;color:var(--charcoal);margin-bottom:14px;transition:box-shadow .2s,border-color .2s;}
.field:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px var(--lime);}
textarea.field{resize:vertical;min-height:120px;}
.form-note{margin-top:8px;font-size:.85rem;}
.form-note.ok{color:#3a7d18;}
.form-note.err{color:#c0392b;}
.hp{position:absolute;left:-9999px;}
.hours-card{background:var(--charcoal);color:#fff;border-radius:24px;padding:40px;}
.hours-card h3{color:#fff;display:flex;align-items:center;gap:12px;font-size:1.25rem;font-weight:600;margin-bottom:20px;}
.hours-card h3 svg{width:22px;height:22px;color:var(--lime);}
.hours-list{list-style:none;padding:0;margin:0;}
.hours-list li{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1);}
.hours-list li:last-child{border-bottom:none;}
.hours-list .day{color:rgba(255,255,255,.8);}
.hours-list .closed{color:rgba(255,255,255,.4);}
.map-wrap{margin-top:24px;border-radius:24px;overflow:hidden;border:1px solid var(--border-light);}
.map-wrap iframe{width:100%;height:300px;border:0;display:block;}

/* ===== Footer ===== */
.site-footer{background:var(--charcoal);color:#fff;padding:64px 0 32px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1);}
.site-footer .name{font-family:"Outfit",sans-serif;font-size:1.5rem;font-weight:600;}
.site-footer .tag{font-size:.65rem;text-transform:uppercase;letter-spacing:.25em;color:var(--lime);margin-top:4px;}
.site-footer p{color:rgba(255,255,255,.7);margin-top:18px;}
.footer-col h4{font-size:1rem;font-weight:600;color:#fff;margin-bottom:16px;}
.footer-col ul{list-style:none;padding:0;margin:0;}
.footer-col li{margin-bottom:10px;}
.footer-col a,.footer-col li{color:rgba(255,255,255,.7);}
.footer-col a:hover{color:var(--lime);}
.footer-contact li{display:flex;align-items:flex-start;gap:10px;}
.footer-contact svg{width:18px;height:18px;color:var(--lime);flex-shrink:0;margin-top:3px;}
.footer-bottom{padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.85rem;color:rgba(255,255,255,.5);}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal.is-visible{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}html{scroll-behavior:auto;}}

/* ===== Responsive ===== */
@media (max-width:1024px){
  .nav,.header-cta{display:none;}
  .menu-toggle{display:block;}
  .grid-4{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:860px){
  .section{padding:64px 0;}
  .hero{padding:120px 0 60px;}
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr;}
  .hero h1{font-size:2.4rem;}
  .hero-media{order:-1;}
  .hero-media img{height:340px;}
  .grid-3{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr;}
  .section-head h2{font-size:1.9rem;}
  .about-photos img:nth-child(2){margin-top:0;}
}
@media (max-width:520px){
  .grid-4,.info-grid,.form-row{grid-template-columns:1fr;}
  .btn{width:100%;}
}

/* ===== Nav dropdown ===== */
.nav .has-sub{position:relative;}
.nav .sub-trigger{display:inline-flex;align-items:center;gap:5px;}
.nav .chev{font-size:.7rem;}
.nav .submenu{position:absolute;top:100%;left:0;padding-top:14px;min-width:300px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s ease,transform .2s ease,visibility .2s;}
.nav .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0);}
.nav .submenu{background:#fff;border:1px solid var(--border-light);border-radius:14px;box-shadow:0 18px 44px rgba(0,0,0,.12);padding:10px;}
.nav .submenu a{display:block;padding:11px 14px;border-radius:9px;font-size:.95rem;color:var(--charcoal);}
.nav .submenu a:hover{background:var(--orange-tint);color:var(--orange);}

/* ===== Service cards as links ===== */
a.card-link{display:flex;flex-direction:column;text-decoration:none;}
.card-more{margin-top:16px;font-weight:600;color:var(--orange);}
.card-link:hover .card-more{text-decoration:underline;}

/* ===== Mobile menu label ===== */
.mm-label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin:6px 0 4px;}
.mm-sub{padding-left:12px !important;border-left:2px solid var(--orange);}

/* ===== Service pages ===== */
.svc-page{padding-top:80px;}
.svc-hero{background:var(--bg-base);padding:56px 0 40px;}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-muted);margin-bottom:26px;}
.breadcrumb a{color:var(--text-muted);}
.breadcrumb a:hover{color:var(--orange);}
.svc-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;}
.svc-hero h1{font-size:2.8rem;font-weight:400;letter-spacing:-.01em;}
.svc-hero-media img{width:100%;height:360px;object-fit:cover;border-radius:24px;box-shadow:0 24px 50px rgba(0,0,0,.15);}
.svc-features{background:#fff;}
.svc-steps{background:var(--bg-base);}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.step{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius);padding:28px;}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--grad);color:#fff;font-family:"Outfit",sans-serif;font-weight:600;font-size:1.2rem;margin-bottom:16px;}
.step h3{font-size:1.1rem;font-weight:600;}
.step p{margin-top:8px;color:var(--text-muted);}
.svc-faq{background:#fff;}
.faq{max-width:820px;}
.faq-item{border:1px solid var(--border-light);border-radius:14px;padding:0 22px;margin-bottom:14px;background:var(--bg-base);}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 0;font-family:"Outfit",sans-serif;font-weight:600;font-size:1.1rem;color:var(--charcoal);display:flex;justify-content:space-between;align-items:center;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";color:var(--orange);font-size:1.5rem;font-weight:400;}
.faq-item[open] summary::after{content:"–";}
.faq-item p{padding:0 0 20px;color:var(--text-muted);}
.cta-band{background:var(--charcoal);color:#fff;padding:56px 0;}
.cta-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;}
.cta-band h2{color:#fff;font-size:1.9rem;font-weight:400;}
.cta-band p{color:rgba(255,255,255,.7);margin-top:8px;}
.svc-related{background:var(--bg-base);}
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.related-card{display:flex;flex-direction:column;justify-content:space-between;gap:18px;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius);padding:26px;min-height:130px;transition:transform .3s ease,box-shadow .3s ease;}
.related-card:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(0,0,0,.08);}
.related-card h3{font-size:1.15rem;font-weight:600;}
.related-arrow{color:var(--orange);font-weight:600;}

@media (max-width:860px){
  .svc-hero-grid{grid-template-columns:1fr;}
  .svc-hero-media{order:-1;}
  .svc-hero h1{font-size:2rem;}
  .steps-grid{grid-template-columns:1fr 1fr;}
  .related-grid{grid-template-columns:1fr 1fr;}
  .cta-inner{flex-direction:column;align-items:flex-start;}
}
@media (max-width:520px){
  .steps-grid,.related-grid{grid-template-columns:1fr;}
}
