/* page-prestations.css — CSS complet de la page */


/* ═══════════════════════════════════════
   TOKENS — identiques à la home v7
═══════════════════════════════════════ */
:root {
  --navy:       #1b375f;
  --navy-dk:    #142843;
  --navy-md:    #1f3f6e;
  --gold:       #c49d74;
  --gold-dk:    #a8824f;
  --gold-lt:    #d4b48e;
  --gold-pale:  #f5ede0;
  --gold-ultra: #faf6f0;
  --gold-line:  rgba(196,157,116,.25);
  --white:      #ffffff;
  --off:        #faf9f7;
  --cream:      #f4f0ea;
  --ink:        #1a1a1a;
  --ink-md:     #3d3d3d;
  --ink-mt:     #6b7280;
  --border:     rgba(196,157,116,.18);
  --border-md:  rgba(196,157,116,.35);
  --border-navy:rgba(27,55,95,.12);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.05);
  --shadow-md:  0 8px 28px rgba(0,0,0,.09);
  --shadow-lg:  0 20px 60px rgba(27,55,95,.12);
  --r:          12px;
  --r-lg:       18px;
  --serif:      'Platypi', Georgia, serif;
  --sans:       'DM Sans', system-ui, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);color:var(--ink);background:var(--off);overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:var(--sans);cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

/* ─── LAYOUT ─────────────────────────────── */
.wrap    {max-width:1160px;margin:0 auto;padding:0 40px}
.wrap-md {max-width:860px;margin:0 auto;padding:0 40px}

/* ─── BOUTONS ────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:8px;border:1.5px solid transparent;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.01em;transition:all .18s;cursor:pointer;white-space:nowrap}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-dk);transform:translateY(-1px);box-shadow:0 4px 16px rgba(196,157,116,.35)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-dk);transform:translateY(-1px)}
.btn-outline-gold{background:transparent;color:var(--gold-dk);border-color:var(--gold)}
.btn-outline-gold:hover{background:var(--gold-ultra)}
.btn-outline-navy{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline-navy:hover{background:var(--gold-ultra);border-color:var(--gold)}
.btn-ghost-white{background:transparent;color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.btn-ghost-white:hover{background:rgba(255,255,255,.1);color:#fff}
.btn-lg{padding:14px 28px;font-size:14px}

/* ─── NAV — bleu #1b375f ─────────────────── */
.nav{background:#1b375f;border-bottom:1px solid rgba(196,157,116,.2);position:sticky;top:0;z-index:100;transition:box-shadow .2s}
.nav.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.2)}
.nav-inner{max-width:1160px;margin:0 auto;padding:12px 40px;height:auto;min-height:72px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-brand{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--gold);letter-spacing:.02em}
.nav-tagline{font-size:9px;letter-spacing:.1em;color:rgba(255,255,255,.35);text-transform:uppercase;display:block;margin-top:1px}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-link{font-size:12px;font-weight:500;color:rgba(255,255,255,.55);padding:6px 12px;border-radius:6px;transition:all .15s}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-link.active{color:#fff;font-weight:700}
.nav-phone{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--gold);padding:8px 14px;border-radius:8px;border:1.5px solid rgba(196,157,116,.4);transition:all .18s}
.nav-phone:hover{background:rgba(196,157,116,.12)}

/* ─── BREADCRUMB ─────────────────────────── */
.breadcrumb{background:#fff;border-bottom:1px solid var(--gold-line);padding:12px 0}
.breadcrumb-inner{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-mt)}
.breadcrumb-inner a{color:var(--gold-dk);transition:color .15s}
.breadcrumb-inner a:hover{color:var(--navy)}
.breadcrumb-sep{color:var(--gold-line);font-size:14px}
.breadcrumb-current{color:var(--navy);font-weight:600}

/* ─── PAGE HERO — fond blanc ─────────────── */
.page-hero{
  background:#fff;
  padding:56px 0 48px;
  border-bottom:1px solid var(--gold-line);
  position:relative;overflow:hidden;
}
.page-hero::after{
  content:'';position:absolute;right:0;top:0;bottom:0;width:40%;
  background-image:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=900&q=70&fit=crop&crop=right');
  background-size:cover;background-position:center;
  opacity:.12;
  mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.7) 40%,rgba(0,0,0,.9) 100%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.7) 40%,rgba(0,0,0,.9) 100%);
}
.page-hero-inner{position:relative;z-index:1}
.page-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--gold-pale);color:var(--gold-dk);border:1px solid var(--border-md);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:16px}
.page-h1{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:700;color:var(--navy);line-height:1.08;letter-spacing:-.01em;margin-bottom:0;max-width:580px}
.page-h1 em{color:var(--gold);font-style:italic}
.page-stroke{width:40px;height:3px;background:var(--gold);border-radius:2px;margin:18px 0}
.page-desc{font-size:15px;color:var(--ink-md);line-height:1.75;max-width:540px;margin-bottom:28px}
.page-desc strong{color:var(--navy);font-weight:600}
.page-actions{display:flex;gap:12px;flex-wrap:wrap}

