/* ================================================================
   MUSIC RESIDENCE — BG Imóveis
   Editorial · cinematográfico · alto padrão
   ================================================================ */

:root{
  --bg:#F4EFE7;
  --bg-2:#EBE3D5;
  --paper:#FBF8F2;
  --ink:#15110E;
  --ink-2:#3A312A;
  --ink-3:#7A6F65;
  --wine:#4A1715;
  --wine-2:#6A2520;
  --green:#1F4F36;
  --gold:#B58E4A;
  --gold-2:#D4AC68;
  --line:rgba(21,17,14,.14);
  --line-light:rgba(255,255,255,.18);
  --shadow:0 40px 80px -30px rgba(21,17,14,.5);
  --serif:"Cormorant Garamond", "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --container:1280px;
  --gutter:clamp(20px, 4vw, 56px);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  font-family:var(--sans);
  font-size:16px;line-height:1.65;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:opacity .25s ease}
a:hover{opacity:.7}
button{font:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);width:100%}

/* === Typography === */
.big-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2.6rem, 6vw, 6rem);
  line-height:.98;
  letter-spacing:-.015em;
  color:var(--ink);
  margin:0 0 .5em;
}
.big-title em{font-style:italic;color:var(--wine);font-weight:400}
.big-title-dark{color:#fff}
.big-title-dark em{color:var(--gold-2)}

.big-lead{
  font-family:var(--serif);
  font-size:clamp(1.15rem, 1.6vw, 1.5rem);
  line-height:1.45;
  font-weight:300;
  color:var(--ink-2);
  max-width:680px;
  margin:0 0 2em;
}
.big-lead-dark{color:rgba(255,255,255,.78)}

/* === Editorial meta (section numbering) === */
.ed-meta{
  display:flex;align-items:baseline;gap:18px;
  margin-bottom:48px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
  width:fit-content;
}
.ed-meta.dark{border-bottom-color:rgba(255,255,255,.25)}
.ed-meta.light{border-bottom-color:var(--line)}
.ed-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.4rem;
  color:var(--gold);
  letter-spacing:.02em;
}
.ed-meta.dark .ed-num{color:var(--gold-2)}
.ed-label{
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--ink-2);
}
.ed-meta.dark .ed-label{color:rgba(255,255,255,.75)}

/* === Buttons === */
.btn-pill{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 32px;border-radius:999px;
  background:var(--wine);color:#fff;
  font-size:.92rem;font-weight:500;letter-spacing:.04em;
  border:1px solid var(--wine);
  transition:background .3s ease, transform .3s ease, gap .3s ease;
  cursor:pointer;
}
.btn-pill .arrow{transition:transform .3s ease}
.btn-pill:hover{background:#fff;color:var(--wine);opacity:1;gap:20px}
.btn-pill:hover .arrow{transform:translateX(4px)}
.btn-pill-light{background:transparent;color:var(--wine);border-color:var(--wine)}
.btn-pill-light:hover{background:var(--wine);color:#fff}
.btn-block{width:100%;justify-content:center}

.btn-link{
  display:inline-flex;align-items:center;
  font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;
  font-weight:500;color:rgba(255,255,255,.85);
  padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.5);
  transition:color .3s ease,border-color .3s ease, letter-spacing .3s ease;
}
.btn-link:hover{color:#fff;border-color:#fff;opacity:1;letter-spacing:.16em}
.btn-link.dark{color:var(--wine);border-bottom-color:var(--wine);margin-top:32px}

/* ================================================================
   CRECI fixo
   ================================================================ */
.creci-fixed{
  position:fixed;top:24px;right:24px;z-index:90;
  width:clamp(150px,15vw,210px);height:auto;
  filter:drop-shadow(0 10px 22px rgba(0,0,0,.4));
}

/* ================================================================
   HERO
   ================================================================ */
.hero{
  position:relative;
  min-height:100vh;min-height:100svh;
  display:flex;
  overflow:hidden;
  color:#fff;
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-bg{
  width:100%;height:100%;object-fit:cover;
  animation:slowZoom 24s ease-out infinite alternate;
}
@keyframes slowZoom{
  0%{transform:scale(1.0)}
  100%{transform:scale(1.12)}
}
.hero-vignette{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 30%, transparent 0%, rgba(0,0,0,.35) 60%, rgba(0,0,0,.85) 100%),
    linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.1) 30%, rgba(0,0,0,.75) 100%);
}
.hero-grain{
  position:absolute;inset:0;opacity:.08;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='.7'/></svg>");
}

