/* ===== Conquérant — Éditorial Luxe ===== */
:root{
  --brun:#442829; --brun2:#3a2122; --brun3:#2e1a1b;
  --or:#EEBA7D; --or2:#D89F5E;
  --creme:#F7F1EA; --creme2:#efe7dc; --gris:#D9D9D9; --texte:#2A1A1B;
  --display:'Cinzel',serif; --accent:'Playfair Display',serif; --body:'Montserrat',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased}
body{font-family:var(--body),sans-serif;color:var(--texte);background:var(--creme);font-weight:300;overflow-x:hidden}
body.lock{overflow:hidden}
h1,h2,h3,h4,.serif{font-family:var(--display),serif;font-weight:600;letter-spacing:.01em}
/* accents italiques en Playfair (Cinzel n'a pas d'italique) */
h1 em,h2 em,h3 em,h4 em,.sec-title em,.hero-copy h1 .l2,.phero h1 em,.bhero h1 em,.btag em{font-family:var(--accent);font-style:italic;font-weight:500;letter-spacing:0}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.wrap{max-width:1320px;margin:0 auto;padding:0 40px}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--or2)}
.italic{font-style:italic}

/* intro logo splash — "on rentre dedans" (façon Normandy Private Driver) */
@keyframes intro-logo-appear{from{opacity:0;transform:scale(.85) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes intro-text-rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes intro-exit{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.08)}}
#intro.intro-overlay{position:fixed;inset:0;z-index:9999;
  background:radial-gradient(circle at 50% 45%,#3a2122 0%,#2e1a1b 55%,#1a0f10 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;pointer-events:all}
.intro-fulllogo{width:min(76vw,400px);height:auto;display:block;
  filter:drop-shadow(0 0 40px rgba(238,186,125,.18));
  animation:intro-logo-appear 1s cubic-bezier(.4,0,.2,1) both}
#intro.intro-exiting{animation:intro-exit .7s cubic-bezier(.4,0,.2,1) forwards;pointer-events:none}
.intro-glow{position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(238,186,125,.12) 0%,transparent 70%);pointer-events:none}
.intro-logo-wrap{margin-bottom:28px;animation:intro-logo-appear .8s cubic-bezier(.4,0,.2,1) .1s both}
.intro-circle{width:112px;height:112px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(238,186,125,.35);box-shadow:0 0 34px rgba(238,186,125,.20);background:rgba(247,241,234,.02)}
.intro-circle img{width:76%;height:76%;object-fit:contain}
.intro-title{font-family:var(--display);font-size:clamp(24px,4vw,34px);font-weight:700;letter-spacing:.22em;
  color:var(--creme);text-transform:uppercase;margin:0 0 10px;text-align:center;
  animation:intro-text-rise .7s cubic-bezier(.4,0,.2,1) .55s both}
.intro-sub{font-family:var(--body);font-size:clamp(10px,1.5vw,12px);font-weight:400;letter-spacing:.35em;
  color:var(--or);text-transform:uppercase;margin:0;text-align:center;
  animation:intro-text-rise .7s cubic-bezier(.4,0,.2,1) .75s both}
.no-intro #intro{display:none}
@media(prefers-reduced-motion:reduce){#intro,#intro.intro-exiting,.intro-logo-wrap,.intro-title,.intro-sub{animation:none!important}}

/* custom cursor removed */
.cursor{display:none!important}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:200;transition:.5s}
header .bar{display:flex;align-items:center;justify-content:space-between;height:92px;transition:.5s}
header.scrolled{background:rgba(46,26,27,.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(238,186,125,.16)}
header.scrolled .bar{height:70px}
.brand{font-family:var(--accent);font-size:30px;font-weight:600;letter-spacing:1px;color:var(--creme);display:inline-flex;align-items:center}
.brand img.logo-img{height:58px;width:auto;display:block;transition:.5s}
header.scrolled .brand img.logo-img{height:46px}
.fsocial{display:flex;gap:12px;margin-top:18px}
.fsocial a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:1px solid rgba(238,186,125,.34);color:var(--or);transition:all .25s ease}
.fsocial a:hover{background:var(--or);color:var(--brun3);border-color:var(--or);transform:translateY(-2px)}

