
/* =====================================================================
   DESIGN TOKENS
   ===================================================================== */
:root{
  --cta:        #A6792E;   /* dourado bronze (CTA) */
  --cta-hover:  #C6A055;   /* dourado claro (hover/acento) */
  --gold-soft:  #D9BE84;   /* dourado suave p/ dark bg */
  --dark:       #1B1A17;   /* charcoal sofisticado */
  --dark-2:     #232118;   /* charcoal alternativo */
  --dark-text:  #F2EEE6;   /* texto sobre dark */
  --bg-soft:    #F6F2EB;   /* fundo secundário creme */
  --bg-soft-2:  #FBF9F5;   /* creme mais claro */
  --white:      #FFFFFF;

  --ink:        #211E18;   /* texto principal (charcoal) */
  --ink-soft:   #6E6557;   /* texto secundário */
  --line:       #E7E0D4;   /* bordas suaves */

  --cta-grad:   linear-gradient(135deg, #9A7430 0%, #C6A055 100%);

  --maxw: 1160px;
  --radius: 4px;
  --shadow-sm: 0 2px 12px rgba(33,30,24,.06);
  --shadow-md: 0 16px 44px rgba(33,30,24,.10);
  --shadow-cta: 0 10px 28px rgba(166,121,46,.30);
}

/* =====================================================================
   RESET
   ===================================================================== */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; -webkit-text-size-adjust:100%; }
body{
  font-family:'Source Sans 3', system-ui, sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }

h1,h2,h3,.display{ font-family:'Playfair Display', Georgia, serif; line-height:1.12; font-weight:800; letter-spacing:-.01em; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }

.eyebrow{
  font-size:14px; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--cta); display:inline-flex; align-items:center; gap:8px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--cta); display:inline-block; }
.eyebrow.center{ justify-content:center; }
.eyebrow.light{ color:var(--cta-hover); }
.eyebrow.light::before{ background:var(--cta-hover); }

.section{ padding:96px 0; }
.section-head{ max-width:720px; margin:0 auto 56px; text-align:center; }
.section-head h2{ font-size:clamp(30px,4.4vw,48px); margin:18px 0 16px; color:var(--ink); }
.section-head p{ font-size:19px; color:var(--ink-soft); }

/* =====================================================================
   BOTÕES
   ===================================================================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:'Source Sans 3', sans-serif; font-size:17px; font-weight:700;
  padding:16px 26px; border-radius:var(--radius); cursor:pointer; border:none;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  text-align:center; line-height:1.2;
}
.btn i{ font-size:20px; }
.btn-primary{ background:var(--cta-grad); color:var(--white); box-shadow:var(--shadow-cta); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 34px rgba(166,121,46,.42); }
.btn-secondary{ background:transparent; color:var(--cta); border:2px solid var(--cta); }
.btn-secondary:hover{ background:var(--cta); color:var(--white); transform:translateY(-2px); }
.btn-secondary.on-dark{ color:var(--dark-text); border-color:rgba(242,238,230,.45); }
.btn-secondary.on-dark:hover{ background:var(--dark-text); color:var(--dark); border-color:var(--dark-text); }
.btn-ghost{ background:transparent; color:var(--ink-soft); border:.5px solid var(--ink-soft); font-weight:600; }
.btn-ghost:hover{ color:var(--cta); border-color:var(--cta); }
.btn-lg{ font-size:19px; padding:20px 36px; }
.btn-block{ width:100%; }

.micro{ font-size:15px; color:var(--ink-soft); display:inline-flex; align-items:center; gap:7px; }
.micro.on-dark{ color:rgba(242,238,230,.72); }

/* =====================================================================
   HEADER
   ===================================================================== */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.88); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:72px; gap:28px; }
