/* ===== Motion cinematográfico (GSAP + ScrollTrigger + Lenis) ===== */
/* Estado inicial dos reveals — só aplicado quando o motion está ativo (classe setada via JS).
   Sem JS / GSAP falho / reduced-motion: nada é escondido, conteúdo aparece normal. */
html.gsap-ready [data-reveal]{opacity:0;will-change:transform,opacity}
html.gsap-ready [data-reveal="up"]{transform:translateY(34px)}
html.gsap-ready [data-reveal="left"]{transform:translateX(-40px)}
html.gsap-ready [data-reveal="right"]{transform:translateX(40px)}
html.gsap-ready [data-reveal="scale"]{transform:scale(.965)}
/* Lenis controla o scroll quando ativo — desliga o smooth nativo pra não brigar */
html.lenis,html.lenis body{height:auto}
html.lenis-smooth{scroll-behavior:auto}
.lenis.lenis-smooth{scroll-behavior:auto}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
@media(prefers-reduced-motion:reduce){
  html.gsap-ready [data-reveal]{opacity:1!important;transform:none!important}
}
:root{
  --ink:#10100d;
  --ink-2:#191813;
  --paper:#f4efe4;
  --paper-2:#e8dfcf;
  --bone:#fffaf0;
  --gold:#c6a14c;
  --gold-2:#8e6d2d;
  --moss:#59644a;
  --wine:#6c2d2d;
  --steel:#5f6b70;
  --line:rgba(16,16,13,.14);
  --line-light:rgba(244,239,228,.2);
  --muted:#746b5d;
  --ease:cubic-bezier(.72,0,.16,1);
  --door-a:#191813;
  --door-b:#3b352c;
  --door-c:#c6a14c;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  min-height:100vh;background:var(--paper);color:var(--ink);overflow-x:hidden;max-width:100vw;
  font-family:Inter,system-ui,sans-serif;font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
body.menu-open,body.lightbox-open{overflow:hidden}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
button{cursor:pointer}
img{max-width:100%;display:block}
::selection{background:var(--gold);color:var(--ink)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.container{width:min(1320px,calc(100% - 48px));margin-inline:auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font:600 11px/1 Cinzel,serif;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-2);
}
.eyebrow::before{content:"";width:34px;height:1px;background:currentColor}
h1,h2,h3{font-family:"Cormorant Garamond",serif;font-weight:300;line-height:.95;letter-spacing:0}
h2{font-size:clamp(42px,6vw,96px)}
h3{font-size:clamp(28px,3vw,44px)}
em{font-style:italic;color:var(--gold-2)}
.lead{max-width:680px;color:var(--muted);font-size:clamp(17px,1.3vw,21px)}
.btn{
  min-height:54px;min-width:184px;padding:7px 22px 7px 7px;border:1px solid currentColor;background:transparent;color:inherit;
  display:inline-grid;grid-template-columns:38px auto;align-items:center;justify-content:center;column-gap:14px;
  font:700 10px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;
  white-space:nowrap;
  position:relative;isolation:isolate;overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
  transition:background .25s,color .25s,transform .25s,border-color .25s,box-shadow .25s;
}
.btn:not(:has(.icon)){grid-template-columns:1fr;padding:7px 26px;text-align:center}
.btn:not(:has(.icon)).gold{background:linear-gradient(135deg,#e0bf60 0%,var(--gold) 46%,#9a762f 100%)}
.btn::before,.btn::after{display:none}
.btn:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 34px rgba(16,16,13,.14);
}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:4px}
.btn.dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn.gold{
  background:
    linear-gradient(90deg,var(--ink) 0 54px,transparent 54px),
    linear-gradient(135deg,#e0bf60 0%,var(--gold) 46%,#9a762f 100%);
  color:var(--ink);border-color:rgba(255,255,255,.18);
  box-shadow:0 10px 28px rgba(198,161,76,.18);
}
.btn.gold .icon{color:var(--gold);border-color:rgba(198,161,76,.65);background:rgba(16,16,13,.45)}
.btn.gold:hover{box-shadow:0 14px 34px rgba(198,161,76,.26)}
.btn.gold[data-whatsapp]{
  background:
    linear-gradient(90deg,#0e6b3a 0 54px,transparent 54px),
    linear-gradient(135deg,#3ee07a 0%,#25d366 46%,#128c4f 100%);
  color:#0a2818;border-color:rgba(255,255,255,.22);
  box-shadow:0 10px 28px rgba(37,211,102,.28);
}
.btn.gold[data-whatsapp] .icon{color:#bff5d3;border-color:rgba(191,245,211,.55);background:rgba(10,40,24,.55)}
.btn.gold[data-whatsapp]:hover{box-shadow:0 14px 36px rgba(37,211,102,.4)}
.btn.gold[data-whatsapp]:hover .icon{background:rgba(10,40,24,.7);color:#fff;border-color:#bff5d3}
.btn.gold[data-whatsapp]:focus-visible{outline-color:#25d366}
.icon{
  width:34px;height:34px;border:1px solid currentColor;border-radius:0;
  display:inline-flex;align-items:center;justify-content:center;font-size:15px;line-height:1;
  flex:0 0 34px;
  transition:transform .35s var(--ease),background .35s,color .35s,border-color .35s;
}
.btn:hover .icon{transform:translateX(1px);background:rgba(16,16,13,.08)}
.btn:not(.gold):not(.dark){
  background:linear-gradient(90deg,rgba(198,161,76,.1) 0 54px,rgba(255,255,255,.02) 54px);
}
.btn:not(.gold):hover .icon{background:rgba(198,161,76,.18);color:var(--gold);border-color:var(--gold)}

/* Header */
.topbar{
  position:fixed;z-index:90;top:0;left:0;right:0;
  padding:18px 0;color:var(--paper);
  transition:background .35s,color .35s,padding .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.topbar.scrolled,.topbar.menu-open{
  padding:10px 0;background:rgba(244,239,228,.9);color:var(--ink);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom-color:rgba(16,16,13,.12);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;width:min(1380px,calc(100% - 48px));margin:auto}
.brand{display:flex;align-items:center;gap:12px;font:600 14px/1 Cinzel,serif;letter-spacing:.16em;text-transform:uppercase}
.brand img{display:block;width:52px;height:52px;object-fit:contain}
.brand-mark{
  width:44px;height:44px;border:1px solid currentColor;display:none;place-items:center;
  font:600 20px/1 "Cormorant Garamond",serif;letter-spacing:0;color:inherit;
}
.brand-text{display:grid;gap:4px;line-height:1}
.brand-name{font-size:14px;letter-spacing:.22em}
.brand-sub{font:700 9px/1 Inter,sans-serif;letter-spacing:.24em;color:var(--gold-2)}
.brand b{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:34px;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase}
.nav-links a{position:relative;padding:10px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:4px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:12px}
.menu-btn{
  display:none;width:44px;height:44px;border:1px solid currentColor;background:transparent;color:inherit;
  align-items:center;justify-content:center;flex-direction:column;gap:5px;
  transition:background .35s,border-color .35s,transform .35s,box-shadow .35s;
}
.menu-btn span{width:18px;height:1px;background:currentColor;transition:transform .35s var(--ease),opacity .25s}
.menu-btn:hover{background:rgba(198,161,76,.18);border-color:var(--gold);transform:translateY(-2px);box-shadow:0 12px 34px rgba(16,16,13,.16)}
.menu-btn:focus-visible{outline:2px solid var(--gold);outline-offset:4px}
body.menu-open .menu-btn span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.menu-open .menu-btn span:nth-child(2){opacity:0}
body.menu-open .menu-btn span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Hero */
.hero{
  min-height:100svh;position:relative;overflow:hidden;background:var(--ink);color:var(--paper);
  display:grid;align-items:end;padding:120px 0 38px;
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media::before{
  content:"";position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(90deg,rgba(16,16,13,.92) 0%,rgba(16,16,13,.52) 43%,rgba(16,16,13,.08) 72%,rgba(16,16,13,.68) 100%),
    linear-gradient(180deg,rgba(16,16,13,.35),rgba(16,16,13,.95));
}
.hero-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);animation:breath 14s var(--ease) forwards}
@keyframes breath{to{transform:scale(1)}}
.hero-grid{position:relative;z-index:4;display:grid;grid-template-columns:minmax(0,1.18fr) minmax(310px,.62fr);gap:48px;align-items:end}
.hero-copy{max-width:920px}
.hero h1{font-size:clamp(70px,13vw,190px);line-height:.78;margin:22px 0 28px;text-transform:uppercase}
.hero h1 span{display:block}
.hero h1 .thin{font-weight:300;color:rgba(244,239,228,.72)}
.hero-text{max-width:690px;font-size:clamp(18px,1.5vw,24px);color:#e7dfce}
.hero-text b{font-weight:600;color:var(--gold)}
.hero-cta{display:flex;align-items:center;gap:14px;margin-top:34px;flex-wrap:wrap}
.hero-panel{
  border-left:1px solid rgba(198,161,76,.5);padding-left:28px;
  display:grid;gap:18px;align-self:stretch;align-content:end;
}
.panel-kicker{font:600 10px/1 Cinzel,serif;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
.hero-proof{
  border:1px solid rgba(244,239,228,.22);background:rgba(16,16,13,.42);
  overflow:hidden;
}
.hero-proof img{width:100%;height:180px;object-fit:cover;display:block;filter:saturate(.9) contrast(1.04)}
.proof-copy{padding:18px;display:grid;gap:10px}
.proof-copy h3{font-size:32px;color:var(--paper)}
.proof-copy p{color:#ddd2bd;font-size:14px;max-width:280px}
.hero-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(244,239,228,.16)}
.fact{background:rgba(16,16,13,.58);padding:16px 12px;min-height:92px}
.fact strong{display:block;font:700 10px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.fact span{font-size:13px;line-height:1.35;color:#d6cdbd}
.scroll-note{
  position:absolute;z-index:5;left:50%;bottom:22px;transform:translateX(-50%);
  font:600 10px/1 Cinzel,serif;letter-spacing:.28em;text-transform:uppercase;color:rgba(244,239,228,.7);
}

section{position:relative;padding:128px 0}
.section-head{display:grid;grid-template-columns:minmax(0,.86fr) minmax(300px,.52fr);gap:44px;align-items:end;margin-bottom:54px}

/* Atelier */
.atelier{background:var(--paper)}
.atelier-grid{display:grid;grid-template-columns:minmax(310px,.72fr) minmax(0,1fr);gap:48px;align-items:stretch}
.door-stage{
  min-height:660px;position:sticky;top:96px;border:1px solid var(--line);
  background:var(--ink);
  overflow:hidden;padding:28px;display:grid;align-content:end;
}
.stage-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.04);transition:opacity .35s ease}
.stage-photo.swapping{opacity:0}
.door-stage::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,16,13,.04) 20%,rgba(16,16,13,.72) 100%)}
.stage-caption{position:relative;z-index:2;display:flex;justify-content:space-between;gap:18px;align-items:end}
.stage-caption h3{font-size:40px;color:var(--paper)}
.stage-caption p{max-width:260px;color:#eadfcd;font-size:14px}
.material-panel{display:grid;gap:18px}
.material-row{
  border-top:1px solid var(--line);padding:26px 0;
  display:grid;grid-template-columns:90px 1fr auto;gap:22px;align-items:center;
}
.material-row button{
  border:1px solid var(--line);background:transparent;width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;color:var(--ink);transition:transform .25s,border-color .25s,background .25s;
}
.material-row button:hover,.material-row.active button{transform:scale(1.08);border-color:var(--gold);background:rgba(198,161,76,.12)}
.swatch{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--a),var(--b))}
.material-row h3{font-size:clamp(28px,3.4vw,54px)}
.material-row p{color:var(--muted);max-width:560px}
.tag{font:600 10px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2)}
.material-carousel{display:none}

/* Signature */
.signature{
  background:
    linear-gradient(90deg,rgba(16,16,13,.92) 0%,rgba(16,16,13,.62) 55%,rgba(16,16,13,.78) 100%),
    url("/Imagens/bg/signature-bg.webp") center/cover no-repeat,
    var(--ink);
  color:var(--paper);overflow:hidden;position:relative}
.signature::before{
  content:"23|10";position:absolute;inset:auto auto 20px -2vw;
  font:300 clamp(160px,28vw,420px)/.8 "Cormorant Garamond",serif;color:rgba(198,161,76,.08);
}
.sig-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1fr);gap:48px;align-items:center}
.sig-copy p{color:#cfc4b2;margin-top:24px;max-width:520px}
.sig-showcase{display:grid;grid-template-columns:1fr .78fr;gap:14px;min-height:540px}
.sig-photo{position:relative;overflow:hidden;border:1px solid var(--line-light);background:#090907}
.sig-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.05)}
.sig-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 48%,rgba(16,16,13,.86))}
.sig-photo figcaption{position:absolute;z-index:2;left:18px;right:18px;bottom:18px;color:var(--paper)}
.sig-photo small,.sig-proof small{font:700 10px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.sig-photo h3{font-size:32px;margin-top:8px}
.sig-stack{display:grid;gap:14px}
.sig-proof{border:1px solid var(--line-light);padding:20px;background:rgba(244,239,228,.045)}
.sig-proof h3{font-size:30px;margin:10px 0 8px}
.sig-proof p{color:#cfc4b2;font-size:15px}

/* Gallery */
.gallery{background:var(--bone);overflow:hidden;padding-top:150px}
.gallery .section-head{
  padding:34px 0 28px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.gallery .section-head h2{max-width:760px}
.portfolio-note{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  margin:-18px 0 34px;border:1px solid var(--line);
}
.portfolio-note div{background:var(--bone);padding:18px}
.portfolio-note strong{display:block;font:500 36px/1 "Cormorant Garamond",serif;color:var(--gold-2)}
.portfolio-note span{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
.gallery-wall{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:340px;gap:14px}
.shot{
  position:relative;overflow:hidden;background:var(--ink);cursor:pointer;border:1px solid rgba(16,16,13,.08);
}
.shot img,.shot video{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.04);transition:transform .7s var(--ease),filter .7s}
.shot:hover img,.shot:hover video{transform:scale(1.06);filter:saturate(1.04) contrast(1.08)}
.shot.is-video .play-badge{position:absolute;z-index:3;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:rgba(198,161,76,.92);color:#10100d;display:flex;align-items:center;justify-content:center;font-size:26px;padding-left:6px;box-shadow:0 8px 32px rgba(0,0,0,.45);transition:transform .4s var(--ease)}
.shot.is-video:hover .play-badge{transform:translate(-50%,-50%) scale(1.08)}
.shot::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(16,16,13,.82));opacity:.86}
.shot figcaption{position:absolute;z-index:2;left:18px;right:18px;bottom:18px;color:var(--paper)}
.shot figcaption small{font:600 10px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.shot figcaption h3{font-size:30px;margin-top:8px}

/* Process */
.process{background:var(--paper-2);overflow:hidden}
.process::before{
  content:"SEM IMPROVISO";position:absolute;right:-2vw;top:28px;
  font:300 clamp(96px,15vw,220px)/1 "Cormorant Garamond",serif;color:rgba(16,16,13,.055);
}
.process-proof{position:relative;display:grid;grid-template-columns:.82fr 1.18fr;gap:24px;align-items:start}
.proof-panel{
  background:var(--ink);color:var(--paper);padding:32px;display:grid;
  grid-template-rows:auto 1fr auto;gap:22px;
  border:1px solid rgba(16,16,13,.18);
}
.proof-panel h3{font-size:clamp(34px,3.6vw,52px);line-height:1.05}
.proof-panel p{color:#d5c9b6;max-width:420px;margin-top:14px;font-size:15px;line-height:1.55}
.proof-photo{position:relative;min-height:260px;overflow:hidden;border:1px solid rgba(244,239,228,.18)}
.proof-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.05)}
.proof-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(16,16,13,.74))}
.proof-stamp{
  display:inline-flex;align-items:center;width:max-content;max-width:100%;border-left:2px solid var(--gold);
  padding:11px 0 11px 16px;color:var(--gold);
  font:700 11px/1.4 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;
}
.proof-grid{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:14px;align-content:start}
.proof-card{
  background:#fbf7ee;border:1px solid var(--line);padding:24px 22px;
  display:grid;grid-template-columns:48px 1fr;gap:16px;align-items:start;
  position:relative;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease,background .35s ease;
}
.proof-card::before{
  content:"";position:absolute;left:-1px;top:-1px;bottom:-1px;width:3px;background:var(--gold);
  transform:scaleY(0);transform-origin:top;transition:transform .45s ease;
}
.proof-card:hover{transform:translateY(-3px);border-color:rgba(198,161,76,.55);box-shadow:0 18px 40px -28px rgba(16,16,13,.45);background:#fff}
.proof-card:hover::before{transform:scaleY(1)}
.proof-card .num{font:500 28px/1 "Cormorant Garamond",serif;color:var(--gold-2);letter-spacing:.04em}
.proof-card h3{font-size:30px;margin-bottom:14px;line-height:1.05}
.proof-card .compare{display:grid;gap:10px;margin-top:2px}
.proof-card .compare-row{display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:start;font-size:14.5px;line-height:1.5}
.proof-card .compare-label{
  font:700 10px/1.4 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;
  padding:5px 0 0;color:#9a8f7c;
}
.proof-card .compare-row.is-noah .compare-label{color:var(--gold-2)}
.proof-card .compare-text{color:#7a7164;text-decoration:line-through;text-decoration-color:rgba(122,113,100,.35);text-decoration-thickness:1px}
.proof-card .compare-row.is-noah .compare-text{color:var(--ink);text-decoration:none;font-weight:500}

/* Quote */
.quote{
  background:
    linear-gradient(90deg,rgba(16,16,13,.93) 0%,rgba(16,16,13,.80) 50%,rgba(16,16,13,.55) 100%),
    url("/Imagens/bg/quote-bg.webp") center/cover no-repeat,
    var(--ink);
  color:var(--paper);padding:110px 0;position:relative;overflow:hidden}
.quote-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,.55fr);gap:48px;align-items:center}
.quote-copy p{color:#d0c5b2;margin-top:20px;max-width:620px;font-size:19px}
.whatsapp-card{
  border:1px solid var(--line-light);padding:28px;background:rgba(244,239,228,.035);
  display:grid;gap:18px;
}
@media(min-width:1001px){
  .whatsapp-card .btn{justify-self:start;justify-content:start;padding-right:28px}
}
.whatsapp-card h3{font-size:38px}
.whatsapp-card p{color:#cfc4b2}
.contact-list{display:grid;gap:10px;color:#d8cebb;font-size:14px}
.contact-list span{display:flex;align-items:center;gap:10px}
.contact-list span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold)}
.testimonials{padding:90px 0;background:var(--bone);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.testimonials h2{font-size:clamp(28px,3.6vw,42px);margin-top:14px}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
.testimonial{padding:28px;background:var(--paper);border:1px solid var(--line);display:flex;flex-direction:column;gap:18px}
.testimonial blockquote{font:italic 17px/1.55 Cormorant Garamond,serif;color:var(--ink);margin:0;flex:1}
.testimonial blockquote::before{content:"\201C";font-size:48px;line-height:0;vertical-align:-18px;margin-right:4px;color:var(--gold)}
.testimonial figcaption{display:grid;gap:4px;border-top:1px solid var(--line);padding-top:14px;font-size:13px;color:var(--muted)}
.testimonial figcaption strong{color:var(--ink);font:600 11px/1 Cinzel,serif;letter-spacing:.16em;text-transform:uppercase}
.testimonial .stars{color:var(--gold);letter-spacing:2px;font-size:14px;margin-top:4px}
@media(max-width:900px){.testimonial-grid{grid-template-columns:1fr}}
.quote-form{display:grid;gap:14px}
.quote-form .field{display:grid;gap:6px}
.quote-form label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#bfb39c}
.quote-form input,.quote-form textarea{
  width:100%;background:rgba(244,239,228,.04);border:1px solid rgba(244,239,228,.18);
  color:var(--paper);padding:14px 16px;font-size:15px;font-family:inherit;
  border-radius:0;transition:border-color .2s,background .2s;
}
.quote-form input:focus,.quote-form textarea:focus{outline:none;border-color:var(--gold);background:rgba(244,239,228,.07)}
.quote-form textarea{resize:vertical;min-height:110px;line-height:1.5}
.quote-form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.quote-form .form-status{font-size:13px;color:#bfb39c;min-height:18px}
.quote-form .form-status.ok{color:#a8c79b}
.quote-form .form-status.err{color:#d8a98a}
.quote-divider{display:flex;align-items:center;gap:14px;color:#8c8270;font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin:6px 0}
.quote-divider::before,.quote-divider::after{content:"";flex:1;height:1px;background:rgba(244,239,228,.14)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:grid;gap:8px}
.field.full{grid-column:1/-1}
label{font:700 10px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
input,select,textarea{
  width:100%;border:1px solid rgba(244,239,228,.18);background:rgba(244,239,228,.08);
  color:var(--paper);padding:15px 14px;border-radius:0;outline:none;
}
textarea{min-height:118px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(198,161,76,.13)}
select option{color:var(--ink)}
.form-actions{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:18px;flex-wrap:wrap}
.form-note{font-size:13px;color:#bdb29f}

/* Footer / float / lightbox */
.footer{background:#0b0b09;color:#d8d0c0;padding:56px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.1fr repeat(4,.55fr);gap:32px}
.footer-logo{width:210px;margin-bottom:20px}
.footer p,.footer li{color:#aaa08e;font-size:14px}
.footer h4{font:600 11px/1 Cinzel,serif;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer ul{list-style:none;display:grid;gap:10px}
.copy{margin-top:42px;padding-top:22px;border-top:1px solid rgba(244,239,228,.12);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#827969}
.wpp{
  position:fixed;right:24px;bottom:24px;z-index:70;width:58px;height:58px;border-radius:50%;
  background:radial-gradient(circle at 35% 25%,#7af0a1,#25d366 54%,#128c43);
  color:white;display:grid;place-items:center;font-size:25px;
  box-shadow:0 18px 50px rgba(37,211,102,.38),inset 0 1px 0 rgba(255,255,255,.38);
  transition:transform .35s var(--ease),box-shadow .35s;
}
.wpp::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:1px solid rgba(37,211,102,.42);animation:wppPulse 2.4s infinite;
}
.wpp:hover{transform:translateY(-4px) scale(1.04);box-shadow:0 24px 66px rgba(37,211,102,.5),inset 0 1px 0 rgba(255,255,255,.46)}
.wpp:focus-visible{outline:2px solid #25d366;outline-offset:5px}
@keyframes wppPulse{to{transform:scale(1.45);opacity:0}}
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(6,6,5,.94);display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.active{display:flex}
.lightbox img,.lightbox video{max-width:min(1100px,94vw);max-height:84vh;object-fit:contain;background:#000}
.lb-close,.lb-prev,.lb-next{
  position:absolute;border:1px solid rgba(244,239,228,.35);background:rgba(244,239,228,.06);
  color:var(--paper);width:46px;height:46px;display:grid;place-items:center;font-size:24px;
}
.lb-close{top:22px;right:22px}.lb-prev{left:22px}.lb-next{right:22px}

@media(max-width:1000px){
  .container,.nav{width:min(100% - 36px,1320px)}
  .nav-links{
    position:fixed;left:18px;right:18px;top:72px;display:grid;gap:0;padding:14px 18px;
    background:rgba(244,239,228,.97);color:var(--ink);border:1px solid var(--line);
    box-shadow:0 24px 90px rgba(16,16,13,.22);
    opacity:0;pointer-events:none;transform:translateY(-12px);
    transition:opacity .28s,transform .35s var(--ease);
    font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  }
  body.menu-open .nav-links{opacity:1;pointer-events:auto;transform:translateY(0)}
  .nav-links a{
    padding:14px 4px;border-bottom:1px solid var(--line);width:100%;
    color:var(--ink);
  }
  .nav-links a:last-child{border-bottom:none}
  .nav-links a::after{display:none}
  .menu-btn{display:flex}
  .nav-actions .btn{display:none}
  .hero-grid,.section-head,.atelier-grid,.sig-grid,.quote-grid{grid-template-columns:1fr}
  .hero{padding-top:110px}
  .hero h1{font-size:clamp(64px,21vw,118px)}
  .hero-panel{border-left:none;padding-left:0}
  .door-stage{position:relative;top:auto;min-height:560px}
  .sig-showcase{grid-template-columns:1fr;min-height:auto}
  .sig-photo{min-height:360px}
  .gallery-wall{grid-template-columns:1fr 1fr;grid-auto-rows:240px}
  .portfolio-note{grid-template-columns:1fr 1fr 1fr}
  .process-proof{grid-template-columns:1fr}
  .proof-grid{grid-template-columns:1fr}
  .proof-panel{min-height:360px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  section{padding:86px 0}
  .container,.nav{width:min(100% - 28px,1320px)}
  .brand{gap:10px}
  .brand img{display:block;width:44px;height:44px}
  .brand-mark{width:40px;height:40px;font-size:19px}
  .brand-name{font-size:12px;letter-spacing:.18em}
  .brand-sub{font-size:8px;letter-spacing:.18em}
  h2{font-size:clamp(38px,12vw,52px);line-height:1}
  .lead{font-size:16px;line-height:1.55}
  .topbar{padding:10px 0}
  .menu-btn{width:42px;height:42px}
  .hero{min-height:100svh;height:100svh;padding:96px 0 32px;display:grid;align-content:end}
  .hero-media img{object-position:56% center}
  .hero h1{font-size:clamp(66px,22vw,92px);line-height:.82;margin:18px 0 22px}
  .hero-text{font-size:18px;line-height:1.55}
  .hero-cta,.form-actions{align-items:stretch;flex-direction:column}
  .btn{
    width:100%;min-height:54px;min-width:0;padding:7px 14px 7px 7px;
    grid-template-columns:42px minmax(0,1fr);justify-content:stretch;column-gap:12px;
    letter-spacing:.14em;text-align:center;
  }
  .btn.gold{
    background:
      linear-gradient(90deg,var(--ink) 0 58px,transparent 58px),
      linear-gradient(135deg,#e0bf60 0%,var(--gold) 46%,#9a762f 100%);
  }
  .btn.gold[data-whatsapp]{
    background:
      linear-gradient(90deg,#0e6b3a 0 58px,transparent 58px),
      linear-gradient(135deg,#3ee07a 0%,#25d366 46%,#128c4f 100%);
  }
  .icon{width:36px;height:36px;flex-basis:36px}
  .hero-panel{display:none}
  .hero-proof img{height:170px}
  .fact{padding:12px 8px}
  .fact strong{font-size:9px}
  .fact span{font-size:9px;letter-spacing:.12em}
  .scroll-note{display:none}
  .hero-facts,.footer-grid,.form-grid,.proof-grid,.portfolio-note{grid-template-columns:1fr}
  .hero-facts{grid-template-columns:1fr 1fr 1fr}
  .gallery-wall{grid-template-columns:1fr 1fr;grid-auto-rows:200px;gap:8px}
  .fact{min-height:auto}
  .section-head{gap:18px;margin-bottom:34px}
  .door-stage,.material-panel{display:none}
  .material-carousel{display:block;width:100%;max-width:100%;overflow:hidden}
  .mc-track{
    display:flex;overflow-x:auto;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
    gap:0;scroll-behavior:smooth;width:100%;
  }
  .mc-track::-webkit-scrollbar{display:none}
  .mc-slide{
    flex:0 0 100%;width:100%;min-width:0;scroll-snap-align:center;scroll-snap-stop:always;
    display:grid;gap:14px;box-sizing:border-box;
  }
  .mc-photo{
    position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--ink);
    border:1px solid var(--line);
  }
  .mc-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.04)}
  .mc-info{padding:4px 4px 0}
  .mc-tag{
    display:inline-block;font:700 9px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;
    color:var(--gold-2);padding:5px 10px;border:1px solid var(--line);border-radius:999px;margin-bottom:10px;
  }
  .mc-info h3{font-size:30px;line-height:1.05;margin-bottom:8px}
  .mc-info p{color:var(--muted);font-size:14px;line-height:1.5;max-width:none}
  .mc-dots{display:flex;justify-content:center;gap:8px;margin-top:18px}
  .mc-dot{
    width:8px;height:8px;border-radius:50%;border:none;padding:0;
    background:rgba(16,16,13,.18);transition:background .25s,transform .25s;
  }
  .mc-dot.active{background:var(--gold);transform:scale(1.3)}
  .mc-hint{
    display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;
    color:var(--muted);font:600 10px/1 Cinzel,serif;letter-spacing:.22em;text-transform:uppercase;
    opacity:.85;transition:opacity .35s;
  }
  .mc-hint svg{animation:mc-swipe 1.6s ease-in-out infinite}
  .mc-hint.hide{opacity:0;pointer-events:none}
  @keyframes mc-swipe{
    0%,100%{transform:translateX(-3px)}
    50%{transform:translateX(5px)}
  }
  .chip{
    flex:0 0 auto;scroll-snap-align:start;display:inline-flex;align-items:center;gap:10px;
    padding:10px 16px 10px 10px;border:1px solid var(--line);border-radius:999px;
    background:var(--paper);color:var(--ink);transition:border-color .25s,background .25s,transform .25s;
    position:relative;
  }
  .chip-dot{width:26px;height:26px;border-radius:50%;flex:0 0 26px;border:1px solid rgba(16,16,13,.12)}
  .chip-label{font:600 13px/1 Inter,sans-serif;letter-spacing:.06em}
  .chip-tag{
    font:700 8px/1 Cinzel,serif;letter-spacing:.16em;text-transform:uppercase;
    color:var(--gold-2);padding-left:8px;border-left:1px solid var(--line);
  }
  .chip.active{border-color:var(--gold);background:rgba(198,161,76,.1)}
  .door-stage{min-height:360px;padding:18px}
  .stage-caption{display:grid;gap:6px}
  .stage-caption h3{font-size:28px}
  .stage-caption p{font-size:13px;max-width:none}
  .gallery{padding-top:88px}
  .gallery .section-head{padding:24px 0}
  .portfolio-note{margin:-12px 0 24px}
  .portfolio-note div{padding:14px}
  .portfolio-note strong{font-size:30px}
  .portfolio-note span{font-size:11px}
  .shot figcaption{left:12px;right:12px;bottom:12px}
  .shot figcaption h3{font-size:18px;margin-top:4px;line-height:1.05}
  .shot figcaption small{font-size:9px;letter-spacing:.14em}
  .process{padding:86px 0}
  .proof-panel{min-height:auto;padding:24px}
  .proof-photo{min-height:190px}
  .proof-stamp{width:auto;height:auto;margin-top:0}
  .proof-card{min-height:auto;padding:20px 18px;grid-template-columns:42px 1fr;gap:14px}
  .proof-card h3{font-size:26px;margin-bottom:12px}
  .proof-card .compare-row{grid-template-columns:54px 1fr;font-size:14px}
  .quote{padding-top:76px;padding-bottom:86px}
  .quote-copy p{font-size:16px;line-height:1.55;margin-top:16px}
  .whatsapp-card{padding:22px}
  .whatsapp-card h3{font-size:32px}
  input,select,textarea{padding:14px;font-size:16px}
  textarea{min-height:132px}
  .form-note{font-size:12px}
  .wpp{right:14px;bottom:14px;width:48px;height:48px;font-size:21px}
  body.hide-wpp .wpp{opacity:0;transform:translateY(20px) scale(.9);pointer-events:none}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
}

/* Services deep grid */
.services-deep{background:var(--paper);padding:120px 0 80px;border-top:1px solid var(--line)}
.services-deep .section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:end;padding:24px 0 36px;border-bottom:1px solid var(--line)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.serv-card{display:flex;flex-direction:column;gap:10px;padding:32px;background:var(--bone);border:1px solid var(--line);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;color:var(--ink)}
.serv-card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(16,16,13,.08);border-color:var(--gold)}
.serv-eyebrow{display:inline-block;font:600 10px/1 Cinzel,serif;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2);align-self:flex-start;padding:6px 10px;background:rgba(198,161,76,.1);border:1px solid rgba(198,161,76,.3)}
.serv-card h3{font-size:26px;color:var(--ink);margin:8px 0 4px}
.serv-card p{font-size:14px;line-height:1.6;color:var(--muted);flex:1}
.serv-link{font:600 11px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);margin-top:14px}
@media(max-width:980px){.services-grid{grid-template-columns:1fr 1fr}.services-deep .section-head{grid-template-columns:1fr}}
@media(max-width:640px){.services-grid{grid-template-columns:1fr}.services-deep{padding:60px 0 40px}}

/* FAQ visível */
.faq{background:var(--paper);padding:120px 0 80px}
.faq .section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:end;padding:24px 0 36px;border-bottom:1px solid var(--line)}
.faq-list{display:grid;gap:0;border-top:1px solid var(--line);margin-top:32px}
.faq-list details{border-bottom:1px solid var(--line);padding:22px 0;cursor:pointer}
.faq-list summary{font:500 22px/1.3 "Cormorant Garamond",serif;color:var(--ink);list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:24px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";font:300 28px/1 "Cormorant Garamond",serif;color:var(--gold-2);transition:transform .3s var(--ease);flex-shrink:0}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list details p{margin-top:14px;color:var(--muted);font-size:15px;max-width:780px;line-height:1.7}

/* Área de atendimento */
.service-area{background:var(--bone);padding:120px 0 80px}
.service-area .section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:end;padding:24px 0 36px;border-bottom:1px solid var(--line)}
.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin:48px 0 48px}
.area-block h3{font-size:22px;color:var(--gold-2);margin-bottom:16px;border-bottom:1px solid var(--line);padding-bottom:10px}
.area-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;font:400 14px/1.6 Inter,sans-serif;color:var(--ink)}
.area-list li{padding:6px 0;border-bottom:1px dashed var(--line)}
.area-list li::before{content:"›";color:var(--gold);margin-right:8px;font-weight:700}
.area-list li a{color:var(--gold-2);font-weight:500;text-decoration:underline;text-decoration-color:rgba(142,109,45,.3);text-underline-offset:3px;transition:text-decoration-color .2s}
.area-list li a:hover{text-decoration-color:var(--gold)}
.area-map{display:grid;grid-template-columns:1.6fr 1fr;gap:24px;border:1px solid var(--line);background:var(--paper);overflow:hidden}
.area-map iframe{width:100%;height:380px;border:0;display:block}
.area-map-info{padding:32px;display:flex;flex-direction:column;justify-content:center;gap:10px}
.area-map-info h3{font-size:24px;color:var(--ink);margin-bottom:6px}
.area-map-info p{color:var(--muted);font-size:14px}
.area-map-info a[href^="tel"]{color:var(--gold-2);font-weight:600}
.area-map-info .btn{margin-top:16px;align-self:flex-start}

@media(max-width:980px){
  .faq .section-head,.service-area .section-head{grid-template-columns:1fr}
  .area-grid{grid-template-columns:1fr 1fr}
  .area-map{grid-template-columns:1fr}
  .area-map iframe{height:280px}
}
@media(max-width:640px){
  .area-grid{grid-template-columns:1fr}
  .area-list{grid-template-columns:1fr 1fr}
  .faq{padding:60px 0 40px}
  .service-area{padding:60px 0 40px}
  .faq-list summary{font-size:18px}
}

/* ===== Páginas internas (landing/serviço/bairro/blog) ===== */
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:24px}
.topnav{display:flex;align-items:center;gap:30px}
.topnav a{position:relative;padding:8px 0;font:700 11px/1 Cinzel,serif;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);transition:color .2s}
.topnav a::after{content:"";position:absolute;left:0;bottom:2px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.topnav a:hover::after{width:100%}

.breadcrumb{font-size:12px;color:var(--muted);margin-bottom:18px;letter-spacing:.05em}
.breadcrumb a{color:var(--gold-2)}
.breadcrumb a:hover{text-decoration:underline}

.hero-land{padding:80px 0 60px;border-bottom:1px solid var(--line);background:var(--bone)}
.hero-land h1{max-width:920px}
.hero-land .lead{font-size:clamp(17px,1.4vw,21px);color:var(--muted);max-width:720px;margin-bottom:32px}
.hero-land--dark{position:relative;border-bottom:none;background:linear-gradient(90deg,rgba(16,16,13,.93) 0%,rgba(16,16,13,.78) 48%,rgba(16,16,13,.5) 100%),var(--hero-bg) center/cover no-repeat,var(--ink);color:var(--paper);padding:120px 0 90px}
.hero-land--dark .breadcrumb{color:rgba(244,239,228,.6)}
.hero-land--dark .breadcrumb a{color:var(--gold)}
.hero-land--dark h1{color:var(--paper)}
.hero-land--dark .lead{color:rgba(244,239,228,.82)}
.hero-land--dark .eyebrow{color:var(--gold)}

.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.hero-land--dark .btn.ghost{color:var(--paper);border-color:rgba(244,239,228,.5)}

.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.feat{padding:24px;background:var(--paper);border:1px solid var(--line)}
.feat h3{font-size:22px;color:var(--gold-2);margin-bottom:10px}
.feat p{font-size:14px;color:var(--muted);margin-bottom:0}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:32px}
.gallery-grid figure{position:relative;aspect-ratio:3/4;overflow:hidden;border:1px solid var(--line)}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-grid figure:hover img{transform:scale(1.05)}
.gallery-grid figcaption{position:absolute;left:14px;bottom:14px;color:#fff;font:500 11px/1.2 Cinzel,serif;letter-spacing:.12em;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.6)}

.cta-block{position:relative;overflow:hidden;background:var(--ink);color:var(--paper);padding:64px 0;text-align:center}
.cta-block::before{content:"";position:absolute;inset:0;background:var(--cta-bg,none) center/cover no-repeat;opacity:.5;z-index:0}
.cta-block .container{position:relative;z-index:1}
.cta-block h2{color:var(--paper);margin-bottom:14px}
.cta-block p{color:rgba(244,239,228,.7);max-width:600px;margin:0 auto 24px}

/* landing usa section com padding/borda próprios */
main section{padding:64px 0;border-bottom:1px solid var(--line)}
main section:last-of-type{border-bottom:0}

@media(max-width:880px){
  .cols-2,.cols-3{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  .gallery-grid{grid-template-columns:1fr}
}