@media(max-width:1000px){.brand img.logo-img{height:48px}}
header.light .brand,header.light nav a,header.light .burger{color:var(--creme)}
nav.menu{display:flex;align-items:center;justify-content:center;flex:1;gap:38px;margin:0 44px}
nav.menu ul{display:flex;gap:38px;list-style:none;align-items:center}
nav.menu a{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--creme);opacity:.82;position:relative;transition:.3s}
nav.menu a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--or);transition:.4s}
nav.menu a:hover{opacity:1}nav.menu a:hover::after,nav.menu a.active::after{width:100%}
nav.menu a.active{opacity:1;color:var(--or)}
.btn-rdv{border:1px solid var(--or);color:var(--or);padding:13px 26px;border-radius:999px;font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;transition:.4s;white-space:nowrap}
.btn-rdv:hover{background:var(--or);color:var(--brun)}
.burger{display:none;background:none;border:none;color:var(--creme);font-size:24px;cursor:pointer;z-index:210}

/* magnetic / buttons */
.btn-line{display:inline-flex;align-items:center;gap:14px;font-size:12px;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--or);padding-bottom:6px;position:relative}
.btn-line::before{content:'';position:absolute;left:0;bottom:0;width:42px;height:1px;background:var(--or);transition:.4s}
.btn-line:hover::before{width:100%}
.btn-gold{display:inline-block;background:var(--or);color:var(--brun);padding:16px 34px;border-radius:999px;font-size:12px;
  font-weight:600;letter-spacing:.12em;text-transform:uppercase;transition:.4s;will-change:transform}
.btn-gold:hover{background:var(--creme);box-shadow:0 16px 40px rgba(238,186,125,.3)}
.btn-ghost{display:inline-block;border:1px solid rgba(247,241,234,.45);color:var(--creme);padding:15px 32px;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;transition:.4s}
.btn-ghost:hover{border-color:var(--or);color:var(--or)}
.btn-dark{display:inline-block;border:1px solid var(--brun);color:var(--brun);padding:15px 32px;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;transition:.4s}
.btn-dark:hover{background:var(--brun);color:var(--creme)}

/* HERO */
.hero{position:relative;min-height:100vh;background:
  radial-gradient(120% 80% at 78% 30%,rgba(238,186,125,.16),transparent 55%),
  linear-gradient(155deg,var(--brun) 0%,var(--brun2) 55%,var(--brun3) 100%);
  color:var(--creme);display:flex;align-items:center;overflow:hidden}
.hero .mono-bg{position:absolute;left:-2%;top:50%;transform:translateY(-50%);font-family:var(--accent);
  font-size:52vh;line-height:.7;color:rgba(247,241,234,.04);pointer-events:none;user-select:none;font-weight:500;letter-spacing:-20px}
.hero-grid{position:relative;z-index:3;display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;width:100%}
.hero-copy .eyebrow{margin-bottom:30px}
.hero-copy h1{font-size:clamp(56px,7vw,108px);font-weight:500;line-height:.96;letter-spacing:-1px}
.hero-copy h1 .l2{display:block;font-style:italic;color:var(--or);margin-left:.5em}
.hero-copy p{margin:30px 0 40px;max-width:420px;font-size:17px;line-height:1.8;opacity:.85}
.hero-3d{position:relative;height:80vh}
#glcanvas{width:100%;height:100%;display:block;cursor:grab}
#glcanvas:active{cursor:grabbing}
.hero-3d .hint{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.25em;
  text-transform:uppercase;color:rgba(238,186,125,.6)}
.scroll-cue{position:absolute;bottom:30px;left:40px;z-index:4;font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--or);display:flex;align-items:center;gap:14px}
.scroll-cue i{width:46px;height:1px;background:var(--or);display:block;transform-origin:left;animation:cue 2.4s infinite}
@keyframes cue{0%,100%{transform:scaleX(.2);opacity:.4}50%{transform:scaleX(1);opacity:1}}

/* reveal words/lines */
.reveal{opacity:0;transform:translateY(40px)}
.split-line{display:block;overflow:hidden}
.split-line>span{display:block;transform:translateY(110%)}

/* sections */
section{position:relative;padding:130px 0}
.sec-head{max-width:760px}
.sec-head .eyebrow{display:block;margin-bottom:18px}
.sec-title{font-size:clamp(36px,4.6vw,64px);font-weight:500;line-height:1.05;letter-spacing:-.5px;color:var(--brun)}
.sec-title em{font-style:italic;color:var(--or2)}
.dark{background:var(--brun);color:var(--creme)}
.dark .sec-title{color:var(--creme)}
.dark .eyebrow{color:var(--or)}

