/* Rêves & Réalités — site vitrine (V0) */
@font-face{
  font-family:"Montserrat";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("../assets/fonts/montserrat-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Montserrat";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("../assets/fonts/montserrat-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Montserrat";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("../assets/fonts/montserrat-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Montserrat";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("../assets/fonts/montserrat-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Montserrat";
  font-style:normal;
  font-weight:700;
  font-display:swap;
  src:url("../assets/fonts/montserrat-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Montserrat";
  font-style:normal;
  font-weight:700;
  font-display:swap;
  src:url("../assets/fonts/montserrat-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Caveat";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("../assets/fonts/caveat-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Caveat";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("../assets/fonts/caveat-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Caveat";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("../assets/fonts/caveat-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"Caveat";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("../assets/fonts/caveat-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"EB Garamond";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("../assets/fonts/eb-garamond-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"EB Garamond";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("../assets/fonts/eb-garamond-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"EB Garamond";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("../assets/fonts/eb-garamond-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"EB Garamond";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("../assets/fonts/eb-garamond-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"EB Garamond";
  font-style:normal;
  font-weight:700;
  font-display:swap;
  src:url("../assets/fonts/eb-garamond-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:"EB Garamond";
  font-style:normal;
  font-weight:700;
  font-display:swap;
  src:url("../assets/fonts/eb-garamond-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
:root{
  --font-base:"Montserrat", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Avenir Next", "Avenir", sans-serif;
  --font-display:"EB Garamond", "adobe-jenson-pro", Georgia, serif;
  --font-script:"Caveat", cursive;
  --bg:#FAF5EE;
  --ink:#1f1b18;
  --muted:#5a4a41;
  --paper:#fff;
  --accent:#D5734B;
  --accent2:#AC4928;
  --border:rgba(31,27,24,.12);
  --shadow: 0 14px 30px rgba(0,0,0,.10);
  --shadow2: 0 8px 20px rgba(0,0,0,.10);
  --radius:20px;
  --radius-sm:16px;
  --max:1280px;
  --pad:24px;
  --header-height:72px;
  --focus: 0 0 0 4px rgba(213,115,75,.22);
  --warm-btn-border:1px solid color-mix(in srgb, var(--accent2) 85%, white);
  --warm-btn-gradient:linear-gradient(
    180deg,
    color-mix(in srgb, var(--accent2) 70%, white) 0%,
    var(--accent2) 100%
  );
  --warm-btn-shadow:0 6px 14px rgba(0,0,0,.10);
}
*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  scroll-snap-type:y mandatory;
}
html.no-snap{
  scroll-snap-type:none;
}
button,input,select,textarea{font-family:var(--font-base)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display)}
body{
  margin:0;
  background:var(--bg);
  color:var(--accent2);
  font-family:var(--font-base);
  line-height:1.55;
}
a{color:inherit}
a:hover{color:var(--accent2)}
img{max-width:100%;display:block}

/* Typography */
.display{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:.02em;
}
.script{
  font-family:var(--font-script);
  font-weight:600;
}
.small{font-size:.92rem;color:var(--muted)}
.accentText{color:var(--accent)}

/* Layout */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{
  padding:72px 0;
  position:relative;
  min-height:calc(100svh - var(--header-height));
  scroll-margin-top:var(--header-height);
  display:flex;
  align-items:center;
}
.section > .container{width:100%}
.section h2{margin:0 0 18px;font-size:2rem}
.kicker{color:var(--accent2);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;font-weight:700}
main > section{
  scroll-snap-align:center;
  scroll-snap-stop:always;
}
#inspirations{
  min-height:72svh;
}

/* Header */
.header{
  position:sticky;top:0;z-index:20;
  background:rgba(250,245,238,.85);
  backdrop-filter:saturate(140%) blur(10px);
  background:color-mix(in srgb, var(--bg) 85%, transparent);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{width:44px;height:44px}
.brand .name{line-height:1.1}
.brand .name strong{display:block;font-family:var(--font-display);font-size:1.24rem;color:var(--accent2)}
.brand .name span{display:block;font-family:var(--font-base);font-size:.8rem;color:var(--accent2)}

.links{
  display:flex;
  flex:1;
  align-items:center;
  justify-content:center;
  gap:28px;
  padding:0 24px;
  white-space:nowrap;
}
.links a{font-weight:600;text-decoration:none;color:var(--accent2)}
.links a:hover{color:var(--ink)}

.cta{display:flex;align-items:center;gap:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:10px 14px;border-radius:14px;
  border:1px solid var(--border);
  background:var(--paper);
  box-shadow:0 8px 18px rgba(0,0,0,.06);
  text-decoration:none;font-weight:700;
}
.btn:hover{transform:none}
.btn:active{transform:translateY(0)}
.btn.primary,
.btn.ghost{
  background:var(--accent2);
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 92%, white) 0%, var(--accent2) 100%);
  color:white;border-color:transparent;
}

.cta .btn.primary,
.cta .btn.ghost,
#devis .btn.primary,
.menuBtn{
  border:var(--warm-btn-border);
  background:var(--accent2);
  background-image:var(--warm-btn-gradient);
  color:#fff;
  box-shadow:var(--warm-btn-shadow);
  cursor:pointer;
}

.menuBtn{
  display:none;
  appearance:none;
  -webkit-appearance:none;
  width:44px;height:44px;border-radius:14px;
  overflow:hidden;
  align-items:center;justify-content:center;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.menuBtn:hover{transform:none;box-shadow:var(--warm-btn-shadow)}
.menuBtn:active{transform:translateY(0)}
.menuBtn[aria-expanded="true"]{filter:saturate(1.08) brightness(.95)}
.menuBtn:focus-visible,.btn:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.heroCtrl:focus-visible,.heroDot:focus-visible,.projectsDot:focus-visible,.beforeAfterRange:focus-visible{
  outline:none;box-shadow:var(--focus)
}

.skip{
  position:absolute;
  left:10px;
  top:-48px;
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--border);
  border-radius:10px;
  padding:8px 12px;
  z-index:50;
  text-decoration:none;
}
.skip:focus{
  top:10px;
  box-shadow:var(--focus);
}

/* Mobile nav */
@media (max-width: 920px){
  .links{display:none}
  .ctaNav > a{display:none !important}
  .ctaNav .btn{display:none !important}
  .menuBtn{display:inline-flex}
}
.mobileMenu{
  display:none;
  margin:10px 0 14px;
  padding:12px 14px 16px;
  background:var(--paper);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:0 10px 24px rgba(0,0,0,.08);
}
.mobileMenu[data-open="true"]{
  display:block;
}
.mobileMenu a{
  display:block;
  padding:11px 12px;
  text-decoration:none;
  color:var(--accent2);
  font-weight:700;
  border-radius:12px;
}
.mobileMenu a:hover{
  color:var(--ink);
  background:rgba(172,73,40,.08);
}
.mobileMenu .cta{
  margin-top:10px;
  display:grid;
  gap:10px;
}
.mobileMenu .cta .btn{
  width:100%;
}

/* Hero */
.hero{
  padding:42px 0 64px;
  min-height:calc(100svh - var(--header-height));
  display:flex;
  align-items:center;
}
.hero > .container{width:100%}
.heroGrid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch;
}
.heroCard,
.heroVisual{
  background:var(--paper);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.heroCard{
  border-radius:var(--radius);
  padding:30px;
  position:relative;overflow:hidden;
}
.heroCard:before{
  content:"";
  position:absolute;inset:-120px -120px auto auto;
  width:280px;height:280px;
  background:radial-gradient(circle at 30% 30%, rgba(213,115,75,.28), rgba(172,73,40,.08) 55%, transparent 70%);
  transform:rotate(18deg);
}
.heroCard h1{margin:6px 0 10px;font-size:2.45rem;line-height:1.1;text-align:center;color:var(--accent2)}
.heroCard p{margin:0 0 18px}
.heroIntro{margin:0 0 18px;color:var(--accent2);font-size:1.05rem}
.heroCard .signatureName{
  margin:0 0 2px;
  color:var(--accent2);
  font-size:2.2rem;
  line-height:1;
  text-align:right;
}
.heroCard .signatureRole{
  margin:0 0 14px;
  color:var(--accent2);
  font-size:1.45rem;
  line-height:1.05;
  text-align:right;
}
.heroVisual{
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
  isolation:isolate;
  min-height:420px;
}
.heroSlides{
  position:absolute;
  inset:0;
  clip-path:inset(0 round calc(var(--radius) - 1px));
}
.heroSlide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .55s ease;
  transform:translateZ(0);
  backface-visibility:hidden;
}
.heroSlide.is-active{opacity:1}
.heroVisual:after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.0) 0%, rgba(0,0,0,.36) 65%, rgba(0,0,0,.50) 100%);
}
.heroControls{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 12px;
  pointer-events:none;
}
.heroCtrl{
  pointer-events:auto;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.5);
  background:rgba(31,27,24,.35);
  color:#fff;
  font-size:1.4rem;
  line-height:1;
  display:grid;
  place-items:center;
}
.heroCtrl:hover{background:rgba(31,27,24,.55)}
.heroDots{
  position:absolute;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  z-index:2;
  display:flex;
  align-items:center;
  gap:8px;
}
.heroDot{
  width:9px;
  height:9px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.75);
  background:rgba(255,255,255,.45);
  padding:0;
}
.heroDot.is-active{
  background:#fff;
  transform:scale(1.15);
}
/* Cards + grids */
.grid{display:grid;gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{
  border:1px solid var(--border);
  background:var(--paper);
  box-shadow:0 10px 20px rgba(0,0,0,.06);
  border-radius:var(--radius-sm);
  padding:18px;
}
.gallery .tile{
  border:1px solid var(--border);
  background:var(--paper);
  box-shadow:0 10px 20px rgba(0,0,0,.06);
}
.card h3{margin:10px 0 8px;font-size:1.18rem}
.card p{margin:0;color:var(--muted)}
.icon{
  width:42px;height:42px;border-radius:14px;
  background:rgba(213,115,75,.18);
  background:color-mix(in srgb, var(--accent) 18%, white);
  display:grid;place-items:center;
  border:1px solid rgba(172,73,40,.2);
  border:1px solid color-mix(in srgb, var(--accent2) 20%, transparent);
}
.icon svg{width:22px;height:22px;fill:none;stroke:var(--accent2);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.icon img{width:22px;height:22px;object-fit:contain}

/* Services: title pinned top-center, body centered vertically */
#services .card{
  position:relative;
  display:flex;
  flex-direction:column;
  padding-right:18px;
}
#services .card .icon{
  position:absolute;
  top:18px;
  right:18px;
  margin:0;
}
#services .card ul{
  margin:8px 0 12px;
  padding-left:18px;
  color:var(--muted);
}
#services .card li{margin:0 0 4px}
#services .card h3{
  font-size:1.4rem;
  line-height:1.2;
  margin:0;
  text-align:center;
  width:100%;
  max-width:calc(100% - 56px);
  margin-left:auto;
  margin-right:auto;
}
#services .card .serviceBody{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
#services .servicesCarousel{
  display:block;
}
#services .servicesHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
}
#services .servicesIntro{
  min-width:0;
}
#services .servicesIntro h2{
  margin:0 0 8px;
}
#services .servicesIntro p{
  margin:0;
}
#services .servicesNav{
  display:flex;
  align-items:center;
  gap:8px;
}
#services .servicesViewport{
  overflow:hidden;
}
#services .servicesTrack{
  display:flex;
  justify-content:flex-start;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:none;
}
#services .servicesTrack::-webkit-scrollbar{display:none}
#services .servicesTrack .card{
  flex:0 0 clamp(260px, 70%, 460px);
  scroll-snap-align:start;
  min-height:560px;
}
.servicesCtrl{
  width:42px;
  height:42px;
  border-radius:999px;
  border:var(--warm-btn-border);
  background:var(--accent2);
  background-image:var(--warm-btn-gradient);
  color:#fff;
  box-shadow:var(--warm-btn-shadow);
  font-size:1.5rem;
  line-height:1;
  display:grid;
  place-items:center;
  cursor:pointer;
}
.servicesCtrl[disabled]{
  opacity:.45;
  cursor:not-allowed;
}