/* ─── STICKY FILTER BAR ──────────────────── */
.filter-bar{
  background:#fff;border-bottom:1px solid var(--gold-line);
  position:sticky;top:64px;z-index:90;
  box-shadow:0 2px 12px rgba(0,0,0,.04);
}
.filter-inner{max-width:1160px;margin:0 auto;padding:0 40px;display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.filter-inner::-webkit-scrollbar{display:none}
.filter-tab{display:flex;align-items:center;gap:7px;padding:16px 18px;font-size:13px;font-weight:500;color:var(--ink-mt);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all .18s;font-family:var(--sans)}
.filter-tab:hover{color:var(--navy)}
.filter-tab.active{color:var(--navy);font-weight:700;border-bottom-color:var(--gold)}
.filter-tab-icon{font-size:16px}

/* ─── SECTIONS ───────────────────────────── */
.sec{padding:64px 0}
.sec-white{background:#fff}
.sec-off{background:var(--off)}
.sec-cream{background:var(--cream)}
.sec-navy{background:var(--navy)}
.sec-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-dk);margin-bottom:6px;display:block}
.sec-title{font-family:var(--serif);font-size:clamp(24px,3vw,34px);font-weight:700;color:var(--navy);line-height:1.15}
.sec-title em{color:var(--gold);font-style:italic}
.sec-sub{font-size:14px;color:var(--ink-mt);line-height:1.75;margin-top:10px;max-width:520px}
.sec-intro{margin-bottom:32px;padding:18px 22px;background:#fff;border-radius:var(--r);border-left:3px solid var(--gold);box-shadow:var(--shadow-sm)}
.sec-intro h2{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--navy);margin-bottom:5px}
.sec-intro p{font-size:13px;color:var(--ink-mt);line-height:1.7}

/* ─── PRESTATION DETAIL CARD ─────────────── */
.prestation-block{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:440px;border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-md);
  margin-bottom:24px;
}
.prestation-block.reverse{direction:rtl}
.prestation-block.reverse > *{direction:ltr}

.prestation-text{
  background:#fff;padding:48px 44px;
  display:flex;flex-direction:column;justify-content:center;
}
.prestation-text.cream{background:var(--cream)}
.prestation-num{
  font-family:var(--serif);font-size:56px;font-weight:700;
  color:var(--gold-line);line-height:1;margin-bottom:4px;
  -webkit-text-stroke:1.5px var(--gold);color:transparent;
}
.prestation-title{
  font-family:var(--serif);font-size:28px;font-weight:700;
  color:var(--navy);line-height:1.15;margin-bottom:6px;
}
.prestation-title em{color:var(--gold);font-style:italic}
.prestation-tagline{
  font-size:13px;color:var(--gold-dk);font-weight:600;
  letter-spacing:.04em;margin-bottom:18px;
}
.prestation-desc{font-size:14px;color:var(--ink-md);line-height:1.8;margin-bottom:20px}
.prestation-desc strong{color:var(--navy);font-weight:600}

/* checklist */
.ck{padding:0;margin:0 0 22px}
.ck li{font-size:13px;color:var(--ink-md);padding:6px 0 6px 20px;position:relative;border-bottom:1px solid rgba(0,0,0,.05);line-height:1.5}
.ck li:last-child{border-bottom:none}
.ck li::before{content:'✓';position:absolute;left:0;top:6px;color:var(--gold);font-weight:700;font-size:11px}

/* photo zone */
.prestation-photo{
  background:var(--navy-md);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;min-height:360px;
}
.prestation-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.prestation-photo-ph{display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.2}
.prestation-photo-ph span{font-size:10px;color:#fff;letter-spacing:.1em;text-transform:uppercase}
/* accent or sur la photo */
.prestation-photo::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);z-index:2}
.prestation-block.reverse .prestation-photo::before{left:auto;right:0}
/* badge numéro dans la photo */
.prestation-badge{
  position:absolute;top:20px;right:20px;z-index:3;
  width:48px;height:48px;border-radius:50%;
  background:var(--gold);color:#fff;
  font-family:var(--serif);font-size:20px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}