/* marquee bands brands */
.marquee{overflow:hidden;border-top:1px solid rgba(238,186,125,.18);border-bottom:1px solid rgba(238,186,125,.18);padding:30px 0;background:var(--brun3)}
.marquee .track{display:flex;gap:70px;white-space:nowrap;width:max-content;animation:scroll 32s linear infinite}
.marquee span{font-family:var(--accent);font-size:34px;color:rgba(247,241,234,.55);font-style:italic}
.marquee .blogo{display:inline-flex;align-items:center;justify-content:center;height:64px;min-width:130px;padding:0 28px;
  background:#fff;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.marquee .blogo img{max-height:36px;max-width:140px;width:auto;object-fit:contain;display:block}
.marquee .blogo b{display:none;font-family:var(--accent);font-style:italic;font-weight:600;font-size:23px;color:var(--brun);white-space:nowrap;line-height:1}
.marquee .blogo.noimg b{display:inline}
@keyframes scroll{to{transform:translateX(-50%)}}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.split.rev .media{order:2}
.media{border-radius:14px;overflow:hidden;position:relative;border:1px solid rgba(238,186,125,.3)}
.media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.7,.2,1)}
.media:hover img{transform:scale(1.05)}
.media.tall{aspect-ratio:4/5}.media.wide{aspect-ratio:4/3}
.lead{font-size:17px;line-height:1.9;color:#5a4a45;margin:24px 0}
.dark .lead{color:rgba(247,241,234,.82)}
.signature{font-family:var(--accent);font-style:italic;font-size:24px;color:var(--brun);margin-top:14px}
.dark .signature{color:var(--or)}

/* specialties cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:60px}
.card{background:var(--creme);border:1px solid var(--gris);border-radius:14px;padding:44px 34px;transition:.5s;position:relative;overflow:hidden;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end}
.dark .card{background:rgba(247,241,234,.03);border-color:rgba(238,186,125,.2)}
.card:hover{transform:translateY(-10px);border-color:var(--or)}
.card .card-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.55;transition:.7s}
.card:hover .card-bg{opacity:.75;transform:scale(1.06)}
.card::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(46,26,27,.45) 0%,rgba(46,26,27,.78) 60%,rgba(46,26,27,.94) 100%)}
.card .n,.card h3,.card p{position:relative;z-index:2}
.card .n{font-family:var(--accent);font-size:18px;color:var(--or);font-style:italic}
.card h3{font-size:26px;color:var(--brun);margin:14px 0 12px}
.dark .card h3{color:var(--creme)}
.card p{font-size:14.5px;line-height:1.7;color:#6a5a55}
.dark .card p{color:rgba(247,241,234,.7)}

/* brand cards illustrated */
.maisons{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:60px}
.maison{border-radius:12px;overflow:hidden;position:relative;aspect-ratio:3/4;border:1px solid rgba(238,186,125,.25);background:var(--brun3)}
.maison img{width:100%;height:100%;object-fit:cover;opacity:.85;transition:.6s}
.maison:hover img{opacity:1;transform:scale(1.06)}
.maison .cap{position:absolute;inset:auto 0 0 0;padding:22px;background:linear-gradient(transparent,rgba(46,26,27,.92));
  font-family:var(--accent);font-size:24px;color:var(--creme)}
.maison .cap small{display:block;font-family:var(--body);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--or);margin-top:4px}

/* brand chips */
.chips{display:flex;flex-wrap:wrap;gap:14px;margin-top:40px}
.chip{border:1px solid var(--gris);border-radius:999px;padding:14px 26px;font-family:var(--accent);font-size:20px;color:var(--brun);transition:.4s}
.dark .chip{border-color:rgba(238,186,125,.25);color:var(--creme)}
.chip:hover{background:var(--brun);color:var(--or);transform:translateY(-4px)}
.dark .chip:hover{background:var(--or);color:var(--brun)}