/* Quote / approach */
.quote{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:20px;
  align-items:stretch;
}
.quoteBox{
  background:linear-gradient(180deg, rgba(213,115,75,.10) 0%, rgba(172,73,40,.06) 100%);
  border:1px solid rgba(172,73,40,.18);
  border:1px solid color-mix(in srgb, var(--accent2) 18%, transparent);
  border-radius:var(--radius);
  padding:24px;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.quoteBox:after{
  content:"";
  position:absolute;right:-30px;top:-30px;
  width:140px;height:140px;
  background:rgba(213,115,75,.16);
  transform:rotate(45deg);
}
.quoteBox blockquote{
  margin:0;
  font-size:1.8rem;
  font-family:var(--font-script);
  font-weight:400;
  flex:1;
  display:flex;
  align-items:center;
  text-align:center;
}
.quoteBox .script{
  font-size:1.85rem;
  color:var(--accent2);
  text-align:right;
  margin:14px 0 0;
}

/* Gallery */
.gallery{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:stretch;
}
.gallery .main{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  aspect-ratio:4/5;
}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.gallery .tile{border-radius:var(--radius-sm);overflow:hidden}
.gallery .tile{
  border:1px solid var(--border);
  box-shadow:0 10px 20px rgba(0,0,0,.06);
  aspect-ratio:1/1;
}
.gallery .tile img{width:100%;height:100%;object-fit:cover;opacity:.96}

#inspirations .gallery{
  max-width:none;
  width:100%;
  display:grid;
  grid-template-columns:repeat(10, minmax(0, 1fr));
  grid-auto-rows:115px;
  gap:14px;
  margin-left:0;
  margin-right:0;
}
#inspirations .inspirationsHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
#inspirations .inspirationsHead h2{
  margin:0;
}
#inspirations .inspirationsNav{
  display:flex;
  align-items:center;
  gap:8px;
}
#inspirations .gallery .tile.is-active{
  border-color:color-mix(in srgb, var(--accent2) 44%, transparent);
  box-shadow:0 12px 22px rgba(0,0,0,.10);
}
#inspirations .gallery .tile.is-active img{
  opacity:1;
}
#inspirations .gallery .main{
  grid-column:1 / span 6;
  grid-row:1 / span 3;
  aspect-ratio:auto;
  min-height:0;
}
#inspirations .gallery .tile{
  aspect-ratio:auto;
}
#inspirations .gallery .t1{
  grid-column:1 / span 3;
  grid-row:4 / span 2;
  min-height:0;
}
#inspirations .gallery .t2{
  grid-column:7 / span 4;
  grid-row:1 / span 3;
  min-height:0;
}
#inspirations .gallery .t3{
  grid-column:4 / span 3;
  grid-row:4;
  min-height:0;
}
#inspirations .gallery .t4{
  grid-column:4 / span 3;
  grid-row:5;
  min-height:0;
}
#inspirations .gallery .trendCard{
  grid-column:7 / span 4;
  grid-row:4 / span 2;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:linear-gradient(180deg, rgba(213,115,75,.10) 0%, rgba(172,73,40,.06) 100%);
  padding:18px;
  box-shadow:0 10px 20px rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
