/* ============================================
   TURN ON CENOGRAFIA — STYLE
   Otimizado para visualização 16:9 (desktop/TV)
   Tipografia: Futura (apenas variações de peso)
   ============================================ */

/* ===== FONTES FUTURA ===== */
@font-face{
  font-family:'Futura';
  src:url('assets/fonts/FuturaStd-Light.otf') format('opentype');
  font-weight:300;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Futura';
  src:url('assets/fonts/FuturaStd-Book.otf') format('opentype');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Futura';
  src:url('assets/fonts/FuturaStd-Medium.otf') format('opentype');
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Futura';
  src:url('assets/fonts/FuturaStd-Bold.otf') format('opentype');
  font-weight:700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Futura';
  src:url('assets/fonts/FuturaStd-Heavy.otf') format('opentype');
  font-weight:800;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Futura';
  src:url('assets/fonts/FuturaStd-ExtraBold.otf') format('opentype');
  font-weight:900;font-style:normal;font-display:swap;
}

/* ===== VARIÁVEIS ===== */
:root{
  --yellow:#FCCE2B;
  --black:#282828;
  --white:#FAFAF7;
  --grey:#9A9A95;
  --grey-light:#E5E5E0;
  --font:'Futura','Trebuchet MS',sans-serif;
  --radius:14px; /* Cantos arredondados padrão */
}

/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box}
*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  background:var(--white);
  color:var(--black);
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea{font-family:inherit}

/* ============================================
   NAVBAR
   ============================================ */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:24px 48px;
  transition:padding .4s ease, background .4s ease;
  pointer-events:none;
}
.nav.scrolled{
  padding:16px 48px;
  background:rgba(40,40,40,.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.nav > *{pointer-events:auto}

.nav-logo-link{
  display:block;
  line-height:0;
  z-index:102; /* sempre por cima do overlay */
  position:relative;
}
.nav-logo-img{
  height:56px;
  width:auto;
  transition:height .4s ease;
}
.nav.scrolled .nav-logo-img{
  height:42px;
}

.nav-links{
  display:flex;
  gap:36px;
  list-style:none;
}
.nav-links a{
  color:var(--white);
  font-size:12px;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  position:relative;
  padding:6px 0;
  transition:color .3s ease;
}
.nav-links a::after{
  content:'';
  position:absolute;
  left:0;bottom:0;
  width:0;height:1px;
  background:var(--yellow);
  transition:width .4s cubic-bezier(.2,.8,.2,1);
}
.nav-links a:hover{color:var(--yellow)}
.nav-links a:hover::after{width:100%}

/* ===== BOTÃO HAMBÚRGUER (só mobile) ===== */
.nav-burger{
  display:none; /* escondido no desktop */
  width:32px;
  height:32px;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  cursor:pointer;
  padding:0;
  background:transparent;
  border:none;
  position:relative; /* necessário pro z-index funcionar */
  z-index:102;
}
.nav-burger span{
  display:block;
  width:24px;
  height:2px;
  background:var(--white);
  border-radius:2px;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), opacity .25s, background .3s;
  transform-origin:center;
}
.nav-burger.is-open span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}
.nav-burger.is-open span:nth-child(2){
  opacity:0;
}
.nav-burger.is-open span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

/* ============================================
   HERO COM VÍDEO FULLSCREEN
   ============================================ */
.hero{
  position:relative;
  width:100%;
  height:100vh;
  min-height:600px;
  overflow:hidden;
  background:var(--black);
}
.hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
}