.hero-shell{
  position:relative;z-index:1;
  width:100%;
  padding:48px var(--gutter) 64px;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:100vh;min-height:100svh;
}

.hero-top{
  display:flex;align-items:center;justify-content:flex-start;
}
.hero-marker{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;font-weight:500;
  color:rgba(255,255,255,.85);
  padding:10px 18px;border:1px solid rgba(255,255,255,.32);border-radius:999px;
  backdrop-filter:blur(8px);
}
.hero-marker-dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold-2);
  box-shadow:0 0 14px var(--gold-2);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.hero-center{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  margin-top:-20px;
}
.hero-logo{
  width:clamp(180px, 22vw, 280px);height:auto;
  margin-bottom:36px;
  filter:brightness(0) invert(1) drop-shadow(0 0 40px rgba(0,0,0,.4));
}
.hero-title{
  font-family:var(--serif);
  font-size:clamp(3rem, 8.5vw, 8rem);
  line-height:.92;letter-spacing:-.02em;
  font-weight:300;color:#fff;
  margin:0;
}
.hero-title span{display:block}
.hero-title em{
  font-style:italic;font-weight:300;
  color:var(--gold-2);
  font-family:var(--serif);
}

.hero-bottom{
  display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end;
}
.hero-sub{
  max-width:480px;
  font-family:var(--serif);
  font-size:clamp(1.05rem, 1.4vw, 1.3rem);
  line-height:1.5;font-weight:300;
  color:rgba(255,255,255,.85);
  margin:0;
}
.hero-actions{
  display:flex;flex-direction:column;align-items:flex-end;gap:18px;
}

.hero-scroll-hint{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.65);
}
.hero-scroll-hint .line{
  width:1px;height:50px;background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,0));
  animation:lineDrop 2.4s ease-in-out infinite;
}
@keyframes lineDrop{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* ================================================================
   MANIFESTO
   ================================================================ */
.manifesto{
  background:var(--paper);
  padding:clamp(80px, 12vw, 160px) 0;
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.manifesto-marquee{
  position:absolute;top:30px;left:0;right:0;
  display:flex;gap:48px;
  font-family:var(--serif);font-style:italic;
  font-size:clamp(2.8rem, 8vw, 7rem);
  color:rgba(74,23,21,.06);
  white-space:nowrap;letter-spacing:.02em;
  animation:scrollLeft 60s linear infinite;
  pointer-events:none;
}
.manifesto-marquee span{display:inline-block}
@keyframes scrollLeft{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.manifesto blockquote{
  position:relative;z-index:1;
  margin:0 auto;max-width:920px;
  font-family:var(--serif);
  font-size:clamp(1.7rem, 3.4vw, 3.2rem);
  line-height:1.25;font-weight:400;
  color:var(--ink);text-align:center;
  letter-spacing:-.01em;
}
.manifesto blockquote em{
  font-style:italic;color:var(--wine);font-weight:400;display:block;margin-top:.3em;
}
.manifesto-sig{
  margin-top:36px;text-align:center;
  font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;
}

/* ================================================================
   EDITORIAL SECTION (01 · Sobre)
   ================================================================ */
.ed{
  background:var(--bg);
  padding:clamp(80px, 11vw, 160px) 0;
}
.ed-shell{}
.ed-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:start;
}
.ed-title{
  font-family:var(--serif);
  font-size:clamp(2.4rem, 5vw, 5rem);
  line-height:1;font-weight:400;
  letter-spacing:-.015em;
  color:var(--ink);
  margin:0 0 32px;
}
.ed-title em{font-style:italic;color:var(--wine);font-weight:400}
.ed-lead{
  font-family:var(--serif);
  font-size:1.4rem;line-height:1.45;font-weight:300;
  color:var(--ink-2);margin:0 0 24px;
}
.ed-copy p{color:var(--ink-2);line-height:1.7}

.ed-facts{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;margin:48px 0 0;padding:0;
}
.ed-facts div{
  border-top:1px solid var(--line);padding-top:18px;
  display:flex;flex-direction:column;gap:6px;
}
.ed-facts dt{
  font-family:var(--serif);
  font-size:clamp(2.4rem, 3.5vw, 3.5rem);
  font-weight:400;color:var(--wine);
  line-height:1;letter-spacing:-.01em;
}
.ed-facts dd{
  margin:0;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);font-weight:500;
}

.ed-media{
  margin:0;position:relative;
  border-radius:2px;overflow:hidden;
  box-shadow:var(--shadow);
}
.ed-media img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
}
.ed-media figcaption{
  position:absolute;left:24px;bottom:24px;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:#fff;background:rgba(21,17,14,.55);
  padding:8px 14px;backdrop-filter:blur(8px);
}