#inspirations .gallery .trendCard h3{
  margin:0 0 8px;
  font-size:1.25rem;
  color:var(--accent2);
}
#inspirations .gallery .trendCard p{
  margin:0;
  color:var(--muted);
}

/* Realisations */
#realisations .projectsHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
#realisations .projectsIntro{
  min-width:0;
}
#realisations .projectsIntro h2{
  margin:0 0 8px;
}
#realisations .projectsIntro p{
  margin:0;
}
#realisations .projectsNav{
  display:flex;
  align-items:center;
  gap:8px;
}
.projectsCarousel{
  display:grid;
  gap:16px;
}
.projectsSlides{
  position:relative;
}
.projectSlide{
  display:none;
  gap:16px;
  align-items:stretch;
}
.projectSlide.is-active{
  display:grid;
  grid-template-columns:minmax(220px, .36fr) minmax(0, .64fr);
}
.projectMeta{
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:linear-gradient(180deg, rgba(213,115,75,.11) 0%, rgba(172,73,40,.07) 100%);
  box-shadow:0 10px 20px rgba(0,0,0,.06);
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.projectMeta h3{
  margin:0 0 8px;
  font-size:1.4rem;
  color:var(--accent2);
}
.projectMeta p{
  margin:0;
  color:var(--muted);
}
.beforeAfter{
  --compare-pos:50%;
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  aspect-ratio:16/10;
  background:#ded6cf;
  isolation:isolate;
  touch-action:pan-y;
}
.beforeAfter:focus-within{
  box-shadow:var(--focus), var(--shadow);
}
.beforeAfterImg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.beforeAfterAfter{
  position:absolute;
  top:0;
  left:0;
  bottom:0;
  width:var(--compare-pos);
  overflow:hidden;
  border-right:1px solid rgba(255,255,255,.65);
}
.beforeAfterBadge{
  position:absolute;
  top:14px;
  z-index:3;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.6);
  background:rgba(31,27,24,.5);
  color:#fff;
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.03em;
}
.beforeAfterBadge.is-before{
  left:14px;
}
.beforeAfterBadge.is-after{
  right:14px;
}
.beforeAfterDivider{
  position:absolute;
  top:0;
  bottom:0;
  left:var(--compare-pos);
  transform:translateX(-50%);
  width:2px;
  background:rgba(255,255,255,.9);
  z-index:3;
  pointer-events:none;
}
.beforeAfterDivider::after{
  content:"↔";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.72);
  background:rgba(31,27,24,.55);
  color:#fff;
  font-size:1rem;
  display:grid;
  place-items:center;
  box-shadow:0 8px 16px rgba(0,0,0,.18);
}
.beforeAfterRange{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  margin:0;
  background:transparent;
  appearance:none;
  -webkit-appearance:none;
  cursor:ew-resize;
  z-index:4;
}
.beforeAfterRange::-webkit-slider-runnable-track{
  width:100%;
  height:100%;
  background:transparent;
}
.beforeAfterRange::-webkit-slider-thumb{
  appearance:none;
  -webkit-appearance:none;
  width:1px;
  height:1px;
  opacity:0;
}
.beforeAfterRange::-moz-range-track{
  width:100%;
  height:100%;
  background:transparent;
  border:none;
}
.beforeAfterRange::-moz-range-thumb{
  width:1px;
  height:1px;
  opacity:0;
  border:none;
}
.projectsDots{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
}
.projectsDot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--accent2) 42%, transparent);
  background:color-mix(in srgb, var(--accent2) 26%, white);
  padding:0;
  cursor:pointer;
}
.projectsDot.is-active{
  background:var(--accent2);
  transform:scale(1.18);
}