.hero-placeholder{
  position:absolute;
  inset:0;
  z-index:0;
  background:
    radial-gradient(ellipse at 30% 40%,rgba(252,206,43,.18) 0%,transparent 50%),
    radial-gradient(ellipse at 70% 60%,rgba(252,206,43,.10) 0%,transparent 60%),
    linear-gradient(135deg,#181818 0%,#2e2e2e 50%,#181818 100%);
  overflow:hidden;
}
.hero-placeholder::before{
  content:'';
  position:absolute;inset:0;
  background:repeating-linear-gradient(
    0deg,
    transparent 0px,
    transparent 2px,
    rgba(255,255,255,.012) 2px,
    rgba(255,255,255,.012) 4px
  );
}
.spotlight{
  position:absolute;
  border-radius:50%;
  filter:blur(80px);
  mix-blend-mode:screen;
}
.spot1{
  width:700px;height:700px;
  background:radial-gradient(circle,var(--yellow) 0%,transparent 70%);
  top:-220px;left:-220px;
  opacity:.45;
  animation:spotMove1 14s ease-in-out infinite;
}
.spot2{
  width:900px;height:900px;
  background:radial-gradient(circle,#ff9430 0%,transparent 70%);
  bottom:-320px;right:-220px;
  opacity:.28;
  animation:spotMove2 18s ease-in-out infinite;
}
.spot3{
  width:480px;height:480px;
  background:radial-gradient(circle,#fff 0%,transparent 70%);
  top:40%;left:50%;
  opacity:.10;
  animation:spotMove3 22s ease-in-out infinite;
}
@keyframes spotMove1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(220px,160px) scale(1.2)}}
@keyframes spotMove2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-180px,-120px) scale(1.3)}}
@keyframes spotMove3{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-30%,-60%) scale(1.5)}}

.hero-overlay{
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(180deg,
    rgba(40,40,40,.55) 0%,
    rgba(40,40,40,.25) 30%,
    rgba(40,40,40,.25) 70%,
    rgba(40,40,40,.65) 100%);
  pointer-events:none;
}

.hero-content{
  position:absolute;
  inset:0;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 48px;
}
.hero-tagline{
  font-family:var(--font);
  font-weight:300;
  /* Reduzido em 50%, em uma linha só */
  font-size:clamp(28px,4.2vw,72px);
  color:var(--white);
  letter-spacing:.04em;
  text-align:center;
  line-height:1;
  text-transform:uppercase;
  white-space:nowrap; /* força uma linha */
  opacity:0;
  animation:fadeUp 1.4s .3s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}

/* ============================================
   PROPÓSITO — TUDO BOLD COM ESPAÇAMENTO
   ============================================ */
.proposito{
  background:var(--white);
  padding:160px 48px;
}
.proposito-grid{
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto;
  gap:80px;
  align-items:end;
}
.proposito-text{
  font-family:var(--font);
  font-weight:700;
  /* Reduzido em 20% */
  font-size:clamp(22px,2.7vw,43px);
  line-height:1.2;
  letter-spacing:-.005em;
  color:var(--black);
  max-width:1100px;
  text-transform:uppercase;
}
.proposito-btn{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:14px 28px;
  border:1px solid var(--black);
  border-radius:100px;
  font-size:11px;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--black);
  background:transparent;
  white-space:nowrap;
  transition:all .4s cubic-bezier(.2,.8,.2,1);
}
.proposito-btn:hover{
  background:var(--black);
  color:var(--yellow);
  gap:18px;
}
.proposito-btn .arrow{
  display:inline-block;
  font-weight:300;
  transition:transform .4s ease;
}
.proposito-btn:hover .arrow{transform:translateX(4px)}

/* ============================================
   GALERIA DE CLIENTES
   ============================================ */
.galeria-section{
  background:var(--white);
  padding:0 48px 160px;
}
.section-tag{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-size:11px;
  font-weight:500;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--black);
}
.section-tag::before{
  content:'';
  width:36px;height:1px;
  background:var(--yellow);
}
.section-tag.dark{color:var(--white)}

.galeria{
  /* reduzido em 30% — antes max-width 1400, agora 980 */
  max-width:980px;
  margin:0 auto;
  display:grid;
  /* Grid de 6 colunas: horizontais ocupam 3, verticais ocupam 2 */
  grid-template-columns:repeat(6,1fr);
  gap:24px;
  align-items:start;
}
.galeria-header{
  max-width:980px;
  margin:0 auto 60px;
}
.cliente{cursor:pointer}

/* Horizontais ocupam metade da largura (3 de 6 colunas) */
.cliente.is-horizontal{
  grid-column:span 3;
}
.cliente.is-horizontal .cliente-media{
  aspect-ratio:16/9;
}