/* ================================================================
   02 · Localização
   ================================================================ */
.loc{
  background:var(--bg-2);
  padding:clamp(80px, 11vw, 160px) 0;
}
.loc-stack{
  margin:48px 0 64px;
  border-top:1px solid var(--line);
}
.loc-row{
  display:grid;
  grid-template-columns:160px 1fr auto;
  gap:32px;align-items:baseline;
  padding:28px 0;
  border-bottom:1px solid var(--line);
  transition:padding .35s ease, background .35s ease;
}
.loc-row:hover{padding-left:16px;background:rgba(255,255,255,.4)}
.loc-dist{
  font-family:var(--serif);
  font-size:clamp(1.8rem, 3.2vw, 2.8rem);
  color:var(--green);font-weight:400;letter-spacing:-.01em;
}
.loc-name{
  font-family:var(--serif);
  font-size:clamp(1.4rem, 2vw, 1.9rem);
  font-style:italic;font-weight:400;color:var(--ink);
}
.loc-time{
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;
}

.map-wrap{
  border-radius:2px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.map-wrap iframe{width:100%;height:480px;border:0;display:block}

/* ================================================================
   03 · Lazer (DARK)
   ================================================================ */
.lazer{
  background:#0E0B09;color:#fff;
  padding:clamp(80px, 11vw, 160px) 0 clamp(80px, 11vw, 140px);
  position:relative;
}
.lazer .ed-label{color:rgba(255,255,255,.75)}
.lazer .ed-num{color:var(--gold-2)}

.lazer-hero{
  position:relative;margin:64px 0;
  height:clamp(420px, 60vh, 720px);
  overflow:hidden;
}
.lazer-hero img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 12s ease-out;
}
.lazer-hero:hover img{transform:scale(1.06)}
.lazer-hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85) 100%);
}
.lazer-hero-caption{
  position:absolute;left:var(--gutter);right:var(--gutter);bottom:clamp(32px,5vw,64px);
  z-index:1;max-width:560px;
}
.lazer-hero-caption span{
  display:block;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-2);font-weight:500;margin-bottom:14px;
}
.lazer-hero-caption h3{
  font-family:var(--serif);
  font-size:clamp(2.2rem, 4.5vw, 4rem);
  line-height:1;font-weight:300;color:#fff;
  margin:0 0 16px;
}
.lazer-hero-caption p{
  font-family:var(--serif);
  font-size:clamp(1.05rem, 1.4vw, 1.3rem);font-weight:300;
  color:rgba(255,255,255,.85);max-width:480px;margin:0;
}