/* Steps */
.steps{
  counter-reset:step;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
.step{
  position:relative;
  padding:52px 16px 16px;
  border:1px solid var(--border);
  background:var(--paper);
  border-radius:var(--radius-sm);
  box-shadow:0 10px 20px rgba(0,0,0,.06);
}
.step:before{
  counter-increment:step;
  content:counter(step);
  position:absolute;
  left:14px;
  top:12px;
  width:30px;
  height:30px;
  border-radius:10px;
  display:grid;place-items:center;
  background:rgba(213,115,75,.16);
  background:color-mix(in srgb, var(--accent) 16%, white);
  border:1px solid rgba(172,73,40,.2);
  border:1px solid color-mix(in srgb, var(--accent2) 20%, transparent);
  color:var(--accent2);
  font-weight:900;
  font-size:.92rem;
}
.step h3{margin:0 0 6px}
.step p{margin:0;color:var(--muted)}

/* FAQ */
.faqGrid{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
.faqGroup{
  padding:16px 18px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:var(--paper);
  box-shadow:0 10px 20px rgba(0,0,0,.06);
}
.faqGroup h3{
  margin:0 0 12px;
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.faqItem{
  border:1px solid color-mix(in srgb, var(--accent2) 18%, transparent);
  border-radius:12px;
  background:color-mix(in srgb, var(--paper) 92%, var(--bg));
  margin:0 0 10px;
  overflow:hidden;
}
.faqItem summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  cursor:pointer;
  font-weight:700;
  color:var(--accent2);
  list-style:none;
  transition:color .2s ease, background-color .2s ease;
}
.faqItem summary:hover{
  background:color-mix(in srgb, var(--accent) 14%, white);
}
.faqItem summary::-webkit-details-marker{
  display:none;
}
.faqItem summary::after{
  content:"▾";
  font-weight:700;
  color:var(--accent2);
  transition:transform .2s ease;
}
.faqItem[open] summary::after{
  transform:rotate(180deg);
}
.faqItem[open]{
  border-color:color-mix(in srgb, var(--accent2) 35%, transparent);
  box-shadow:0 8px 16px rgba(0,0,0,.05);
}
.faqItem[open] summary{
  background:color-mix(in srgb, var(--accent) 12%, white);
}
.faqItem p{
  margin:0;
  padding:0 14px 10px 18px;
  color:color-mix(in srgb, var(--ink) 78%, var(--muted));
  font-size:1.08rem;
}
.faqItem p:first-of-type{
  padding-top:8px;
}
.faqItem p strong{
  line-height:1.2;
}
.faqItem p + p{
  margin-top:2px;
}
.faqItem p:last-child{
  padding-bottom:14px;
}
.faqItem[open] p{
  margin-top:2px;
  background:color-mix(in srgb, var(--paper) 88%, var(--bg));
  border-radius:0 10px 10px 0;
}

/* Contact */
.contactGrid{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px}
#contact .contactTitle{
  margin:0 0 18px;
}
#contact .contactGrid > div{
  display:flex;
  flex-direction:column;
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow2);
  padding:20px;
}
.contactStack{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.formRow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:block;font-weight:800;font-size:.92rem;margin:0 0 6px}
.contactIntro p{
  margin:0;
  color:var(--accent2);
  font-size:1.1rem;
  line-height:1.55;
}
.contactIntro p + p{
  margin-top:6px;
}
.contactDownloadCard{
  display:block;
  width:min(100%, 460px);
  margin-inline:auto;
  position:relative;
  padding-right:68px;
  background:color-mix(in srgb, var(--accent) 86%, transparent);
  color:#fff;
  border-color:transparent;
}
.contactDownloadCard h3{
  margin:0 0 6px;
  color:#fff;
}
.contactDownloadCard p{
  color:rgba(255,255,255,.92);
}
.contactBridge{
  margin:0;
  color:var(--accent2);
  line-height:1.65;
}
.contactCards .card{
  min-height:110px;
}
.contactInfoCard{
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.contactIdentity{
  width:min(100%, 460px);
  margin-inline:auto;
  position:relative;
  background:color-mix(in srgb, var(--accent) 86%, transparent);
  color:#fff;
  border-color:transparent;
}
.contactIdentity img{
  width:88px;
  height:auto;
  margin-bottom:6px;
}
.contactIdentity .small{
  margin:0 0 6px;
  color:rgba(255,255,255,.92);
}
.contactIdentity .small:first-of-type{
  color:#fff;
  font-size:1rem;
}
.contactIdentity .small:last-of-type{
  margin-bottom:0;
}
.contactIdentity a{
  color:#fff;
}
.contactSaveBtn{
  position:absolute;
  top:12px;
  right:12px;
  width:42px;
  height:42px;
  padding:0;
  border-radius:12px;
  display:grid;
  place-items:center;
  line-height:1;
}
.contactPdfBtn{
  top:10px;
}
.contactSaveBtn svg{
  width:18px;
  height:18px;
  display:block;
  color:#fff;
}
.btn.primary.contactSaveBtn{
  background:transparent;
  background-image:none;
  color:#fff;
  border-color:rgba(255,255,255,.7);
  box-shadow:none;
}
.btn.primary.contactSaveBtn:hover{
  background:transparent;
  background-image:none;
  box-shadow:none;
}
#devis{
  padding:24px;
  display:grid;
  gap:16px;
}
#devis h3{
  margin:0;
}
#devis .small{
  margin:0;
  line-height:1.65;
}
#devis .formRow{
  gap:16px;
}
#devis label{
  margin:0;
}
#devis label > span{
  display:block;
  margin:0 0 8px;
}
input,textarea,select{
  width:100%;padding:12px 12px;border-radius:14px;
  border:1px solid var(--border);
  background:var(--paper);
  background:color-mix(in srgb, var(--paper) 85%, var(--bg));
  font:inherit
}
textarea{min-height:120px;resize:vertical}
#devis textarea{
  min-height:150px;
}
select{
  color:var(--accent2);
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--accent2) 50%),
    linear-gradient(135deg, var(--accent2) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 2px),
    calc(100% - 12px) calc(50% - 2px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
  padding-right:34px;
}
select:invalid{
  color:var(--muted);
}
select option{
  color:var(--accent2);
  background:var(--paper);
}
select option[disabled]{
  color:var(--muted);
}