/* Verticais ocupam um terço (2 de 6 colunas) */
.cliente.is-vertical{
  grid-column:span 2;
}
.cliente.is-vertical .cliente-media{
  aspect-ratio:9/16;
}

.cliente-media{
  position:relative;
  width:100%;
  overflow:hidden;
  background:var(--black);
  margin-bottom:18px;
  border-radius:var(--radius);
}
.cliente-media video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:2;
  transition:transform .9s cubic-bezier(.2,.8,.2,1);
}
.cliente:hover .cliente-media video{transform:scale(1.04)}
.cliente-placeholder{
  position:absolute;
  inset:0;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#1f1f1f 0%,#2e2e2e 100%);
  color:rgba(252,206,43,.25);
  font-size:32px;
  font-weight:700;
  letter-spacing:.1em;
  user-select:none;
}
.cliente-nome{
  font-family:var(--font);
  font-weight:400;
  font-size:18px;
  letter-spacing:.05em;
  color:var(--black);
}

/* ============================================
   SERVIÇOS / TÓPICOS
   Título em UMA LINHA, escala 50% menor
   ============================================ */
.servicos{
  background:var(--black);
  color:var(--white);
  padding:160px 48px;
}
.servicos-titulo{
  font-family:var(--font);
  font-weight:300;
  font-size:clamp(48px,8vw,140px);
  text-align:center;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--white);
  line-height:1;
  margin-bottom:120px;
  max-width:1400px;
  margin-left:auto;
  margin-right:auto;
  /* removido white-space:nowrap pra permitir quebra em duas linhas */
}
.servicos-grid{
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.servico{
  padding:48px 40px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius); /* CANTOS ARREDONDADOS */
  transition:all .5s cubic-bezier(.2,.8,.2,1);
  position:relative;
  overflow:hidden;
}
.servico::before{
  content:'';
  position:absolute;
  left:0;top:0;
  width:100%;height:2px;
  background:var(--yellow);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.servico:hover{
  background:rgba(252,206,43,.04);
  border-color:rgba(252,206,43,.25);
}
.servico:hover::before{transform:scaleX(1)}
.servico:hover .servico-num{color:var(--yellow)}

.servico-num{
  font-family:var(--font);
  font-weight:300;
  font-size:14px;
  letter-spacing:.3em;
  color:rgba(250,250,247,.4);
  margin-bottom:32px;
  transition:color .4s ease;
}
.servico-nome{
  font-family:var(--font);
  font-weight:400;
  font-size:clamp(28px,3vw,42px);
  letter-spacing:.02em;
  color:var(--white);
  margin-bottom:24px;
  line-height:1.1;
}
.servico-desc{
  font-family:var(--font);
  font-weight:400;
  font-size:16px;
  line-height:1.7;
  color:rgba(250,250,247,.7);
  max-width:520px;
}

/* ============================================
   SOBRE NÓS
   ============================================ */
.sobre{
  background:var(--white);
  padding:160px 48px;
}
.sobre-grid{
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:200px 1fr;
  gap:80px;
  align-items:start;
}
.sobre-grid .section-tag{color:var(--black)}
.sobre-grid .section-tag::before{background:var(--yellow)}

.sobre-content{max-width:880px}
.sobre-titulo{
  font-family:var(--font);
  font-weight:300;
  font-size:clamp(32px,3.6vw,52px);
  line-height:1.2;
  letter-spacing:-.005em;
  color:var(--black);
  margin-bottom:48px;
}
.sobre-titulo em{
  font-style:normal;
  font-weight:700;
}
.sobre-texto{
  font-family:var(--font);
  font-weight:400;
  font-size:17px;
  line-height:1.75;
  color:#404040;
  margin-bottom:24px;
}
.sobre-texto:last-child{margin-bottom:0}

/* Big Numbers */
.big-numbers{
  max-width:1400px;
  margin:140px auto 0;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:36px;
  padding-top:60px;
  border-top:1px solid var(--grey-light);
}
.bignum{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.bignum-valor{
  font-family:var(--font);
  font-weight:300;
  font-size:clamp(40px,4vw,68px);
  line-height:1;
  letter-spacing:-.03em;
  color:var(--black);
}
.bignum-label{
  font-family:var(--font);
  font-weight:500;
  font-size:11px;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--grey);
}

/* ============================================
   PROJETO EM DESTAQUE
   ============================================ */
.destaque{
  background:var(--black);
  padding:120px 48px;
  color:var(--white);
}
.destaque-header{
  max-width:1400px;
  margin:0 auto 48px;
}
.destaque-header .section-tag{color:var(--white)}
.destaque-header .section-tag::before{background:var(--yellow)}

.destaque-video-wrap{
  position:relative;
  /* reduzido em 30% — antes 1400, agora 980 */
  max-width:980px;
  margin:0 auto;
  display:block;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  background:#1a1a1a;
  border-radius:var(--radius);
  cursor:pointer;
  padding:0;
  border:none;
  font:inherit;
  color:inherit;
  text-align:left;
}
.destaque-video-wrap:focus-visible{
  outline:2px solid var(--yellow);
  outline-offset:4px;
}
.destaque-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:2;
  transition:transform .8s cubic-bezier(.2,.8,.2,1), filter .4s ease;
}
.destaque-placeholder{
  position:absolute;
  inset:0;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#1a1a1a 0%,#2a2a2a 100%);
}
.destaque-placeholder-text{
  font-family:var(--font);
  font-weight:300;
  font-size:80px;
  color:rgba(252,206,43,.18);
  letter-spacing:.02em;
  text-align:center;
  line-height:1;
  user-select:none;
}
/* Botão de play sobreposto no vídeo de destaque */
.destaque-play{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:4;
  width:88px;height:88px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--yellow);
  color:var(--black);
  border-radius:50%;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
  transition:transform .4s cubic-bezier(.2,.8,.2,1), background .3s ease;
  pointer-events:none;
}
.destaque-play svg{
  margin-left:4px; /* ajuste óptico do triângulo */
}
.destaque-hint{
  position:absolute;
  bottom:20px;left:50%;
  transform:translateX(-50%) translateY(8px);
  z-index:4;
  font-family:var(--font);
  font-weight:500;
  font-size:11px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--white);
  background:rgba(0,0,0,.55);
  padding:8px 16px;
  border-radius:100px;
  opacity:0;
  transition:opacity .4s ease, transform .4s ease;
  pointer-events:none;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.destaque-video-wrap:hover .destaque-video{
  transform:scale(1.03);
  filter:brightness(.75);
}
.destaque-video-wrap:hover .destaque-play{
  transform:translate(-50%,-50%) scale(1.08);
}
.destaque-video-wrap:hover .destaque-hint{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
.destaque-cta-wrap{
  max-width:980px;
  margin:48px auto 0;
  display:flex;
  justify-content:flex-end;
}
.destaque-cta{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:14px 28px;
  border:1px solid var(--white);
  border-radius:100px;
  font-size:11px;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--white);
  transition:all .4s cubic-bezier(.2,.8,.2,1);
}
.destaque-cta:hover{
  background:var(--yellow);
  border-color:var(--yellow);
  color:var(--black);
  gap:18px;
}
.destaque-cta .arrow{
  display:inline-block;
  font-weight:300;
  transition:transform .4s ease;
}
.destaque-cta:hover .arrow{transform:translateX(4px)}