/* testimonials carousel */
.reviews{overflow:hidden;margin-top:60px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.reviews-track{display:flex;align-items:stretch;gap:26px;width:max-content;animation:revscroll 70s linear infinite}
.reviews:hover .reviews-track{animation-play-state:paused}
@keyframes revscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rev-card{width:430px;flex:none;display:flex;flex-direction:column;padding:40px;
  border:1px solid rgba(238,186,125,.22);border-radius:14px;background:rgba(247,241,234,.025);transition:.4s}
.rev-card:hover{border-color:var(--or);background:rgba(238,186,125,.05)}
.rev-card .stars{color:var(--or);letter-spacing:3px;margin-bottom:18px;font-size:15px}
.rev-card p{font-family:var(--accent);font-size:21px;font-style:italic;line-height:1.5;color:var(--creme);
  flex:1;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
.rev-card .who{margin-top:24px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--or);
  display:flex;align-items:center;gap:10px}
.rev-card .who .gg{width:18px;height:18px;flex:none;border-radius:50%;background:#fff;display:inline-flex;
  align-items:center;justify-content:center;font-family:var(--body);font-weight:700;font-size:11px;color:#4285F4;font-style:normal}
@media(max-width:1000px){.rev-card{width:84vw}}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:50px}
.gallery .g{aspect-ratio:1;border-radius:10px;overflow:hidden;border:1px solid rgba(238,186,125,.2)}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:.7s}
.gallery .g:hover img{transform:scale(1.12)}

/* CTA */
.cta{position:relative;text-align:center;overflow:hidden}
.cta .mono-bg{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--accent);
  font-size:46vh;color:rgba(238,186,125,.05);line-height:.7;pointer-events:none}
.cta h2{position:relative;z-index:2;font-size:clamp(40px,5.5vw,80px);font-weight:500;line-height:1.04}
.cta h2 em{font-style:italic;color:var(--or)}
.cta p{position:relative;z-index:2;margin:26px auto 40px;max-width:480px;opacity:.85;font-size:17px;line-height:1.7}

/* page hero (sous-pages) */
.phero{position:relative;min-height:64vh;display:flex;align-items:flex-end;overflow:hidden;
  background:linear-gradient(155deg,var(--brun),var(--brun3));color:var(--creme);padding-bottom:70px}
.phero .mono-bg{position:absolute;right:-3%;top:46%;transform:translateY(-50%);font-family:var(--accent);font-size:42vh;color:rgba(247,241,234,.045);line-height:.7;letter-spacing:-14px}
.phero .wrap{position:relative;z-index:2}
.phero .crumb{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or);margin-bottom:22px}
.phero h1{font-size:clamp(54px,8vw,120px);font-weight:500;line-height:.94;letter-spacing:-1px}
.phero h1 em{font-style:italic;color:var(--or)}
.phero p{margin-top:22px;max-width:520px;opacity:.85;font-size:17px;line-height:1.7}
/* phero : vidéo de fond (Higgsfield) façon hero accueil */
.phero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.phero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.phero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(118deg,rgba(46,26,27,.9) 0%,rgba(46,26,27,.72) 42%,rgba(46,26,27,.44) 76%,rgba(46,26,27,.3) 100%)}
.phero.has-video .mono-bg{z-index:1}
@media(max-width:1000px){
  /* phero empilé façon accueil : bandeau vidéo 16:9 en haut + texte dessous */
  .phero.has-video{display:block;min-height:auto;align-items:stretch;padding-top:92px;padding-bottom:48px;
    background:linear-gradient(160deg,var(--brun),var(--brun3))}
  .phero.has-video .phero-bg{position:relative;inset:auto;width:100%;height:auto;aspect-ratio:16/9}
  .phero.has-video .phero-bg::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:44%;z-index:3;
    background:linear-gradient(180deg,transparent,var(--brun3) 97%)}
  .phero.has-video .phero-overlay{display:none}
  .phero.has-video .wrap{padding-top:30px}
  .phero.has-video .mono-bg{display:none}
}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:40px 16px;border:1px solid rgba(238,186,125,.25);border-radius:14px}
.stat .n{font-family:var(--accent);font-size:60px;color:var(--or);line-height:1}
.stat .l{font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-top:10px;opacity:.8}

/* faq */
.faqwrap{max-width:880px;margin:0 auto}
.faq{border-bottom:1px solid var(--gris)}
.faq q{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:30px 4px;cursor:pointer;
  font-family:var(--accent);font-size:26px;color:var(--brun);transition:.3s}