.lazer-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(20px, 2.5vw, 36px);
}
.lazer-card{
  margin:0;position:relative;overflow:hidden;
  aspect-ratio:3/4;
  background:#000;
}
.lazer-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1s cubic-bezier(.2,.7,.2,1), opacity .6s ease;
  opacity:.92;
}
.lazer-card:hover img{transform:scale(1.06);opacity:1}
.lazer-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.92) 100%);
}
.lazer-card figcaption{
  position:absolute;left:24px;right:24px;bottom:24px;z-index:1;
}
.card-num{
  font-family:var(--serif);font-style:italic;
  color:var(--gold-2);font-size:.95rem;letter-spacing:.04em;
  display:block;margin-bottom:8px;
}
.lazer-card h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(1.5rem,2vw,1.9rem);
  color:#fff;margin:0 0 8px;letter-spacing:-.01em;
}
.lazer-card p{
  font-size:.92rem;color:rgba(255,255,255,.78);
  margin:0;line-height:1.55;
}

/* ================================================================
   04 · Vídeo
   ================================================================ */
.video-section{
  background:var(--paper);
  padding:clamp(80px, 11vw, 160px) 0;
}
.video-stack{display:flex;flex-direction:column;gap:24px;margin-top:48px}
.video-frame{
  width:100%;border-radius:2px;overflow:hidden;
  background:#0E0B09;aspect-ratio:16/9;
  display:flex;align-items:center;justify-content:center;
  position:relative;box-shadow:var(--shadow);
}
.video-frame video,.video-frame iframe{width:100%;height:100%;border:0;display:block}
.video-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.video-placeholder::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(45deg,rgba(255,255,255,.025) 0 14px,transparent 14px 28px),
    radial-gradient(circle at 50% 50%, rgba(181,142,74,.12), transparent 60%);
}
.video-placeholder-text{
  position:relative;z-index:1;
  font-family:var(--serif);font-style:italic;
  color:rgba(255,255,255,.7);
  font-size:clamp(1rem, 1.5vw, 1.3rem);letter-spacing:.04em;
}
.video-placeholder::after{
  content:"";
  position:absolute;
  width:80px;height:80px;border-radius:50%;
  border:1px solid rgba(255,255,255,.5);
  top:50%;left:50%;transform:translate(-50%,calc(-50% - 36px));
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M8 5v14l11-7z'/></svg>")
    center/26px no-repeat;
}

/* ================================================================
   05 · Decorados (carrossel)
   ================================================================ */
.decorados{
  background:var(--bg);
  padding:clamp(80px, 11vw, 160px) 0 clamp(60px, 7vw, 100px);
}

/* ===== Carrossel genérico ===== */
.carousel{
  margin-top:64px;
  --slide-aspect: 16 / 10;
}
.carousel-stage{
  position:relative;
  background:var(--ink);
  overflow:hidden;
}
.carousel-track{
  display:flex;
  transition:transform .8s cubic-bezier(.65,0,.15,1);
  will-change:transform;
}
.carousel-slide{
  margin:0;flex:0 0 100%;
  width:100%;aspect-ratio:var(--slide-aspect);
  position:relative;
  background:#0E0B09;
}
.carousel-slide img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.carousel-slide figcaption{
  position:absolute;left:24px;bottom:24px;
  background:rgba(11,9,7,.7);color:#fff;
  padding:10px 18px;backdrop-filter:blur(10px);
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
}
.carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:2;
  width:60px;height:60px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--ink);
  border:0;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s ease, background .3s ease, opacity .3s ease;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
}
.carousel-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.08)}
.carousel-arrow.prev{left:24px}
.carousel-arrow.next{right:24px}
.carousel-arrow:disabled{opacity:.35;cursor:default}
.carousel-arrow:disabled:hover{transform:translateY(-50%) scale(1);background:rgba(255,255,255,.92)}