/* ============================================
   CONTATO
   ============================================ */
.contato{
  background:var(--yellow);
  color:var(--black);
  padding:160px 48px 120px;
  position:relative;
  overflow:hidden;
}
.contato-content{
  position:relative;
  z-index:2;
  max-width:1100px;
  margin:0 auto;
  text-align:center;
}
.contato-titulo{
  font-family:var(--font);
  font-weight:300;
  font-size:clamp(28px,3.6vw,56px);
  letter-spacing:-.01em;
  color:var(--black);
  line-height:1.15;
  margin-bottom:24px;
  max-width:980px;
  margin-left:auto;
  margin-right:auto;
}
.contato-sub{
  font-family:var(--font);
  font-weight:400;
  font-size:17px;
  line-height:1.6;
  color:rgba(40,40,40,.75);
  margin-bottom:60px;
  max-width:560px;
  margin-left:auto;
  margin-right:auto;
}

.contato-form{
  display:flex;
  flex-direction:column;
  gap:20px;
  align-items:center;
}

/* CTA principal de email — abre o cliente já preenchido */
.email-cta{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:20px 36px;
  background:var(--black);
  color:var(--yellow);
  border-radius:100px;
  font-family:var(--font);
  font-weight:500;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  transition:transform .4s ease, gap .4s ease, background .4s ease;
  min-width:340px;
  justify-content:center;
}
.email-cta:hover{
  transform:translateY(-2px);
  gap:18px;
}
.email-cta-icon{
  display:inline-flex;
  align-items:center;
  color:var(--yellow);
}
.email-cta .arrow{
  font-weight:300;
  transition:transform .3s ease;
}
.email-cta:hover .arrow{transform:translateX(4px)}