.faq q .p{flex:none;width:34px;height:34px;border:1px solid var(--or2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--body);font-size:20px;color:var(--or2);transition:.4s}
.faq.open q .p{transform:rotate(45deg);background:var(--or);border-color:var(--or);color:var(--brun)}
.faq .a{max-height:0;overflow:hidden;transition:max-height .5s ease}
.faq.open .a{max-height:300px}
.faq .a p{padding:0 4px 30px;font-size:16px;line-height:1.8;color:#5a4a45;max-width:680px}

/* blog */
.feat-post{display:grid;grid-template-columns:1.1fr 1fr;border:1px solid var(--gris);border-radius:16px;overflow:hidden}
.feat-post .media{border:none;border-radius:0}.feat-post .media img{min-height:380px}
.feat-post .body{padding:54px;display:flex;flex-direction:column;justify-content:center}
.feat-post h2{font-size:38px;color:var(--brun);line-height:1.12;margin:14px 0 18px}
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:60px}
.post{border:1px solid var(--gris);border-radius:14px;overflow:hidden;transition:.5s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-10px);border-color:var(--or)}
.post .media{border:none;border-radius:0;aspect-ratio:16/10}
.post .body{padding:28px;flex:1;display:flex;flex-direction:column}
.post .cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--or2);font-weight:600}
.post h3{font-size:24px;color:var(--brun);margin:10px 0 12px;line-height:1.25}
.post p{font-size:14.5px;line-height:1.7;color:#6a5a55;flex:1}

/* contact */
.ct{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.info b{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--or2);margin-bottom:8px}
.info .row{margin-bottom:28px}.info .row p{font-size:17px;line-height:1.6;color:#3a2a26}
.map{height:300px;border-radius:14px;overflow:hidden;border:1px solid var(--gris)}
.map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) sepia(.12)}
form{background:#fff;border:1px solid var(--gris);border-radius:16px;padding:42px}
.field{margin-bottom:20px}
.field label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#6a5a55;margin-bottom:8px}
.field input,.field textarea{width:100%;border:1px solid var(--gris);border-radius:8px;padding:15px 16px;font-family:var(--body);font-size:15px;background:var(--creme);transition:.3s;color:var(--texte)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--or);box-shadow:0 0 0 3px rgba(238,186,125,.18)}
.field textarea{min-height:120px;resize:vertical}
.chk{display:flex;gap:10px;font-size:13px;color:#6a5a55;line-height:1.5;margin-bottom:22px}
form button{width:100%;background:var(--or);color:var(--brun);border:none;padding:17px;border-radius:999px;font-family:var(--body);
  font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:.4s}
form button:hover{background:var(--brun);color:var(--or)}
.ok{display:none;margin-top:16px;background:rgba(238,186,125,.16);border:1px solid var(--or);border-radius:8px;padding:14px;font-size:14px;color:var(--brun)}

/* legal */
.legal{max-width:860px;margin:0 auto}
.legal h2{font-size:28px;color:var(--brun);margin:42px 0 14px;padding-bottom:10px;border-bottom:1px solid var(--gris)}
.legal p,.legal li{font-size:15.5px;line-height:1.85;color:#4a3a36}
.legal ul{list-style:none}.legal li{padding:4px 0}.legal li strong{color:var(--brun)}

/* footer */
footer{background:var(--brun3);color:var(--creme);padding:90px 0 34px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:46px;padding-bottom:50px;border-bottom:1px solid rgba(238,186,125,.14)}
footer .brand{display:block;margin-bottom:18px}
footer h4{font-family:var(--body);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or);margin-bottom:22px}
footer p,footer li{font-size:14px;line-height:1.95;color:rgba(247,241,234,.78);list-style:none}
footer a:hover{color:var(--or)}
.fbot{display:flex;justify-content:space-between;padding-top:26px;font-size:12px;color:rgba(247,241,234,.5);flex-wrap:wrap;gap:10px}

@media(max-width:1000px){
  .hero-grid,.split,.ct,.feat-post{grid-template-columns:1fr;gap:40px}
  .split.rev .media{order:0}
  .hero-3d{height:50vh}
  .cards,.quotes,.posts,.stats{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .maisons{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .fgrid{grid-template-columns:1fr 1fr}
  nav.menu{position:fixed;top:0;left:0;right:0;height:100vh;height:100dvh;margin:0;background:var(--brun3);flex-direction:column;align-items:center;justify-content:center;gap:26px;
    overflow-y:auto;transform:translateY(-100%);transition:.5s;z-index:205}
  nav.menu.open{transform:none}
  nav.menu ul{flex-direction:column;gap:26px;text-align:center}
  nav.menu .nav-side{margin-left:0}
  nav.menu a{font-size:18px}
  .burger{display:block}.header-cta{display:none}
  .wrap{padding:0 22px}
}
@media(max-width:600px){
  /* footer en colonne unique sur mobile (sinon colonnes trop étroites → texte coupé) */
  footer{padding:58px 0 30px}
  .fgrid{grid-template-columns:1fr;gap:34px;padding-bottom:38px}
  footer h4{margin-bottom:14px}
  .fbot{justify-content:flex-start;gap:6px}
}

/* ===================== PAGE MARQUE (détail) ===================== */
.bhero{position:relative;overflow:hidden;padding:160px 0 90px;
  background:linear-gradient(155deg,var(--brun) 0%,var(--brun2) 55%,var(--brun3) 100%);color:var(--creme)}
.bhero .mono-bg{position:absolute;right:-3%;top:50%;transform:translateY(-50%);font-family:var(--accent);
  font-size:46vh;color:rgba(247,241,234,.045);line-height:.7;letter-spacing:-14px;pointer-events:none}
.bhero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr .9fr;gap:50px;align-items:center}
.bhero .crumb{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--or);margin-bottom:24px}
.bhero .crumb a{color:var(--creme);opacity:.7;transition:.3s}.bhero .crumb a:hover{color:var(--or);opacity:1}
.bhero h1{font-size:clamp(52px,7vw,108px);font-weight:500;line-height:.95;letter-spacing:-1px;color:var(--creme)}
.btag{margin-top:20px;font-family:var(--accent);font-size:clamp(22px,2.4vw,30px);font-style:italic;color:var(--or);max-width:620px;line-height:1.35}
.bmeta{display:flex;flex-wrap:wrap;gap:0 14px;margin-top:30px}
.bmeta span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--creme);opacity:.72;
  padding-right:14px;border-right:1px solid rgba(238,186,125,.3)}
