/* ============================================================
   LMT Maçonnerie — Design system
   ============================================================ */
:root{
  --ink:#1b1815;
  --ink-2:#2a2521;
  --charcoal:#211d1a;
  --cream:#faf6f0;
  --cream-2:#f3ece2;
  --sand:#ece2d4;
  --stone:#6f665c;
  --stone-2:#8a8076;
  --line:#e4d9c9;
  --accent:#c8862e;
  --accent-2:#e0a93f;
  --accent-deep:#a4691c;
  --white:#ffffff;

  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 2px 10px rgba(40,30,15,.06);
  --shadow:0 18px 50px -22px rgba(45,33,15,.45);
  --shadow-lg:0 40px 90px -30px rgba(40,28,12,.55);

  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --ff-display:"Fraunces",Georgia,serif;
  --ff-body:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
em{font-style:italic}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.ic{width:1em;height:1em;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:middle}

/* ---------- Typography helpers ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent);border-radius:2px}
.eyebrow--light{color:var(--accent-2)}
.eyebrow--light::before{background:var(--accent-2)}

.head{max-width:640px;margin:0 auto 3.2rem;text-align:center}
.head__title{
  font-family:var(--ff-display);font-weight:600;line-height:1.05;
  font-size:clamp(2rem,4.6vw,3.3rem);letter-spacing:-.01em;
}
.head__title em{color:var(--accent-deep)}
.head--light .head__title{color:var(--cream)}
.head__sub{margin-top:1rem;color:var(--stone);font-size:1.06rem}
.head--light .head__sub{color:#c9bdac}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--ff-body);font-weight:700;font-size:.98rem;
  padding:.85em 1.45em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s,border-color .25s;
  white-space:nowrap;line-height:1;
}
.btn .ic{width:1.1em;height:1.1em}
.btn--lg{padding:1.05em 1.8em;font-size:1.02rem}
.btn--block{width:100%}
.btn--accent{background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#2a1c08;box-shadow:0 12px 28px -10px rgba(200,134,46,.7)}
.btn--accent:hover{transform:translateY(-3px);box-shadow:0 20px 40px -12px rgba(200,134,46,.85)}
.btn--ghost{background:rgba(255,255,255,.08);color:var(--white);border-color:rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(255,255,255,.18);transform:translateY(-3px)}
.btn--dark{background:var(--ink);color:var(--cream)}
.btn--dark:hover{background:var(--accent-deep);transform:translateY(-3px)}

.link{display:inline-flex;align-items:center;gap:.35em;font-weight:700;color:var(--accent-deep);transition:gap .25s var(--ease),color .2s}
.link:hover{gap:.7em;color:var(--ink)}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{background:var(--ink);color:#d8cfc2;font-size:.84rem}
.topbar__inner{display:flex;align-items:center;gap:.9rem;padding-block:.55rem;flex-wrap:wrap}
.topbar__item{display:inline-flex;align-items:center;gap:.45em;white-space:nowrap}
.topbar__item .ic{width:15px;height:15px;color:var(--accent-2)}
.topbar__sep{width:1px;height:14px;background:rgba(255,255,255,.18)}
.topbar__badge{margin-left:auto;background:rgba(224,169,63,.16);color:var(--accent-2);
  padding:.3em .9em;border-radius:999px;font-weight:700;border:1px solid rgba(224,169,63,.3)}
.topbar__badge:hover{background:var(--accent);color:#2a1c08}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,246,240,.78);
  backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid transparent;transition:.3s var(--ease)}
.nav.scrolled{background:rgba(250,246,240,.92);border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}

.brand{display:flex;align-items:center;gap:.7rem}
.brand__mark{
  font-family:var(--ff-display);font-weight:700;font-size:1.15rem;letter-spacing:.04em;
  background:linear-gradient(135deg,var(--ink),var(--ink-2));color:var(--cream);
  width:46px;height:46px;display:grid;place-items:center;border-radius:13px;
  box-shadow:inset 0 0 0 1px rgba(224,169,63,.4),var(--shadow-sm);
}
.brand__text{font-family:var(--ff-display);font-weight:600;font-size:1.18rem;line-height:1;display:flex;flex-direction:column;gap:.25rem}
.brand__text small{font-family:var(--ff-body);font-weight:600;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone-2)}

.nav__links{display:flex;align-items:center;gap:.35rem}
.nav__links>a:not(.btn):not(.nav__phone){
  padding:.5em .8em;border-radius:999px;font-weight:600;font-size:.96rem;color:var(--ink-2);
  position:relative;transition:color .2s,background .2s;
}
.nav__links>a:not(.btn):not(.nav__phone):hover{color:var(--accent-deep);background:rgba(200,134,46,.09)}
.nav__phone{display:none;font-weight:700;color:var(--accent-deep);margin-inline:.4rem .2rem}
.nav__cta{margin-left:.4rem}

.burger{display:none;width:46px;height:46px;border:1px solid var(--line);background:var(--white);
  border-radius:12px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:min(92vh,820px);display:flex;align-items:center;color:var(--white);overflow:hidden}
.hero__bg{position:absolute;inset:0;
  background:#1b1815 url('https://images.unsplash.com/photo-1503387762-592deb58ef4e?auto=format&fit=crop&w=1800&q=80') center/cover no-repeat;
  transform:scale(1.08);animation:heroZoom 18s var(--ease) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__overlay{position:absolute;inset:0;
  background:
    radial-gradient(120% 100% at 15% 20%,rgba(27,24,21,.35),transparent 60%),
    linear-gradient(105deg,rgba(20,17,14,.92) 0%,rgba(20,17,14,.72) 42%,rgba(20,17,14,.28) 100%)}
.hero__inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;width:100%;padding-block:6rem}

.hero__content{max-width:640px}
.hero__title{font-family:var(--ff-display);font-weight:600;line-height:.98;letter-spacing:-.02em;
  font-size:clamp(2.8rem,6.6vw,5.2rem);margin-bottom:1.4rem;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero__title em{color:var(--accent-2)}
.hero__lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:#e8ddce;max-width:520px;margin-bottom:2rem}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.2rem}
.hero__badges{display:flex;gap:1.4rem;flex-wrap:wrap}
.hero__badges li{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.92rem;color:#e8ddce}
.hero__badges .ic{width:1.25em;height:1.25em;color:var(--accent-2)}

.hero__card{justify-self:end;width:min(340px,100%);
  background:rgba(31,27,23,.55);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.16);border-radius:22px;padding:1.7rem;box-shadow:var(--shadow-lg)}
.hero__cardtop{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;font-weight:700;
  color:#e8ddce;background:rgba(255,255,255,.07);padding:.4em .9em;border-radius:999px;margin-bottom:1.1rem}
.dot{width:8px;height:8px;border-radius:50%;background:#5bd07a;box-shadow:0 0 0 0 rgba(91,208,122,.7);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 8px rgba(91,208,122,0)}100%{box-shadow:0 0 0 0 rgba(91,208,122,0)}}
.hero__cardq{font-family:var(--ff-display);font-size:1.22rem;line-height:1.35;margin-bottom:1.4rem;color:#fff}
.hero__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.14)}
.hero__stats strong{display:block;font-family:var(--ff-display);font-size:1.5rem;color:var(--accent-2)}
.hero__stats span{font-size:.72rem;color:#c9bdac;line-height:1.25}
.hero__cardlink{display:inline-block;margin-top:1.3rem;font-weight:700;color:var(--accent-2)}
.hero__cardlink:hover{color:#fff}

.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  width:26px;height:42px;border:2px solid rgba(255,255,255,.45);border-radius:14px;display:grid;place-items:start center;padding-top:7px}
.hero__scroll span{width:4px;height:8px;border-radius:4px;background:var(--accent-2);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}100%{opacity:0;transform:translateY(10px)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--ink);color:#cdbfab;overflow:hidden;border-block:1px solid rgba(255,255,255,.07);padding-block:.95rem}
.marquee__track{display:flex;gap:1.6rem;align-items:center;width:max-content;animation:marquee 32s linear infinite;
  font-family:var(--ff-display);font-size:1.15rem;color:#8a8076}
.marquee__track span:nth-child(odd){color:#e0d4c2}
.marquee__track span:nth-child(even){color:var(--accent)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding-block:clamp(4rem,8vw,7rem)}
.section--alt{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.section--dark{background:radial-gradient(120% 120% at 80% 0%,#2a2521,#1b1815);color:var(--cream)}

/* ---------- Service cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card__media{aspect-ratio:4/3;background:var(--img) center/cover no-repeat,var(--sand);transition:transform .6s var(--ease)}
.card:hover .card__media{transform:scale(1.07)}
.card__body{padding:1.5rem 1.4rem 1.6rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.card__num{font-family:var(--ff-display);font-size:.85rem;font-weight:700;color:var(--accent);letter-spacing:.1em}
.card__body h3{font-family:var(--ff-display);font-size:1.28rem;font-weight:600;line-height:1.15}
.card__body p{font-size:.95rem;color:var(--stone);flex:1}
.card__body .link{margin-top:.4rem}

/* ---------- Split / about ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split__media{position:relative;min-height:440px}
.split__img{position:absolute;inset:0;width:80%;height:88%;border-radius:var(--radius);
  background:var(--img) center/cover no-repeat;box-shadow:var(--shadow)}
.split__img--small{left:auto;right:0;top:auto;bottom:0;width:48%;height:46%;border:6px solid var(--cream);z-index:2}
.split__chip{position:absolute;left:0;bottom:-18px;z-index:3;background:var(--ink);color:var(--cream);
  padding:1rem 1.3rem;border-radius:16px;box-shadow:var(--shadow);max-width:200px;display:flex;flex-direction:column;gap:.2rem}
.split__chip strong{font-family:var(--ff-display);font-size:1.7rem;color:var(--accent-2)}
.split__chip span{font-size:.82rem;color:#cdbfab;line-height:1.3}

.split__text p{color:var(--stone);margin-bottom:1.5rem}
.checklist{display:grid;gap:.8rem;margin-bottom:2rem}
.checklist li{display:flex;align-items:flex-start;gap:.7rem;font-weight:600;color:var(--ink-2)}
.checklist .ic{width:1.4em;height:1.4em;color:#fff;background:var(--accent);border-radius:50%;padding:.2em;flex-shrink:0;stroke-width:2.6}

/* ---------- Stats ---------- */
.stats{background:var(--ink);color:var(--cream);padding-block:clamp(2.5rem,5vw,3.5rem)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat{padding:1rem;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:0;top:20%;height:60%;width:1px;background:rgba(255,255,255,.12)}
.stat__num{font-family:var(--ff-display);font-weight:700;font-size:clamp(2.4rem,5vw,3.4rem);color:var(--accent-2);line-height:1;display:block}
.stat__label{font-size:.86rem;color:#c9bdac;margin-top:.5rem;display:block;letter-spacing:.02em}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;counter-reset:s}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem 1.5rem;position:relative;transition:.3s var(--ease)}
.step:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-5px)}
.step__num{font-family:var(--ff-display);font-weight:700;font-size:1.05rem;color:#fff;
  width:44px;height:44px;display:grid;place-items:center;border-radius:13px;
  background:linear-gradient(135deg,var(--accent-2),var(--accent-deep));margin-bottom:1.1rem;box-shadow:0 10px 20px -8px rgba(200,134,46,.7)}
.step h3{font-family:var(--ff-display);font-size:1.18rem;font-weight:600;margin-bottom:.4rem}
.step p{font-size:.93rem;color:var(--stone)}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.gallery__item{position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:zoom-in;background:#000}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),opacity .4s}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,12,9,.55),transparent 55%);opacity:.6;transition:opacity .3s}
.gallery__item:hover img{transform:scale(1.1)}
.gallery__item:hover::after{opacity:.9}
.gallery__item--tall{grid-row:span 2}
.gallery__item--wide{grid-column:span 2}
.gallery__tag{position:absolute;left:14px;bottom:14px;z-index:2;color:#fff;font-size:.78rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;background:rgba(200,134,46,.85);padding:.3em .8em;border-radius:999px}

/* ---------- Reviews ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.review{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;position:relative;transition:.3s var(--ease)}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.review__stars{color:var(--accent);letter-spacing:.15em;font-size:1.05rem;margin-bottom:.9rem}
.review blockquote{font-family:var(--ff-display);font-size:1.06rem;line-height:1.5;color:var(--ink-2);margin-bottom:1.3rem}
.review figcaption{display:flex;align-items:center;gap:.7rem;font-weight:700}
.review figcaption small{display:block;font-weight:500;color:var(--stone-2);font-size:.8rem}
.review__avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;
  background:linear-gradient(135deg,var(--accent-2),var(--accent-deep))}

/* ---------- CTA band ---------- */
.cta{background:linear-gradient(120deg,var(--accent-deep),var(--accent));color:#2a1c08;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?auto=format&fit=crop&w=1400&q=70') center/cover;opacity:.12;mix-blend-mode:multiply}
.cta__inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding-block:clamp(2.6rem,5vw,3.6rem)}
.cta h2{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1.1}
.cta p{font-weight:600;margin-top:.4rem;color:#3a2810}
.cta__actions{display:flex;gap:1rem;flex-wrap:wrap}
.cta .btn--ghost{border-color:rgba(42,28,8,.4);color:#2a1c08;background:rgba(255,255,255,.25)}
.cta .btn--ghost:hover{background:rgba(255,255,255,.5)}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact__info .head__title{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.contact__info .head__sub{margin-bottom:2rem}
.contact__list{display:grid;gap:1.1rem;margin-bottom:2rem}
.contact__list li{display:flex;align-items:center;gap:1rem}
.contact__ic{width:48px;height:48px;flex-shrink:0;border-radius:14px;display:grid;place-items:center;
  background:var(--sand);color:var(--accent-deep)}
.contact__ic .ic{width:1.4em;height:1.4em}
.contact__list small{display:block;font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--stone-2);font-weight:700}
.contact__list a,.contact__list span{font-weight:600;color:var(--ink-2)}
.contact__list a:hover{color:var(--accent-deep)}
.contact__map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);height:240px}
.contact__map iframe{width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.02)}

.form{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem);box-shadow:var(--shadow-sm);display:grid;gap:1.1rem}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field>span{font-size:.85rem;font-weight:700;color:var(--ink-2)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:.98rem;color:var(--ink);background:var(--cream);
  border:1.5px solid var(--line);border-radius:12px;padding:.85em 1em;transition:.2s;width:100%}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px rgba(200,134,46,.13)}