/* ─── APPLICATIONS GRID ──────────────────── */
/* Petites cards d'applications (neuf, réno, pro, particulier) */
.appli-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:28px}
.appli-card{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r);
  padding:20px 16px;text-align:center;transition:all .18s;
}
.appli-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.appli-icon{font-size:28px;margin-bottom:10px}
.appli-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px}
.appli-desc{font-size:11px;color:var(--ink-mt);line-height:1.55}

/* ─── PRODUITS / MARQUES ─────────────────── */
.marques-bar{
  background:var(--navy);padding:24px 0;
  border-top:1px solid rgba(196,157,116,.15);
  border-bottom:1px solid rgba(196,157,116,.15);
}
.marques-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:14px}
.marques-list{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.marque-item{
  font-family:var(--serif);font-size:16px;font-weight:700;
  color:rgba(255,255,255,.25);letter-spacing:.04em;
  transition:color .2s;
}
.marque-item:hover{color:var(--gold)}

/* ─── COMPARATIF / TABLEAU ───────────────── */
.ptable{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.ptable-hd{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;background:var(--navy);color:rgba(255,255,255,.65);padding:14px 24px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.ptable-hd span:not(:first-child){text-align:center}
.prow{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:14px 24px;border-bottom:1px solid var(--border);transition:background .15s;align-items:center}
.prow:last-child{border-bottom:none}
.prow:hover{background:var(--gold-ultra)}
.prow.hi{border-left:3px solid var(--gold);background:rgba(196,157,116,.05)}
.pr-name{font-size:14px;font-weight:600;color:var(--navy)}
.pr-sub{font-size:11px;color:var(--ink-mt);margin-top:2px}
.pr-cell{font-size:13px;color:var(--ink-md);text-align:center}
.pr-check{font-size:16px;text-align:center;color:var(--gold)}
.pr-cross{font-size:16px;text-align:center;color:var(--ink-mt);opacity:.35}

/* ─── PROCESS STEPS ──────────────────────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;margin-top:36px}
.process-grid::before{
  content:'';position:absolute;top:28px;left:10%;right:10%;height:2px;
  background:linear-gradient(to right,var(--gold),rgba(196,157,116,.3));z-index:0;
}
.process-step{text-align:center;padding:0 16px;position:relative;z-index:1}
.process-dot{
  width:56px;height:56px;border-radius:50%;
  background:var(--navy);border:3px solid var(--gold);
  color:var(--gold);font-family:var(--serif);font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;box-shadow:var(--shadow-sm);
}
.process-title{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--navy);margin-bottom:6px}
.process-desc{font-size:12px;color:var(--ink-mt);line-height:1.65}

/* ─── FAQ ────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:28px}
.faq-item{background:#fff;border-radius:var(--r);border:1px solid var(--border);overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;text-align:left;font-family:var(--serif);font-size:15px;font-weight:700;color:var(--navy);background:#fff;cursor:pointer;transition:background .12s}
.faq-q:hover{background:var(--gold-ultra)}
.faq-item.open .faq-q{background:var(--navy);color:#fff}
.faq-arrow{font-size:11px;color:var(--gold);flex-shrink:0;transition:transform .2s}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;font-size:13px;color:rgba(255,255,255,.65);line-height:1.75;background:var(--navy)}
.faq-item.open .faq-a{max-height:240px}
.faq-a-in{padding:0 18px 16px}
.faq-a-in strong{color:var(--gold-lt);font-weight:600}

/* ─── FEATURED BAND ──────────────────────── */
.featured{background:var(--navy);border-radius:var(--r-lg);padding:32px 36px;display:flex;justify-content:space-between;align-items:center;gap:24px;box-shadow:var(--shadow-md);margin-bottom:0}
.featured-badge{display:inline-flex;align-items:center;gap:6px;background:var(--gold);color:#fff;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:10px}
.featured-title{font-family:var(--serif);font-size:24px;font-weight:700;color:#fff;margin-bottom:8px;line-height:1.2}
.featured-desc{font-size:13px;color:rgba(255,255,255,.62);line-height:1.65;margin-bottom:18px;max-width:440px}
.featured-actions{display:flex;gap:10px;flex-wrap:wrap}
.featured-stats{display:flex;gap:24px;flex-shrink:0}
.fstat{text-align:center;border-left:2px solid rgba(196,157,116,.35);padding-left:16px}
.fstat-num{font-family:var(--serif);font-size:34px;font-weight:700;color:var(--gold);display:block;line-height:1}
.fstat-label{font-size:11px;color:rgba(255,255,255,.42);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}

/* ─── ZONE BLOCK ─────────────────────────── */
.zone-wrap{background:var(--navy);border-radius:var(--r-lg);padding:28px;position:relative;overflow:hidden}
.zone-wrap::before{content:'';position:absolute;top:0;right:0;width:60px;height:60px;border-top:2px solid rgba(196,157,116,.4);border-right:2px solid rgba(196,157,116,.4)}
.zone-title{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--gold-lt);margin-bottom:8px}
.zone-desc{font-size:13px;color:rgba(255,255,255,.52);line-height:1.75;margin-bottom:14px;max-width:500px}
.zone-tags{display:flex;flex-wrap:wrap;gap:6px}
.zone-tag{font-size:11px;font-weight:600;letter-spacing:.07em;padding:5px 13px;border:1px solid rgba(196,157,116,.3);color:rgba(255,255,255,.58);border-radius:6px;transition:all .15s}
.zone-tag:hover{background:rgba(196,157,116,.15);border-color:var(--gold);color:#fff}

/* ─── CTA SECTION ────────────────────────── */
.cta-sec{background:var(--off);border-top:2px solid var(--gold-line);padding:72px 0;text-align:center}
.cta-title{font-family:var(--serif);font-size:clamp(26px,3.2vw,40px);font-weight:700;color:var(--navy);line-height:1.15;margin-bottom:10px}
.cta-title em{color:var(--gold);font-style:italic}
.cta-sub{font-size:14px;color:var(--ink-mt);margin-bottom:28px;line-height:1.75}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ─── FOOTER ─────────────────────────────── */
.footer{background:var(--navy-dk);border-top:2px solid var(--gold-line)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:52px;padding:52px 0 40px}
.footer-brand{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--gold-lt);margin-bottom:4px}
.footer-tagline{font-size:11px;color:rgba(255,255,255,.28);font-style:italic;margin-bottom:14px}
.footer-about{font-size:13px;color:rgba(255,255,255,.32);line-height:1.8}
.footer-head{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.32);transition:color .15s}
.footer-links a:hover{color:var(--gold-lt)}
.footer-contact-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.32);line-height:1.65;margin-bottom:10px}
.footer-contact-row a{color:rgba(255,255,255,.32);transition:color .15s}
.footer-contact-row a:hover{color:var(--gold-lt)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:16px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px}
.footer-copy{font-size:11px;color:rgba(255,255,255,.2)}
.footer-legal{font-size:11px}
.footer-legal a{color:rgba(255,255,255,.2);transition:color .15s}
.footer-legal a:hover{color:var(--gold)}

/* ─── FLOAT BTN MOBILE ───────────────────── */
.float-call{display:none;position:fixed;bottom:16px;right:14px;z-index:999;background:var(--gold);color:#fff;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 4px 20px rgba(0,0,0,.25);align-items:center;gap:8px}

/* ─── ANIMATIONS ─────────────────────────── */
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ─── RESPONSIVE ─────────────────────────── */
@media(max-width:960px){
  .nav-links{display:none}
  .prestation-block{grid-template-columns:1fr}
  .prestation-block.reverse{direction:ltr}
  .prestation-photo{min-height:280px}
  .appli-grid{grid-template-columns:1fr 1fr}
  .process-grid{grid-template-columns:1fr 1fr;gap:24px}
  .process-grid::before{display:none}
  .ptable-hd,.prow{grid-template-columns:2fr 1fr 1fr}
  .ptable-hd span:last-child,.prow .pr-cell:last-child{display:none}
  .footer-top{grid-template-columns:1fr;gap:28px}
  .faq-grid{grid-template-columns:1fr}
  .float-call{display:flex}
  .featured{flex-direction:column}
  .featured-stats{display:none}
}
@media(max-width:600px){
  .wrap,.wrap-md{padding:0 18px}
  .prestation-text{padding:36px 22px}
  .appli-grid{grid-template-columns:1fr 1fr}
  .process-grid{grid-template-columns:1fr}
  .sec{padding:48px 0}
}

/* ─── Overlay photo prestation ─────────────────── */
.prestation-photo-overlay{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(to top,rgba(27,55,95,.7) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;
}