.footer{
  padding:28px 0 34px;
  border-top:1px solid var(--border);
  color:var(--muted);
  scroll-snap-align:start;
  background:var(--bg);
}
.footer a{text-decoration:none}
.footerPanel{
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow2);
  padding:20px;
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  gap:20px;
}
.footerPanel > p.small{
  margin:0;
  justify-self:center;
  text-align:center;
  white-space:nowrap;
  color:var(--muted);
}
.footerLinks{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:8px 16px;
  text-align:center;
}
.footerLinks h3{
  flex-basis:100%;
  margin:0 0 4px;
  font-size:1.2rem;
  color:var(--accent2);
}
.footerLinks a{
  color:var(--muted);
  font-weight:600;
}
.footerLinks a:hover{color:var(--accent2)}

/* Utility */
.badges{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 0}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  background:var(--paper);
  background:color-mix(in srgb, var(--paper) 80%, var(--bg));
  border:1px solid var(--border);
  color:var(--muted);font-weight:700;font-size:.92rem
}
.pill b{color:var(--accent2)}
.mt-18{margin-top:18px}

@media (max-width: 920px){
  .heroGrid{grid-template-columns:1fr;}
  .heroVisual{min-height:320px}
  .heroControls{padding:0 8px}
  .heroCard h1{font-size:2.4rem}
  .heroCard .signatureName{font-size:1.85rem}
  .heroCard .signatureRole{font-size:1.25rem}
  .grid.cols-3{grid-template-columns:1fr}
  .grid.cols-2{grid-template-columns:1fr}
  .quote{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .gallery .main{aspect-ratio:16/10}
  .gallery .tile{aspect-ratio:4/3}
  #inspirations .gallery{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    grid-auto-rows:auto;
  }
  #inspirations .gallery .main{
    grid-column:1 / -1;
    grid-row:auto;
    min-height:300px;
  }
  #inspirations .gallery .t1,
  #inspirations .gallery .t2,
  #inspirations .gallery .t3,
  #inspirations .gallery .t4{
    grid-column:auto;
    grid-row:auto;
    min-height:170px;
  }
  #inspirations .gallery .trendCard{
    grid-column:1 / -1;
    grid-row:auto;
    order:-1;
  }
  #inspirations .inspirationsHead{
    align-items:flex-start;
  }
  .projectSlide.is-active{
    grid-template-columns:1fr;
  }
  .beforeAfter{
    aspect-ratio:4/3;
    min-height:300px;
  }
  #realisations .projectsHead{
    align-items:flex-start;
  }
  .contactGrid{grid-template-columns:1fr}
  .contactCards{
    grid-template-columns:1fr;
  }
  #devis{
    padding:20px;
    gap:14px;
  }
  .footerPanel{
    grid-template-columns:1fr;
  }
  #services .servicesTrack .card{
    flex-basis:min(84vw, 420px);
    min-height:auto;
  }
  #services .servicesHead{
    align-items:flex-start;
  }
  #services .card{
    padding-top:18px;
    padding-right:72px;
  }
  #services .card .icon{
    position:absolute;
    top:18px;
    right:18px;
    left:auto;
    transform:none;
    margin:0;
  }
  #services .card h3{
    width:auto;
    max-width:none;
    margin:0 0 10px;
    text-align:left;
    min-height:42px;
    display:flex;
    align-items:center;
  }
}