.carousel-bar{
  display:grid;grid-template-columns:auto 1fr auto;
  gap:32px;align-items:center;
  padding-top:32px;
}
.carousel-counter{
  display:flex;align-items:baseline;gap:12px;
  font-family:var(--serif);
}
.carousel-counter [data-current]{
  font-size:clamp(1.6rem, 2.6vw, 2.4rem);
  color:var(--wine);font-weight:400;
  min-width:1.6em;display:inline-block;
}
.carousel-counter [data-total]{
  font-size:1rem;color:var(--ink-3);
}
.counter-divider{
  width:32px;height:1px;background:var(--ink-3);display:inline-block;
}
.carousel-progress{
  height:1px;background:var(--line);position:relative;overflow:hidden;
}
.carousel-progress span{
  position:absolute;left:0;top:0;bottom:0;
  background:var(--wine);
  width:0%;
  transition:width .8s cubic-bezier(.65,0,.15,1);
}
.carousel-caption{
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-2);font-weight:500;
  text-align:right;
}

/* ================================================================
   06 · Plantas
   ================================================================ */
.plantas{
  background:var(--bg-2);
  padding:clamp(80px, 11vw, 160px) 0;
}

/* Carrossel de plantas (split: info + planta) */
.carousel-plantas{
  --slide-aspect: 16 / 9;
}
.carousel-plantas .carousel-stage{
  background:var(--paper);
}
.tipo-slide{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  background:var(--paper);
}
.tipo-slide .tipo-info{
  padding:clamp(36px, 5vw, 72px);
  display:flex;flex-direction:column;justify-content:center;gap:14px;
  background:var(--paper);
}
.tipo-slide .tipo-img{
  background:#fff;
  padding:clamp(28px, 4vw, 56px);
  display:flex;align-items:center;justify-content:center;
  border-left:1px solid var(--line);
  min-height:100%;
}
.tipo-slide .tipo-img img{
  max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;
  display:block;
}
.tipo-tag{
  display:inline-block;font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
}
.tipo-slide h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(2.4rem, 4.5vw, 4.5rem);
  color:var(--wine);
  margin:0;letter-spacing:-.015em;line-height:1;
}
.tipo-meta{
  font-family:var(--serif);
  font-size:clamp(1.2rem, 1.8vw, 1.7rem);
  color:var(--ink);font-weight:400;
  margin:0;
}
.tipo-meta span{
  font-style:italic;color:var(--ink-3);font-size:.85em;margin-left:6px;
}
.tipo-features{
  list-style:none;padding:0;margin:18px 0 0;
  display:flex;flex-direction:column;gap:10px;
}
.tipo-features li{
  font-size:.92rem;color:var(--ink-2);
  padding-left:18px;position:relative;
}
.tipo-features li::before{
  content:"";position:absolute;left:0;top:.6em;
  width:8px;height:1px;background:var(--gold);
}

/* ================================================================
   07 · Fachadas (full-bleed)
   ================================================================ */
.fachadas-section{background:var(--bg)}
.fachadas-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;
}
.fachadas-grid figure{
  margin:0;position:relative;overflow:hidden;
}
.fachadas-grid img{
  width:100%;height:clamp(500px, 80vh, 820px);
  object-fit:cover;
  transition:transform 1.2s cubic-bezier(.2,.7,.2,1);
}
.fachadas-grid figure:hover img{transform:scale(1.04)}
.fachadas-grid figcaption{
  position:absolute;left:32px;bottom:32px;
  background:rgba(21,17,14,.65);color:#fff;
  padding:10px 18px;backdrop-filter:blur(8px);
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
}

/* ================================================================
   EXCLUSIVIDADE
   ================================================================ */