.brand{ display:flex; align-items:center; gap:12px; color:var(--ink); }
.nav-links{ display:flex; align-items:center; gap:24px; }
.nav-links a{ color:var(--ink-soft); font-size:16px; font-weight:500; transition:color .15s; white-space:nowrap; }
.nav-links a:hover{ color:var(--cta); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-cta .btn{ padding:11px 20px; font-size:15px; white-space:nowrap; }
.nav-mobile{ display:none; }
.nav-toggle{ display:none; background:none; border:none; color:var(--ink); font-size:28px; cursor:pointer; }

/* =====================================================================
   HERO
   ===================================================================== */
.hero{ position:relative; background:linear-gradient(180deg,#FBF9F5 0%, #FFFFFF 100%); color:var(--ink); overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; object-position:center 52%; opacity:.7; filter:brightness(1.13) saturate(1.05);
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 82%, rgba(0,0,0,.55) 94%, transparent 100%);
  mask-image:linear-gradient(180deg, #000 0%, #000 82%, rgba(0,0,0,.55) 94%, transparent 100%); }
.hero-bg::after{ /* lavagem creme para legibilidade + fade suave no rodapé */
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(251,249,245,.18) 0%, rgba(250,247,242,.24) 60%, rgba(255,255,255,.55) 95%, #FFFFFF 100%);
}
.hero::before{ /* glow dourado sutil */
  content:""; position:absolute; top:-28%; right:-12%; width:58vw; height:58vw; z-index:1;
  background:radial-gradient(circle, rgba(198,160,85,.18), transparent 62%); pointer-events:none;
}
.hero::after{ /* textura sutil de linhas */
  content:""; position:absolute; inset:0; opacity:.35; pointer-events:none; z-index:1;
  background-image:linear-gradient(rgba(33,30,24,.025) 1px, transparent 1px);
  background-size:100% 46px;
}
.hero-inner{ position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; text-align:center; max-width:860px; margin:0 auto; padding:104px 0 110px; }
.tag-mcmv{
  display:inline-flex; align-items:center; gap:11px; background:rgba(255,253,249,.62);
  border:1.5px solid rgba(166,121,46,.55); color:#8A5E1E;
  padding:12px 24px; border-radius:100px; font-size:19px; font-weight:700; letter-spacing:.01em;
  box-shadow:0 6px 22px rgba(33,30,24,.12); white-space:nowrap; backdrop-filter:blur(3px);
}
.tag-mcmv i{ font-size:22px; }
.hero h1{ font-size:clamp(38px,5.6vw,68px); margin:28px 0 22px; color:var(--ink); max-width:16ch; }
.hero h1 em{ font-style:normal; color:var(--cta); }
.hero-sub{ font-size:21px; color:var(--ink); font-weight:600; max-width:620px; margin:0 auto 34px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:16px; align-items:center; justify-content:center; }
.hero .btn-secondary{ background:rgba(255,253,249,.6); color:#8A5E1E; border-color:rgba(166,121,46,.6); box-shadow:0 6px 22px rgba(33,30,24,.1); backdrop-filter:blur(3px); }
.hero .btn-secondary:hover{ background:var(--cta); color:#fff; border-color:var(--cta); }
.hero-micro{ margin-top:22px; }
.hero-trust{ display:flex; gap:48px; margin-top:46px; padding-top:32px; border-top:1px solid var(--line); flex-wrap:wrap; justify-content:center; }
.hero-trust .t{ display:flex; flex-direction:column; align-items:center; }
.hero-trust b{ font-family:'Playfair Display',serif; font-size:34px; color:var(--ink); line-height:1; }
.hero-trust small{ font-size:13.5px; color:var(--ink-soft); margin-top:7px; letter-spacing:.02em; }

/* placeholder de imagem */
.ph{
  position:relative; border-radius:8px; overflow:hidden; background:#efe2d4;
  background-image:repeating-linear-gradient(135deg, #e7d6c4 0 14px, #efe2d4 14px 28px);
  display:grid; place-items:center; color:#9a8369; border:1px solid var(--line);
}
.ph span{ font-family:'IBM Plex Mono', ui-monospace, monospace; font-size:13px; letter-spacing:.04em; background:rgba(255,255,255,.78); padding:7px 13px; border-radius:4px; }
.hero-media{ position:relative; }
.hero-media .ph{ aspect-ratio:4/5; box-shadow:0 30px 70px rgba(0,0,0,.45); }
.hero-media .badge{
  position:absolute; left:-26px; bottom:34px; background:var(--white); color:var(--ink);
  border-radius:8px; padding:16px 20px; box-shadow:var(--shadow-md); display:flex; gap:12px; align-items:center; max-width:250px;
}
.hero-media .badge i{ font-size:30px; color:var(--cta); }
.hero-media .badge b{ display:block; font-size:16px; font-weight:700; }
.hero-media .badge small{ color:var(--ink-soft); font-size:13.5px; }

/* =====================================================================
   DOR
   ===================================================================== */
.pain{ background:var(--white); }
.pain-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:8px; }
.pain-card{
  display:flex; gap:16px; align-items:flex-start; padding:24px 26px; border-radius:8px;
  background:var(--bg-soft); border:1px solid var(--line);
}
.pain-card i{ font-size:26px; color:var(--cta); flex:none; margin-top:2px; }
.pain-card p{ font-size:17.5px; color:var(--ink); }
.pain-card p b{ font-weight:700; }
.pain-foot{ text-align:center; margin-top:44px; font-size:21px; font-family:'Playfair Display',serif; font-weight:700; color:var(--ink); }
.pain-foot em{ color:var(--cta); font-style:normal; }

/* =====================================================================
   SOLUÇÃO
   ===================================================================== */
.solution{ background:var(--bg-soft); }
.sol-list{ display:flex; flex-direction:column; gap:18px; }
.sol-row{
  display:grid; grid-template-columns:auto 1fr; gap:22px; align-items:center;
  background:var(--white); border:1px solid var(--line); border-radius:10px; padding:26px 30px;
  box-shadow:var(--shadow-sm); transition:transform .18s, box-shadow .18s;
}
.sol-row:hover{ transform:translateX(4px); box-shadow:var(--shadow-md); }
.sol-ic{ width:60px; height:60px; border-radius:10px; background:var(--cta-grad); color:#fff; display:grid; place-items:center; font-size:30px; flex:none; }
.sol-row h3{ font-size:21px; margin-bottom:5px; color:var(--ink); }
.sol-row p{ font-size:17px; color:var(--ink-soft); }
.sol-from{ display:block; font-size:14px; color:var(--cta); font-weight:600; margin-bottom:6px; letter-spacing:.02em; }

/* =====================================================================
   BENEFÍCIOS
   ===================================================================== */
.benefits{ background:var(--white); }
.ben-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.ben-card{
  background:var(--white); border:1px solid var(--line); border-radius:12px; padding:34px 30px;
  transition:transform .2s, box-shadow .2s, border-color .2s; position:relative;
}
.ben-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:transparent; }
.ben-ic{ width:58px; height:58px; border-radius:12px; background:var(--bg-soft); color:var(--cta); display:grid; place-items:center; font-size:30px; margin-bottom:22px; }
.ben-card:hover .ben-ic{ background:var(--cta-grad); color:#fff; }
.ben-card h3{ font-size:21px; margin-bottom:10px; color:var(--ink); }
.ben-card p{ font-size:16.5px; color:var(--ink-soft); }

/* =====================================================================
   DIFERENCIAL — PERSONALIZAÇÃO
   ===================================================================== */
.diff{ background:var(--dark); color:var(--dark-text); position:relative; overflow:hidden; }
.diff::before{ content:""; position:absolute; bottom:-30%; left:-12%; width:55vw; height:55vw; background:radial-gradient(circle, rgba(166,121,46,.26), transparent 64%); pointer-events:none; }
.diff-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1.05fr; gap:60px; align-items:center; }
.diff h2{ font-size:clamp(30px,4.2vw,50px); color:var(--white); margin:18px 0 20px; }
.diff h2 em{ font-style:normal; color:var(--cta-hover); }
.diff-lead{ font-size:19px; color:rgba(242,238,230,.82); margin-bottom:30px; }
.diff-chips{ display:flex; flex-wrap:wrap; gap:12px; }
.chip{
  display:inline-flex; align-items:center; gap:9px; padding:11px 18px; border-radius:100px;
  background:rgba(242,238,230,.07); border:1px solid rgba(242,238,230,.18); font-size:15.5px; font-weight:500;
}
.chip i{ color:var(--cta-hover); font-size:18px; }
.diff-media{ display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:14px; }
.diff-media .ph{ background:#241608; background-image:repeating-linear-gradient(135deg,#2d1c0c 0 14px,#241608 14px 28px); border-color:rgba(242,238,230,.12); color:#7d6a52; }
.diff-media .ph span{ background:rgba(20,18,15,.7); color:#c9b79b; }
.diff-media .ph:first-child{ grid-row:span 2; aspect-ratio:auto; }

/* =====================================================================
   PROVA SOCIAL
   ===================================================================== */
.proof{ background:var(--bg-soft); }
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-bottom:60px; }
.stat{ text-align:center; }
.stat b{ font-family:'Playfair Display',serif; font-weight:800; font-size:clamp(36px,5vw,56px); color:var(--cta); display:block; line-height:1; }
.stat span{ display:block; font-size:15.5px; color:var(--ink-soft); margin-top:10px; letter-spacing:.01em; }
.tst-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.tst{ background:var(--white); border:1px solid var(--line); border-radius:12px; padding:32px 30px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.tst .stars{ color:var(--cta-hover); font-size:18px; display:flex; gap:2px; margin-bottom:16px; }
.tst p{ font-size:17px; color:var(--ink); flex:1; }
.tst .who{ display:flex; align-items:center; gap:13px; margin-top:22px; padding-top:20px; border-top:1px solid var(--line); }
.tst .av{ width:46px; height:46px; border-radius:50%; background:var(--cta-grad); color:#fff; display:grid; place-items:center; font-weight:700; font-size:18px; flex:none; }
.tst .who b{ font-size:16px; display:block; }
.tst .who small{ font-size:13.5px; color:var(--ink-soft); }

/* =====================================================================
   FAIXAS MCMV
   ===================================================================== */
.faixas{ background:var(--white); }
.faixa-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.faixa{
  border:1px solid var(--line); border-radius:12px; padding:30px 26px; background:var(--white);
  display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s; position:relative;
}
.faixa:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.faixa.feat{ border-color:var(--cta); box-shadow:0 16px 40px rgba(166,121,46,.16); }
.faixa.feat::before{ content:"Mais procurada"; position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--cta-grad); color:#fff; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:5px 14px; border-radius:100px; white-space:nowrap; }
.faixa h3{ font-family:'Source Sans 3',sans-serif; font-size:15px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--cta); }
.faixa .renda{ font-family:'Playfair Display',serif; font-weight:800; font-size:24px; color:var(--ink); margin:12px 0 4px; }
.faixa .renda small{ display:block; font-family:'Source Sans 3',sans-serif; font-weight:500; font-size:13.5px; color:var(--ink-soft); letter-spacing:0; text-transform:none; }
.faixa ul{ margin:20px 0 24px; display:flex; flex-direction:column; gap:11px; }
.faixa li{ display:flex; gap:9px; align-items:flex-start; font-size:15.5px; color:var(--ink); }
.faixa li i{ color:var(--cta); font-size:18px; flex:none; margin-top:2px; }
.faixa .btn{ margin-top:auto; }
.faixas-note{ text-align:center; margin-top:30px; font-size:14.5px; color:var(--ink-soft); }

/* =====================================================================
   OBJEÇÕES
   ===================================================================== */
.obj{ background:var(--bg-soft); }
.obj-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.obj-card{ background:var(--white); border:1px solid var(--line); border-radius:12px; padding:30px; box-shadow:var(--shadow-sm); }
.obj-q{ display:flex; gap:13px; align-items:flex-start; margin-bottom:14px; }
.obj-q i{ font-size:24px; color:#c0392b; flex:none; }
.obj-q b{ font-size:18.5px; color:var(--ink); font-family:'Playfair Display',serif; font-weight:700; line-height:1.3; }
.obj-a{ display:flex; gap:13px; align-items:flex-start; }
.obj-a i{ font-size:24px; color:var(--cta); flex:none; }
.obj-a p{ font-size:16.5px; color:var(--ink-soft); }

/* =====================================================================
   GARANTIA
   ===================================================================== */
.guarantee{ background:var(--white); }
.guarantee-box{
  display:grid; grid-template-columns:auto 1fr; gap:36px; align-items:center;
  background:var(--bg-soft); border:1px solid var(--line); border-radius:16px; padding:48px 52px; position:relative; overflow:hidden;
}
.guarantee-box::before{ content:""; position:absolute; top:0; left:0; width:6px; height:100%; background:var(--cta-grad); }
.shield{ width:110px; height:110px; border-radius:18px; background:var(--cta-grad); color:#fff; display:grid; place-items:center; font-size:58px; flex:none; box-shadow:var(--shadow-cta); }
.guarantee-box h2{ font-size:clamp(26px,3.4vw,38px); color:var(--ink); margin-bottom:12px; }
.guarantee-box p{ font-size:18px; color:var(--ink-soft); max-width:680px; }

/* =====================================================================
   URGÊNCIA
   ===================================================================== */
.urgency{ background:var(--dark); color:var(--dark-text); padding:40px 0; }
.urgency-inner{ display:flex; align-items:center; justify-content:center; gap:22px; flex-wrap:wrap; text-align:center; }
.urgency i{ font-size:34px; color:var(--cta-hover); }
.urgency b{ font-family:'Playfair Display',serif; font-size:clamp(20px,2.6vw,26px); color:var(--white); }
.urgency span{ color:rgba(242,238,230,.8); font-size:17px; }
.pulse{ width:11px; height:11px; border-radius:50%; background:#C6A055; box-shadow:0 0 0 0 rgba(198,160,85,.6); animation:pulse 1.8s infinite; display:inline-block; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(198,160,85,.55);} 70%{box-shadow:0 0 0 14px rgba(198,160,85,0);} 100%{box-shadow:0 0 0 0 rgba(198,160,85,0);} }

/* =====================================================================
   FAQ
   ===================================================================== */
.faq{ background:var(--bg-soft); }
.faq-list{ max-width:980px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:16px; align-items:start; }
.faq-item{ background:var(--white); border:1px solid var(--line); border-radius:10px; overflow:hidden; transition:box-shadow .2s, border-color .2s; }
.faq-item.open{ box-shadow:var(--shadow-md); border-color:rgba(166,121,46,.35); }
.faq-item:not(.open):hover{ border-color:rgba(166,121,46,.55); box-shadow:var(--shadow-sm); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:18px; padding:24px 28px; background:none; border:none; cursor:pointer; text-align:left; font-family:'Source Sans 3',sans-serif; transition:background .18s; }
.faq-q:hover{ background:rgba(166,121,46,.07); }
.faq-q span{ font-size:18.5px; font-weight:600; color:var(--ink); transition:color .18s; }
.faq-q:hover span{ color:var(--cta); }
.faq-q i{ font-size:24px; color:var(--cta); flex:none; transition:transform .3s; }
.faq-item.open .faq-q i{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .34s ease; }
.faq-a-inner{ padding:0 28px 26px; font-size:17px; color:var(--ink-soft); }

/* =====================================================================
   CTA FINAL
   ===================================================================== */
.final{ background:var(--dark); color:var(--dark-text); text-align:center; position:relative; overflow:hidden; }
.final::before{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:80vw; height:80vw; max-width:900px; max-height:900px; background:radial-gradient(circle, rgba(166,121,46,.22), transparent 60%); pointer-events:none; }
.final-inner{ position:relative; z-index:2; max-width:760px; margin:0 auto; }
.final h2{ font-size:clamp(32px,4.8vw,56px); color:var(--white); margin:20px 0 20px; }
.final h2 em{ font-style:normal; color:var(--cta-hover); }
.final p{ font-size:20px; color:rgba(242,238,230,.82); margin-bottom:38px; }
.final .micro{ margin-top:22px; display:block; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{ background:#16140F; color:rgba(242,238,230,.7); padding:64px 0 32px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:46px; border-bottom:1px solid rgba(242,238,230,.1); }
.footer .brand{ margin-bottom:18px; }
.footer-about{ font-size:15.5px; max-width:320px; line-height:1.7; }
.footer h4{ font-family:'Source Sans 3',sans-serif; font-size:14px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--dark-text); margin-bottom:18px; }
.footer-col a, .footer-col p{ display:flex; align-items:center; gap:10px; font-size:15.5px; margin-bottom:12px; transition:color .15s; }
.footer-col a:hover{ color:var(--cta-hover); }
.footer-col i{ font-size:18px; color:var(--cta); }
.footer-bottom{ display:flex; align-items:center; justify-content:space-between; padding-top:26px; font-size:14px; flex-wrap:wrap; gap:12px; }

/* =====================================================================
   WHATSAPP FLUTUANTE
   ===================================================================== */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:90; width:60px; height:60px; border-radius:50%;
  background:#25D366; color:#fff; display:grid; place-items:center; font-size:34px;
  box-shadow:0 10px 30px rgba(37,211,102,.45); transition:transform .2s;
}
.wa-float:hover{ transform:scale(1.08); }

/* =====================================================================
   LOGO (imagem)
   ===================================================================== */
.brand-logo{ display:block; width:auto; }
.site-header .brand-logo{ height:44px; filter:saturate(1.16) contrast(1.04); }
.footer .brand-logo{ height:46px; margin-bottom:18px; }

/* =====================================================================
   HERO / DIFF IMAGENS
   ===================================================================== */
.hero-media .hero-img{ aspect-ratio:4/5; border-radius:10px; overflow:hidden; box-shadow:0 30px 70px rgba(33,30,24,.22); border:1px solid var(--line); }
.hero-media .hero-img img{ width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.diff-media .dimg{ border-radius:8px; overflow:hidden; box-shadow:0 18px 40px rgba(0,0,0,.42); }
.diff-media .dimg img{ width:100%; height:100%; object-fit:cover; display:block; }
.diff-media .dimg.tall{ grid-row:span 2; }

/* =====================================================================
   QUEM SOMOS
   ===================================================================== */
.about{ background:var(--white); padding-bottom:0; }
.about h2{ font-size:clamp(28px,4vw,46px); color:var(--ink); }
.about h2 em{ font-style:normal; color:var(--cta); }
.about p{ font-size:18px; color:var(--ink-soft); margin-bottom:16px; }

/* Intro + stats */
.about-top{ display:grid; grid-template-columns:1.08fr .92fr; gap:64px; align-items:center; }
.about-intro h2{ margin:16px 0 22px; }
.about-intro p{ max-width:520px; }
.about-stats{ display:flex; flex-direction:column; gap:16px; }
.astat{ display:flex; align-items:center; gap:18px; background:var(--bg-soft-2); border:1px solid var(--line); border-radius:12px; padding:20px 24px; transition:transform .18s, box-shadow .18s; }
.astat:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.astat-ic{ width:52px; height:52px; border-radius:10px; background:#fff; border:1px solid var(--line); color:var(--cta); display:grid; place-items:center; font-size:26px; flex:none; }
.astat b{ font-family:'Playfair Display',serif; font-weight:800; font-size:26px; color:var(--ink); line-height:1; display:block; }
.astat small{ font-size:14.5px; color:var(--ink-soft); display:block; margin-top:5px; }

/* Fundador */
.founder{ display:grid; grid-template-columns:.82fr 1.18fr; gap:60px; align-items:start; margin-top:96px; }
.founder-side{ position:sticky; top:96px; }
.founder-card{ background:var(--cta-grad); color:#fff; border-radius:12px 12px 0 0; padding:22px 26px; box-shadow:var(--shadow-cta); }
.founder-card b{ font-family:'Playfair Display',serif; font-size:22px; display:block; line-height:1.1; letter-spacing:.01em; }
.founder-card small{ font-size:13.5px; opacity:.92; letter-spacing:.04em; display:block; margin-top:5px; text-transform:uppercase; }
.founder-photo{ border-radius:0 0 12px 12px; overflow:hidden; box-shadow:var(--shadow-md); }
.founder-photo img{ width:100%; display:block; filter:grayscale(100%) contrast(1.04); }
.founder-story h3{ font-family:'Playfair Display',serif; font-weight:800; font-size:clamp(26px,3.4vw,40px); color:var(--ink); margin:16px 0 22px; line-height:1.14; }
.founder-story h3 em{ font-style:normal; color:var(--cta); }
.founder-story p{ font-size:18px; color:var(--ink-soft); margin-bottom:16px; max-width:620px; }
.founder-quote{ position:relative; background:var(--bg-soft); border-left:4px solid var(--cta); border-radius:0 12px 12px 0; padding:26px 30px; margin:30px 0; font-family:'Playfair Display',serif; font-style:italic; font-size:20px; line-height:1.5; color:var(--ink); }
.founder-quote cite{ display:block; margin-top:16px; font-family:'Source Sans 3',sans-serif; font-style:normal; font-size:15px; font-weight:600; color:var(--cta); }
.founder-mini{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:30px; }
.fmini{ background:var(--white); border:1px solid var(--line); border-radius:10px; padding:20px 16px; text-align:center; transition:transform .18s, box-shadow .18s, border-color .18s; }
.fmini:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:transparent; }
.fmini i{ font-size:26px; color:var(--cta); }
.fmini b{ display:block; font-size:15px; color:var(--ink); margin:10px 0 4px; }
.fmini small{ font-size:12.5px; color:var(--ink-soft); line-height:1.35; display:block; }

/* Timeline */
.about-timeline-wrap{ background:var(--bg-soft); margin-top:96px; padding:88px 0; }
.timeline{ position:relative; margin:0; padding:0 0 0 30px; list-style:none; }
.timeline::before{ content:""; position:absolute; left:5px; top:6px; bottom:6px; width:2px; background:var(--line); }
.tl-item{ position:relative; padding:0 0 38px 30px; }
.tl-item:last-child{ padding-bottom:0; }
.tl-item::before{ content:""; position:absolute; left:-29px; top:4px; width:13px; height:13px; border-radius:50%; background:var(--cta); border:3px solid var(--bg-soft); box-shadow:0 0 0 2px var(--cta); }
.tl-year{ font-size:12.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--cta); }
.tl-item h4{ font-family:'Playfair Display',serif; font-weight:700; font-size:21px; color:var(--ink); margin:8px 0 8px; }
.tl-item p{ font-size:16.5px; color:var(--ink-soft); max-width:680px; }

/* Valores */
.values-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-bottom:90px; }
.values-head{ text-align:left; max-width:640px; margin:72px 0 40px; }
/* desktop: sobe os valores (reduz o vão grande acima) */
@media (min-width:681px){
  .values-head{ margin-top:14px; }
  .about-timeline-wrap{ padding-bottom:44px; }
}
.value-card{ background:var(--white); border:1px solid var(--line); border-radius:14px; padding:36px 32px; text-align:center; transition:transform .2s, box-shadow .2s, border-color .2s; }
.value-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:transparent; }
.value-ic{ width:62px; height:62px; border-radius:14px; background:var(--bg-soft); color:var(--cta); display:grid; place-items:center; font-size:32px; margin:0 auto 20px; }
.value-card:hover .value-ic{ background:var(--cta-grad); color:#fff; }
.value-card h4{ font-family:'Playfair Display',serif; font-weight:700; font-size:22px; color:var(--ink); margin-bottom:12px; }
.value-card p{ font-size:16.5px; color:var(--ink-soft); }

/* =====================================================================
   SIMULADOR MCMV
   ===================================================================== */
.sim-grid{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:20px; align-items:stretch; }
.sim-card{ background:var(--white); border:1px solid var(--line); border-radius:14px; padding:30px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.sim-card > h3{ font-family:'Source Sans 3',sans-serif; font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:22px; }
.sim-field{ margin-bottom:20px; }
.sim-field label{ display:block; font-size:15px; font-weight:600; color:var(--ink); margin-bottom:8px; }
.sim-field .hint{ font-size:13px; color:var(--ink-soft); margin-top:6px; font-weight:400; line-height:1.4; }
.sim-input, .sim-select{ width:100%; font-family:'Source Sans 3',sans-serif; font-size:18px; font-weight:600; color:var(--ink); padding:14px 16px; border:1.5px solid var(--line); border-radius:8px; background:var(--bg-soft); transition:border-color .15s; -webkit-appearance:none; appearance:none; }
.sim-input:focus, .sim-select:focus{ outline:none; border-color:var(--cta); background:var(--white); }
.sim-select{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23B3631A' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:42px; cursor:pointer; }
.sim-prefix{ position:relative; }
.sim-prefix > span{ position:absolute; left:15px; top:50%; transform:translateY(-50%); font-weight:600; color:var(--ink-soft); pointer-events:none; font-size:17px; }
.sim-prefix .sim-input{ padding-left:40px; }
.sim-card .btn{ margin-top:auto; }

.sim-result{ background:var(--dark); color:var(--dark-text); border:none; }
.sim-result > h3{ color:rgba(242,238,230,.55); }
.sim-sub-label{ font-size:14px; color:rgba(242,238,230,.6); margin-bottom:6px; }
.sim-sub-value{ font-family:'Source Sans 3', sans-serif; font-weight:800; font-size:clamp(38px,4.8vw,52px); letter-spacing:-.02em; font-variant-numeric:tabular-nums; color:var(--cta-hover); line-height:1.0; }
.sim-faixa-badge{ display:inline-flex; align-items:center; gap:7px; margin-top:16px; padding:7px 15px; border-radius:100px; background:rgba(198,160,85,.16); border:1px solid rgba(198,160,85,.5); color:var(--cta-hover); font-size:14px; font-weight:600; }
.sim-rows{ margin-top:24px; border-top:1px solid rgba(242,238,230,.12); }
.sim-row{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; padding:13px 0; border-bottom:1px solid rgba(242,238,230,.12); }
.sim-row > span{ font-size:15px; color:rgba(242,238,230,.7); }
.sim-row > b{ font-size:16px; color:var(--dark-text); font-weight:700; text-align:right; }
.sim-row > b em{ font-style:normal; color:var(--cta-hover); }
.sim-note{ font-size:12.5px; color:rgba(242,238,230,.5); margin-top:18px; line-height:1.55; }

.sim-table{ padding:0; overflow:hidden; }
.sim-table > h3{ padding:26px 26px 0; }
.sim-tbl{ width:100%; border-collapse:collapse; margin-top:14px; }
.sim-tbl th, .sim-tbl td{ text-align:left; padding:13px 12px; font-size:14px; border-bottom:1px solid var(--line); vertical-align:middle; }
.sim-tbl th{ font-size:11.5px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); }
.sim-tbl td:first-child, .sim-tbl th:first-child{ padding-left:26px; }
.sim-tbl td:last-child, .sim-tbl th:last-child{ padding-right:26px; }
.sim-tbl td:first-child{ font-weight:700; color:var(--ink); }
.sim-tbl tr[data-faixa].active{ background:var(--bg-soft); box-shadow:inset 3px 0 0 var(--cta); }
.sim-tbl .sub-yes{ color:#1f8a4c; font-weight:700; white-space:nowrap; }
.sim-tbl .sub-no{ color:var(--ink-soft); }
.sim-tag-new{ display:inline-block; font-size:10px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:#7C3AED; background:rgba(124,58,237,.14); padding:2px 6px; border-radius:4px; margin-left:5px; vertical-align:middle; }
.sim-tbl-note{ font-size:12px; color:var(--ink-soft); padding:14px 26px 22px; line-height:1.5; }
/* dica de arrastar (só aparece no celular) */
.swipe-hint{ display:none; }
@keyframes swipeNudge{ 0%,100%{ transform:translateX(-4px); } 50%{ transform:translateX(4px); } }

/* =====================================================================
   RESPONSIVO
   ===================================================================== */
@media (max-width:980px){
  .about-top{ grid-template-columns:1fr; gap:40px; }
  .founder{ grid-template-columns:1fr; gap:36px; margin-top:64px; }
  .founder-side{ position:static; max-width:420px; }
  .sim-grid{ grid-template-columns:1fr; }
  .diff-inner{ grid-template-columns:1fr; gap:44px; }
  .ben-grid{ grid-template-columns:repeat(2,1fr); }
  .faixa-grid{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); gap:34px 24px; }
  .tst-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:34px; }
}
@media (max-width:680px){
  body{ font-size:17px; }
  .section{ padding:64px 0; }
  .section-head{ margin-bottom:40px; }
  .nav-links{ display:none; }
  .nav-cta .btn span.full{ display:none; }
  .nav-toggle{ display:block; }
  .nav-mobile{ display:none; flex-direction:column; gap:4px; padding:8px 24px 20px; background:var(--white); border-bottom:1px solid var(--line); }
  .nav-mobile.open{ display:flex; }
  .nav-mobile a{ color:var(--ink); padding:12px 0; border-bottom:1px solid var(--line); font-weight:500; }
  .pain-grid{ grid-template-columns:1fr; }
  /* benefícios: 2 blocos por vez no celular */
  .ben-grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .ben-card{ padding:20px 16px; border-radius:10px; }
  .ben-ic{ width:46px; height:46px; font-size:24px; margin-bottom:14px; border-radius:10px; }
  .ben-card h3{ font-size:16px; margin-bottom:7px; line-height:1.2; }
  .ben-card p{ font-size:13.5px; line-height:1.45; }
  .founder-mini{ grid-template-columns:1fr 1fr; }
  /* valores (Quem Somos): 2 por linha no celular */
  .values-grid{ grid-template-columns:1fr 1fr; gap:12px; margin-bottom:56px; }
  .value-card{ padding:22px 16px; border-radius:12px; }
  .value-ic{ width:48px; height:48px; font-size:24px; margin-bottom:14px; border-radius:11px; }
  .value-card h4{ font-size:16px; margin-bottom:8px; }
  .value-card p{ font-size:13.5px; line-height:1.45; }
  .about-stats{ gap:12px; }
  .faixa-grid{ grid-template-columns:1fr; }
  .obj-grid{ grid-template-columns:1fr; }
  .faq-list{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  /* reduz o vão entre Obras e os números no celular */
  .obras-sec{ padding-bottom:28px; }
  .obras-rail{ padding-bottom:14px; }
  .proof{ padding-top:40px; }
  .guarantee-box{ grid-template-columns:1fr; text-align:center; padding:26px 20px; gap:14px; justify-items:center; }
  .guarantee-box::before{ display:none; }
  .shield{ width:66px; height:66px; font-size:34px; border-radius:14px; }
  .guarantee-box p{ font-size:15px; }
  /* depoimentos: deslizar para o lado (swipe) no celular */
  .tst-grid{ grid-template-columns:repeat(3, 86%); gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:12px; scrollbar-width:thin; }
  .tst{ scroll-snap-align:center; padding:24px 22px; }
  .tst p{ font-size:15.5px; }
  /* solução: 2 cards por linha no celular */
  .sol-list{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .sol-row{ grid-template-columns:1fr; text-align:left; gap:10px; padding:18px 16px; }
  .sol-ic{ width:46px; height:46px; font-size:24px; border-radius:9px; }
  .sol-from{ font-size:12px; margin-bottom:4px; }
  .sol-row h3{ font-size:16px; line-height:1.2; margin-bottom:6px; }
  .sol-row p{ font-size:13.5px; line-height:1.45; }
  /* rodapé compacto no celular */
  .footer{ padding:44px 0 26px; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:24px 20px; padding-bottom:28px; }
  .footer-top > div:first-child{ grid-column:1 / -1; }
  .footer .brand{ margin-bottom:12px; }
  .footer-about{ font-size:14px; line-height:1.6; }
  .footer h4{ font-size:13px; margin-bottom:12px; }
  .footer-col a, .footer-col p{ font-size:14px; margin-bottom:9px; gap:8px; }
  /* botões do hero menores (não ocupam a linha toda) */
  .hero-actions{ gap:10px; }
  .hero-actions .btn{ width:auto; font-size:15px; padding:13px 22px; }
  .hero-actions .btn.btn-lg{ font-size:15px; padding:13px 22px; }
  .hero-actions .btn i{ font-size:18px; }
  .hero-inner{ padding:72px 0 78px; }
  .tag-mcmv{ font-size:15.5px; padding:10px 18px; gap:8px; }
  .tag-mcmv i{ font-size:18px; }
  .hero-sub{ font-size:18.5px; }
  /* texto "sem compromisso" menor no celular */
  .hero-micro{ margin-top:16px; }
  .hero-micro .micro, .hero .micro.on-dark{ font-size:12.5px; gap:5px; }
  /* títulos das seções menores no celular */
  .section-head{ margin-bottom:34px; }
  .section-head h2{ font-size:26px; margin:14px 0 12px; }
  .section-head p{ font-size:16px; }
  .guarantee-box h2{ font-size:22px; }
  .hero-trust{ gap:30px; }
  .diff-media{ grid-template-columns:1fr 1fr; }
  /* simulador: 3 blocos juntos (deslizar para o lado), compactos */
  .sim-grid{ grid-template-columns:repeat(3, 82%); gap:12px; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:12px; scrollbar-width:thin; }
  .sim-card{ scroll-snap-align:center; padding:20px; border-radius:12px; }
  .sim-card > h3{ margin-bottom:14px; }
  .sim-field{ margin-bottom:13px; }
  .sim-input, .sim-select{ font-size:16px; padding:12px 14px; }
  .sim-prefix .sim-input{ padding-left:36px; }
  .sim-sub-value{ font-size:36px; }
  .sim-rows{ margin-top:14px; }
  .sim-row{ padding:10px 0; }
  .sim-row > span{ font-size:13.5px; }
  .sim-row > b{ font-size:14.5px; }
  .sim-table > h3{ padding:20px 18px 0; }
  .sim-tbl th, .sim-tbl td{ padding:10px 8px; font-size:12.5px; }
  .sim-tbl td:first-child, .sim-tbl th:first-child{ padding-left:18px; }
  .sim-tbl td:last-child, .sim-tbl th:last-child{ padding-right:18px; }
  .sim-tbl-note{ padding:12px 18px 18px; }
  /* dica "arraste para o lado" no celular */
  .swipe-hint{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:4px; font-size:13px; font-weight:600; color:var(--cta); text-align:center; }
  .swipe-hint i{ font-size:18px; animation:swipeNudge 1.5s ease-in-out infinite; }
}


/* === navegação ativa / páginas === */
.nav-links a.active{ color:var(--cta); font-weight:600; }
.page-back{ display:inline-flex; align-items:center; gap:8px; font-size:15px; font-weight:600; color:var(--ink-soft); transition:color .15s; }
.page-back:hover{ color:var(--cta); }
.page-back i{ font-size:18px; }

/* =====================================================================
   OBRAS ENTREGUES — galeria / carrossel
   ===================================================================== */
.obras-sec{ background:var(--bg-soft); overflow:hidden; }
.obras-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; margin-bottom:44px; }
.obras-head h2{ font-size:clamp(28px,4vw,46px); color:var(--ink); margin:16px 0 12px; max-width:680px; }
.obras-head h2 em{ font-style:normal; color:var(--cta); }
.obras-head p{ font-size:18px; color:var(--ink-soft); max-width:540px; }
.obras-head .btn{ flex:none; }

.obras-rail{ display:flex; gap:24px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 4px 24px; scrollbar-width:thin; scrollbar-color:var(--cta) transparent; }
.obras-rail::-webkit-scrollbar{ height:8px; }
.obras-rail::-webkit-scrollbar-track{ background:transparent; }
.obras-rail::-webkit-scrollbar-thumb{ background:var(--line); border-radius:100px; }
.obras-rail::-webkit-scrollbar-thumb:hover{ background:var(--cta); }

.obra-card{ flex:0 0 320px; scroll-snap-align:start; background:var(--white); border:1px solid var(--line); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s, border-color .2s; color:inherit; }
.obra-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.obra-thumb{ position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--bg-soft); }
.obra-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.obra-card:hover .obra-thumb img{ transform:scale(1.05); }
.obra-badge{ position:absolute; top:14px; left:14px; display:inline-flex; align-items:center; gap:6px; background:rgba(27,26,23,.78); backdrop-filter:blur(4px); color:#fff; font-size:12.5px; font-weight:600; letter-spacing:.02em; padding:6px 13px; border-radius:100px; }
.obra-badge i{ font-size:14px; color:var(--gold-soft); }
.obra-badge.construcao i{ color:#7FB6E8; }
.obra-info{ padding:22px 24px 24px; display:flex; flex-direction:column; flex:1; }
.obra-info h3{ font-family:'Playfair Display',serif; font-weight:700; font-size:22px; color:var(--ink); margin-bottom:6px; }
.obra-info .obra-loc{ font-size:14.5px; color:var(--ink-soft); margin-bottom:18px; display:flex; align-items:center; gap:6px; }
.obra-info .obra-loc i{ font-size:16px; color:var(--cta); }
.obra-specs{ display:flex; flex-wrap:wrap; gap:8px 16px; margin-bottom:22px; }
.obra-specs li{ display:flex; align-items:center; gap:7px; font-size:14.5px; color:var(--ink); font-weight:500; }
.obra-specs i{ font-size:17px; color:var(--cta); }
.obra-link{ margin-top:auto; display:inline-flex; align-items:center; gap:8px; font-size:15px; font-weight:600; color:var(--cta); }
.obra-link i{ transition:transform .2s; }
.obra-card:hover .obra-link i{ transform:translateX(4px); }

/* card "em breve" */
.obra-soon{ border-style:dashed; background:transparent; }
.obra-soon:hover{ transform:none; box-shadow:none; border-color:var(--cta); }
.obra-soon .obra-thumb{ display:grid; place-items:center; aspect-ratio:4/5; background:rgba(166,121,46,.05); }
.obra-soon-ic{ width:58px; height:58px; border-radius:50%; background:var(--white); border:1px solid var(--line); color:var(--cta); display:grid; place-items:center; font-size:28px; }
.obra-soon .obra-info h3{ color:var(--ink-soft); }
.obra-soon .obra-info p{ font-size:14.5px; color:var(--ink-soft); }

/* =====================================================================
   PÁGINA DE DETALHE DA OBRA
   ===================================================================== */
.obra-hero{ padding:34px 0 0; }
.obra-hero-head{ text-align:center; max-width:780px; margin:30px auto 0; }
.obra-hero-head .eyebrow{ justify-content:center; }
.obra-hero-head h1{ font-family:'Playfair Display',serif; font-weight:800; font-size:clamp(32px,5vw,56px); color:var(--ink); margin:14px 0 14px; line-height:1.1; }
.obra-hero-head p{ font-size:19px; color:var(--ink-soft); }
.obra-cover{ margin:44px 0 0; border-radius:16px; overflow:hidden; box-shadow:var(--shadow-md); aspect-ratio:16/10; }
.obra-cover img{ width:100%; height:100%; object-fit:cover; display:block; }

.obra-about{ display:grid; grid-template-columns:.85fr 1.15fr; gap:54px; align-items:start; padding:60px 0 10px; }
.obra-about .lead{ font-family:'Playfair Display',serif; font-size:clamp(22px,2.6vw,30px); font-weight:700; line-height:1.3; color:var(--ink); }
.obra-about .lead em{ font-style:normal; color:var(--cta); }
.obra-about .body p{ font-size:18px; color:var(--ink-soft); margin-bottom:18px; }
.obra-about .obra-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:26px; }

/* vídeo do tour da obra — vertical (9:16), faixa escura full-bleed */
.obra-video{ background:linear-gradient(180deg,#16140F 0%, #1B1A17 100%); margin-top:70px; padding:72px 0 80px; }
.obra-video .vhead{ text-align:center; max-width:560px; margin:0 auto 38px; }
.obra-video .vlabel{ display:inline-flex; align-items:center; gap:9px; font-size:13px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--cta-hover); margin-bottom:14px; }
.obra-video .vlabel i{ font-size:18px; }
.obra-video .vhead h2{ font-family:'Playfair Display',serif; font-weight:800; font-size:clamp(26px,3.4vw,38px); color:#fff; margin-bottom:10px; }
.obra-video .vhead p{ color:rgba(245,236,216,.72); font-size:17px; }
/* palco com "modo ambiente" (luz desfocada do vídeo vazando atrás) */
.video-stage{ position:relative; display:grid; place-items:center; padding:14px 0; }
.video-stage .vbg{ position:absolute; top:-6%; left:50%; transform:translateX(-50%) scale(1.05); width:74%; max-width:560px; height:112%; object-fit:cover; filter:blur(64px) brightness(.62) saturate(1.35); opacity:.6; z-index:0; border-radius:48px; pointer-events:none; }
.video-frame{ position:relative; z-index:1; width:100%; max-width:336px; margin:0 auto; aspect-ratio:9/16; border-radius:26px; overflow:hidden; background:#0E0D0A; box-shadow:0 24px 60px rgba(0,0,0,.55), 0 0 0 1px rgba(245,236,216,.12), inset 0 0 0 1px rgba(255,255,255,.04); }
.video-frame video{ position:relative; z-index:1; width:100%; height:100%; object-fit:cover; display:block; }
.video-frame .poster{ position:absolute; inset:0; z-index:1; width:100%; height:100%; object-fit:cover; transition:opacity .4s; }
.video-frame.playing .poster{ opacity:0; pointer-events:none; }
/* botão de som (autoplay mudo) */
.vsound{ position:absolute; right:14px; bottom:14px; z-index:3; width:50px; height:50px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(22,20,15,.6); color:#fff; display:grid; place-items:center; font-size:24px; backdrop-filter:blur(6px); transition:background .2s, transform .2s; }
.vsound:hover{ background:var(--cta); transform:scale(1.08); }
.vsound .ti-volume{ display:none; }
.vsound.on .ti-volume{ display:block; }
.vsound.on .ti-volume-off{ display:none; }
/* tap-to-play (fallback caso autoplay seja bloqueado) */
.vtap{ position:absolute; inset:0; z-index:2; display:none; flex-direction:column; align-items:center; justify-content:center; gap:14px; border:none; cursor:pointer;
  background:linear-gradient(180deg, rgba(14,13,10,.15), rgba(14,13,10,.5)); }
.video-frame.paused .vtap{ display:flex; }
.vtap .vbtn{ width:74px; height:74px; border-radius:50%; background:rgba(255,255,255,.94); color:var(--cta); display:grid; place-items:center; font-size:36px; box-shadow:0 12px 34px rgba(0,0,0,.35); transition:transform .25s, background .25s, color .25s; }
.vtap:hover .vbtn{ transform:scale(1.08); background:var(--cta); color:#fff; }
.vtap .vhint{ color:#fff; font-size:15px; font-weight:600; text-shadow:0 2px 10px rgba(0,0,0,.5); }
/* estado "em breve" enquanto o MP4 não foi enviado */
.vsoon{ position:absolute; inset:0; z-index:2; display:none; flex-direction:column; align-items:center; justify-content:center; gap:12px; text-align:center; padding:24px;
  background:linear-gradient(180deg, rgba(14,13,10,.25), rgba(14,13,10,.6)); color:#F5ECD8; }
.vsoon .ti{ font-size:40px; color:var(--cta-hover); }
.vsoon b{ font-size:16px; font-weight:700; }
.vsoon small{ font-size:13px; color:rgba(245,236,216,.7); max-width:220px; }
.video-frame.no-video .vsoon{ display:flex; }
.video-frame.no-video .vsound, .video-frame.no-video .vtap{ display:none; }

/* ficha técnica / diferenciais */
.spec-strip{ border-top:1px solid var(--line); margin-top:50px; padding-top:40px; }
.spec-strip .spec-label{ font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:22px; }
.spec-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:16px; }
.spec-card{ background:var(--bg-soft-2); border:1px solid var(--line); border-radius:12px; padding:22px 18px; text-align:center; }
.spec-card i{ font-size:26px; color:var(--cta); }
.spec-card b{ display:block; font-family:'Playfair Display',serif; font-size:22px; color:var(--ink); margin:10px 0 4px; }
.spec-card small{ font-size:13px; color:var(--ink-soft); letter-spacing:.02em; }

/* galeria de fotos */
.obra-gallery{ padding:66px 0 0; }
.obra-gallery .section-head{ text-align:left; margin:0 0 34px; max-width:560px; }
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.gallery-grid figure{ background:var(--white); border:1px solid var(--line); border-radius:14px; overflow:hidden; transition:transform .2s, box-shadow .2s, border-color .2s; }
.gallery-grid figure:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:transparent; }
.gallery-grid .g-photo{ aspect-ratio:4/5; overflow:hidden; background:var(--bg-soft); }
.gallery-grid img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
.gallery-grid figure:hover img{ transform:scale(1.05); }
.gallery-grid figcaption{ display:flex; align-items:center; gap:9px; padding:16px 20px; font-size:16px; font-weight:600; color:var(--ink); }
.gallery-grid figcaption i{ font-size:19px; color:var(--cta); }

/* CTA da obra — faixa full-bleed que funde no rodapé */
.obra-end-cta{ background:linear-gradient(180deg,#1B1A17 0%, #16140F 100%); color:var(--dark-text); padding:96px 0 104px; text-align:center; margin-top:84px; position:relative; overflow:hidden; }
.obra-end-cta::before{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:150%; height:80%; background:radial-gradient(ellipse at center, rgba(198,160,85,.09) 0%, transparent 68%); pointer-events:none; }
.obra-end-cta > *{ position:relative; z-index:2; }
.obra-end-cta h2{ font-size:clamp(26px,3.4vw,40px); color:#fff; margin-bottom:14px; }
.obra-end-cta p{ font-size:18px; color:rgba(242,238,230,.82); margin-bottom:28px; max-width:560px; margin-left:auto; margin-right:auto; }

@media (max-width:980px){
  .obras-head{ flex-direction:column; align-items:flex-start; gap:20px; }
  .obra-about{ grid-template-columns:1fr; gap:28px; }
  .spec-grid{ grid-template-columns:repeat(3,1fr); }
  .gallery-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .obra-card{ flex:0 0 270px; }
  .spec-grid{ grid-template-columns:1fr 1fr; }
  /* galeria das obras: deslizar para o lado (swipe) no celular */
  .gallery-grid{ display:flex; grid-template-columns:none; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:12px; scrollbar-width:thin; }
  .gallery-grid figure{ flex:0 0 82%; scroll-snap-align:center; }
  .obra-end-cta{ padding:60px 0 68px; margin-top:56px; }
  .obra-cover{ aspect-ratio:4/3; }
}

/* =====================================================================
   MARCAS PARCEIRAS — carrossel infinito (trusted-by)
   ===================================================================== */
.partners{ background:var(--white); padding:68px 0 72px; border-top:1px solid var(--line); overflow:hidden; }
/* versão compacta nas páginas de obra (fica entre dois blocos escuros) */
.partners.partners-obra{ padding:44px 0 48px; border-top:none; }
.partners.partners-obra .partners-head{ margin-bottom:28px; }
.partners-head{ text-align:center; margin-bottom:40px; }
.partners-head .eyebrow{ justify-content:center; }
.partners-head h2{ font-family:'Playfair Display',serif; font-weight:800; font-size:clamp(24px,3vw,34px); color:var(--ink); margin-top:14px; }
.partners-head p{ color:var(--ink-soft); font-size:17px; margin-top:8px; }

.marquee{ position:relative; width:100%; overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent); }
.marquee-track{ display:flex; align-items:center; gap:0; width:max-content; animation:marquee 52s linear infinite; will-change:transform; backface-visibility:hidden; }
/* hover é controlado por JS (partners-marquee.js) para a mudança de velocidade ser fluida */
@keyframes marquee{ from{ transform:translate3d(0,0,0); } to{ transform:translate3d(-50%,0,0); } }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }

.partner{ flex:0 0 auto; display:grid; place-items:center; padding:0 46px; height:64px; }
/* logos reais — coloridas (a maioria do público acessa pelo celular, sem hover) */
.partner img{ max-height:50px; max-width:160px; width:auto; object-fit:contain; opacity:.92; transition:transform .3s, opacity .3s; }
.marquee:hover .partner img{ opacity:1; }
/* placeholder textual (fallback) */
.partner .plogo{ font-family:'Source Sans 3',sans-serif; font-weight:700; font-size:22px; letter-spacing:.04em; color:#A99B89; white-space:nowrap; transition:color .3s; text-transform:uppercase; }
.marquee:hover .partner .plogo{ color:var(--cta); }
.partner .plogo small{ display:block; font-size:11px; font-weight:600; letter-spacing:.14em; color:#C3B7A6; text-align:center; margin-top:1px; }

@media (max-width:680px){
  .partner{ padding:0 30px; height:54px; }
  .partner .plogo{ font-size:18px; }
  .partner img{ max-height:40px; max-width:124px; }
}