.field input.invalid,.field textarea.invalid{border-color:#d6533f;box-shadow:0 0 0 4px rgba(214,83,63,.12)}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--stone);line-height:1.4}
.consent input{margin-top:.25rem;accent-color:var(--accent);width:17px;height:17px;flex-shrink:0}
.form__note{font-size:.9rem;font-weight:600;min-height:1.2em}
.form__note.ok{color:#2f8f4e}
.form__note.err{color:#d6533f}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);color:#c9bdac;padding-top:clamp(3rem,6vw,4.5rem)}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem}
.brand--footer .brand__mark{background:linear-gradient(135deg,#2a2521,#161310)}
.brand--footer .brand__text{color:var(--cream)}
.footer__brand p{margin:1.1rem 0;font-size:.92rem;max-width:320px}
.footer__social{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:rgba(255,255,255,.07);color:var(--cream);transition:.25s}
.footer__social:hover{background:var(--accent);color:#2a1c08;transform:translateY(-3px)}
.footer__social .ic{width:1.3em;height:1.3em;fill:currentColor;stroke:none}
.footer__col h4{font-family:var(--ff-display);color:var(--cream);font-size:1.05rem;margin-bottom:1rem;font-weight:600}
.footer__col a,.footer__col span{display:block;font-size:.92rem;margin-bottom:.6rem;transition:color .2s}
.footer__col a:hover{color:var(--accent-2)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-block:1.4rem;border-top:1px solid rgba(255,255,255,.1);font-size:.84rem}
.footer__legal a:hover{color:var(--accent-2)}
.footer__credit{color:#8a8076}
.footer__credit a{color:#b9ad9c;font-weight:600}
.footer__credit a:hover{color:var(--accent-2)}

/* ---------- FAB ---------- */
.fab{position:fixed;right:18px;bottom:18px;z-index:40;width:58px;height:58px;border-radius:50%;
  display:none;place-items:center;background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#2a1c08;
  box-shadow:0 14px 30px -8px rgba(200,134,46,.8)}
.fab .ic{width:1.5em;height:1.5em;stroke-width:2.2}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(15,12,9,.92);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .3s}
.lightbox.open{display:flex;opacity:1}
.lightbox figure{max-width:1000px;text-align:center}
.lightbox img{max-height:80vh;width:auto;border-radius:14px;box-shadow:var(--shadow-lg)}
.lightbox figcaption{color:#e8ddce;margin-top:1rem;font-family:var(--ff-display);font-size:1.1rem}
.lightbox__close{position:absolute;top:18px;right:24px;width:46px;height:46px;border-radius:50%;border:none;
  background:rgba(255,255,255,.12);color:#fff;font-size:1.8rem;line-height:1;cursor:pointer;transition:.2s}
.lightbox__close:hover{background:var(--accent);color:#2a1c08;transform:rotate(90deg)}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.cards .card,.steps .step,.reviews .review,.gallery__item{transition-delay:var(--d,0s)}

@media (prefers-reduced-motion:reduce) and (min-width:999999px){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery__item--wide{grid-column:span 2}
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__card{justify-self:start;width:min(380px,100%)}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2)::after{display:none}
}

@media (max-width:860px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:var(--cream);
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.3rem;
    padding:6rem 1.6rem 2rem;box-shadow:var(--shadow-lg);transform:translateX(110%);transition:transform .4s var(--ease);overflow-y:auto}
  .nav__links.open{transform:none}
  .nav__links>a:not(.btn):not(.nav__phone){padding:.9em 1em;font-size:1.05rem}
  .nav__phone{display:block;padding:.9em 1em}
  .nav__cta{margin:1rem 0 0}
  .burger{display:flex}
  .topbar__item:nth-child(3),.topbar__sep{display:none}
  .topbar__badge{margin-left:auto}
  .fab{display:grid}
  .split{grid-template-columns:1fr}
  .split__media{min-height:360px;margin-bottom:1.5rem}
  .contact{grid-template-columns:1fr}
  .reviews{grid-template-columns:1fr}
  .cta__inner{flex-direction:column;align-items:flex-start}
}

@media (max-width:560px){
  body{font-size:16px}
  .container{padding-inline:18px}
  .cards{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;grid-auto-rows:200px}
  .gallery__item--wide,.gallery__item--tall{grid-column:auto;grid-row:auto}
  .hero__badges{gap:.8rem 1.2rem}
  .form__row{grid-template-columns:1fr}
  .hero__actions .btn{flex:1}
  .topbar__inner{justify-content:center}
  .topbar__item:first-child{margin-right:auto}
}

/* ============================================================
   LEGAL PAGES (mentions légales / confidentialité)
   ============================================================ */
.legalhead{position:sticky;top:0;z-index:50;background:rgba(250,246,240,.92);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line)}
.legalhead__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}
.legalhead .back{display:inline-flex;align-items:center;gap:.5em;font-weight:700;color:var(--accent-deep)}
.legalhead .back .ic{width:1.1em;height:1.1em}
.legalhead .back:hover{gap:.8em;color:var(--ink)}
.legal{padding-block:clamp(2.5rem,6vw,4.5rem);background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.legal__wrap{max-width:780px;margin:0 auto}
.legal h1{font-family:var(--ff-display);font-weight:600;line-height:1.05;font-size:clamp(2rem,5vw,3rem);letter-spacing:-.01em;margin-bottom:.5rem}
.legal h1 em{color:var(--accent-deep)}
.legal__meta{color:var(--stone);margin-bottom:2.4rem;font-size:.95rem}
.legal h2{font-family:var(--ff-display);font-weight:600;font-size:1.4rem;margin:2.2rem 0 .6rem;color:var(--ink);padding-top:1.2rem;border-top:1px solid var(--line)}
.legal h3{font-size:1.02rem;font-weight:700;margin:1.3rem 0 .2rem;color:var(--ink-2)}
.legal p{color:var(--ink-2);margin-bottom:1rem;font-size:1rem}
.legal a{color:var(--accent-deep);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--ink)}
.legal .infobox{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.6rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}
.legal .infobox p{margin:.25rem 0;font-size:.98rem}
.legal .infobox strong{color:var(--ink)}

/* ── Filet de securite : ouverture garantie + contenu visible si le JS echoue/est bloque (navigateur Insta/WhatsApp, reseau filtre, erreur JS) ── */
html.failsafe .loader,html.failsafe .intro,html.failsafe .intro-lock,html.failsafe .preloader,html.failsafe .loading{opacity:0!important;visibility:hidden!important;pointer-events:none!important;transition:none!important;animation:none!important}
html.failsafe [class*="reveal"],html.failsafe [class*="fade"],html.failsafe [class*="gs-"],html.failsafe [class*="appear"],html.failsafe [class*="rise"],html.failsafe [data-reveal],html.failsafe [data-aos]{opacity:1!important;transform:none!important;visibility:visible!important;clip-path:none!important;transition:none!important;animation:none!important}