.exclusividade{
  background:var(--paper);
  padding:clamp(80px, 10vw, 140px) 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.exclusividade-shell{
  display:grid;grid-template-columns:auto 1fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:center;
}
.exclusividade-seal{
  width:clamp(180px, 18vw, 280px);
  height:auto;
  filter:drop-shadow(0 20px 40px rgba(0,0,0,.18));
  animation:bob 6s ease-in-out infinite;
}
@keyframes bob{
  0%,100%{transform:translateY(0) rotate(-3deg)}
  50%{transform:translateY(-10px) rotate(3deg)}
}
.exclusividade .ed-label{
  display:block;margin-bottom:20px;
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
}

/* ================================================================
   CTA
   ================================================================ */
.cta{
  background:linear-gradient(160deg, var(--wine) 0%, #2A0907 70%, #1A0504 100%);
  color:#fff;
  padding:clamp(80px, 11vw, 160px) 0;
  position:relative;overflow:hidden;
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at top right, rgba(181,142,74,.18), transparent 60%);
  pointer-events:none;
}
.cta-grid{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:clamp(40px, 6vw, 96px);align-items:start;
  position:relative;z-index:1;
}
.cta-contacts{
  list-style:none;padding:0;margin:40px 0 0;
  display:flex;flex-direction:column;
  border-top:1px solid rgba(255,255,255,.18);
}
.cta-contacts li{
  display:grid;grid-template-columns:140px 1fr;gap:24px;
  padding:22px 0;
  border-bottom:1px solid rgba(255,255,255,.18);
  align-items:baseline;
}
.cta-contacts span{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-2);font-weight:600;
}
.cta-contacts a{
  font-family:var(--serif);font-size:clamp(1.3rem,1.8vw,1.9rem);
  color:#fff;font-weight:400;
}

.lead-form{
  background:var(--paper);color:var(--ink);
  padding:clamp(28px, 3.5vw, 48px);
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:18px;
  box-shadow:0 30px 60px -25px rgba(0,0,0,.6);
}
.lead-form h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(1.7rem, 2.2vw, 2.3rem);
  color:var(--wine);margin:0 0 8px;
  padding-bottom:18px;border-bottom:1px solid var(--line);
}
.lead-form label{
  display:flex;flex-direction:column;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);font-weight:600;gap:8px;
}
.lead-form input,
.lead-form select,
.lead-form textarea{
  font:inherit;font-size:1rem;letter-spacing:0;text-transform:none;
  padding:14px 0;
  border:0;border-bottom:1px solid var(--line);
  background:transparent;color:var(--ink);font-weight:400;
  transition:border-color .25s ease;
}
.lead-form input::placeholder,
.lead-form textarea::placeholder{color:var(--ink-3);opacity:.6}
.lead-form input:focus,
.lead-form select:focus,
.lead-form textarea:focus{
  outline:none;border-bottom-color:var(--wine);
}
.lead-form textarea{resize:vertical;min-height:64px}
.lead-form button{margin-top:8px}
.form-status{font-size:.9rem;margin:0;min-height:1.2em;letter-spacing:0;text-transform:none;font-weight:500}
.form-status.ok{color:var(--green)}
.form-status.err{color:var(--wine)}
.form-legal{
  font-size:.72rem;color:var(--ink-3);margin:0;
  letter-spacing:0;text-transform:none;font-weight:400;line-height:1.5;
}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{
  background:#0B0907;color:rgba(255,255,255,.7);
  padding:80px 0 30px;
}
.footer-top{
  display:flex;flex-direction:column;align-items:center;gap:18px;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center;
}
.footer-logo{height:70px;width:auto;filter:brightness(0) invert(1)}
.footer-tag{
  font-family:var(--serif);font-style:italic;
  font-size:1.4rem;color:rgba(255,255,255,.85);margin:0;
}
.footer-grid{
  display:grid;grid-template-columns:1fr 1fr 2fr;gap:48px;
  margin:60px auto;
  font-size:.92rem;
}
.footer-grid h4{
  font-family:var(--sans);font-weight:600;color:var(--gold-2);
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;margin:0 0 18px;
}
.footer-grid p{color:rgba(255,255,255,.7);margin:0 0 10px;line-height:1.65}
.footer-grid a{color:#fff;text-decoration:underline;text-decoration-color:rgba(255,255,255,.3);text-underline-offset:3px}
.footer-legal p{font-size:.78rem;line-height:1.6;color:rgba(255,255,255,.55)}

.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.08);
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.4);
}

