:root{
  --navy:#2b3a52;
  --navy-deep:#1f2b3d;
  --gold:#d39a2c;
  --gold-soft:#e0ad48;
  --paper:#fbfaf7;
  --paper-2:#f3f0ea;
  --ink:#2b3a52;
  --muted:#8a8f99;
  --line:#e6e2da;
  --display:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:1.2rem}
.eyebrow.center{text-align:center}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.6rem 0;transition:background .4s,padding .4s,box-shadow .4s}
.header-inner{position:relative;z-index:1001}
.site-header.scrolled{background:rgba(251,250,247,.95);backdrop-filter:blur(10px);padding:1rem 0;box-shadow:0 1px 0 var(--line)}
.header-inner{max-width:1320px;margin:0 auto;padding:0 2.2rem;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:.6rem;color:#fff;transition:color .4s}
.site-header.scrolled .brand{color:var(--navy)}
.brand-mark{width:42px;height:42px;color:var(--gold)}
.brand-text{font-family:var(--display);font-size:1.9rem;font-weight:500;letter-spacing:.01em}
.nav{display:flex;align-items:center;gap:1.1rem;position:relative;z-index:2}
.nav a{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;transition:color .3s;position:relative;white-space:nowrap}
.site-header.scrolled .nav a{color:var(--navy)}
.nav a:not(.nav-cta):not(.nav-promo){padding:.4rem .7rem;border-radius:3px;border:1px solid transparent;transition:background .25s,color .25s,border-color .25s}
.nav a:not(.nav-cta):not(.nav-promo):hover{background:#d58f1f;border-color:#d58f1f;color:#fff!important}
.site-header.scrolled .nav a:not(.nav-cta):not(.nav-promo):hover{color:#fff!important}
.nav-cta{background:#2a394c;border:1px solid #2a394c;color:#fff!important;padding:.55rem 1.3rem;border-radius:2px;font-weight:700}
.nav-cta:hover{background:var(--gold);border-color:var(--gold);color:#fff!important}
.site-header.scrolled .nav-cta{color:#fff!important}
/* élément de menu de la page courante : encadré + coloré */
.nav a.active{color:#fff!important;background:#d58f1f;border:1px solid #d58f1f;border-radius:3px;padding:.45rem .9rem;font-weight:700!important}
.nav a.active::after{display:none}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}
.site-header.scrolled .burger span{background:var(--navy)}
.mobile-nav{display:none;flex-direction:column;background:var(--navy);padding:1rem 2.2rem 2rem}
.mobile-nav a{color:#fff;padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.12);letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}

/* HERO */
.hero{position:relative;z-index:1;height:100vh;min-height:620px;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);animation:slowzoom 14s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(31,43,61,.78) 0%,rgba(31,43,61,.35) 60%,rgba(31,43,61,.15) 100%)}
.hero-content{position:relative;max-width:1320px;margin:0 auto;padding:0 2.2rem;width:100%}
.hero h1{font-family:var(--display);font-weight:300;font-size:clamp(3rem,7vw,6rem);line-height:1.02;margin-bottom:1.6rem;letter-spacing:-.01em}
.hero-sub{max-width:480px;font-size:1.1rem;font-weight:300;color:rgba(255,255,255,.9);margin-bottom:2.4rem}
.scroll-hint{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.75)}
.scroll-hint::after{content:'';display:block;width:1px;height:36px;background:rgba(255,255,255,.5);margin:.8rem auto 0;animation:scrolldot 2s infinite}
@keyframes scrolldot{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* BUTTONS */
.btn-light{display:inline-block;background:var(--gold);color:#fff;padding:1rem 2.4rem;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;border-radius:2px;transition:.3s}
.btn-light:hover{background:var(--gold-soft);transform:translateY(-2px)}
.btn-dark{display:inline-block;background:var(--navy);color:#fff;padding:1rem 2.4rem;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;border-radius:2px;transition:.3s}
.btn-dark:hover{background:var(--navy-deep);transform:translateY(-2px)}
.link-arrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--navy);font-weight:500;border-bottom:1px solid var(--gold);padding-bottom:.35rem;transition:gap .3s}
.link-arrow::after{content:'→';color:var(--gold);transition:transform .3s}
.link-arrow:hover{gap:1rem}
.link-arrow:hover::after{transform:translateX(4px)}

/* INTRO */
.intro{max-width:840px;margin:0 auto;padding:4rem 2.2rem;text-align:center}
.intro-title{font-family:var(--display);font-weight:300;font-size:clamp(2rem,4vw,3.2rem);line-height:1.12;margin-bottom:1.6rem}
.intro-text{font-size:1.12rem;color:#5a606b;max-width:620px;margin:0 auto}

/* FEATURE */
.feature{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;min-height:560px}
.feature-img{background-size:cover;background-position:center}
.feature-text{display:flex;flex-direction:column;justify-content:center;padding:5rem 6rem}
.feature-text h2{font-family:var(--display);font-weight:300;font-size:clamp(2.2rem,4vw,3.4rem);margin-bottom:1.2rem;line-height:1.05}
.feature-text p{font-size:1.05rem;color:#5a606b;margin-bottom:2rem;max-width:420px}
.feature-right .feature-img{order:2}
.feature-right .feature-text{order:1}
.feature-left:nth-of-type(even) .feature-text{background:var(--paper-2)}

/* PROCESS */
.process{padding:8rem 2.2rem;max-width:1320px;margin:0 auto}
.process-title{font-family:var(--display);font-weight:300;font-size:clamp(2rem,4vw,3rem);text-align:center;margin-bottom:4rem}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2.4rem}
.step{border-top:1px solid var(--line);padding-top:1.6rem}
.step-num{font-family:var(--display);font-size:2.6rem;color:var(--gold);display:block;margin-bottom:.6rem}
.step h3{font-size:1.05rem;font-weight:500;letter-spacing:.05em;margin-bottom:.6rem;text-transform:uppercase}
.step p{font-size:.95rem;color:#6a6f78}

/* CTA */
.cta-band{background:var(--navy);color:#fff;text-align:center;padding:7rem 2.2rem}
.cta-band h2{font-family:var(--display);font-weight:300;font-size:clamp(2.2rem,4vw,3.4rem);margin-bottom:1rem}
.cta-band p{color:rgba(255,255,255,.75);margin-bottom:2.4rem;font-size:1.05rem}

/* FOOTER */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,.85);padding:5rem 2.2rem 2rem}
.footer-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand .brand-text{color:#fff;display:block;margin-bottom:1rem}
.footer-brand p{color:rgba(255,255,255,.6);font-style:italic;font-family:var(--display);font-size:1.15rem}
.footer-col h4{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;font-weight:500}
.footer-col a,.footer-col span{display:block;color:rgba(255,255,255,.7);font-size:.95rem;padding:.35rem 0;transition:color .3s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{max-width:1320px;margin:2rem auto 0;font-size:.82rem;color:rgba(255,255,255,.45);letter-spacing:.05em}

/* PAGE HERO (interior pages) */
.page-hero{position:relative;height:60vh;min-height:420px;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.page-hero .hero-bg{animation:none;transform:none}
.page-hero-content{position:relative;max-width:1320px;margin:0 auto;padding:0 2.2rem 4rem;width:100%}
.page-hero h1{font-family:var(--display);font-weight:300;font-size:clamp(2.6rem,6vw,5rem);line-height:1}
.page-hero p{margin-top:1rem;max-width:460px;color:rgba(255,255,255,.9)}

/* CONTENT SECTIONS */
.section{max-width:1320px;margin:0 auto;padding:3rem 2.2rem}
.section-narrow{max-width:780px}
.section h2{font-family:var(--display);font-weight:300;font-size:clamp(2rem,4vw,3rem);margin-bottom:1.4rem;line-height:1.1}
.section p{color:#5a606b;font-size:1.05rem;margin-bottom:1.2rem}
.lead{font-size:1.3rem;color:var(--navy);font-family:var(--display);font-style:italic}

/* GALLERY GRID */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;max-width:1320px;margin:0 auto;padding:0 2.2rem 6rem}
.gallery figure{overflow:hidden;border-radius:3px;position:relative}
.gallery img{width:100%;height:320px;object-fit:cover;transition:transform .6s}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;left:0;bottom:0;right:0;padding:1.2rem;background:linear-gradient(transparent,rgba(31,43,61,.8));color:#fff;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;opacity:0;transition:opacity .4s}
.gallery figure:hover figcaption{opacity:1}
.gallery .tall img{height:480px}

/* FEATURE LIST */
.feat-list{display:grid;grid-template-columns:repeat(3,1fr);gap:2.4rem;max-width:1320px;margin:0 auto;padding:0 2.2rem 6rem}
.feat-card{border-top:2px solid var(--gold);padding-top:1.4rem}
.feat-card h3{font-family:var(--display);font-size:1.5rem;font-weight:400;margin-bottom:.7rem}
.feat-card p{font-size:.98rem;color:#6a6f78}

/* CONTACT */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:5rem;max-width:1320px;margin:0 auto;padding:6rem 2.2rem}
.contact-info h2{font-family:var(--display);font-weight:300;font-size:2.6rem;margin-bottom:1.4rem}
.contact-info p{color:#5a606b;margin-bottom:2rem}
.contact-line{display:flex;flex-direction:column;gap:.2rem;margin-bottom:1.6rem}
.contact-line span:first-child{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.contact-line span:last-child{font-size:1.1rem}
form{display:flex;flex-direction:column;gap:1.2rem}
form label{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;display:block}
form input,form select,form textarea{width:100%;padding:.9rem 1rem;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:1rem;color:var(--ink);border-radius:2px;transition:border .3s}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--gold)}
form button{align-self:flex-start;cursor:pointer;border:none}
.form-note{font-size:.85rem;color:var(--muted)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s,transform .9s}
.reveal.in{opacity:1;transform:none}
.hero .reveal:nth-child(1){transition-delay:.1s}
.hero .reveal:nth-child(2){transition-delay:.25s}
.hero .reveal:nth-child(3){transition-delay:.4s}
.hero .reveal:nth-child(4){transition-delay:.55s}

/* RESPONSIVE */
@media(max-width:900px){
  .nav{display:none}
  .burger{display:flex}
  .mobile-nav.open{display:flex}
  .feature{grid-template-columns:1fr}
  .feature-img{min-height:300px}
  .feature-right .feature-img{order:0}
  .feature-right .feature-text{order:1}
  .feature-text{padding:3.2rem 2.2rem}
  .steps{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .gallery,.feat-list{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr;gap:3rem}
  .intro{padding:2.5rem 2.2rem}
  .section{padding:2rem 2.2rem}
}
@media(max-width:560px){
  .steps,.gallery,.feat-list,.footer-grid{grid-template-columns:1fr}
  .gallery img,.gallery .tall img{height:260px}
}

/* ===== LOGO IMAGE (fond blanc arrondi) ===== */
/* image source 200x100 (ratio 2:1) */
.brand-logo-wrap{display:inline-block;background:#fff;padding:10px 16px;border-radius:12px;box-shadow:0 6px 22px rgba(0,0,0,.18);transition:padding .4s,box-shadow .4s}
.site-header.scrolled .brand-logo-wrap{padding:7px 12px;box-shadow:0 3px 12px rgba(0,0,0,.12)}
.brand-logo{height:56px;width:auto;display:block;transition:height .4s,opacity .3s}
.site-header.scrolled .brand-logo{height:46px}
.brand:hover .brand-logo{opacity:.85}
/* logo dans le pied de page (fond bleu foncé) */
.brand-logo-footer{height:70px;width:auto;display:block;margin-bottom:1.4rem;background:#fff;padding:14px 20px;border-radius:12px;box-shadow:0 6px 20px rgba(0,0,0,.18)}
@media(max-width:560px){
  .brand-logo{height:46px}
  .brand-logo-wrap{padding:8px 12px}
}

/* ===== PAGE CONTACT REDESIGN ===== */
.contact-hero{padding-top:7rem}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1320px;margin:0 auto}
.contact-left{background:var(--paper-2);padding:4.5rem 4rem}
.contact-left h1{font-family:var(--display);font-weight:500;font-size:clamp(2.4rem,4vw,3.4rem);color:var(--navy);line-height:1;margin-bottom:.4rem;position:relative;text-transform:uppercase;letter-spacing:.01em}
.contact-left h1::after{content:'';display:block;width:64px;height:3px;background:var(--gold);margin-top:1rem}
.contact-intro{color:#5a606b;font-size:1.1rem;margin:1.4rem 0 2.4rem}

.info-block{display:flex;gap:1.2rem;align-items:flex-start;margin-bottom:1.6rem}
.info-icon{flex:0 0 auto;width:48px;height:48px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center}
.info-icon svg{width:22px;height:22px;color:var(--gold)}
.info-text h3{font-size:.92rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:.3rem}
.info-text p{color:#4a5160;font-size:1rem;line-height:1.5;border-bottom:1px solid var(--line);padding-bottom:1rem}
.info-text a{color:#4a5160;transition:color .2s}
.info-text a:hover{color:var(--gold)}

.project-box{display:flex;gap:1.1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:6px;padding:1.4rem 1.6rem;margin-top:2rem}
.project-icon{flex:0 0 auto}
.project-icon svg{width:40px;height:40px;color:var(--gold)}
.project-box h4{font-size:.92rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);font-weight:600;margin-bottom:.4rem}
.project-box p{color:#5a606b;font-size:.95rem}

.contact-right{background:#fff;padding:4.5rem 4rem;display:flex;align-items:center}
.form-card{width:100%}
.form-card h2{font-family:var(--display);font-weight:400;font-size:2.2rem;color:var(--navy);margin-bottom:.6rem}
.form-lead{color:#5a606b;font-size:1rem;margin-bottom:2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}

.radio-group{display:flex;gap:1rem}
.radio-pill{flex:1;position:relative;cursor:pointer}
.radio-pill input{position:absolute;opacity:0;pointer-events:none}
.radio-pill span{display:block;text-align:center;padding:.85rem 1rem;border:1px solid var(--line);border-radius:3px;font-size:.95rem;color:#5a606b;transition:.25s;background:#fff}
.radio-pill input:checked + span{background:var(--navy);color:#fff;border-color:var(--navy)}
.radio-pill:hover span{border-color:var(--gold)}

.contact-band{background:var(--navy-deep);color:#fff;display:flex;align-items:center;gap:1.2rem;justify-content:center;padding:1.6rem 2.2rem;margin-top:0}
.contact-band .band-pin svg{width:26px;height:26px;color:var(--gold);display:block}
.contact-band p{font-size:1.05rem;color:rgba(255,255,255,.92);max-width:640px}
.contact-band strong{color:var(--gold);font-weight:500}

@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr}
  .contact-left,.contact-right{padding:3rem 1.8rem}
  .form-row{grid-template-columns:1fr}
  .contact-band{flex-direction:column;text-align:center;gap:.6rem}
}

/* ===== ENGAGEMENTS (3 cartes paramétrables) ===== */
.engagements{background:var(--paper);padding:5rem 2.2rem}
.engagements-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.eng-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:10px;padding:2.4rem 2.2rem 3.4rem;transition:box-shadow .3s,transform .3s}
.eng-card:hover{box-shadow:0 14px 40px rgba(31,43,61,.10);transform:translateY(-4px)}
.eng-icon{width:78px;height:78px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-left:auto;margin-bottom:1.4rem}
.eng-icon svg{width:42px;height:42px}
.eng-icon-eco{background:#dff3d6;color:#4a9d3f}
.eng-icon-fr{background:transparent}
.eng-icon-fr svg{width:54px;height:54px}
.eng-icon-gar{background:#d8f1f7;color:#1f8fb0}
.eng-card h3{font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--navy);margin-bottom:1rem}
.eng-card p{font-size:.98rem;color:#5a606b;line-height:1.6}
.eng-arrow{position:absolute;right:2.2rem;bottom:1.8rem;font-size:1.3rem;color:var(--navy);transition:transform .3s,color .3s}
.eng-card:hover .eng-arrow{color:var(--gold);transform:translateX(5px)}

@media(max-width:900px){
  .engagements-grid{grid-template-columns:1fr;gap:1.4rem}
  .engagements{padding:3.5rem 1.8rem}
}

/* ===== BANNIÈRE CONTACT (optionnelle, si image définie) ===== */
.contact-banner{color:#fff;padding:7rem 0 3.5rem}
.contact-banner .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);animation:slowzoom 14s ease-out forwards}
.contact-banner .hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,43,61,.55) 0%,rgba(31,43,61,.45) 50%,rgba(31,43,61,.7) 100%)}
.contact-banner-content{position:relative;max-width:760px;padding:0 2.2rem;width:100%}
.contact-banner-content .eyebrow{color:var(--gold)}
.contact-banner-content h1{font-family:var(--display);font-weight:300;font-size:clamp(2.8rem,6.5vw,5.5rem);line-height:1.02;margin-bottom:1.2rem}
.contact-banner-sub{font-size:1.1rem;color:rgba(255,255,255,.9);max-width:520px;margin:0 auto 2rem}
.contact-steps{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:0 auto 2.4rem;flex-wrap:wrap}
.contact-step{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.contact-step-num{width:44px;height:44px;border-radius:50%;border:2px solid var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:1.3rem;font-weight:600;background:rgba(211,154,44,.18)}
.contact-step-lbl{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;font-weight:500}
.contact-step-line{width:54px;height:2px;background:rgba(255,255,255,.4);margin-bottom:1.6rem}
@media(max-width:560px){
  .contact-step-line{width:24px}
  .contact-step-num{width:38px;height:38px;font-size:1.1rem}
  .contact-step-lbl{font-size:.66rem;letter-spacing:.08em}
}
.banner-arrow{display:inline-flex;flex-direction:column;align-items:center;gap:.9rem;color:#fff;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;transition:color .3s}
.banner-arrow:hover{color:var(--gold)}
.banner-arrow svg{width:34px;height:34px;animation:arrowbounce 1.8s infinite}
@keyframes arrowbounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
/* quand il y a une bannière, l'en-tête de page ne pousse plus sous le menu */
.contact-hero.has-banner{padding-top:0;scroll-margin-top:90px}

/* ===== PAGE RÉALISATIONS ===== */
.realisations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1080px;margin:0 auto;padding:0 2.2rem 6rem}
.real-card{position:relative;border-radius:8px;overflow:hidden;background:#fff;border:1px solid var(--line);transition:box-shadow .35s,transform .35s}
.real-card:hover{box-shadow:0 18px 46px rgba(31,43,61,.14);transform:translateY(-5px)}
.real-img{overflow:hidden;aspect-ratio:4/3}
.real-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.real-card:hover .real-img img{transform:scale(1.07)}
.real-card figcaption{padding:1.4rem 1.6rem 1.8rem}
.real-cat{display:inline-block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:var(--gold);padding:.3rem .8rem;border-radius:20px;margin-bottom:.8rem}
.real-card h3{font-family:var(--display);font-weight:500;font-size:1.45rem;color:var(--navy);margin-bottom:.5rem}
.real-card figcaption p{font-size:.95rem;color:#6a6f78;line-height:1.55}

/* picto "réalisations" dans le menu */
.nav-real{display:inline-flex;align-items:center;gap:.4rem}
.nav-real svg{width:16px;height:16px;color:var(--gold);transition:transform .4s}
.nav a.nav-real.active svg{color:#fff!important}
.nav a.nav-real:hover svg{transform:rotate(18deg) scale(1.2)}

@media(max-width:900px){
  .realisations-grid{grid-template-columns:1fr 1fr;gap:1.2rem}
}
@media(max-width:560px){
  .realisations-grid{grid-template-columns:1fr}
}

/* ===== PAGE PROMO ===== */
.promo-hero{position:relative;height:auto;min-height:520px;padding:9rem 0 4rem;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.promo-hero .hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transform:scale(1.05);animation:slowzoom 14s ease-out forwards}
.promo-hero .hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(31,43,61,.55),rgba(31,43,61,.78))}
.promo-hero-content{position:relative;z-index:2;max-width:760px;padding:0 2.2rem}
.promo-badge{display:inline-block;background:var(--gold);color:#fff;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;padding:.5rem 1.2rem;border-radius:30px;margin-bottom:1.6rem;font-weight:500}
.promo-hero-content h1{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,6vw,5rem);line-height:1.05;margin-bottom:1.2rem}
.promo-sub{font-size:1.2rem;color:rgba(255,255,255,.92);margin-bottom:2.4rem}
.promo-cta{font-size:.85rem!important;padding:1.1rem 2.8rem!important}
.promo-conditions{font-size:.9rem;color:var(--muted);font-style:italic;max-width:520px;margin:1.5rem auto 0}
.promo-cta-big{font-size:.9rem!important;padding:1.2rem 3rem!important}

.promo-band{background:var(--navy);color:#fff;padding:3.5rem 2.2rem}
.promo-band-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.promo-band-inner h3{font-family:var(--display);font-weight:400;font-size:1.9rem;color:var(--gold);margin-bottom:.3rem}
.promo-band-inner p{color:rgba(255,255,255,.8)}
.nav-promo{color:#fff!important;font-weight:600!important;display:inline-flex;align-items:center;gap:.45rem;border:1px solid currentColor;padding:.55rem 1.3rem;border-radius:2px}
.nav-promo:hover{background:var(--gold);border-color:var(--gold);color:#fff!important}
.nav-promo svg{width:18px;height:18px;color:currentColor;animation:giftwiggle 2.5s ease-in-out infinite}
.nav-promo:hover svg{animation:none;transform:scale(1.15)}
.nav-promo.active{background:var(--gold);border-color:var(--gold);color:#fff!important}
.nav-promo.active svg{color:#fff;animation:none}
.site-header.scrolled .nav-promo{color:#d58f1f!important}
.site-header.scrolled .nav-promo.active{color:#fff!important;background:var(--gold);border-color:var(--gold)}
.site-header.scrolled .nav-promo.active svg{color:#fff}
.site-header.scrolled .nav-promo:hover{background:var(--gold);border-color:var(--gold);color:#fff!important}
@keyframes giftwiggle{0%,92%,100%{transform:rotate(0)}94%{transform:rotate(-10deg)}96%{transform:rotate(8deg)}98%{transform:rotate(-5deg)}}

/* ===== AVIS CLIENTS sur réalisations ===== */
.real-stars{display:flex;gap:2px;margin-bottom:.6rem}
.real-stars svg{width:16px;height:16px}
.real-stars .on{color:var(--gold)}
.real-stars .off{color:var(--line)}
.real-avis{font-style:italic;color:#5a606b;font-size:.95rem;line-height:1.55;border-left:3px solid var(--gold);padding-left:.9rem;margin-top:.9rem}
.real-client{display:block;margin-top:.5rem;font-style:normal;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);font-weight:500}

@media(max-width:760px){
  .promo-band-inner{flex-direction:column;text-align:center}
}

/* ===== POP-UP PROMO ===== */
.promo-popup-overlay{position:fixed;inset:0;z-index:2000;background:rgba(31,43,61,.6);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;transition:opacity .35s}
.promo-popup-overlay[hidden]{display:none!important}
.promo-popup-overlay:not(.show){pointer-events:none}
.promo-popup-overlay.show{opacity:1;pointer-events:auto}
.promo-popup{position:relative;width:100%;max-width:380px;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.4);transform:translateY(24px) scale(.96);transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.promo-popup-overlay.show .promo-popup{transform:none}
.promo-popup-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:1.8rem;line-height:1;color:#fff;cursor:pointer;z-index:3;opacity:.9;transition:opacity .2s}
.promo-popup-close:hover{opacity:1}
.promo-popup-top{background:var(--navy);background:linear-gradient(135deg,var(--navy-deep),var(--navy));height:130px;display:flex;align-items:flex-end;justify-content:center;position:relative}
.promo-popup-gift{position:absolute;bottom:-34px}
.promo-popup-gift svg{width:96px;height:96px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.3))}
.promo-popup-body{padding:3.4rem 2rem 2rem;text-align:center}
.promo-popup-badge{display:inline-block;background:var(--paper-2);color:var(--navy);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;padding:.35rem .9rem;border-radius:20px;margin-bottom:1rem;font-weight:600}
.promo-popup-body h3{font-family:var(--display);font-weight:500;font-size:1.9rem;color:var(--gold);line-height:1.1;margin-bottom:.6rem}
.promo-popup-sub{color:#5a606b;font-size:.98rem;margin-bottom:1.6rem}
.promo-popup-btn{display:block;background:var(--gold);color:#fff;padding:1rem;border-radius:6px;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;transition:.25s}
.promo-popup-btn:hover{background:var(--gold-soft);transform:translateY(-2px)}
.promo-popup-more{display:block;margin-top:1rem;color:var(--navy);font-size:.88rem;text-decoration:underline;text-underline-offset:3px}
.promo-popup-more:hover{color:var(--gold)}
.promo-popup-nothanks{display:block;width:100%;margin-top:1rem;background:none;border:none;color:var(--muted);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:color .2s}
.promo-popup-nothanks:hover{color:var(--navy)}
@media(max-width:420px){
  .promo-popup-body{padding:3rem 1.4rem 1.6rem}
  .promo-popup-body h3{font-size:1.6rem}
}

/* ===== RÉSEAUX SOCIAUX (footer) ===== */
.footer-social{display:flex;gap:.8rem;margin-top:1.4rem}
.social-link{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8);transition:all .25s}
.social-link svg{width:20px;height:20px}
.social-link:hover{background:var(--gold);border-color:var(--gold);color:#fff;transform:translateY(-3px)}

/* ===== ASSISTANT IA (chat) ===== */
.chat-launcher{position:fixed;bottom:24px;right:24px;z-index:3000;display:flex;align-items:center;gap:.6rem;background:var(--navy);color:#fff;border:none;padding:.9rem 1.3rem;border-radius:50px;cursor:pointer;box-shadow:0 8px 28px rgba(31,43,61,.35);transition:transform .25s,background .25s;font-family:var(--sans);font-size:.9rem}
.chat-launcher:hover{background:var(--navy-deep);transform:translateY(-2px)}
.chat-launcher.hidden{display:none}
.chat-launcher svg{width:24px;height:24px;color:var(--gold)}
.chat-launcher-label{font-weight:500}

.chat-window{position:fixed;bottom:24px;right:24px;z-index:3000;width:380px;max-width:calc(100vw - 32px);height:560px;max-height:calc(100vh - 48px);background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(20px) scale(.98);transition:opacity .3s,transform .3s}
.chat-window[hidden]{display:none!important}
.chat-window.show{opacity:1;transform:none}
.chat-header{background:var(--navy);color:#fff;padding:1.1rem 1.3rem;display:flex;justify-content:space-between;align-items:center}
.chat-header strong{display:block;font-size:1rem}
.chat-header span{font-size:.74rem;color:rgba(255,255,255,.7)}
.chat-close{background:none;border:none;color:#fff;font-size:1.6rem;cursor:pointer;line-height:1;opacity:.85}
.chat-close:hover{opacity:1}
.chat-messages{flex:1;overflow-y:auto;padding:1.2rem;display:flex;flex-direction:column;gap:.8rem;background:var(--paper)}
.chat-msg{max-width:82%;padding:.75rem 1rem;border-radius:14px;font-size:.94rem;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.chat-msg.bot{background:#fff;border:1px solid var(--line);color:var(--ink);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.user{background:var(--gold);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-typing{display:flex;gap:4px;align-items:center}
.chat-typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:chatdot 1.2s infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes chatdot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.chat-cta{padding:.8rem 1.2rem;background:var(--paper-2);border-top:1px solid var(--line)}
.chat-cta-btn{display:block;text-align:center;background:var(--gold);color:#fff;padding:.85rem;border-radius:8px;font-size:.85rem;font-weight:600;letter-spacing:.04em;transition:background .25s}
.chat-cta-btn:hover{background:var(--gold-soft)}
.chat-input{display:flex;gap:.5rem;padding:.9rem;border-top:1px solid var(--line);background:#fff}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:24px;padding:.7rem 1.1rem;font-family:var(--sans);font-size:.94rem;outline:none}
.chat-input input:focus{border-color:var(--gold)}
.chat-input button{flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:none;background:var(--navy);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s}
.chat-input button:hover{background:var(--gold)}
.chat-input button svg{width:20px;height:20px}
@media(max-width:480px){
  .chat-window{width:100%;height:100%;max-height:100vh;bottom:0;right:0;border-radius:0}
  .chat-launcher-label{display:none}
  .chat-launcher{padding:1rem;border-radius:50%}
}



/* ===================================================== */
/* ===== PAGES PLACARDS / DRESSINGS (nouvelles sections) */
/* ===================================================== */

.col-intro-title{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--navy);line-height:1.15;margin-bottom:1rem}

/* --- SÉLECTEUR coloris/rails/accessoires --- */
.selector-section{position:relative;width:calc(100% - 4.4rem);max-width:1200px;margin:2rem auto;background:linear-gradient(180deg,#fff,var(--paper-2));border:1px solid #d2d5da;border-radius:16px;padding:3rem 2.4rem 3.5rem;box-shadow:0 18px 50px -28px rgba(43,58,82,.45);overflow:hidden}
.selector-section::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#b9bdc4,#d8dbe0)}
.selector-head{max-width:820px;margin:0 auto 2.6rem;text-align:center}
.selector-head h2{font-family:var(--display);font-weight:500;font-size:clamp(1.7rem,3vw,2.4rem);color:var(--navy);margin-bottom:.9rem;line-height:1.2}
.selector-head p{color:#5a606b;font-size:1.02rem}
.selector-layout{display:grid;grid-template-columns:0.9fr 1.1fr;gap:3rem;align-items:start}
.selector-preview{position:sticky;top:100px;border-radius:12px;overflow:hidden;box-shadow:0 14px 40px rgba(31,43,61,.12);aspect-ratio:4/5;background:var(--paper-2)}
.selector-preview img{width:100%;height:100%;object-fit:cover}
.selector-panel{min-height:300px}
.selector-tabs{display:flex;gap:.4rem;border-bottom:1px solid var(--line);margin-bottom:1.6rem}
.sel-tab{background:none;border:none;padding:.9rem 1.4rem;font-family:var(--sans);font-size:.95rem;color:var(--muted);cursor:pointer;position:relative;transition:color .25s}
.sel-tab:hover{color:var(--navy)}
.sel-tab.active{color:var(--gold);font-weight:600}
.sel-tab.active::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--gold)}
.sel-panel{display:none}
.sel-panel.active{display:block;animation:fadeIn .4s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
/* sous-familles Bois/Unis/Mat */
.subfam-tabs{display:flex;gap:1.4rem;margin-bottom:1.6rem}
.subfam-tab{background:none;border:none;padding:.3rem 0;font-family:var(--sans);font-size:.88rem;color:var(--muted);cursor:pointer;position:relative;transition:color .2s}
.subfam-tab:hover{color:var(--navy)}
.subfam-tab.active{color:var(--navy);font-weight:600}
.subfam-tab.active::after{content:'';position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--navy)}
.subfam-panel{display:none}
.subfam-panel.active{display:block;animation:fadeIn .35s}
.swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:1.4rem}
.swatch{text-align:center}
.swatch-img{width:74px;height:74px;margin:0 auto .6rem;border-radius:50%;overflow:hidden;border:2px solid #fff;box-shadow:0 0 0 1px var(--line),0 6px 16px rgba(0,0,0,.1);transition:transform .25s,box-shadow .25s;cursor:pointer}
.swatch:hover .swatch-img{transform:translateY(-4px);box-shadow:0 0 0 2px var(--gold),0 12px 26px rgba(0,0,0,.16)}
.swatch-img img{width:100%;height:100%;object-fit:cover}
.swatch figcaption{font-size:.82rem;color:var(--navy);font-weight:500;line-height:1.3}
.swatch-ref{display:block;font-size:.74rem;color:var(--muted);font-weight:400;margin-top:.1rem}

/* --- 4 CARTES D'ACTION --- */
.action-cards-section{background:var(--paper);padding:2rem 2.2rem}
.action-cards{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.action-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:2rem 1.6rem;text-align:center;display:flex;flex-direction:column;align-items:center;transition:box-shadow .3s,transform .3s}
.action-card:hover{box-shadow:0 14px 36px rgba(31,43,61,.1);transform:translateY(-4px)}
.action-card h3{font-size:1.05rem;font-weight:600;color:var(--navy);line-height:1.4;margin-bottom:1.4rem;min-height:3em;display:flex;align-items:center}
.action-tel{color:var(--gold)}
.action-icon{width:70px;height:70px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.4rem}
.action-icon svg{width:32px;height:32px}
.ac-devis{background:#fbe4f0;color:#d6589a}
.ac-rdv{background:#dff3ea;color:#3fa37a}
.ac-aide{background:#fdf2d6;color:#d3a13a}
.ac-tel{background:#d8edf7;color:#3a8fc0}
.action-card p{font-size:.92rem;color:#6a6f78;line-height:1.5;margin-bottom:1.6rem;flex:1}
.action-btn{display:inline-block;border:1px solid var(--navy);color:var(--navy);padding:.7rem 1.4rem;border-radius:4px;font-size:.8rem;letter-spacing:.06em;transition:.25s}
.action-btn:hover{background:var(--navy);color:#fff}

/* --- PERSONNALISATION --- */
.perso-section{background:var(--paper-2);padding:2.5rem 2.2rem}
.perso-wrap{max-width:1200px;margin:0 auto}
.perso-head{max-width:760px;margin-bottom:2.4rem}
.perso-head h2{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--navy);margin-bottom:1rem;line-height:1.15}
.perso-head p{color:#5a606b;font-size:1.02rem}
.perso-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.perso-gallery figure{border-radius:6px;overflow:hidden;aspect-ratio:4/3}
.perso-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.perso-gallery figure:hover img{transform:scale(1.06)}

/* --- SLIDER RÉALISATIONS --- */
.real-slider-section{background:#fff;padding:1.6rem 2.2rem;text-align:center}
.real-slider-title{font-family:var(--display);font-weight:500;font-size:clamp(1.9rem,4vw,2.8rem);color:var(--navy);margin-bottom:1rem}
.real-slider-title::after{content:'';display:block;width:60px;height:3px;background:var(--gold);margin:1rem auto 0}
.real-slider-sub{color:#5a606b;max-width:560px;margin:1.4rem auto 2.6rem}
.real-slider{position:relative;max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:.8rem}
.slider-track{display:flex;gap:1.4rem;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding:.5rem}
.slider-track::-webkit-scrollbar{display:none}
.slide{flex:0 0 auto;width:340px;max-width:80vw;aspect-ratio:4/3;border-radius:8px;overflow:hidden;cursor:pointer;scroll-snap-align:center;position:relative}
.slide img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.slide:hover img{transform:scale(1.06)}
.slide::after{content:'⤢';position:absolute;top:12px;right:12px;background:rgba(31,43,61,.7);color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;opacity:0;transition:opacity .3s}
.slide:hover::after{opacity:1}
.slide-legend{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1rem .9rem;background:linear-gradient(transparent,rgba(31,43,61,.85));color:#fff;font-size:.92rem;letter-spacing:.03em;text-align:left}
.slider-arrow{flex:0 0 auto;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--navy);font-size:1.2rem;cursor:pointer;transition:.25s;z-index:2}
.slider-arrow:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
.real-slider-cta{margin-top:2.6rem}

/* --- LIGHTBOX --- */
.lightbox{position:fixed;inset:0;z-index:3500;background:rgba(20,28,40,.92);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;opacity:0;transition:opacity .3s}
.lightbox[hidden]{display:none!important}
.lightbox.show{opacity:1}
.lightbox img{max-width:90vw;max-height:80vh;border-radius:6px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox-caption{color:#fff;margin-top:1.2rem;font-size:1rem;letter-spacing:.05em}
.lightbox-close{position:absolute;top:24px;right:30px;background:none;border:none;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}

@media(max-width:900px){
  .action-cards{grid-template-columns:1fr 1fr}
  .perso-gallery{grid-template-columns:1fr 1fr}
  .selector-layout{grid-template-columns:1fr;gap:2rem}
  .selector-preview{position:relative;top:0;aspect-ratio:16/10;max-height:340px}
}
@media(max-width:560px){
  .action-cards{grid-template-columns:1fr}
  .perso-gallery{grid-template-columns:1fr}
  .swatch-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}
}

/* ============ BLOC SEO (bas des pages collection, au-dessus du footer) ============ */
.seo-block{background:var(--paper-2);padding:3rem 2.2rem}
.seo-block-inner{max-width:900px;margin:0 auto}
.seo-block-title{font-family:var(--display);font-weight:500;font-size:clamp(1.5rem,2.6vw,2rem);color:var(--navy);line-height:1.2;margin:0 0 1.2rem;text-align:center}
.seo-block-text p{color:#5a606b;font-size:.96rem;line-height:1.75;margin:0 0 1rem}
.seo-block-text p:last-child{margin-bottom:0}
.seo-block-text strong{color:var(--navy);font-weight:600}
.seo-block-text a{color:var(--gold);text-decoration:underline;text-underline-offset:2px}
.seo-block-text a:hover{color:var(--navy)}
@media(max-width:760px){
  .seo-block{padding:2.2rem 1.2rem}
  .seo-block-text p{font-size:.92rem;line-height:1.7}
}


@media(max-width:760px){
  /* Sections : padding latéral réduit pour ne plus serrer le contenu */
  .section{padding:2.2rem 1.2rem}
  .action-cards-section{padding:2rem 1.2rem}
  .perso-section{padding:2.2rem 1.2rem}
  .real-slider-section{padding:1.6rem 1.2rem}

  /* Carte sélecteur : occupe quasi toute la largeur, padding allégé */
  .selector-section{width:calc(100% - 1.6rem);margin:1.6rem auto;padding:1.8rem 1.1rem 2.2rem;border-radius:12px}
  .selector-head{margin-bottom:1.8rem}

  /* Onglets : défilent horizontalement au lieu de déborder */
  .selector-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.2rem}
  .selector-tabs::-webkit-scrollbar{display:none}
  .sel-tab{padding:.75rem .9rem;font-size:.88rem;white-space:nowrap}
  .subfam-tabs{flex-wrap:wrap;gap:1rem}

  /* Aperçu du sélecteur : hauteur raisonnable sur mobile */
  .selector-preview{aspect-ratio:4/3;max-height:300px}

  /* Cartes d'action : un peu moins de padding interne */
  .action-card{padding:1.6rem 1.2rem}
  .action-card h3{min-height:0;margin-bottom:1rem}

  /* Slider : flèches plus petites, slides adaptées à l'écran */
  .real-slider{gap:.3rem}
  .slider-arrow{width:38px;height:38px;font-size:1rem}
  .slide{width:78vw;max-width:78vw}
}

@media(max-width:480px){
  /* Hero des pages collection : un peu plus court, padding resserré */
  .page-hero, .page-hero-centered{min-height:46vh}
  .page-hero .page-hero-content, .page-hero-centered .page-hero-content{padding:1.5rem 1.1rem}

  /* Pastilles coloris : 4 par ligne, taille réduite */
  .swatch-grid{grid-template-columns:repeat(4,1fr);gap:.9rem}
  .swatch-img{width:60px;height:60px}
  .swatch figcaption{font-size:.74rem}
  .swatch-ref{font-size:.68rem}

  /* Sélecteur encore plus compact */
  .selector-section{padding:1.5rem .9rem 2rem}

  /* Slider en plein écran sur très petit mobile */
  .slide{width:84vw;max-width:84vw}

  /* Lightbox : moins de padding pour une image plus grande */
  .lightbox{padding:1rem}
  .lightbox img{max-width:94vw;max-height:82vh}
  .lightbox-close{top:14px;right:16px;font-size:2rem}
}


/* ===================================================== */
/* ===== STYLE DES TITRES : plus gras + mot manuscrit === */
/* ===================================================== */

/* Renforcement du gras de TOUS les grands titres (Cormorant) */
.hero h1,
.intro-title,
.feature-text h2,
.process-title,
.cta-band h2,
.page-hero h1,
.section h2,
.col-intro-title,
.selector-head h2,
.perso-head h2,
.real-slider-title {
  font-weight: 700 !important;
  letter-spacing: -0.005em;
}

/* Le mot manuscrit (entre *astérisques* dans l'admin) */
.title-script {
  font-family: 'Petit Formal Script', cursive;
  font-weight: 400;
  font-style: normal;
  color: var(--gold);
  font-size: 1.08em;
  padding: 0 0.05em;
  white-space: nowrap;
}

/* Titres centrés pour les pages produits */
.col-intro-title,
.selector-head h2,
.real-slider-title {
  text-align: center;
}
.section-narrow {
  text-align: center;
}
.section-narrow p {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

/* --- BANNIÈRE CENTRÉE SUR LA PHOTO (toutes les pages) --- */
.page-hero, .page-hero-centered{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;min-height:54vh;overflow:hidden}
.page-hero .hero-bg, .page-hero-centered .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.page-hero .hero-overlay, .page-hero-centered .hero-overlay{position:absolute;inset:0;background:rgba(20,28,40,.45);z-index:1}
.page-hero .page-hero-content, .page-hero-centered .page-hero-content{position:relative;z-index:2;color:#fff;max-width:1000px;padding:2rem 1.5rem}
.page-hero .eyebrow, .page-hero-centered .eyebrow{color:#fff;opacity:1;justify-content:center;display:block;text-shadow:0 1px 4px rgba(0,0,0,.55)}
.page-hero h1, .page-hero-centered h1{font-family:var(--display);font-weight:700 !important;font-size:clamp(2.2rem,5.5vw,4.4rem);line-height:1.05;color:#fff;margin:0 auto .9rem;text-shadow:0 2px 10px rgba(0,0,0,.45)}
.page-hero .page-hero-content > p, .page-hero-centered .page-hero-content > p{color:rgba(255,255,255,.95);font-size:1.05rem;max-width:620px;margin:0 auto;text-shadow:0 1px 6px rgba(0,0,0,.45)}
.page-hero .title-script, .page-hero-centered .title-script{color:#fff}

/* ===================================================== */
/* ===== PAGE NOS CLIENTS + LIGHTBOX CGV =============== */
/* ===================================================== */

/* le + doré dans le menu */
.nav-plus{color:var(--gold);font-weight:700;font-size:1.15em;line-height:1}
.nav a.active .nav-plus{color:#fff}

/* --- MENU D'ANCRES (style 01/02/03/04) --- */
.anchors-section{background:var(--paper);padding:1.6rem 2.2rem}
.anchors-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.anchor-item{display:block;padding-top:1.4rem;border-top:1px solid var(--line);transition:border-color .3s}
.anchor-item:hover{border-color:var(--gold)}
.anchor-num{display:block;font-family:var(--display);font-size:2.2rem;font-weight:500;color:var(--gold);line-height:1;margin-bottom:.8rem}
.anchor-label{display:block;font-size:.95rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);margin-bottom:.4rem}
.anchor-desc{display:block;font-size:.9rem;color:var(--muted)}

/* --- SECTIONS ALTERNÉES image/texte (Nos Clients) --- */
.nc-split{padding:1.6rem 2.2rem;scroll-margin-top:90px}
.nc-split-inner{max-width:1150px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:2.6rem;align-items:center}
.nc-split.reversed .nc-split-media{order:2}
.nc-split-media{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 18px 50px rgba(31,43,61,.15)}
.nc-split-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.nc-split:hover .nc-split-media img{transform:scale(1.04)}
.nc-badge{position:absolute;left:0;bottom:0;background:var(--navy-deep);color:#fff;padding:1.4rem 1.8rem;text-align:center;border-top-right-radius:10px}
.nc-badge-num{display:block;font-family:var(--display);font-size:2.6rem;font-weight:500;line-height:1}
.nc-badge-label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;opacity:.85;margin-top:.3rem}
.nc-split-text{position:relative}
.nc-split-num{display:block;font-family:var(--display);font-size:3rem;font-weight:500;color:var(--gold);opacity:.35;line-height:1;margin-bottom:.4rem}
.nc-split-text .eyebrow{color:var(--gold);margin-bottom:.6rem}
.nc-split-text h2{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.6rem);color:var(--navy);line-height:1.15;margin-bottom:1.2rem}
.nc-split-text p{color:#5a606b;font-size:1.05rem;line-height:1.75}

/* --- BLOC PRENDRE RENDEZ-VOUS --- */
.nc-rdv-band{background:var(--navy-deep);color:#fff;padding:1.6rem 2.2rem;text-align:center}
.nc-rdv-inner{max-width:640px;margin:0 auto}
.nc-rdv-band h2{font-family:var(--display);font-weight:700;font-size:clamp(2rem,4vw,3rem);margin-bottom:1rem;color:#fff}
.nc-rdv-band .title-script{color:var(--gold-soft)}
.nc-rdv-band p{color:rgba(255,255,255,.85);font-size:1.08rem;margin-bottom:2rem}
.btn-gold{display:inline-block;background:var(--gold);color:#fff;padding:1rem 2.4rem;border-radius:4px;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;transition:background .25s,transform .25s}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-2px)}

.nc-cgv-link{text-align:center;padding:1.6rem 2.2rem;max-width:1320px;margin:0 auto}
.nc-cgv-link a{color:var(--navy);text-decoration:underline;text-underline-offset:3px}
.nc-cgv-link a:hover{color:var(--gold)}

/* --- LIGHTBOX CGV --- */
.cgv-overlay{position:fixed;inset:0;z-index:3500;background:rgba(20,28,40,.7);display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;transition:opacity .3s}
.cgv-overlay[hidden]{display:none!important}
.cgv-overlay.show{opacity:1}
.cgv-modal{position:relative;background:#fff;max-width:760px;width:100%;max-height:85vh;overflow-y:auto;border-radius:10px;padding:2.6rem 2.4rem;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.cgv-modal h2{font-family:var(--display);font-weight:700;font-size:1.8rem;color:var(--navy);margin-bottom:1.4rem;padding-right:2rem}
.cgv-body{color:#4a4f58;font-size:.96rem;line-height:1.7}
.cgv-close{position:absolute;top:1.2rem;right:1.4rem;background:none;border:none;font-size:2rem;line-height:1;color:var(--muted);cursor:pointer}
.cgv-close:hover{color:var(--navy)}

@media(max-width:900px){
  .anchors-grid{grid-template-columns:1fr 1fr;gap:1.6rem}
  .nc-split-inner{grid-template-columns:1fr;gap:2rem}
  .nc-split.reversed .nc-split-media{order:0}
}
@media(max-width:520px){
  .anchors-grid{grid-template-columns:1fr 1fr;gap:1.2rem}
}

/* ============================================================
   BLOC SPACEUM (page Cuisines uniquement)
   ============================================================ */
.spaceum-section{padding:1rem 2.2rem 3.5rem}
.spaceum-card{max-width:1200px;margin:0 auto;position:relative;background:linear-gradient(180deg,#fff,var(--paper-2));border:1px solid var(--line);border-radius:16px;padding:2.8rem 2.4rem;box-shadow:0 18px 50px -28px rgba(43,58,82,.45);overflow:hidden}
.spaceum-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-soft))}
.spaceum-head{text-align:center;max-width:680px;margin:0 auto 2.4rem}
.spaceum-logo{display:block;width:auto;max-width:min(340px,80%);height:auto;margin:.2rem auto 1.2rem;border-radius:16px;box-shadow:0 14px 36px -16px rgba(0,0,0,.55)}
.spaceum-text{color:var(--muted);font-size:1.02rem;line-height:1.7}
.spaceum-options{display:flex;align-items:stretch;gap:1.2rem;justify-content:center}
.spaceum-opt{flex:1 1 0;min-width:0;width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.8rem 1.6rem;font:inherit;color:inherit;cursor:pointer;transition:transform .3s,box-shadow .3s,border-color .3s}
.spaceum-opt:hover{transform:translateY(-4px);box-shadow:0 16px 40px -24px rgba(43,58,82,.5);border-color:var(--gold)}
.spaceum-opt-stock{border-top:3px solid var(--gold)}
.spaceum-opt-sur{border-top:3px solid var(--navy)}
.spaceum-opt-icon{width:54px;height:54px;margin:0 auto 1rem;color:var(--navy);display:flex;align-items:center;justify-content:center;background:var(--paper-2);border-radius:50%}
.spaceum-opt-icon svg{width:28px;height:28px}
.spaceum-badge{display:inline-block;background:var(--gold);color:#fff;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:.32rem .9rem;border-radius:20px;margin-bottom:.9rem}
.spaceum-badge-soft{background:var(--navy)}
.spaceum-opt h3{font-family:var(--display);font-weight:600;font-size:1.45rem;color:var(--navy);margin-bottom:.6rem}
.spaceum-opt p{color:var(--muted);font-size:.95rem;line-height:1.6;flex:1 1 auto}
.spaceum-opt-more{margin-top:1rem;font-size:.82rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gold)}
.spaceum-or{display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.spaceum-or span{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--paper);color:var(--muted);font-family:var(--display);font-style:italic;font-size:1.05rem}
.spaceum-cta{text-align:center;margin-top:2.2rem}
@media(max-width:760px){
  .spaceum-card{padding:2rem 1.3rem}
  .spaceum-options{flex-direction:column;align-items:stretch}
  .spaceum-opt{max-width:none}
  .spaceum-or{padding:.2rem 0}
  .spaceum-or span{width:40px;height:40px}
}

/* ============================================================
   LIGHTBOX PARTAGÉE (.rlb) — Réalisations ET Spaceum/Cuisines
   ============================================================ */
.rlb{position:fixed;inset:0;z-index:9999;display:none;opacity:0;transition:opacity .3s}
.rlb.open{display:block;opacity:1}
.rlb-backdrop{position:absolute;inset:0;background:rgba(18,24,36,.9);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.rlb-frame{position:relative;max-width:880px;width:92%;margin:4vh auto;max-height:92vh;overflow-y:auto;border-radius:14px;background:linear-gradient(180deg,#1d2738,#141c2a);box-shadow:0 40px 100px rgba(0,0,0,.6);border:1px solid rgba(211,154,44,.35);transform:scale(.96);transition:transform .35s}
.rlb.open .rlb-frame{transform:scale(1)}
.rlb-stage{position:relative;border-radius:14px 14px 0 0;overflow:hidden}
.rlb-stage img{width:100%;max-height:62vh;object-fit:cover;display:block}
.rlb-overlay{position:absolute;left:0;right:0;bottom:0;padding:2.4rem 1.8rem 1.4rem;background:linear-gradient(180deg,transparent,rgba(15,21,32,.92));color:#fff}
.rlb-cat{display:inline-block;background:var(--gold,#d39a2c);color:#fff;padding:.28rem .85rem;border-radius:20px;font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700;margin-bottom:.6rem}
.rlb-overlay h3{font-family:var(--display,'Cormorant Garamond',serif);font-weight:600;font-size:clamp(1.8rem,4vw,2.6rem);line-height:1.05;margin:0;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.rlb-stars{display:flex;gap:3px;margin-top:.5rem}
.rlb-stars svg{width:19px;height:19px}
.rlb-stars svg.on{color:var(--gold,#d39a2c)}
.rlb-stars svg.off{color:rgba(255,255,255,.3)}
.rlb-bottom{padding:1.6rem 1.9rem 2rem}
.rlb-desc{color:rgba(255,255,255,.82);line-height:1.65;font-size:1rem;margin:0}
.rlb-desc:empty{display:none}
.rlb-avis{position:relative;margin-top:1.3rem;padding:1.1rem 1.3rem 1.1rem 2.6rem;background:rgba(211,154,44,.08);border-left:3px solid var(--gold,#d39a2c);border-radius:0 8px 8px 0}
.rlb-quote{position:absolute;left:.7rem;top:.1rem;font-family:var(--display,serif);font-size:2.6rem;color:var(--gold,#d39a2c);opacity:.6;line-height:1}
.rlb-avis p{margin:0;font-style:italic;color:#fff;font-size:1.02rem;line-height:1.5}
.rlb-client{display:block;margin-top:.6rem;font-weight:700;color:var(--gold,#d39a2c);font-size:.85rem;letter-spacing:.04em;text-transform:uppercase}
.rlb-close{position:absolute;top:14px;right:16px;z-index:3;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);width:40px;height:40px;border-radius:50%;font-size:1.6rem;line-height:1;cursor:pointer;color:#fff;transition:all .2s}
.rlb-close:hover{background:var(--gold,#d39a2c);border-color:var(--gold,#d39a2c);transform:rotate(90deg)}
@media(max-width:600px){.rlb-stage img{max-height:45vh}.rlb-overlay{padding:1.8rem 1.2rem 1rem}}

/* ============================================================
   PROMOS PAR UNIVERS (page promo.php) — encadrés colorés arrondis
   ============================================================ */
.promos-section{max-width:1200px;margin:0 auto;padding:3rem 2.2rem 4rem;text-align:center}
.promos-title{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4vw,2.8rem);color:var(--navy);line-height:1.1;margin:.2rem 0 .5rem}
.promos-sub{color:var(--muted);font-size:1.02rem;margin-bottom:2.6rem}
.promos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;text-align:left}
.promo-uni{position:relative;display:flex;flex-direction:column;background:linear-gradient(180deg,#fff,var(--paper-2));border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 14px 40px -30px rgba(43,58,82,.5);transition:transform .3s,box-shadow .3s}
.promo-uni:hover{transform:translateY(-5px);box-shadow:0 22px 50px -28px rgba(43,58,82,.55)}
.promo-uni::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;z-index:2}
.promo-uni-media{position:relative;aspect-ratio:4/3;overflow:hidden;cursor:pointer}
.promo-uni-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.promo-uni:hover .promo-uni-media img{transform:scale(1.06)}
.promo-uni-tag{position:absolute;top:12px;left:12px;z-index:2;color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.32rem .85rem;border-radius:20px}
.promo-uni-zoomhint{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(31,43,61,.7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;opacity:0;transition:opacity .3s;pointer-events:none}
.promo-uni:hover .promo-uni-zoomhint{opacity:1}
.promo-uni-body{display:flex;flex-direction:column;align-items:flex-start;padding:1.4rem 1.3rem 1.5rem;flex:1 1 auto}
.promo-uni-badge{display:inline-block;color:#fff;font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:.28rem .75rem;border-radius:20px;margin-bottom:.7rem}
.promo-uni-body h3{font-family:var(--display);font-weight:600;font-size:1.35rem;color:var(--navy);line-height:1.12;margin-bottom:.4rem}
.promo-uni-soustitre{font-family:var(--display);font-style:italic;font-size:1rem;margin-bottom:.6rem}
.promo-uni-desc{color:var(--muted);font-size:.9rem;line-height:1.6;margin-bottom:.7rem}
.promo-uni-cond{color:#a2a7b0;font-size:.78rem;line-height:1.5;margin-bottom:1rem}
.promo-uni-btn{margin-top:auto;display:inline-block;color:#fff;text-decoration:none;font-weight:600;font-size:.85rem;padding:.7rem 1.3rem;border-radius:30px;transition:filter .25s,transform .25s}
.promo-uni-btn:hover{filter:brightness(1.08);transform:translateY(-2px)}
/* couleurs par univers : Cuisine=or, Placard=bleu, Dressing=vert */
.promo-uni-gold::before{background:linear-gradient(90deg,var(--gold),var(--gold-soft))}
.promo-uni-gold .promo-uni-tag,.promo-uni-gold .promo-uni-badge,.promo-uni-gold .promo-uni-btn{background:var(--gold)}
.promo-uni-gold .promo-uni-soustitre{color:var(--gold)}
.promo-uni-blue::before{background:linear-gradient(90deg,#3a6ea5,#5a90c9)}
.promo-uni-blue .promo-uni-tag,.promo-uni-blue .promo-uni-badge,.promo-uni-blue .promo-uni-btn{background:#3a6ea5}
.promo-uni-blue .promo-uni-soustitre{color:#3a6ea5}
.promo-uni-green::before{background:linear-gradient(90deg,#3f8f6b,#5cae87)}
.promo-uni-green .promo-uni-tag,.promo-uni-green .promo-uni-badge,.promo-uni-green .promo-uni-btn{background:#3f8f6b}
.promo-uni-green .promo-uni-soustitre{color:#3f8f6b}
@media(max-width:820px){.promos-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

/* Pop-up promo version image */
.promo-popup-hasimg{padding:0;overflow:hidden}
.promo-popup-imgwrap{display:block;width:100%;border:none;padding:0;position:relative;background:none}
.promo-popup-imgwrap img{width:100%;display:block}
.promo-popup-zoom{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(31,43,61,.7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem}
.promo-popup-hasimg .promo-popup-body{padding:1.4rem 1.6rem 1.6rem}

/* ============================================================
   PAGE RÉALISATIONS — Section "3 univers signature" + CTA final
   ============================================================ */
.realisations-hero{height:auto;min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:9rem 2.2rem 8rem;position:relative}
.realisations-hero .hero-overlay{background:linear-gradient(180deg,rgba(31,43,61,.55),rgba(31,43,61,.82))}
.realisations-hero .signature-head{position:relative;z-index:2;max-width:680px;margin:0;color:#fff}
.realisations-hero .signature-script{display:block;font-size:2.6rem;color:var(--gold-soft);margin-bottom:.4rem;white-space:normal}
.realisations-hero .signature-title{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4.5vw,3rem);color:#fff;line-height:1.1;margin-bottom:1rem;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.realisations-hero .signature-intro{color:rgba(255,255,255,.85);font-size:1.05rem;line-height:1.7}
.signature-section{background:var(--navy-deep);padding:0 2.2rem 5rem;position:relative;z-index:3}
.signature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;max-width:1140px;margin:0 auto;position:relative;z-index:3;transform:translateY(-90px);margin-bottom:-50px}
.signature-card{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 30px 70px -28px rgba(0,0,0,.55);transition:transform .4s,box-shadow .4s}
.signature-card:hover{transform:translateY(-8px);box-shadow:0 40px 90px -28px rgba(0,0,0,.65)}
.signature-card-body{padding:2.6rem 1.8rem 2.4rem;text-align:center}
.signature-num{display:block;font-family:var(--display);font-style:italic;font-size:3.4rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:.6rem}
.signature-card-body h3{font-family:var(--display);font-weight:600;font-size:1.55rem;color:var(--navy);margin-bottom:.7rem;position:relative;padding-bottom:.8rem}
.signature-card-body h3::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:42px;height:2px;background:var(--gold)}
.signature-card-body p{color:var(--muted);font-size:.95rem;line-height:1.65}

/* CTA final — Rencontrez un concepteur */
.rdv-band{background:linear-gradient(160deg,var(--navy),var(--navy-deep));color:#fff;padding:5rem 2.2rem;text-align:center;position:relative;overflow:hidden}
.rdv-band::before{content:"";position:absolute;bottom:-140px;left:-100px;width:420px;height:420px;background:radial-gradient(circle,rgba(211,154,44,.14),transparent 65%);pointer-events:none}
.rdv-band-inner{max-width:680px;margin:0 auto;position:relative;z-index:1}
.rdv-band-script{display:block;font-size:2.6rem;color:var(--gold-soft);margin-bottom:.5rem;white-space:normal}
.rdv-band-title{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4.5vw,3rem);line-height:1.1;margin-bottom:1.1rem;color:#fff}
.rdv-band-text{color:rgba(255,255,255,.78);font-size:1.08rem;line-height:1.75;margin-bottom:2.2rem}
.rdv-band-btn{display:inline-block;background:var(--gold);color:#fff;padding:1rem 2.4rem;border-radius:32px;font-weight:600;font-size:.95rem;letter-spacing:.03em;text-decoration:none;transition:transform .25s,box-shadow .25s,background .25s}
.rdv-band-btn:hover{background:var(--gold-soft);transform:translateY(-3px);box-shadow:0 14px 32px -12px rgba(211,154,44,.7)}

@media(max-width:820px){
  .signature-grid{grid-template-columns:1fr;max-width:460px;transform:none;margin-bottom:0}
  .realisations-hero{padding:7rem 1.4rem 4rem}
  .signature-section{padding:3.5rem 1.4rem 4rem}
  .rdv-band{padding:3.5rem 1.4rem}
}

/* ============================================================
   GALERIE RÉALISATIONS — style "affiche signature"
   ============================================================ */
.real-gallery-section{background:var(--paper);padding:5rem 0 1rem}
.real-gallery-head{text-align:center;max-width:680px;margin:0 auto 3rem;padding:0 2.2rem}
.real-gallery-script{display:block;font-size:2.4rem;color:var(--gold);margin-bottom:.3rem;white-space:normal}
.real-gallery-title{font-family:var(--display);font-weight:500;font-size:clamp(1.9rem,4vw,2.7rem);color:var(--navy);line-height:1.1;margin-bottom:1rem}
.real-gallery-intro{color:var(--muted);font-size:1.02rem;line-height:1.7}
/* la carte affiche : plus de fond blanc ni bordure, juste l'image */
.real-gallery-section .real-card{border:none;background:none;border-radius:0;box-shadow:none}
.real-gallery-section .real-card:hover{transform:translateY(-5px)}

/* ============================================================
   PAGE NOS CLIENTS — Section Financement en encadré (style sélecteur)
   ============================================================ */
.finance-section{position:relative;width:calc(100% - 4.4rem);max-width:1200px;margin:1.6rem auto;background:linear-gradient(180deg,#fff,var(--paper-2));border:1px solid #d2d5da;border-radius:16px;padding:2.4rem 2.4rem 2.8rem;box-shadow:0 18px 50px -28px rgba(43,58,82,.45);overflow:hidden}
.finance-section::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#b9bdc4,#d8dbe0)}
.finance-head{max-width:820px;margin:0 auto 1.8rem;text-align:center;position:relative}
.finance-num{display:block;font-family:var(--display);font-style:italic;font-size:2.6rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:.3rem;opacity:.5}
.finance-head .eyebrow{justify-content:center}
.finance-head h2{font-family:var(--display);font-weight:500;font-size:clamp(1.7rem,3vw,2.4rem);color:var(--navy);margin-bottom:.9rem;line-height:1.2}
.finance-intro{color:#5a606b;font-size:1.02rem;line-height:1.6}
.finance-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;max-width:980px;margin:0 auto}
.finance-card{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 30px -22px rgba(0,0,0,.4);transition:transform .35s,box-shadow .35s;cursor:pointer}
.finance-card:hover{transform:translateY(-6px);box-shadow:0 20px 45px -22px rgba(0,0,0,.5)}
.finance-card-media{position:relative;aspect-ratio:4/3;overflow:hidden;display:block;width:100%}
.finance-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.finance-card:hover .finance-card-media img{transform:scale(1.07)}
.finance-card-zoom{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(31,43,61,.72);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:300;line-height:1;opacity:0;transition:opacity .3s}
.finance-card:hover .finance-card-zoom{opacity:1}
.finance-card-titre{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--navy);text-align:center;margin:1.2rem 1.1rem .5rem;position:relative;padding-bottom:.7rem}
.finance-card-titre::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:38px;height:2px;background:var(--gold)}
.finance-card-texte{color:var(--muted);font-size:.9rem;line-height:1.6;text-align:center;margin:0 1.2rem 1.5rem}
/* Lightbox texte financement */
.finance-lb{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.finance-lb.show{opacity:1}
.finance-lb[hidden]{display:none}
.finance-lb-backdrop{position:absolute;inset:0;background:rgba(18,24,36,.72);backdrop-filter:blur(5px)}
.finance-lb-box{position:relative;background:#fff;border-radius:14px;max-width:520px;width:92%;padding:2.6rem 2.2rem;text-align:center;box-shadow:0 40px 100px rgba(0,0,0,.5);border-top:4px solid var(--gold);transform:scale(.95);transition:transform .3s}
.finance-lb.show .finance-lb-box{transform:scale(1)}
.finance-lb-script{display:block;font-size:1.8rem;color:var(--gold);margin-bottom:.3rem}
.finance-lb-box h3{font-family:var(--display);font-weight:600;font-size:1.7rem;color:var(--navy);margin-bottom:1rem}
.finance-lb-box p{color:#5a606b;font-size:1rem;line-height:1.7;margin:0}
.finance-lb-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:2rem;line-height:1;color:var(--muted);cursor:pointer;transition:color .2s}
.finance-lb-close:hover{color:var(--navy)}
@media(max-width:820px){
  .finance-section{width:calc(100% - 2rem);padding:2.2rem 1.2rem 2.6rem}
  .finance-cards{grid-template-columns:1fr;max-width:380px}
}

/* ============================================================
   PAGE NOS CLIENTS — Section Conception (5 étapes fléchées)
   ============================================================ */
.concept-section{position:relative;width:calc(100% - 4.4rem);max-width:1200px;margin:1.6rem auto;background:var(--navy-deep);color:#fff;border-radius:16px;padding:2.6rem 2.4rem 3rem;overflow:hidden}
.concept-section::before{content:"";position:absolute;top:-100px;right:-80px;width:340px;height:340px;background:radial-gradient(circle,rgba(211,154,44,.15),transparent 65%);pointer-events:none}
.concept-head{max-width:720px;margin:0 auto 2rem;text-align:center;position:relative;z-index:1}
.concept-num{display:block;font-family:var(--display);font-style:italic;font-size:2.6rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:.3rem;opacity:.6}
.concept-head .eyebrow{justify-content:center;color:var(--gold-soft)}
.concept-head h2{font-family:var(--display);font-weight:500;font-size:clamp(1.7rem,3vw,2.4rem);color:#fff;margin-bottom:.9rem;line-height:1.2}
.concept-intro{color:rgba(255,255,255,.72);font-size:1.02rem;line-height:1.6}
.concept-steps{display:flex;align-items:flex-start;justify-content:center;gap:.4rem;flex-wrap:wrap;position:relative;z-index:1}
.concept-step{display:flex;flex-direction:column;align-items:center;gap:.7rem;cursor:pointer;width:130px;text-align:center;transition:transform .25s}
.concept-step:hover{transform:translateY(-4px)}
.concept-step-num{width:54px;height:54px;border-radius:50%;border:2px solid var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:1.5rem;font-weight:600;background:rgba(211,154,44,.16);transition:background .25s}
.concept-step:hover .concept-step-num{background:var(--gold)}
.concept-step-lbl{font-size:.82rem;letter-spacing:.04em;color:#fff;font-weight:500;line-height:1.3}
.concept-step-arrow{color:var(--gold);font-size:1.4rem;margin-top:14px;flex:0 0 auto}
@media(max-width:880px){
  .concept-section{width:calc(100% - 2rem);padding:2.4rem 1.2rem 2.8rem}
  .concept-steps{flex-direction:column;align-items:center;gap:.2rem}
  .concept-step{flex-direction:row;width:100%;max-width:320px;gap:1rem;text-align:left;justify-content:flex-start}
  .concept-step-arrow{transform:rotate(90deg);margin:0}
}
/* Lightbox photo + texte conception */
.concept-lb{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.concept-lb.show{opacity:1}
.concept-lb[hidden]{display:none}
.concept-lb-backdrop{position:absolute;inset:0;background:rgba(18,24,36,.75);backdrop-filter:blur(5px)}
.concept-lb-box{position:relative;background:#fff;border-radius:14px;max-width:560px;width:92%;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.5);transform:scale(.95);transition:transform .3s}
.concept-lb.show .concept-lb-box{transform:scale(1)}
.concept-lb-media{aspect-ratio:16/9;overflow:hidden;background:#1a2230}
.concept-lb-media img{width:100%;height:100%;object-fit:cover;display:block}
.concept-lb-body{padding:1.8rem 2rem 2.2rem;text-align:center}
.concept-lb-script{display:block;font-size:1.6rem;color:var(--gold);margin-bottom:.2rem}
.concept-lb-body h3{font-family:var(--display);font-weight:600;font-size:1.6rem;color:var(--navy);margin-bottom:.8rem}
.concept-lb-body p{color:#5a606b;font-size:1rem;line-height:1.7;margin:0}
.concept-lb-close{position:absolute;top:12px;right:14px;z-index:2;background:rgba(255,255,255,.85);border:none;width:38px;height:38px;border-radius:50%;font-size:1.6rem;line-height:1;color:var(--navy);cursor:pointer;transition:background .2s}
.concept-lb-close:hover{background:#fff}

/* ============ ANTI-DEBORDEMENT HORIZONTAL GLOBAL (mobile) ============ */
html,body{max-width:100%;overflow-x:hidden}
@media(max-width:760px){
  /* le selecteur ne doit jamais depasser la largeur ecran */
  .selector-section{width:auto;max-width:100%;margin-left:.8rem;margin-right:.8rem;box-sizing:border-box}
  .selector-layout,.selector-panel,.selector-preview{max-width:100%;min-width:0}
  .selector-preview img{max-width:100%}
  /* securite : aucune image ou media ne depasse */
  img,video,iframe{max-width:100%}
}