.bmeta span:last-child{border-right:0}
.bhero-actions{display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-top:38px}
.bhero-logo{display:flex;justify-content:center}
.lgcard{background:#fff;border-radius:18px;width:100%;max-width:320px;aspect-ratio:1/.72;display:flex;align-items:center;justify-content:center;
  padding:42px;box-shadow:0 30px 70px rgba(0,0,0,.35)}
.lgcard img{max-width:100%;max-height:120px;width:auto;object-fit:contain}
.lgcard.wordmark{font-family:var(--accent);font-size:clamp(28px,3vw,40px);font-weight:600;color:var(--brun);text-align:center;line-height:1.1}

.bvisual{position:relative;height:clamp(280px,42vw,520px);overflow:hidden}
.bvisual img{width:100%;height:100%;object-fit:cover;display:block}
.bvisual::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(46,26,27,.15),rgba(46,26,27,.45))}
.bvisual-cap{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--creme);opacity:.9}

.bstory{display:grid;grid-template-columns:1.6fr .9fr;gap:60px;align-items:start}
.bstory-text .sec-title{margin:10px 0 26px}
.bstory-text .lead{margin-bottom:20px}
.bsign{background:#fff;border:1px solid var(--gris);border-radius:16px;padding:36px;position:sticky;top:110px}
.bsign .eyebrow{margin-bottom:18px}
.bsign ul{list-style:none;margin:0;padding:0}
.bsign li{font-family:var(--accent);font-size:21px;color:var(--brun);padding:16px 0 16px 26px;position:relative;border-bottom:1px solid var(--creme2)}
.bsign li:last-child{border-bottom:0}
.bsign li::before{content:'';position:absolute;left:0;top:24px;width:9px;height:9px;border:1px solid var(--or2);transform:rotate(45deg)}
.bsign-note{margin-top:22px;font-size:12.5px;color:#8a7a75;line-height:1.6}

@media(max-width:1000px){
  .bhero{padding:130px 0 64px}
  .bhero-grid{grid-template-columns:1fr;gap:38px}
  .bhero-logo{justify-content:flex-start}
  .lgcard{max-width:260px}
  .bstory{grid-template-columns:1fr;gap:38px}
  .bsign{position:static}
}

a.maison{text-decoration:none;color:inherit;display:block}

/* ===================== HERO VIDÉO multi-scènes (façon Normandy) ===================== */
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;opacity:0;transition:opacity 1.8s ease}
.hero-video.active{opacity:1}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg,rgba(46,26,27,.95) 0%,rgba(46,26,27,.8) 38%,rgba(46,26,27,.5) 70%,rgba(46,26,27,.32) 100%)}
.hero .mono-bg{z-index:2}
.hero-grid{position:relative;z-index:3}
.hero .scroll-cue{z-index:4}
@media(max-width:1000px){
  /* hero empilé façon Normandy : bandeau vidéo en haut + texte dessous */
  .hero{display:block;min-height:auto;align-items:stretch;padding-top:88px}
  .hero-bg{position:relative;inset:auto;width:100%;height:auto;aspect-ratio:16/9}
  .hero-bg::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:42%;z-index:3;
    background:linear-gradient(180deg,transparent,var(--brun3) 97%)}
  .hero-overlay{display:none}
  .hero-grid{display:block;padding:34px 0 60px}
  .hero-copy h1{font-size:clamp(40px,12vw,60px)}
  .hero-copy p{max-width:none}
  .hero .mono-bg{display:none}
  .hero .scroll-cue{display:none}
}