/* ================================================================
   WhatsApp FAB
   ================================================================ */
.wa-fab{
  position:fixed;right:24px;bottom:24px;z-index:80;
  width:62px;height:62px;
  min-width:62px;min-height:62px;
  flex-shrink:0;aspect-ratio:1/1;
  border-radius:50%;
  background:#25D366;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px rgba(37,211,102,.5);
  transition:transform .3s ease;
  padding:0;line-height:0;
}
.wa-fab i{font-size:30px;line-height:1}
.wa-fab svg{display:block;width:28px;height:28px}
.wa-fab:hover{transform:translateY(-4px) scale(1.06);opacity:1}

/* ================================================================
   Lightbox
   ================================================================ */
.lightbox{
  position:fixed;inset:0;z-index:120;
  background:rgba(11,9,7,.96);
  display:none;align-items:center;justify-content:center;
  padding:24px;
}
.lightbox.open{display:flex}
.lightbox img{max-width:96vw;max-height:92vh;object-fit:contain}
.lightbox-close{
  position:absolute;top:24px;right:24px;
  background:none;border:1px solid rgba(255,255,255,.4);color:#fff;
  width:48px;height:48px;border-radius:50%;cursor:pointer;
  font-size:1.5rem;line-height:1;
  transition:background .25s ease;
}
.lightbox-close:hover{background:rgba(255,255,255,.1)}

/* ================================================================
   Reveal-on-scroll
   ================================================================ */
.lazer-card,.loc-row,.ed-grid,.ed-facts div{
  opacity:0;transform:translateY(28px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);
}
.lazer-card.in-view,.loc-row.in-view,.ed-grid.in-view,.ed-facts div.in-view{
  opacity:1;transform:translateY(0);
}

/* ================================================================
   Responsivo
   ================================================================ */
@media (max-width:1024px){
  .ed-grid{grid-template-columns:1fr;gap:60px}
  .ed-facts{grid-template-columns:repeat(2,1fr)}
  .cta-grid{grid-template-columns:1fr}
  .lazer-grid{grid-template-columns:repeat(2,1fr)}
  .tipo-slide{grid-template-columns:1fr}
  .tipo-slide .tipo-img{border-left:0;border-top:1px solid var(--line)}
  .carousel-plantas{--slide-aspect: auto}
  .carousel{--slide-aspect: 4 / 3}
  .carousel-arrow{width:48px;height:48px}
  .carousel-arrow.prev{left:12px}
  .carousel-arrow.next{right:12px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .hero-bottom{grid-template-columns:1fr;gap:32px;align-items:start}
  .hero-actions{align-items:flex-start}
  .fachadas-grid{grid-template-columns:1fr}
  .exclusividade-shell{grid-template-columns:1fr;text-align:center;justify-items:center}
}

@media (max-width:720px){
  :root{--gutter:20px}
  .creci-fixed{width:120px;top:16px;right:16px}
  .hero-top{justify-content:center}
  .hero-marker{font-size:.65rem;padding:8px 14px}
  .hero-shell{padding-top:96px}
  .hero-bottom{padding-bottom:80px}
  .loc-row{grid-template-columns:90px 1fr auto;gap:16px;padding:20px 0}
  .lazer-grid{grid-template-columns:1fr}
  .carousel{--slide-aspect: 4 / 5}
  .carousel-bar{grid-template-columns:auto 1fr;gap:18px}
  .carousel-caption{display:none}
  .carousel-arrow{width:40px;height:40px}
  .video-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px}
  .cta-contacts li{grid-template-columns:1fr;gap:6px;padding:18px 0}
  .map-wrap iframe{height:380px}
  .gallery-track img{height:340px}
  .wa-fab{right:14px;bottom:14px;width:54px;height:54px}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto}
}