@media (max-width: 680px){
  .formRow{grid-template-columns:1fr}
  .backBtn{
    width:46px;
    height:46px;
    padding:0;
    font-size:0;
    display:grid;
    place-items:center;
    position:relative;
    border-radius:14px;
    border:var(--warm-btn-border);
    background:var(--accent2);
    background-image:var(--warm-btn-gradient);
    box-shadow:var(--warm-btn-shadow);
  }
  .backBtn::before{
    content:none;
  }
  .backBtn::after{
    content:"";
    position:absolute;
    width:7px;
    height:7px;
    border-left:2px solid #fff;
    border-bottom:2px solid #fff;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%) rotate(45deg);
  }
  html{
    scroll-snap-type:none;
  }
  main > section{
    scroll-snap-align:none;
    scroll-snap-stop:normal;
  }
  #services .servicesCarousel{
    display:block;
  }
  #services .servicesTrack{
    gap:12px;
  }
  #services .servicesTrack .card{
    flex-basis:88vw;
  }
  #services .card{
    padding-top:18px;
    padding-right:72px;
  }
  #services .card h3{
    font-size:1.25rem;
    width:auto;
    max-width:none;
    margin:0 0 10px;
    text-align:left;
    min-height:42px;
    display:flex;
    align-items:center;
  }
  #services .servicesHead{
    flex-direction:column;
    align-items:stretch;
  }
  #services .servicesNav{
    justify-content:flex-end;
  }
  #inspirations .inspirationsHead{
    flex-direction:column;
    align-items:stretch;
  }
  #inspirations .inspirationsNav{
    justify-content:flex-end;
  }
  #realisations .projectsHead{
    flex-direction:column;
    align-items:stretch;
  }
  #realisations .projectsNav{
    justify-content:flex-end;
  }
  .beforeAfter{
    min-height:240px;
  }
  .projectMeta h3{
    font-size:1.25rem;
  }
  .footer{
    padding:20px 0 26px;
  }
  .footerPanel{
    padding:16px;
    gap:16px;
  }
  .servicesCtrl{
    width:38px;
    height:38px;
    font-size:1.3rem;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  html{
    scroll-behavior:auto;
    scroll-snap-type:none;
  }
  .btn:hover{transform:none}
}