.post-link{display:block;color:inherit;text-decoration:none}
.post-link .post{height:100%}


/* ===== cookies / consentement ===== */
.cqc{position:fixed;left:16px;right:16px;bottom:16px;z-index:9998;background:var(--brun3);color:var(--creme);border:1px solid rgba(238,186,125,.3);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.35);transform:translateY(150%);transition:transform .45s cubic-bezier(.16,.84,.44,1);max-width:980px;margin:0 auto}
.cqc.show{transform:none}
.cqc-in{display:flex;gap:22px;align-items:center;padding:20px 24px;flex-wrap:wrap}
.cqc-txt{flex:1 1 380px}
.cqc-txt strong{display:block;font-family:'Cinzel',Georgia,serif;color:var(--or);font-size:15px;letter-spacing:.04em;margin-bottom:5px}
.cqc-txt p{font-size:13px;line-height:1.6;color:rgba(247,241,234,.82);margin:0}
.cqc-txt a{color:var(--or);text-decoration:underline}
.cqc-btns{display:flex;gap:10px;flex-wrap:wrap}
.cqc-b{cursor:pointer;border-radius:9px;padding:11px 18px;font-size:13px;font-weight:600;font-family:inherit;border:1px solid rgba(238,186,125,.5);background:transparent;color:var(--creme);transition:all .2s}
.cqc-b:hover{border-color:var(--or);color:var(--or)}
.cqc-accept,.cqc-save{background:var(--or);color:var(--brun3);border-color:var(--or)}
.cqc-accept:hover,.cqc-save:hover{filter:brightness(1.08);color:var(--brun3)}
.cqc-panel{position:fixed;inset:0;z-index:9999;background:rgba(20,12,12,.62);display:flex;align-items:center;justify-content:center;padding:18px;opacity:0;visibility:hidden;transition:opacity .25s}
.cqc-panel.show{opacity:1;visibility:visible}
.cqc-card{background:#fff;color:#2c2522;border-radius:16px;max-width:480px;width:100%;padding:26px;max-height:88vh;overflow:auto;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.cqc-card h3{font-family:'Cinzel',Georgia,serif;color:var(--brun);font-size:21px;margin:0 0 12px}
.cqc-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:13px 0;border-top:1px solid #eee;cursor:pointer}
.cqc-row strong{display:block;font-size:14px;color:#2e1a1b}
.cqc-row span{display:block;font-size:12px;color:#8a7a75;margin-top:2px}
.cqc-row em{font-size:12px;color:#9a8a78;font-style:normal;white-space:nowrap}
.cqc-row input{width:20px;height:20px;accent-color:#c98b3a;flex:none}
.cqc-card-btns{display:flex;gap:10px;margin-top:18px}
.cqc-card-btns .cqc-b{flex:1;text-align:center;color:#2c2522;border-color:#cfc3b4}
.cqc-card-btns .cqc-b:hover{border-color:var(--or);color:var(--brun)}
.cqc-card-btns .cqc-save{color:var(--brun3)}
.cqc-manage{cursor:pointer}
@media(max-width:600px){.cqc-in{padding:16px}.cqc-btns{width:100%}.cqc-btns .cqc-b{flex:1;text-align:center}}