.whatsapp-btn{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:20px 36px;
  background:transparent;
  border:1.5px solid var(--black);
  color:var(--black);
  border-radius:100px;
  font-family:var(--font);
  font-weight:500;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  transition:transform .4s ease, gap .4s ease, background .4s ease;
  min-width:340px;
  justify-content:center;
}
.whatsapp-btn:hover{
  transform:translateY(-2px);
  gap:18px;
  background:rgba(40,40,40,.06);
}
.wa-icon{
  display:inline-flex;
  align-items:center;
  color:var(--black);
}

.contato-tel{
  margin-top:24px;
  text-align:center;
}
.form-label{
  display:block;
  font-family:var(--font);
  font-weight:500;
  font-size:11px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--black);
  opacity:.6;
  margin-bottom:8px;
}
.contato-tel-num{
  font-family:var(--font);
  font-weight:500;
  font-size:24px;
  letter-spacing:.04em;
  color:var(--black);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease;
}
.contato-tel-num:hover{border-color:var(--black)}

/* ============================================
   FOOTER (sem logo)
   ============================================ */
.footer{
  background:var(--black);
  color:var(--white);
  padding:48px 48px 36px;
}
.footer-content{
  max-width:1400px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:40px;
  flex-wrap:wrap;
}
.footer-info{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.footer-endereco{
  font-family:var(--font);
  font-weight:500;
  font-size:13px;
  letter-spacing:.06em;
  color:var(--white);
}
.footer-copy{
  font-family:var(--font);
  font-weight:400;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(250,250,247,.45);
}

/* ============================================
   MODAL DE ORÇAMENTO
   ============================================ */
.modal-overlay{
  position:fixed;
  inset:0;
  z-index:200;
  background:rgba(20,20,20,.7);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .35s ease, visibility .35s ease;
}
.modal-overlay.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.modal-box{
  background:var(--white);
  color:var(--black);
  width:100%;
  max-width:520px;
  max-height:92vh;
  overflow-y:auto;
  border-radius:var(--radius);
  padding:48px 44px 40px;
  position:relative;
  transform:translateY(20px) scale(.98);
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
  box-shadow:0 24px 60px rgba(0,0,0,.4);
}
.modal-overlay.is-open .modal-box{
  transform:translateY(0) scale(1);
}
.modal-close{
  position:absolute;
  top:14px;right:18px;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
  font-weight:300;
  color:var(--black);
  background:transparent;
  cursor:pointer;
  line-height:1;
  border-radius:50%;
  transition:background .2s ease;
}
.modal-close:hover{background:rgba(0,0,0,.06)}
.modal-header{
  margin-bottom:28px;
}
.modal-title{
  font-family:var(--font);
  font-weight:500;
  font-size:24px;
  letter-spacing:-.005em;
  color:var(--black);
  margin-bottom:8px;
}
.modal-subtitle{
  font-family:var(--font);
  font-weight:400;
  font-size:14px;
  line-height:1.5;
  color:#555;
}
.orcamento-form{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.form-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.form-field label{
  font-family:var(--font);
  font-weight:500;
  font-size:10px;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:#666;
}
.form-field input,
.form-field textarea{
  font-family:var(--font);
  font-weight:400;
  font-size:15px;
  color:var(--black);
  padding:12px 14px;
  background:#f5f5f0;
  border:1.5px solid transparent;
  border-radius:8px;
  outline:none;
  transition:border-color .25s ease, background .25s ease;
  resize:none;
  width:100%;
}
.form-field input:focus,
.form-field textarea:focus{
  border-color:var(--yellow);
  background:#fff;
}
.form-field textarea{
  min-height:110px;
  font-family:var(--font);
}
.form-field input::placeholder,
.form-field textarea::placeholder{
  color:#999;
}
/* honeypot — esconde do humano, mostra pra bot */
.hidden-honeypot{
  position:absolute !important;
  left:-9999px !important;
  width:1px;height:1px;opacity:0;pointer-events:none;
}
.form-submit{
  margin-top:6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:16px 28px;
  background:var(--black);
  color:var(--yellow);
  border-radius:100px;
  font-family:var(--font);
  font-weight:500;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
  transition:transform .3s ease, gap .3s ease, opacity .3s ease;
  width:100%;
}
.form-submit:hover{transform:translateY(-2px);gap:16px}
.form-submit:disabled{opacity:.55;cursor:wait;transform:none}
.form-submit .arrow{font-weight:300}
.form-status{
  margin-top:4px;
  text-align:center;
  font-size:13px;
  font-family:var(--font);
  font-weight:500;
  min-height:18px;
}
.form-status.is-success{color:#1f7a3a}
.form-status.is-error{color:#b03030}

body.modal-open{overflow:hidden}

/* ============================================
   MODAL DE VÍDEO (lightbox YouTube)
   ============================================ */
.video-modal{
  position:fixed;
  inset:0;
  z-index:210;
  background:rgba(0,0,0,.92);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:48px 24px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .35s ease, visibility .35s ease;
}
.video-modal.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.video-modal-close{
  position:absolute;
  top:20px;right:24px;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  font-size:32px;
  font-weight:300;
  line-height:1;
  color:var(--white);
  background:rgba(255,255,255,.08);
  border-radius:50%;
  cursor:pointer;
  transition:background .25s ease, transform .25s ease;
  z-index:2;
}
.video-modal-close:hover{
  background:rgba(255,255,255,.18);
  transform:scale(1.08);
}
.video-modal-frame{
  width:100%;
  max-width:1200px;
  aspect-ratio:16/9;
  background:#000;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,.6);
  transform:scale(.94);
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.video-modal.is-open .video-modal-frame{
  transform:scale(1);
}
.video-modal-iframe-wrap{
  width:100%;
  height:100%;
  position:relative;
}
.video-modal-iframe-wrap iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}

/* ============================================
   POPUP VÍDEO DESTAQUE (canto inferior direito)
   ============================================ */
.featured-popup{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:90;
  width:260px;
  background:var(--black);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 16px 40px rgba(0,0,0,.35);
  opacity:0;
  visibility:hidden;
  transform:translateY(24px);
  transition:opacity .5s ease, visibility .5s ease, transform .5s cubic-bezier(.2,.8,.2,1);
}
.featured-popup.is-visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.featured-popup-close{
  position:absolute;
  top:6px;right:6px;
  width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.55);
  color:var(--white);
  border-radius:50%;
  cursor:pointer;
  font-size:18px;
  line-height:1;
  z-index:3;
  font-weight:300;
  transition:background .2s ease;
}
.featured-popup-close:hover{background:rgba(0,0,0,.85)}
.featured-popup-link{
  display:block;
  width:100%;
  text-decoration:none;
  color:var(--white);
  background:transparent;
  border:none;
  padding:0;
  cursor:pointer;
  text-align:left;
  font:inherit;
}
.featured-popup-media{
  position:relative;
  aspect-ratio:16/9;
  overflow:hidden;
  background:#111;
}
.featured-popup-media video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .6s ease;
}
.featured-popup-link:hover .featured-popup-media video{
  transform:scale(1.06);
}
.featured-popup-text{
  padding:14px 16px 16px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.featured-popup-label{
  font-family:var(--font);
  font-weight:500;
  font-size:10px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--yellow);
}
.featured-popup-cta{
  font-family:var(--font);
  font-weight:400;
  font-size:14px;
  line-height:1.3;
  color:var(--white);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width:1024px){
  .nav{padding:18px 28px}
  .nav.scrolled{padding:14px 28px}
  .nav-links{gap:20px}
  .nav-links a{font-size:11px;letter-spacing:.18em}
  .proposito,.galeria-section,.servicos,.sobre,.destaque,.contato{padding-left:28px;padding-right:28px}
  .galeria-section{padding-bottom:120px}
  /* Tablet: ainda mantém o layout, mas menos extremo */
  .galeria{grid-template-columns:repeat(6,1fr);gap:20px}
  .cliente.is-vertical .cliente-media{aspect-ratio:3/4}
  .servicos-grid{grid-template-columns:1fr;gap:16px}
  .servico{padding:36px 28px}
  .sobre-grid{grid-template-columns:1fr;gap:36px}
  .big-numbers{grid-template-columns:repeat(2,1fr);gap:32px;margin-top:100px}
}
@media (max-width:760px){
  /* Mostra hambúrguer no mobile */
  .nav-burger{display:flex}

  /* Menu vira overlay fullscreen */
  .nav-links{
    position:fixed;
    top:0;left:0;right:0;bottom:0;
    z-index:101;
    background:rgba(40,40,40,.98);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:36px;
    margin:0;
    padding:0;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:opacity .4s ease, visibility .4s ease;
  }
  .nav-links.is-open{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
  }
  .nav-links a{
    font-size:18px;
    letter-spacing:.25em;
    padding:8px 0;
  }
  /* No overlay, o nav fica visível mas a parte de fundo não muda — bloquear scroll do body quando aberto via JS */

  .nav-logo-img{height:40px}
  .nav.scrolled .nav-logo-img{height:32px}
  .hero-tagline{
    font-size:24px;
    white-space:normal;
  }
  .proposito{padding:100px 24px}
  .proposito-grid{grid-template-columns:1fr;gap:32px;align-items:start}
  .galeria-section{padding:0 24px 100px}
  .galeria{grid-template-columns:1fr;gap:20px}
  .cliente.is-horizontal,.cliente.is-vertical{grid-column:span 1}
  .cliente.is-vertical .cliente-media{aspect-ratio:9/16}
  .servicos{padding:100px 24px}
  .servicos-titulo{
    margin-bottom:60px;
    font-size:48px;
  }
  .sobre{padding:100px 24px}
  .destaque{padding:80px 24px}
  .destaque-cta-wrap{justify-content:flex-start}
  .contato{padding:100px 24px 80px}
  .contato-titulo{font-size:30px}
  .email-cta,.whatsapp-btn{min-width:0;width:100%;font-size:11px;padding:18px 24px}
  .footer{padding:36px 24px 28px}
  .footer-content{flex-direction:column;align-items:flex-start;gap:16px}
  .big-numbers{grid-template-columns:1fr;gap:32px}

  /* Quando o menu está aberto, escurece e bloqueia scroll */
  body.menu-open{overflow:hidden}

  /* Modal responsivo */
  .modal-box{padding:36px 24px 28px}
  .modal-title{font-size:20px}

  /* Modal de vídeo */
  .video-modal{padding:24px 12px}
  .video-modal-close{top:12px;right:12px;width:38px;height:38px;font-size:26px}

  /* Botão de play menor no mobile */
  .destaque-play{width:64px;height:64px}
  .destaque-play svg{width:22px;height:22px}
  .destaque-hint{font-size:9px;padding:6px 12px;bottom:14px}

  /* Popup mais discreto no mobile */
  .featured-popup{
    width:200px;
    right:14px;
    bottom:14px;
  }
  .featured-popup-cta{font-size:12px}
}
