/* ==========================================================================
   Bauen-like autoral — Multi Classic Slider Dark
   ========================================================================== */
@import url("https://fonts.googleapis.com/css2?family=Didact+Gothic&family=Oswald:wght@300;400;500;600;700&display=swap");

/* ===== Tokens ===== */
:root{
  --bg:#0f0f10; --panel:#151518; --panel-2:#121214;
  --text:#ececec; --muted:#a7a7ab; --line:#242428;
  --gold:#b79b64; --gold-2:#9e8655;

  --max:1240px; --radius:14px; --shadow:0 10px 30px rgba(0,0,0,.35);

  --sidebar-w:160px;     /* largura do bloco fixo à esquerda */
  --page-max:1200px;     /* largura do palco central */
  --nav-shift:325px;     /* desloca o menu p/ a direita (look do demo) */
}

/* ===== Base ===== */
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--text);
  font:16px/1.75 "Didact Gothic", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none} a:hover{color:var(--gold)}
h1,h2,h3,h4,h5{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.18em;margin:0 0 12px;font-weight:500}
h1{font-size:clamp(36px,4.6vw,60px);line-height:1.05}
h2{font-size:clamp(28px,3.4vw,44px)}
h3{font-size:clamp(20px,2.2vw,28px)}
p{margin:0 0 16px;color:#d6d6da}
.lead{color:var(--muted)}
.colorTextGold{
color: #9e8655;
font-style: bold;

}
/* ===== Layout ===== */
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.row{display:flex;flex-wrap:wrap;margin:0 -12px}
.row>[class*="col-"]{padding:0 12px}
@media(min-width:768px){.col-md-4{width:33.3333%}.col-md-6{width:50%}}
.mt-30{margin-top:30px}
.mb-30{margin-bottom:30px}
.center{text-align:center}

/* ===== Sidebar fixa ===== */
.side-brand{
  inset:0 auto 0 0; width:var(--sidebar-w);
  background:#1b1b1f;
  display:grid; grid-template-rows:120px 1fr auto; z-index:60;
}
.side-logo{display:grid;place-items:center;padding: 20px 0 0 35px;}
.side-logo img{max-width:120px;height:auto;filter:saturate(.9)}
.side-social{
  position:relative; display:grid; gap:14px; justify-content:center; align-content:end;
  padding:0 0 26px;
}
.side-social::before{
      content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 460px;
    bottom: 235px;
    width: 1px;
    background: #b79b64;/* linha vertical */
}
.side-social a{
  width:36px; height:36px; display:grid; place-items:center;
  border:1px solid #2a2a2e; border-radius:50%; color:#cfcfd4; font-weight:700;
}
.side-social a:hover{border-color:var(--gold);color:var(--gold)}
.page{margin-left:var(--sidebar-w);background:var(--bg)}


.sideLogo{
    
    inset: 0 auto 0 0;
    width: 11%;
    height: 21%;
    background: #1b1b1f;
    /* border-right: 1px solid rgba(255, 255, 255, .06); */
    display: grid
;
    grid-template-rows: 48px 1fr auto;
    z-index: 60;
}



/* ===== Navbar ===== */
.navbar{
  position:sticky; top:0; z-index:40;
  backdrop-filter:blur(8px); background:rgba(15,15,16,.30);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .25s,border-color .25s;
}
.navbar.is-solid{background:rgba(15,15,16,.80);border-bottom-color:rgba(255,255,255,.08)}
.navbar .container{
  display:flex; align-items:center; justify-content:center; height:78px;
  max-width:var(--page-max); position:relative;
}
.navbar .logo{
  position:absolute; left:calc(var(--sidebar-w) + 24px); top:50%; transform:translateY(-50%);
  display:flex; align-items:center; gap:12px;
}
.logo-img{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#2b2b2f,#18181b);box-shadow:0 0 0 2px #000 inset}
.custom-logo-sub-gray{color:var(--muted);font-size:12px;letter-spacing:.18em}
.main-menu{display:flex;align-items:center;transform:translateX(var(--nav-shift))}
.main-menu ul{list-style:none;display:flex;gap:30px;margin:0;padding:0}
.nav-link{color:#a7a7ab;font:600 12px/1 "Didact Gothic",sans-serif;letter-spacing:.12em;text-transform:uppercase;padding:8px 0;display:inline-flex;gap:6px;align-items:center}
.nav-link:hover,.nav-link.active{color:#fff}
.nav-link.active::before{content:"•";color:var(--gold);margin-right:8px;display:inline-block;transform:translateY(-2px)}
.menu__toggle{display:none}
@media(max-width:820px){
  .main-menu{transform:none}
  .menu__toggle{display:inline-block;border:1px solid var(--line);background:#141416;color:#fff;border-radius:8px;padding:8px 10px}
  .main-menu ul{
    position:absolute; right:16px; top:74px; background:#141416; border:1px solid var(--line);
    border-radius:12px; padding:10px 12px; flex-direction:column; display:none; box-shadow:var(--shadow);
  }
  .main-menu ul.is-open{display:flex}
}

/* ===== Moldura lateral e cantoneiras ===== */
.page::before,.page::after{content:"";position:fixed;top:0;bottom:0;width:70px;pointer-events:none;}
.page::before{left:var(--sidebar-w)} .page::after{right:0}
.frame-corners{position:fixed;inset:0 0 0 auto;width:0;height:0;pointer-events:none;z-index:50}
.frame-corners::before,.frame-corners::after{
  content:"";position:fixed;right:24px;width:64px;height:64px;opacity:.75;
  border-right:1px solid rgba(255,255,255,.2);border-top:1px solid rgba(255,255,255,.2);
  border-radius:6px 6px 0 0;
}
.frame-corners::after{top:auto;bottom:24px;border-top:0;border-bottom:1px solid rgba(255,255,255,.2);border-radius:0 0 6px 6px}

/* ===== HERO — Slider ===== */
.bn-hero{position:relative;min-height:88vh;overflow:hidden;background:#0e0e10;padding:120px 0 110px}
.bn-hero .slide{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .6s ease; display:grid; place-items:center;
}
.bn-hero .slide.is-active{opacity:1;visibility:visible;pointer-events:auto}
.bn-hero .overlay{
  position:absolute; inset:0;
      background: rgb(27 27 31 / 65%);
      z-index: 10;
}

.textBanner{


  
}


.bn-hero .caption{position:relative;text-align:center;padding:0 24px;max-width:var(--page-max);margin:0 auto}
.caption .sub-title{font:700 12px/1 "Oswald",sans-serif;color:var(--gold);letter-spacing:.35em;text-transform:uppercase;margin-bottom:18px}
.caption .title{font-family:"Oswald",sans-serif;font-weight:500;letter-spacing:.32em;text-transform:uppercase;font-size:clamp(44px,7vw,96px);line-height:1.08;color:#efefef;margin:0 0 18px}
.caption .desc{color:#bfc3c9;max-width:860px;margin:0 auto 26px}
.btn{padding:10px 22px;letter-spacing:.18em;font-size:11px;background:transparent;color:var(--text);border-radius:0;transition:color .2s,border-color .2s}
.btn:hover{border-color:var(--gold);color:var(--gold)}
.btn-gold{border-color:var(--gold);color:#fff;background:var(--gold)} .btn-gold:hover{background:var(--gold-2);border-color:var(--gold-2)}
.dots{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);display:flex;gap:10px;z-index:5}
.dots button{width:9px;height:9px;border-radius:50%;border:0;background:#6c6c6c;opacity:.75;cursor:pointer}
.dots .active{background:var(--gold);opacity:1}
.slider-nav{position:absolute;left:calc(var(--sidebar-w) + 32px);bottom:26px;display:flex;gap:10px;z-index:6}
.slider-nav .nav-prev,.slider-nav .nav-next{
  width:42px;height:42px;display:grid;place-items:center;background:rgba(0,0,0,.45);color:#fff;
  border:1px solid rgba(255,255,255,.18);border-radius:50%;cursor:pointer;transition:transform .15s,border-color .2s;
}
.slider-nav .nav-prev:hover,.slider-nav .nav-next:hover{transform:translateY(-1px);border-color:var(--gold)}

/* ===== Sections ===== */
.section{padding:90px 0}
.section.section-alt{background:var(--panel-2)}
.section .section-head{margin-bottom:32px}
.section .section-head p{color:var(--muted)}

/* About */
.about .figure{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.about .figure img{width:100%}
.about .badge{position:absolute;left:16px;bottom:16px;background:rgba(0,0,0,.55);color:#fff;padding:10px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.14)}
.title[data-count]{font-size:34px;display:inline-block}

/* Promo video */
.promo{position:relative;overflow:hidden;background:#0e0e10}
.promo .bg{position:relative;min-height:520px;background:center/cover no-repeat}
.promo .bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(55% 55% at 30% 40%,rgba(0,0,0,.0) 0, rgba(0,0,0,.55) 70%),
  linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.55))}
.promo .inner{position:absolute;inset:0;display:grid;grid-template-columns:1fr minmax(300px,480px);gap:40px;align-items:center;padding:40px;max-width:1400px;margin:0 auto}
.promo .cta{position:relative;z-index:2;color:#fff;display:flex;align-items:center;gap:28px}
.play-cta{width:160px;height:160px;border-radius:999px;display:grid;place-items:center;background:rgba(183,155,100,.9);color:#0e0e10;border:1px solid rgba(255,255,255,.15);box-shadow:0 10px 40px rgba(0,0,0,.35);transition:transform .2s}
.play-cta:hover{transform:translateY(-2px)}
.play-cta .tri{width:0;height:0;border-left:22px solid #111;border-top:14px solid transparent;border-bottom:14px solid transparent;margin-left:6px}
.promo .cta .label{font:600 15px/1.4 "Didact Gothic",sans-serif;letter-spacing:.45em;text-transform:uppercase;color:#e8e8ea}
.promo .panel{position:relative;z-index:2;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:28px 28px 24px}
.promo .panel .line{height:1px;background:rgba(255,255,255,.08);margin:10px 0 16px}
.promo .quote{position:relative;padding-left:70px}
.promo .quote::before{content:"“";position:absolute;left:18px;top:-10px;font:700 84px/1 "Oswald",sans-serif;color:rgba(255,255,255,.06)}
.promo .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.promo .who img{width:48px;height:48px;border-radius:999px;object-fit:cover;border:1px solid rgba(255,255,255,.2)}
.promo .iconbar{background:#191a1d;border-top:1px solid var(--line);display:flex;gap:80px;justify-content:center;padding:26px 16px}
.promo .iconbar .ico{width:58px;height:58px;border-radius:999px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.12);color:var(--gold);background:#111;font-size:26px}
@media(max-width:980px){.promo .inner{grid-template-columns:1fr;gap:24px}.promo .panel{order:2}.promo .cta{order:1;justify-content:center}}

/* Cards / Features */
.card,.feature{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}

/* Projects / Masonry */
.grid,.masonry{column-gap:18px}
.masonry{columns:1 260px}
@media(min-width:640px){.masonry{columns:2 280px}}
@media(min-width:960px){.masonry{columns:3 300px}}
.filters{display:flex;gap:12px;justify-content:center}
.filters button{padding:8px 16px;border:1px solid var(--line);background:#111114;color:#cfcfd4;border-radius:999px;cursor:pointer}
.filters .is-active,.filters button:hover{border-color:var(--gold);color:#fff}
.thum{position:relative;display:block;overflow:hidden;border-radius:12px;background:#17171b;border:1px solid var(--line);margin:0 0 18px}
.thum img{width:100%;transition:transform .7s cubic-bezier(.22,1,.36,1)} .thum:hover img{transform:scale(1.05)}
.thum .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.55));opacity:0;transition:opacity .25s} .thum:hover .overlay{opacity:1}
.thum figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;color:#fff;font-weight:700;letter-spacing:.08em}

/* Blog (se usar) */
.post{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.post .entry-title{margin:16px;font-size:20px}
.post .meta{margin:0 16px 12px;color:var(--muted);font-size:12px;letter-spacing:.06em}

/* Footer / Utilidades */
.footer{background:#0d0d0f;border-top:1px solid var(--line);padding:40px 0;color:#a9a9ae}
.fothead{color:#fff;letter-spacing:.14em;margin-bottom:8px}
.fotcont{color:var(--muted)}
.footer .social a{width:36px;height:36px;display:inline-grid;place-items:center;border:1px solid var(--line);border-radius:50%;margin-right:8px;color:#cfcfcf}
.footer .social a:hover{border-color:var(--gold);color:var(--gold)}
.progress-wrap{position:fixed;right:20px;bottom:20px;z-index:60;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:#121214;display:grid;place-items:center;color:var(--gold);box-shadow:var(--shadow);cursor:pointer}
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.reveal{animation:fadeInUp .6s cubic-bezier(.22,1,.36,1) both}
:focus-visible{outline:3px solid rgba(183,155,100,.35);outline-offset:2px}

/* Preloader */
.loader-wrapper{position:fixed;inset:0;display:grid;place-items:center;background:#0d0d0f;z-index:9999}
.loader{width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.15);border-top-color:var(--gold);animation:spin 1s linear infinite}
.loading-text{margin-top:10px;color:#cfcfd4;letter-spacing:.2em;text-transform:uppercase;font-size:12px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Lightbox (dialog) */
#lightbox-dialog::backdrop{background:rgba(0,0,0,.85)}
#lightbox-dialog{border:0;padding:0;background:transparent}
#lightbox-dialog .lb-wrap{position:relative;max-width:92vw;max-height:88vh;margin:auto}
#lightbox-dialog .lb-content{display:grid;place-items:center;background:#000;border-radius:12px;overflow:hidden}
#lightbox-dialog .lb-content>*{max-width:92vw;max-height:88vh}
#lightbox-dialog .lb-close,#lightbox-dialog .lb-prev,#lightbox-dialog .lb-next{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.5);color:#fff;border:1px solid rgba(255,255,255,.2);
  border-radius:999px;width:42px;height:42px;display:grid;place-items:center;cursor:pointer
}
#lightbox-dialog .lb-close{top:0;right:0;transform:none;margin:10px}
#lightbox-dialog .lb-prev{left:-56px}
#lightbox-dialog .lb-next{right:-56px}
@media(max-width:720px){#lightbox-dialog .lb-prev{left:8px}#lightbox-dialog .lb-next{right:8px}}

/* Breakpoints */
@media(max-width:1100px){
  :root{--sidebar-w:160px;--nav-shift:70px}
  .page::before{left:var(--sidebar-w)}
  .navbar .logo{left:calc(var(--sidebar-w) + 16px)}
}
@media(max-width:860px){
  :root{--sidebar-w:0;--nav-shift:0}
  .side-brand{display:none}
  .page{margin-left:0}
  .page::before,.page::after,.frame-corners{display:none}
  .navbar .logo{position:static;transform:none}
  .slider-nav{left:18px}
}


/* ============================
   NAVBAR 100% TRANSPARENTE
   (vira sólida só no scroll)
   ============================ */
.navbar{
  backdrop-filter: none;               /* remove o blur */
  background: transparent;             /* 100% transparente */
  border-bottom-color: transparent;    /* sem linha inicial */
}
.navbar.is-solid{
  backdrop-filter: blur(8px);          /* glass leve ao rolar (opcional) */
  background: rgba(15,15,16,.82);      /* sólido no scroll */
  border-bottom-color: rgba(255,255,255,.08);
}
/* garante que nada do container adicione fundo */
.navbar .container{ background: transparent !important; }

/* =========================================
   HERO FULL-BLEED (cobre todo o lado direito)
   ========================================= */
/* só no hero: some com o "gutter" fixo da direita */
.page.page--hero-fullbleed::after{ display: none; }

/* hero ocupando a viewport inteira */
.bn-hero{
  min-height: 100vh;                   /* antes era ~88vh */
  padding-top: 120px;                  /* respiro p/ a navbar sobreposta */
  padding-bottom: 110px;
}

/* se quiser o hero realmente colado no topo, diminua o padding-top:
   .bn-hero{ padding-top: 80px; } */

/* segurança em mobile (lida bem com barras do navegador) */
@media (max-width: 860px){
  .bn-hero{ min-height: 100svh; }      /* usa viewport segura em iOS/Android */
}

/* as cantoneiras do lado direito continuam visíveis,
   mas agora o slide vai até a borda da viewport */


   /* NAVBAR 100% TRANSPARENTE (sempre) */
.navbar,
.navbar::before,
.navbar .container,
.navbar.is-solid {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

/* garante legibilidade no hero escuro */
.nav-link { color: rgba(255,255,255,.92); }
.nav-link:hover { color:#fff; }
.nav-link.active { color: var(--gold); }


/* ================== SOBRE GILDO ================== */
.about-slice{
  position: relative;
  padding: 100px 0;
  background: var(--panel-2);
}

/* linhas do grid de fundo (vertical + horizontal) */
.about-slice::before{
  content:"";
  position:absolute; inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(
      to right,
      transparent 0 399px,
      rgba(255,255,255,.06) 400px 401px
    ),
    repeating-linear-gradient(
      to bottom,
      transparent 0 239px,
      rgba(255,255,255,.06) 240px 241px
    );
  opacity:.35;
}

/* layout 2 colunas */
.about-grid{
  position:relative; z-index:1;     /* acima do grid */
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 56px;
}
@media (max-width: 980px){
  .about-grid{ grid-template-columns: 1fr; gap: 32px; }
}

/* título com espaçamento entre letras */
.about-title{
  margin: 0 0 22px;
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .42em;
  display:flex; flex-wrap:wrap; gap:.4em;
}
.about-title .word{ line-height:1.1 }
.about-title .word-white{ color:#fff }
.about-title .word-gold{ color: var(--gold) }

/* texto */
.about-copy p{ color:#cfd0d4; margin: 0 0 18px }

/* figura com moldura e linha “técnica” */
.about-figure{ position:relative; margin:0 }
.media-frame{
  position:relative;
  background:#111; border:1px solid var(--line);
  padding: 18px;                      /* “margem” interna da moldura */
  border-radius: 6px;
}
.media-frame::before{
  content:""; position:absolute; inset:0;
  border:1px solid rgba(255,255,255,.05); border-radius: 6px;
  pointer-events:none;
}
.media-frame img{ width:100%; height:auto; display:block }

/* etiqueta inferior */
.media-tag{
  position:absolute;
  left: 50%;
  bottom: -22px;
  transform: translateX(-10%);       /* levemente à direita como no print */
  background:#2a2a2e;
  color:#fff; letter-spacing:.28em;
  text-transform:uppercase; font:700 12px/1 "Didact Gothic",sans-serif;
  padding:14px 26px; border:1px solid var(--line);
  border-radius: 2px;
  white-space:nowrap;
}
@media (max-width:980px){
  .media-tag{ left: 16px; transform:none; }
}



/* ================== NOSSOS PROJETOS ================== */
.projects-slice{
  position: relative;
  padding: 90px 0 110px;
  background: var(--panel-2);
}

/* linhas finas de fundo (vertical e horizontal) */
.projects-slice::before{
  content:"";
  position:absolute; inset:0; pointer-events:none;
  background:
    repeating-linear-gradient(
      to right,
      transparent 0 399px,
      rgba(255,255,255,.06) 400px 401px
    ),
    repeating-linear-gradient(
      to bottom,
      transparent 0 239px,
      rgba(255,255,255,.06) 240px 241px
    );
  opacity:.35;
}

/* título com duas cores e tracking alto */
.projects-title{
  position:relative; z-index:1;
  margin: 0 0 28px;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .42em;
  display:flex; gap:.45em; flex-wrap:wrap;
}
.projects-title .word-white{ color:#fff }
.projects-title .word-gold{ color: var(--gold) }

/* grid de dois cards 16:9 */
.projects-grid{
  position:relative; z-index:1;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
}
@media (max-width: 980px){
  .projects-grid{ grid-template-columns: 1fr; gap: 28px; }
}

/* card / mídia */
.project-card{ display:block }
.project-media{
  position:relative; margin:0; border:1px solid var(--line); background:#111;
  aspect-ratio: 16 / 9;             /* garante 16:9 como no print */
  overflow:hidden;
}
.project-media img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition: transform .8s cubic-bezier(.22,1,.36,1);
}
.project-media::after{              /* overlay escura */
  content:""; position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(0,0,0,.55), rgba(0,0,0,.10));
  transition: opacity .35s ease; opacity:.9;
}
.project-card:hover .project-media img{ transform: scale(1.035) }
.project-card:hover .project-media::after{ opacity: .75 }

/* legenda inferior esquerda */
.project-caption{
  position:absolute; left:22px; bottom:18px; right:22px;
  display:flex; flex-direction:column; gap:8px;
  pointer-events:none;
}
.project-caption .kicker{
  color: var(--gold);
  font: 700 12px/1 "Oswald", sans-serif;
  letter-spacing: .42em; text-transform: uppercase;
  opacity:.95;
}
.project-caption .name{
  color:#fff;
  font: 700 22px/1.1 "Didact Gothic", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-shadow: 0 1px 8px rgba(0,0,0,.25);
}

/* dots decorativos */
.projects-dots{
  position:relative; z-index:1;
  display:flex; gap:10px; justify-content:center; margin-top:24px;
}
.projects-dots button{
  width:7px; height:7px; border-radius:50%;
  border:1px solid var(--gold); background:transparent; opacity:.7;
}
.projects-dots .is-active{ background: var(--gold); opacity:1 }


/* =============== NOSSA ATUAÇÃO =============== */
.svc-slice{
  position:relative;
  padding: 90px 0 110px;
  background: var(--panel-2);
}

/* Linhas verticais e horizontais de fundo (look técnico) */
.svc-slice::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    /* linhas verticais nas quebras de coluna */
    linear-gradient(to right,
      transparent 0 calc(33.333% - .5px),
      rgba(255,255,255,.06) calc(33.333% - .5px) calc(33.333% + .5px),
      transparent calc(33.333% + .5px) calc(66.666% - .5px),
      rgba(255,255,255,.06) calc(66.666% - .5px) calc(66.666% + .5px),
      transparent calc(66.666% + .5px) 100%
    ),
    /* horizontais longas e suaves */
    repeating-linear-gradient(
      to bottom,
      transparent 0 239px,
      rgba(255,255,255,.06) 240px 241px
    );
  opacity:.35;
}

/* Dots decorativos superiores */
.svc-dots{
  display:flex; gap:10px; justify-content:center; margin-bottom:14px;
}
.svc-dots span{
  width:6px; height:6px; border-radius:50%;
  border:1px solid var(--gold); background:transparent; opacity:.7;
}
.svc-dots span:first-child{ background: var(--gold); opacity:1 }

/* Título */
.svc-title{
  margin: 0 0 34px;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .42em;
  display:flex; gap:.45em; flex-wrap:wrap;
}
.svc-title .word-white{ color:#fff }
.svc-title .word-gold{ color: var(--gold) }

/* Grid 3 colunas */
.svc-grid{
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap: 56px;
}
@media (max-width: 1024px){ .svc-grid{ gap: 40px } }
@media (max-width: 900px){ .svc-grid{ grid-template-columns:1fr; gap:28px } }

/* Card */
.svc-item{
  position:relative;
  padding: 28px 28px 48px;
  background: #202024;                 /* levemente diferente do fundo */
  border: 1px solid var(--line);
  min-height: 320px;
  overflow:hidden;
}
.svc-item .svc-icon{
  color: var(--gold);
  margin-bottom: 18px;
}
.svc-head{
  margin: 0 0 10px;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  letter-spacing: .38em;
  font-size: 14px;
  color:#fff;
}
.svc-underline{
  display:block; width:46px; height:2px;
  background: rgba(255,255,255,.10);
  margin: 8px 0 16px;
}
.svc-text{ color:#cfd0d4 }

/* Número gigante no canto inferior direito */
.svc-item::after{
  content: attr(data-idx);
  position:absolute; right: 14px; bottom: 10px;
  font-family: "Oswald", sans-serif; font-weight:700;
  font-size: 54px; line-height:1;
  color:#fff; opacity:.08; letter-spacing:.12em;
}

/* Hover sutil */
.svc-item:hover{ border-color: rgba(255,255,255,.24) }


/* ================== PROMO + TESTIMONIAL ================== */
.promo-slice{ padding:0; background:transparent; }
.promo-hero{
  position:relative; min-height: 520px; display:block;
  background-size: cover; background-position:center;
}
.promo-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.55));
  pointer-events:none;
}

/* Layout interno */
.promo-left{ position:absolute; left:calc(var(--sidebar-w) + 220px); top:140px; z-index:2; }
@media (max-width:1280px){ .promo-left{ left:calc(var(--sidebar-w) + 160px) } }
@media (max-width:980px){ .promo-left{ left:40px; top:120px } }

/* Botão play */
.play-cta{
  width: 160px; height:160px; border-radius:50%;
  background: radial-gradient(ellipse at 50% 50%, rgba(183,155,100,.95) 0%, rgba(183,155,100,.82) 70%, rgba(183,155,100,.65) 100%);
  border:0; display:grid; place-items:center; cursor:pointer; transition: transform .18s ease;
  box-shadow: 0 10px 30px rgba(0,0,0,.28);
}
.play-cta .triangle{
  width:0; height:0; border-left:22px solid #fff; border-top:14px solid transparent; border-bottom:14px solid transparent; margin-left:6px;
}
.play-cta:hover{ transform: translateY(-2px) scale(1.02) }

.play-label{
  margin-top: 18px; color:#fff; letter-spacing:.32em; font:700 13px/1 "Didact Gothic",sans-serif; text-transform:uppercase;
  opacity:.95;
}

/* Card de depoimento (direita) */
.testi-card{
  position:absolute; right: 8vw; top: 110px; z-index:2;
  width: min(660px, 46vw);
  background:#131316; border:1px solid rgba(255,255,255,.08);
  padding: 28px 30px 34px; box-shadow: 0 12px 36px rgba(0,0,0,.35);
}
@media (max-width:980px){ .testi-card{ position:relative; right:auto; top:auto; margin:120px 24px 0; width:auto } }

.testi-title{
  margin:0 0 14px; color:#fff; font-family:"Oswald",sans-serif; font-weight:600;
  letter-spacing:.32em; text-transform:uppercase; font-size:18px;
}
.testi-sep{ height:1px; background:rgba(255,255,255,.08); margin:10px 0 16px }

.testi-track{ position:relative; min-height:160px }
.testi{ opacity:0; visibility:hidden; position:absolute; inset:0; transition:opacity .35s ease }
.testi.is-active{ opacity:1; visibility:visible }

.testi-text{ color:#cfd0d4; margin:0 0 18px }
.testi-author{ display:flex; align-items:center; gap:12px }
.avatar{ width:44px; height:44px; border-radius:50%; object-fit:cover; display:block }
.testi-author .meta strong{ color:#fff; font-weight:700 }
.testi-author .meta span{ color: var(--muted) }

/* citação fantasma */
.quote-ghost{
  position:absolute; right:24px; bottom:20px; font-family:"Georgia",serif;
  font-size:140px; line-height:.3; color:#fff; opacity:.06; pointer-events:none;
}

/* Dots */
.testi-dots{ display:flex; gap:10px; justify-content:center; margin-top:10px }
.testi-dots button{
  width:7px; height:7px; border-radius:50%; border:0; background:#7a7a7e; opacity:.85; cursor:pointer
}
.testi-dots .active{ background: var(--gold); opacity:1 }

/* Faixa inferior com ícones */
.promo-icons{ background:#111114; border-top:1px solid rgba(255,255,255,.06) }
.promo-icons-row{ display:flex; gap:80px; justify-content:center; padding:28px 0 }
.promo-icons .ico{
  color: var(--gold); width:56px; height:56px; display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.10); border-radius:50%;
  background:transparent;
}
.promo-icons .ico svg{ width:30px; height:30px; display:block }
@media (max-width:780px){
  .promo-icons-row{ gap:24px }
  .promo-icons .ico{ width:48px; height:48px }
  .promo-icons .ico svg{ width:26px; height:26px }
}

/* Acessibilidade */
.sr-only{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0 }


/* ===== Navbar com dropdowns (autoral) ===== */
:root{
  /* ajuste conforme a sua sidebar fixa */
  --sidebar-w: 200px;
  --page-max: 1200px;
  --gold: #b79b64;
  --muted:#a7a7ab;
}

/* container principal, transparente 100% */
.bn-navbar{
  position:absolute; left:var(--sidebar-w); top:0; width:calc(100% - var(--sidebar-w));
  z-index:99; background:transparent; border:0; padding:0;
}
@media (max-width:860px){
  .bn-navbar{ left:0; width:100% }
}

.bn-nav__inner{
  max-width: var(--page-max);
  margin: 0 auto;
  padding: 0 24px;
  height: 78px;
  display:flex; align-items:center; justify-content:center;
  transform: translateX(110px); /* leve deslocamento, como no demo */
}
@media (max-width:1024px){
  .bn-nav__inner{ transform:none }
}

/* menu raiz */
.bn-menu{ list-style:none; display:flex; gap:30px; margin:0; padding:0; background:transparent }
.bn-item{ position:relative }
.bn-link{
  color:#e7e7ea; opacity:.92; text-decoration:none;
  text-transform:uppercase; letter-spacing:.22em;
  font:600 12px/1 "Didact Gothic",system-ui,sans-serif;
  padding:8px 0; display:inline-flex; align-items:center; gap:8px;
}
.bn-link:hover{ opacity:1 }
.bn-link.is-active{ color: var(--gold) }

/* caret */
.caret{
  width:0; height:0; display:inline-block; margin-left:6px;
  border-left:4px solid transparent; border-right:4px solid transparent; border-top:6px solid rgba(255,255,255,.85);
  transform: translateY(2px);
}

/* dropdown (desktop) */
.has-drop .bn-drop{
  position:absolute; top:100%; left:0;
  min-width: 220px;
  display:none;
  background:#141416; border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:10px 12px; box-shadow:0 12px 36px rgba(0,0,0,.35);
}
.has-drop:hover > .bn-drop{ display:block }
.bn-drop li{ list-style:none }
.bn-drop a{
  display:block; padding:10px 12px; border-radius:8px; color:#d6d6da; letter-spacing:.08em; text-decoration:none;
}
.bn-drop a:hover{ color:#fff; background:rgba(255,255,255,.06) }

/* toggle mobile */
.bn-toggle{
  margin-left:auto; display:none; width:42px; height:42px; border-radius:6px;
  border:1px solid rgba(255,255,255,.35); background:transparent; color:#fff; position:relative;
}
.bn-toggle__bar,
.bn-toggle__bar::before,
.bn-toggle__bar::after{
  content:""; position:absolute; left:50%; width:18px; height:2px; background:#fff; transform:translateX(-50%);
}
.bn-toggle__bar{ top:50% }
.bn-toggle__bar::before{ top:-6px }
.bn-toggle__bar::after{ top:6px }

/* comportamento mobile */
@media (max-width:1024px){
  .bn-toggle{ display:block }
  .bn-menu{
    position:absolute; right:24px; top:74px; flex-direction:column; gap:0;
    display:none; background:#141416; border:1px solid rgba(255,255,255,.08);
    border-radius:12px; padding:10px 12px;
  }
  .bn-menu.is-open{ display:flex }
  .bn-drop{ position:static; display:none; background:transparent; border:0; padding:6px 0; box-shadow:none; min-width:unset }
  .has-drop.open > .bn-drop{ display:block }
  .bn-drop__btn{ background:transparent; border:0; cursor:pointer; padding:10px 0 }
}

/* acessibilidade */
.bn-navbar .sr-only{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0 }


/* ===== NAVBAR – Bauen-like com bloco escuro do logo e corner direito ===== */
:root{
  --sidebar-w: 200px;          /* mesma largura da sua sidebar fixa */
  --page-max: 1200px;
  --logo-block-w: 125px;       /* largura visual do bloco do logo na navbar */
  --nav-h: 78px;
  --gold: #b79b64; --muted:#a7a7ab;
}

/* header transparente (fica sólida ao rolar) */
.nav-bauen{
  position:absolute;
  left: var(--sidebar-w);
  top: 0;
  width: calc(100% - var(--sidebar-w));
  height: var(--nav-h);
  z-index: 90;
  background: transparent;
  transition: background .35s ease, box-shadow .35s ease, transform .25s ease;
}
@media (max-width: 860px){
  .nav-bauen{ left:0; width:100% }
}

.nav-bauen.is-sticky{
  position: fixed;
  background:#1b1b1f; /* faixa sólida no scroll */
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}

/* linha de conteúdo centralizada */
.nav-bauen .nav-inner{
    position: relative;
    max-width: var(--page-max);
    margin: 0;
    height: 100%;
    padding: 0 24px;
    display: flex
;
    align-items: center;
    justify-content: center;
    transform: translateX(110px);
}
@media (max-width:1024px){
  .nav-bauen .nav-inner{ transform:none }
}

/* bloco escuro do logo (fica dentro da navbar) */
.nav-bauen .nav-logo{
  position:absolute; left:0; top:0;
  width: var(--logo-block-w); height:100%;
  background:#1b1b1f;
  display:flex; align-items:center; justify-content:center;
  padding-left: 10px; padding-right: 10px;
}
.nav-bauen .nav-logo img{ height: 100px; width:auto; display:block }

/* menu raiz */
.nav-menu{ list-style:none; display:flex; gap:30px; margin:0;     padding: 0 0 0 950px; }
.nav-menu .link{
  color:#e7e7ea; opacity:.92; text-decoration:none;
  text-transform:uppercase; letter-spacing:.22em;
  font:600 12px/1 "Didact Gothic",system-ui,sans-serif;
  padding:8px 0; display:inline-flex; align-items:center; gap:8px;
}
.nav-menu .link:hover{ opacity:1 }
.nav-menu .link.is-active{ color: var(--gold) }

/* caret dropdown */
.caret{
  width:0; height:0; display:inline-block; margin-left:6px;
  border-left:4px solid transparent; border-right:4px solid transparent; border-top:6px solid rgba(255,255,255,.9);
  transform: translateY(2px);
}

/* dropdown desktop */
.has-drop .drop{
  position:absolute; top:100%; left:0;
  min-width: 220px; display:none;
  background:#141416; border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:10px 12px;
  box-shadow: 0 12px 36px rgba(0,0,0,.35);
}
.has-drop:hover > .drop{ display:block }
.drop li{ list-style:none }
.drop a{
  display:block; padding:10px 12px; border-radius:8px; color:#d6d6da; letter-spacing:.08em; text-decoration:none;
}
.drop a:hover{ color:#fff; background:rgba(255,255,255,.06) }

/* botão mobile */
.nav-toggle{
  margin-left:auto; display:none;
  width:42px; height:42px; border-radius:6px;
  border:1px solid rgba(255,255,255,.35);
  background:transparent; color:#fff; position:absolute; right:24px;
}
.nav-toggle .bar,
.nav-toggle .bar::before,
.nav-toggle .bar::after{
  content:""; position:absolute; left:50%;
  width:18px; height:2px; background:#fff; transform:translateX(-50%);
}
.nav-toggle .bar{ top:50% }
.nav-toggle .bar::before{ top:-6px }
.nav-toggle .bar::after{ top:6px }

/* corner decorativo no topo-direito */
.nav-corner{
  position:absolute; right:24px; top:10px;
  width:88px; height:58px;
  border:1px solid rgba(255,255,255,.18);
  border-left:none; border-bottom:none;
  pointer-events:none; opacity:.8;
  transition: opacity .25s ease, border-color .25s ease;
}
.nav-bauen.is-sticky .nav-corner{ opacity:.5; border-color: rgba(255,255,255,.12) }

/* responsivo / mobile */
@media (max-width:1024px){
  .nav-toggle{ display:block }
  .nav-menu{
    position:absolute; right:24px; top:calc(var(--nav-h) - 4px);
    flex-direction:column; gap:0; display:none;
    background:#141416; border:1px solid rgba(255,255,255,.08);
    border-radius:12px; padding:10px 12px; z-index:5;
  }
  .nav-menu.is-open{ display:flex }

  .has-drop .drop{ position:static; display:none; background:transparent; border:0; padding:6px 0; box-shadow:none; min-width:unset }
  .has-drop.open > .drop{ display:block }
  .drop__btn{ background:transparent; border:0; cursor:pointer; padding:10px 0 }
}

/* quando a sidebar some no mobile */
@media (max-width:860px){
  .nav-bauen .nav-logo{ width: 180px }
}


/* ===== Sidebar fixa à esquerda (estilo Bauen) ===== */
:root{
  /* mantenha esse token igual ao que a navbar usa */
  --sidebar-w: 200px;
}

/* fixa a barra lateral e dá 100% de altura */
.side-brand{
  position: fixed;
  inset: 0 auto 0 0;           /* top:0; right:auto; bottom:0; left:0 */
  width: var(--sidebar-w);
  background: #1b1b1f;
  border-right: 1px solid rgba(255,255,255,.06);
  display: grid;
  grid-template-rows: 120px 1fr auto;  /* topo (logo), espaço, redes */
  z-index: 80;                         /* abaixo da navbar (que está em 90) */
}

/* bloco do logo centralizado */
.side-logo{
  display: grid;
  place-items: center;
  padding: 16px 0 0;
  text-align: center;
}
.side-logo img{
  width: 160px; max-width: 80%; height: auto; display: block;
  filter: saturate(.9);
}
.brand-label{
  margin-top: 8px;
  line-height: 1.1;
}
.brand-name{
  color: #e9e9ed;
  letter-spacing: .18em;
}
.brand-tag{
  color: #a6a6ab;
  letter-spacing: .25em;
  font-size: 11px;
}

/* redes sociais empilhadas na base, como no demo */
.side-social{
  align-self: end;
  display: grid;
  justify-content: center;
  gap: 14px;
  padding: 0 0 26px;
}
.side-social a{
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border: 1px solid #2a2a2e; border-radius: 50%;
  color: #cfcfd4; font-weight: 700; text-decoration: none;
  transition: border-color .2s ease, color .2s ease;
}
.side-social a:hover{ border-color: #b79b64; color: #b79b64 }

/* empurra todo o conteúdo para a direita da sidebar */
.page{ margin-left: var(--sidebar-w); }

/* molduras/corners à direita não devem bloquear clique */
.frame-corners{ pointer-events: none }

/* responsivo: some a sidebar e libera o conteúdo em telas pequenas */
@media (max-width: 860px){
  .side-brand{ display:none }
  .page{ margin-left: 0 }         /* volta a ocupar 100% */
}


.barraEsquerdaIcons{
    inset: 0 auto 0 0;
    width: var(--sidebar-w);
    background: #1b1b1f;
    border-right: 1px solid rgba(255, 255, 255, .06);
    display: grid
;
    grid-template-rows: 120px 1fr auto;
    z-index: 80;


}/* Grid em 2 colunas: barra + conteúdo  */
.layout-2col{
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
}

/* A BARRA NÃO é fixa – fica no fluxo da coluna esquerda */
.side-brand{
  position: static;       /* <— importante: não-fixed */
  width: 100%;
  background: #1b1b1f;
  border-right: 1px solid rgba(255,255,255,.06);
  
}

/* conteúdo interno da barra */
.barraEsquerdaIcons{
  display: grid;
  grid-template-rows: 140px 1fr auto;
  min-height: 100%;
}
.side-logo{
  display:grid; place-items:center;
  padding-top: 16px; text-align:center;
}
.side-logo img{ width: 160px; max-width: 90%; height:auto }
.brand-label{ margin-top: 8px; line-height:1.1 }
.brand-name{ color:#e9e9ed; letter-spacing:.18em }
.brand-tag{ color:#a6a6ab; letter-spacing:.25em; font-size:11px }

.side-social{
  align-self:end; display:grid; gap:14px; justify-content:center; padding: 550px 0 26px 0;;
}
.side-social a{
  width:36px; height:36px; display:grid; place-items:center;
  border:1px solid #2a2a2e; border-radius:50%; color:#cfcfd4; font-weight:700; text-decoration:none;
}
.side-social a:hover{ border-color:#b79b64; color:#b79b64 }

/* O conteúdo não precisa mais de margin-left */
.page{ margin-left: 0 }

/* A NAVBAR volta a ocupar 100% (não compensa sidebar) */
.nav-bauen{
  left: 0;
  width: 100%;
}

/* responsivo: em telas menores, vira 1 coluna */
@media (max-width: 860px){
  .layout-2col{ grid-template-columns: 1fr; }
  /* Se quiser esconder a barra no mobile, descomente: */
  /* .side-brand{ display:none } */
}

/* Logo da navbar invisível no topo; aparece só quando .is-sticky */
.nav-bauen .nav-logo{
  opacity: 0;
  pointer-events: none;              /* não bloqueia cliques no hero */
  background: transparent;           /* sem bloco escuro no topo */
  border-right-color: transparent;
  transform: translateY(-6px) scale(.98);
  transition:
    opacity .25s ease,
    transform .25s ease,
    background .25s ease,
    border-color .25s ease;
}

/* Quando rola a página (navbar ganha .is-sticky), mostra o logo/bloco */
.nav-bauen.is-sticky .nav-logo{
  opacity: 1;
  pointer-events: auto;
  background: #1b1b1f;               /* faixa escura do logo */
  transform: none;
}

/* Esconde o “corner” direito no topo e mostra apenas no sticky */
.nav-bauen .nav-corner{
  opacity: 0;
  transition: opacity .25s ease, border-color .25s ease;
}
.nav-bauen.is-sticky .nav-corner{
  opacity: .75;
  border-color: rgba(255,255,255,.18);
}

/* (opcional) reforço: navbar realmente transparente no topo */
.nav-bauen{
  background: transparent;
  box-shadow: none;
}
.nav-bauen.is-sticky{
  background: #1b1b1f;               /* sólida no scroll */
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}


.hero-bauen .caption-box .title{ text-shadow: 0 2px 12px rgba(0,0,0,.35); }
.hero-bauen .caption-box .desc { text-shadow: 0 1px 8px rgba(0,0,0,.25); }

/* ================== CONTATO ================== */
.contact-slice{ background: var(--panel-2); padding: 90px 0 110px; position:relative; }
.contact-slice::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.35;
  background:
    repeating-linear-gradient(to right, transparent 0 399px, rgba(255,255,255,.06) 400px 401px),
    repeating-linear-gradient(to bottom, transparent 0 239px, rgba(255,255,255,.06) 240px 241px);
}
.contact-head{ position:relative; z-index:1; text-align:center; margin-bottom:28px; }
.contact-title{
  margin:0 0 8px; display:flex; gap:.45em; justify-content:center; flex-wrap:wrap;
  font-family:"Oswald",sans-serif; font-weight:700; text-transform:uppercase; letter-spacing:.42em;
}
.contact-title .word-white{ color:#fff } .contact-title .word-gold{ color:var(--gold) }
.contact-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns: 1.1fr .9fr; gap:28px;
}
@media (max-width: 980px){ .contact-grid{ grid-template-columns:1fr; } }

.contact-form.card{ padding:22px 22px 24px; }
.form-title{ margin:0 0 14px; letter-spacing:.28em; text-transform:uppercase; font-family:"Oswald",sans-serif; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:720px){ .form-row{ grid-template-columns:1fr; } }

.field{ display:grid; gap:8px; }
.field label{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:#c9c9cd; }
.field input, .field textarea{
  width:100%; border:1px solid var(--line); background:#111114; color:#e9e9ed; border-radius:10px;
  padding:12px 14px; font:16px/1.4 "Didact Gothic",sans-serif;
}
.field textarea{ resize:vertical }
.field input::placeholder, .field textarea::placeholder{ color:#8d8d92 }
.field input:focus, .field textarea:focus{ outline:0; border-color:var(--gold); box-shadow:0 0 0 3px rgba(183,155,100,.12); }

.check{ display:flex; align-items:flex-start; gap:10px; color:#cfd0d4; font-size:14px; margin:6px 0 12px; }
.check input{ margin-top:3px; accent-color:var(--gold); }

.contact-info{ display:grid; gap:18px; }
.info-card h3{ margin:0 0 8px; letter-spacing:.28em; text-transform:uppercase; font-family:"Oswald",sans-serif; }
.info-list{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.info-list li{ display:flex; gap:12px; align-items:flex-start; }
.info-list .ico{ width:34px; height:34px; display:grid; place-items:center; border:1px solid var(--line); border-radius:50%; color:var(--gold); background:#111; }
.info-list a{ color:#e9e9ed; text-decoration:none; } .info-list a:hover{ color:var(--gold); }

.map{ padding:0; overflow:hidden; }
.map .map-placeholder{
  aspect-ratio: 16/9; display:grid; place-items:center; color:#b9bac0;
  background: radial-gradient(70% 70% at 50% 50%, #0f0f10, #0b0b0d);
  border:1px solid var(--line); border-radius:var(--radius);
}

/* ================== FOOTER ================== */
.site-footer{ background:#0d0d0f; color:#a9a9ae; border-top:1px solid var(--line); }
.footer-top{
  display:grid; grid-template-columns: 1.1fr .6fr .6fr; gap:28px; padding:42px 0;
}
@media (max-width:980px){ .footer-top{ grid-template-columns:1fr; } }

.brand{ line-height:1.1; margin-bottom:8px; }
.brand-mark{ color:#fff; font-weight:700; letter-spacing:.28em; text-transform:uppercase; }
.brand-sub{ color:var(--gold); letter-spacing:.35em; text-transform:uppercase; font-size:12px; }
.muted{ color:var(--muted); }

.footer-col h4{
  margin:0 0 10px; color:#fff; font-family:"Oswald",sans-serif; text-transform:uppercase; letter-spacing:.28em;
}
.footer-links, .footer-contacts{ list-style:none; margin:0; padding:0; display:grid; gap:8px; }
.footer-links a{ color:#cfd0d4; text-decoration:none; } .footer-links a:hover{ color:#fff; }
.footer-contacts a{ color:#e9e9ed; text-decoration:none; } .footer-contacts a:hover{ color:var(--gold); }

.footer-social{ display:flex; gap:10px; margin-top:12px; }
.footer-social a{
  width:36px; height:36px; display:grid; place-items:center; border:1px solid var(--line); border-radius:50%; color:#cfcfcf;
}
.footer-social a:hover{ border-color:var(--gold); color:var(--gold); }

.footer-bottom{ border-top:1px solid var(--line); padding:14px 0; text-align:center; color:#9c9ca1; }


/* ===== Mobile tweaks ===== */
@media (max-width: 860px){
  .side-logo{ display: none !important; }
  /* 1) esconder os ícones sociais da barra lateral no mobile */
  .side-social{ display: none !important; }

  /* (opcional) se também quiser esconder o logo da barra lateral:
     .side-logo, .brand-label{ display:none !important; } */

  /* 2) dar respiro lateral pros textos no mobile */
  .caption-wrap{ padding-inline: clamp(16px, 5vw, 28px); } /* HERO */
  .section .container,
  .promo-icons .container,
  .footer .container .site-footer{
    padding-inline: clamp(16px, 5vw, 28px);
  }

  .site-footer{
    padding-inline: clamp(16px, 5vw, 28px);
  }
}


/* ↓ card um pouco mais baixo */
.testi-card{ top: 190px !important; }

/* ↓ botão de play centralizado; o top será ajustado via JS */
.promo-left{
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  text-align: center;
  z-index: 3;
}
.play-label{ text-align:center; margin-top: 12px; }

/* mobile: mantém centralizado e com respiro */
@media (max-width: 980px){
  .testi-card{ top: 120px !important; margin: 0 16px; }
}


/* ↓ tablet */
@media (max-width: 980px){
  .play-cta{ width:120px; height:120px; }
  .play-cta .triangle{
    border-left-width:18px;
    border-top-width:12px;
    border-bottom-width:12px;
  }
}

/* ↓ phones */
@media (max-width: 640px){
  .play-cta{ width:65px; height:65px; }
  .play-cta .triangle{
    border-left-width:14px;
    border-top-width:9px;
    border-bottom-width:9px;
  }
  .play-label{ font-size:12px; letter-spacing:.26em; }
}


/* Desktop: fixa o play-cta no ponto desejado (ajuste fino: left/top) */
@media (min-width: 981px){
  .promo-left{
    left: calc(var(--sidebar-w) + 120px) !important;  /* ← ajuste fino */
    top: 220px !important;                             /* ← ajuste fino */
    transform: none !important;
    z-index: 2;
  }
}


/* mantém o estilo do botão que já passamos */
.whatsapp-fab{
  position: fixed;
  right: 5px;
  bottom: 88px;          /* fica acima do back-to-top */
  width: 75px;
  height: 75px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  z-index: 80;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  text-decoration: none;
}
.whatsapp-fab:hover{
  transform: translateY(-3px);
}

/* o GIF dentro do botão */
.whatsapp-fab .whatsapp-icon{
  width: 100px;
  height: 100px;
  display: block;
  object-fit: contain;   /* garante que não distorce */
  pointer-events: none;  /* clique acerta o link */
}

/* mobile: botão um pouco menor */
@media (max-width: 860px){
  .whatsapp-fab{
    right: 16px;
    bottom: 86px;
    width: 52px;
    height: 52px;
  }
  .whatsapp-fab .whatsapp-icon{
    width: 24px;
    height: 24px;
  }
}
