*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --gold1:#FFD700;
  --gold2:#b89600;
  --gold3:#d4af37;
  --bg:#040404;
  --panel:#0b0b0b;
}
body{
  background:var(--bg);
  color:#fff;
  font-family:Poppins, sans-serif;
  overflow-x:hidden;
}
body.page{padding-top:95px;}

/* INTRO CINEMA */
.cinema-intro{
  position:fixed; inset:0;
  background:#000;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  z-index:9999;
  animation:fadeOut 1.8s ease forwards;
  animation-delay:2.2s;
}
.cinema-logo{
  font-family:Cinzel, serif;
  font-size:64px;
  letter-spacing:10px;
  background:linear-gradient(45deg,var(--gold1),var(--gold2));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:0 0 40px rgba(255,215,0,.25);
  animation:cinemaZoom 1.6s ease;
}
.cinema-sub{
  margin-top:14px;
  font-size:14px;
  letter-spacing:3px;
  color:rgba(255,255,255,.7);
}
@keyframes cinemaZoom{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}
@keyframes fadeOut{to{opacity:0;visibility:hidden}}

/* CANVAS PARTICLES */
#goldParticles{
  position:fixed;
  inset:0;
  z-index:1;
  pointer-events:none;
  opacity:.55;
}

/* NAVBAR */
.navbar{
  position:fixed; top:0; left:0; right:0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 56px;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(12px);
  z-index:50;
  border-bottom:1px solid rgba(212,175,55,.18);
}
.nav-left{display:flex;align-items:center;gap:14px;}
.logo{height:62px;}
.brand__name{
  font-family:Cinzel, serif;
  letter-spacing:1px;
  font-size:16px;
  color:rgba(255,255,255,.92);
}
.brand__tag{
  font-size:11px;
  letter-spacing:2px;
  color:rgba(212,175,55,.75);
}
.nav-links a{
  margin-left:34px;
  text-decoration:none;
  color:var(--gold3);
  font-weight:500;
  transition:.25s;
}
.nav-links a:hover{filter:brightness(1.15); text-shadow:0 0 18px rgba(212,175,55,.35);}
.nav-cta{
  padding:10px 16px;
  border-radius:999px;
  border:1px solid rgba(212,175,55,.35);
  background:rgba(0,0,0,.35);
}

/* HERO */
.hero{
  min-height:100vh;
  background:url("../img/bg.jpg") center/cover no-repeat;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:130px 20px 70px;
  z-index:10;
}
.overlay{
  position:absolute; inset:0;
  background:radial-gradient(circle at 50% 30%, rgba(255,215,0,.10), transparent 50%),
             linear-gradient(to bottom, rgba(0,0,0,.82), rgba(0,0,0,.96));
  z-index:2;
}
/* LUZ CINEMA */
.cinema-light{
  position:absolute;
  top:-40%;
  left:-60%;
  width:180%;
  height:180%;
  background:linear-gradient(90deg, transparent, rgba(255,215,0,.12), transparent);
  transform:rotate(18deg);
  z-index:3;
  animation:lightSweep 6.5s linear infinite;
  filter:blur(0.6px);
}
@keyframes lightSweep{
  0%{transform:translateX(-20%) rotate(18deg); opacity:.22;}
  50%{opacity:.42;}
  100%{transform:translateX(20%) rotate(18deg); opacity:.22;}
}

.hero-content{
  position:relative;
  z-index:5;
  max-width:980px;
  animation:fadeUp 1.2s ease;
}
@keyframes fadeUp{from{opacity:0; transform:translateY(30px)}to{opacity:1; transform:translateY(0)}}

.badge{
  display:inline-block;
  padding:10px 16px;
  border:1px solid rgba(212,175,55,.45);
  border-radius:999px;
  letter-spacing:2px;
  font-size:12px;
  color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.35);
  margin-bottom:18px;
}

.gold-title{
  font-family:Cinzel, serif;
  font-size:66px;
  line-height:1.05;
  background:linear-gradient(45deg,var(--gold1),var(--gold2));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:0 0 45px rgba(255,215,0,.18);
  margin-bottom:18px;
}
.gold-title--small{font-size:46px;}
.sub{
  font-size:22px;
  opacity:.9;
  margin-bottom:34px;
}

.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:18px;}

.gold-btn{
  padding:18px 56px;
  border:none;
  cursor:pointer;
  font-weight:800;
  letter-spacing:1px;
  font-size:16px;
  color:#1a1400;
  background:linear-gradient(45deg,var(--gold1),var(--gold2));
  transition:.35s;
  box-shadow:0 10px 25px rgba(255,215,0,.12);
  border-radius:14px;
}
.gold-btn:hover{
  transform:scale(1.06);
  box-shadow:0 0 45px rgba(255,215,0,.32);
}
.gold-btn.big{font-size:18px;padding:20px 70px;}

.ghost-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:18px 36px;
  border-radius:14px;
  border:1px solid rgba(212,175,55,.35);
  color:rgba(255,255,255,.88);
  text-decoration:none;
  background:rgba(0,0,0,.35);
  transition:.25s;
}
.ghost-btn:hover{transform:translateY(-2px);border-color:rgba(255,215,0,.55);}

/* COUNTDOWN */
.countdown-wrap{
  margin:18px auto 0;
  display:inline-block;
  padding:16px 18px;
  border:1px solid rgba(212,175,55,.28);
  background:rgba(0,0,0,.35);
  border-radius:18px;
}
.countdown-title{
  font-weight:700;
  color:rgba(255,255,255,.9);
  margin-bottom:10px;
  letter-spacing:.5px;
}
.countdown{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}
.timebox{
  width:92px;
  padding:12px 10px;
  border-radius:14px;
  background:rgba(10,10,10,.85);
  border:1px solid rgba(212,175,55,.22);
}
.timebox span{
  display:block;
  font-family:Cinzel, serif;
  font-size:28px;
  color:var(--gold3);
  text-shadow:0 0 18px rgba(212,175,55,.25);
}
.timebox small{
  display:block;
  margin-top:2px;
  font-size:11px;
  opacity:.75;
  letter-spacing:1px;
}

.mini{
  margin-top:8px;
  font-weight:500;
  font-size:12px;
  opacity:.75;
  letter-spacing:1px;
}

/* VAGAS */
.vagas-box{
  margin:18px auto 0;
  display:inline-block;
  padding:14px 18px;
  border:1px solid rgba(255,215,0,.40);
  background:rgba(0,0,0,.35);
  border-radius:16px;
  font-size:18px;
  color:#ffdb5a;
  font-weight:700;
  animation:urgency 1.8s ease-in-out infinite;
}
.vagas-box #vagas{
  font-size:22px;
  text-shadow:0 0 18px rgba(255,215,0,.35);
}
@keyframes urgency{
  0%{transform:translateY(0)}
  50%{transform:translateY(-2px)}
  100%{transform:translateY(0)}
}

.stats{
  margin-top:26px;
  display:flex;
  justify-content:center;
  gap:26px;
  flex-wrap:wrap;
  color:var(--gold3);
  font-weight:650;
  text-shadow:0 0 18px rgba(212,175,55,.18);
}

/* SEÇÕES */
.section{
  position:relative;
  z-index:10;
  padding:110px 60px;
  text-align:center;
}
.section-dark{background:#070707;}
h2{
  font-family:Cinzel, serif;
  font-size:44px;
  color:var(--gold3);
  margin-bottom:16px;
}
.section-sub{
  max-width:760px;
  margin:0 auto;
  opacity:.85;
  line-height:1.6;
}

/* CARDS */
.cards{
  margin-top:56px;
  display:flex;
  justify-content:center;
  gap:28px;
  flex-wrap:wrap;
}
.card{
  width:300px;
  padding:38px;
  background:rgba(12,12,12,.92);
  border:1px solid rgba(212,175,55,.28);
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  transition:.25s;
  text-align:left;
}
.card h3{color:rgba(255,255,255,.92);margin-bottom:10px;}
.card p{opacity:.82;line-height:1.6;}
.card:hover{
  transform:translateY(-6px);
  border-color:rgba(255,215,0,.55);
  box-shadow:0 0 35px rgba(255,215,0,.12);
}
@keyframes whatsMove{
    0%{transform:translateX(0)}
    20%{transform:translateX(-3px)}
    40%{transform:translateX(3px)}
    60%{transform:translateX(-3px)}
    80%{transform:translateX(3px)}
    100%{transform:translateX(0)}
    }

/* GALERIA RESULTADOS (zoom) */
.gallery{
  margin-top:56px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.shot{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(212,175,55,.25);
  background:rgba(0,0,0,.35);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.shot img{
    width:100%;
    height:auto;            /* mostra imagem inteira */
    object-fit:contain;     /* não corta */
    transform:scale(1);
    transition:transform .45s ease;
    filter:saturate(1.05) contrast(1.05);
  }
.shot:hover img{
    transform:scale(1.05);
    }
.shot::after{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(255,215,0,.14), transparent 45%),
             linear-gradient(to bottom, transparent, rgba(0,0,0,.40));
  opacity:.8;
  transition:opacity .45s ease;
}
.shot:hover img{transform:scale(1.16);}
.shot:hover::after{opacity:1;}

.mid-cta{margin-top:60px;display:flex;justify-content:center;}
.mid-cta__box{
  width:min(980px, 100%);
  padding:26px;
  border-radius:20px;
  border:1px solid rgba(212,175,55,.25);
  background:rgba(0,0,0,.35);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.mid-cta__title{font-family:Cinzel, serif;color:rgba(255,255,255,.92);font-size:22px;}
.mid-cta__sub{opacity:.8;margin-top:6px;}
.mid-cta__actions{margin-top:16px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* SOBRE */
.about{
  margin-top:56px;
  display:grid;
  grid-template-columns: 360px 1fr;
  gap:26px;
  align-items:center;
  text-align:left;
  width:min(1100px, 100%);
  margin-left:auto;
  margin-right:auto;
}
.about__photo{
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(212,175,55,.25);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.about__photo img{width:100%;height:420px;object-fit:cover;display:block;}
.about__text h3{font-family:Cinzel, serif;font-size:26px;margin-bottom:10px;color:rgba(255,255,255,.92);}
.about__text p{opacity:.84;line-height:1.7;margin-bottom:14px;}
.about__list{list-style:none;display:grid;gap:8px;margin:14px 0 16px;}
.about__list li{
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(212,175,55,.18);
  background:rgba(0,0,0,.25);
}
.about__actions{display:flex;gap:12px;flex-wrap:wrap;}

/* APPLY PAGE */
.apply{position:relative;z-index:10;padding:120px 20px;}
.apply-card{
  width:min(860px, 100%);
  margin:0 auto;
  padding:28px;
  border-radius:22px;
  border:1px solid rgba(212,175,55,.25);
  background:rgba(0,0,0,.42);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.apply-top{margin-bottom:18px;text-align:center;}
.form{margin-top:18px;display:grid;gap:14px;}
.row{display:grid;gap:8px;}
label{font-size:13px;opacity:.9;letter-spacing:.4px;}
input, select, textarea{
  width:100%;
  padding:14px 14px;
  border-radius:14px;
  border:1px solid rgba(212,175,55,.18);
  background:rgba(10,10,10,.85);
  color:rgba(255,255,255,.9);
  outline:none;
}
input:focus, select:focus, textarea:focus{
  border-color:rgba(255,215,0,.55);
  box-shadow:0 0 0 3px rgba(255,215,0,.08);
}
.form-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;margin-top:8px;}

/* FINAL CTA */
.final-actions{margin-top:18px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* WHATS FLUTUANTE com tooltip + vibração */
.whats-float{
  position:fixed;
  bottom:22px;
  right:22px;
  width:72px;
  height:72px;
  border-radius:50%;
  border:none;
  background:#25D366;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:9999;
  box-shadow:0 0 20px rgba(37,211,102,0.6);
  animation:whatsMove 2s infinite;
  transition:.35s;
  }
  
  /* HOVER INSANO */
  .whats-float:hover{
  transform:scale(1.15);
  box-shadow:
  0 0 25px #25D366,
  0 0 50px #25D366,
  0 0 80px rgba(37,211,102,0.7),
  0 0 120px rgba(37,211,102,0.4);
  }

.whats-tooltip{
  position:absolute;
  right:90px;
  bottom:50%;
  transform:translateY(50%);
  background:rgba(0,0,0,.72);
  border:1px solid rgba(212,175,55,.22);
  color:rgba(255,255,255,.92);
  padding:10px 12px;
  border-radius:12px;
  font-size:13px;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:.25s;
  backdrop-filter: blur(10px);
}
.whats-float:hover .whats-tooltip{opacity:1;}

@keyframes whatsPulse{
  0%{transform:translateX(0) scale(1)}
  10%{transform:translateX(-1px) scale(1.01)}
  20%{transform:translateX(1px) scale(1.01)}
  30%{transform:translateX(-1px) scale(1.01)}
  40%{transform:translateX(0) scale(1)}
  100%{transform:translateX(0) scale(1)}
}

/* BANNER FLUTUANTE */
.float-banner{
  position:fixed;
  top:90px;
  right:22px;
  width:min(420px, calc(100% - 44px));
  z-index:90;
  border-radius:18px;
  border:1px solid rgba(212,175,55,.25);
  background:rgba(0,0,0,.62);
  backdrop-filter: blur(10px);
  overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.45);
  transform:translateY(-10px);
  opacity:0;
  animation:bannerIn .9s ease forwards;
  animation-delay:2.8s;
}
.float-banner__glow{
  position:absolute; inset:-60px;
  background:radial-gradient(circle at 20% 20%, rgba(255,215,0,.22), transparent 55%);
  filter:blur(0.5px);
  pointer-events:none;
}
.float-banner__content{position:relative;padding:16px 16px 14px;}
.float-banner__title{font-weight:800;color:rgba(255,255,255,.94);letter-spacing:.3px;}
.float-banner__sub{margin-top:6px;font-size:13px;opacity:.82;line-height:1.4;}
.float-banner__actions{
  position:relative;
  display:flex;
  gap:10px;
  justify-content:flex-end;
  padding:0 14px 14px;
}
.mini-btn{
  padding:10px 14px;
  border-radius:12px;
  border:1px solid rgba(212,175,55,.22);
  background:linear-gradient(45deg,var(--gold1),var(--gold2));
  color:#1a1400;
  font-weight:900;
  cursor:pointer;
}
.x-btn{
  width:42px;height:42px;
  border-radius:12px;
  border:1px solid rgba(212,175,55,.22);
  background:rgba(0,0,0,.35);
  color:rgba(255,255,255,.9);
  cursor:pointer;
}
@keyframes bannerIn{to{opacity:1;transform:translateY(0)}}
.float-banner.closing{animation:bannerOut .45s ease forwards;}
@keyframes bannerOut{to{opacity:0;transform:translateY(-10px)}}

/* LIVE TOAST */
.live-toast{
  position:fixed;
  left:18px;
  bottom:24px;
  z-index:85;
  padding:14px 16px;
  border-radius:14px;
  background:rgba(0,0,0,.65);
  border:1px solid rgba(212,175,55,.25);
  color:rgba(255,255,255,.9);
  font-size:14px;
  opacity:0;
  transform:translateY(12px);
  transition:.35s;
  pointer-events:none;
}
.live-toast.show{opacity:1;transform:translateY(0);}

/* RESPONSIVO */
@media (max-width: 980px){
  .navbar{padding:14px 18px;}
  .nav-links a{margin-left:18px;}
  .gold-title{font-size:46px;}
  .section{padding:90px 18px;}
  .about{grid-template-columns:1fr;}
  .about__photo img{height:360px;}
  .gallery{grid-template-columns:repeat(2, minmax(0, 1fr));}
}
@media (max-width: 560px){
  .gallery{grid-template-columns:1fr;}
  .timebox{width:78px;}
}
/* BARRA PROGRESSO */
.scroll-progress-wrap{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:6px;
    background:rgba(255,255,255,0.05);
    z-index:9999;
    }
    
    .scroll-progress-bar{
    height:6px;
    width:0%;
    background:linear-gradient(90deg,#FFD700,#b89600);
    transition:width .25s;
    box-shadow:0 0 15px gold;
    }
    
    .scroll-progress-text{
    position:fixed;
    top:10px;
    left:50%;
    transform:translateX(-50%);
    background:rgba(0,0,0,0.7);
    padding:6px 14px;
    border-radius:20px;
    font-size:13px;
    color:#FFD700;
    border:1px solid rgba(255,215,0,0.3);
    backdrop-filter:blur(6px);
    letter-spacing:.5px;
    }
    /* NOTIFICAÇÃO AO VIVO */
.live-notify{
    position:fixed;
    left:20px;
    bottom:20px;
    background:rgba(0,0,0,0.75);
    color:#FFD700;
    padding:14px 18px;
    border-radius:14px;
    border:1px solid rgba(255,215,0,0.3);
    font-size:14px;
    opacity:0;
    transform:translateY(20px);
    transition:.4s;
    z-index:9999;
    backdrop-filter:blur(8px);
    }
    
    .live-notify.show{
    opacity:1;
    transform:translateY(0);
    }
    @keyframes whatsMove{
0%{transform:translateX(0)}
20%{transform:translateX(-3px)}
40%{transform:translateX(3px)}
60%{transform:translateX(-3px)}
80%{transform:translateX(3px)}
100%{transform:translateX(0)}
}
/* ===== RESPONSIVO (FIX) ===== */

/* evita zoom e quebra */
img{max-width:100%; height:auto;}
html{scroll-behavior:smooth;}

/* botão hamburguer (só aparece no mobile) */
.nav-toggle{
  display:none;
  width:46px;height:46px;
  border-radius:12px;
  border:1px solid rgba(212,175,55,.25);
  background:rgba(0,0,0,.35);
  cursor:pointer;
  align-items:center;
  justify-content:center;
  gap:5px;
}
.nav-toggle span{
  display:block;
  width:20px;
  height:2px;
  background:rgba(255,255,255,.85);
  border-radius:2px;
}

/* <= 980px */
@media (max-width: 980px){
  :root{ --navH: 80px; } /* ajuda também a label da barra de progresso */

  .navbar{padding:12px 16px;}
  .logo{height:54px;}
  .brand{display:none;} /* opcional: some o texto ao lado do logo */

  /* menu vira dropdown */
  .nav-toggle{display:flex;}
  .nav-links{
    position:fixed;
    top:78px; right:14px;
    width:min(320px, calc(100% - 28px));
    display:flex;
    flex-direction:column;
    gap:10px;
    padding:14px;
    border-radius:18px;
    background:rgba(0,0,0,.78);
    border:1px solid rgba(212,175,55,.22);
    backdrop-filter: blur(12px);
    transform:translateY(-8px);
    opacity:0;
    pointer-events:none;
    transition:.25s;
    z-index:99999;
  }
  .nav-links a{margin-left:0; padding:12px 12px; border-radius:12px;}
  .nav-links a:hover{background:rgba(255,215,0,.06);}
  .nav-links.open{
    opacity:1;
    pointer-events:auto;
    transform:translateY(0);
  }

  /* hero ajusta */
  .hero{padding:120px 16px 60px;}
  .gold-title{font-size:44px;}
  .sub{font-size:18px;}
  .hero-actions{gap:10px;}
  .gold-btn{padding:16px 26px;}
  .ghost-btn{padding:16px 22px;}

  /* seções com menos padding */
  .section{padding:80px 16px;}
  h2{font-size:34px;}

  /* cards e stats quebram sem estourar */
  .stats{gap:14px;}
  .cards{gap:16px;}
  .card{width:min(420px, 100%);}

  /* countdown encaixa */
  .timebox{width:78px;}
}

/* <= 560px */
@media (max-width: 560px){
  .gold-title{font-size:36px;}
  .sub{font-size:16px;}

  /* galeria vira 1 coluna */
  .gallery{grid-template-columns:1fr;}

  /* about vira 1 coluna sempre */
  .about{
    grid-template-columns:1fr !important;
    text-align:left;
  }
  .about__photo img{height:auto; max-height:420px;}

  /* banner flutuante não ficar gigante */
  .float-banner{
    right:12px;
    top:84px;
    width:calc(100% - 24px);
  }

  /* tooltip do whats não sair da tela */
  .whats-tooltip{
    right:86px;
    max-width:210px;
    white-space:normal;
  }
}
/* ===== SOBRE STORY PREMIUM ===== */

.sobre-title{
  font-family:Cinzel,serif;
  font-size:44px;
  color:#FFD700;
  margin-bottom:60px;
  text-align:center;
  }
  
  .sobre-container{
  display:grid;
  grid-template-columns:420px 1fr;
  gap:60px;
  max-width:1300px;
  margin:auto;
  align-items:start;
  }
  
  /* FOTO */
  .foto-wrap{
  position:sticky;
  top:120px;
  border-radius:20px;
  overflow:hidden;
  }
  
  .foto-wrap img{
  width:100%;
  height:520px;
  object-fit:cover;
  border-radius:20px;
  }
  
  .foto-glow{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 10%, rgba(255,215,0,0.25), transparent 60%);
  pointer-events:none;
  }
  
  .sobre-frase{
  margin-top:20px;
  font-family:Cinzel,serif;
  font-size:20px;
  color:#FFD700;
  opacity:.9;
  }
  
  /* TEXTO */
  .sobre-right{
  max-width:720px;
  }
  
  .story-block{
  margin-bottom:40px;
  padding:26px;
  border:1px solid rgba(255,215,0,0.25);
  border-radius:18px;
  background:rgba(0,0,0,0.35);
  }
  
  .story-block h3{
  color:#FFD700;
  font-size:20px;
  margin-bottom:12px;
  }
  
  .story-block p{
  opacity:.9;
  line-height:1.7;
  font-size:15.5px;
  }
  
  .sobre-cta{
  margin-top:40px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  }
  
  /* MOBILE */
  @media(max-width:980px){
  
  .sobre-container{
  grid-template-columns:1fr;
  gap:40px;
  }
  
  .foto-wrap{
  position:relative;
  top:auto;
  }
  
  .foto-wrap img{
  height:380px;
  }
  
  .sobre-right{
  max-width:100%;
  }
  
  .story-block{
  padding:20px;
  }
  
  }
  /* ===== BANNER FLUTUANTE ELITE ===== */

.elite-banner{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:30px;
  width:min(720px, calc(100% - 40px));
  background:rgba(0,0,0,0.75);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,215,0,0.25);
  border-radius:18px;
  padding:18px 20px;
  z-index:99999;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
  opacity:0;
  pointer-events:none;
  animation:bannerFade 1s ease forwards;
  animation-delay:2.5s;
  }
  
  /* glow dourado */
  .elite-glow{
  position:absolute;
  inset:-60px;
  background:radial-gradient(circle at 50% 20%, rgba(255,215,0,0.25), transparent 60%);
  pointer-events:none;
  }
  
  .elite-content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  position:relative;
  }
  
  .elite-text{
  font-size:15px;
  opacity:.9;
  }
  
  .elite-text strong{
  color:#FFD700;
  font-size:16px;
  }
  
  .elite-actions{
  display:flex;
  align-items:center;
  gap:10px;
  }
  
  .elite-btn{
  padding:12px 22px;
  border:none;
  border-radius:10px;
  font-weight:700;
  cursor:pointer;
  background:linear-gradient(45deg,#FFD700,#b89600);
  color:#000;
  }
  
  .elite-close{
  width:38px;
  height:38px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(0,0,0,.4);
  color:#fff;
  cursor:pointer;
  }
  
  @keyframes bannerFade{
  to{
  opacity:1;
  pointer-events:auto;
  bottom:40px;
  }
  }
  
  /* MOBILE */
  @media(max-width:600px){
  
  .elite-content{
  flex-direction:column;
  align-items:flex-start;
  gap:12px;
  }
  
  .elite-actions{
  width:100%;
  justify-content:space-between;
  }
  
  .elite-btn{
  flex:1;
  }
  
  }
/* ============================
   PATCH RESPONSIVO (COLAR NO FINAL)
   ============================ */

   html, body { width: 100%; overflow-x: hidden; }

   .cinema-logo{
     font-size: clamp(34px, 7vw, 64px);
     letter-spacing: clamp(3px, 1.5vw, 10px);
     text-align:center;
     padding: 0 12px;
   }
   
   .cinema-sub{
     padding: 0 14px;
     text-align:center;
   }
   
   .hero-content{
     width: min(980px, 100%);
     padding: 0 10px;
   }
   
   .section-sub{
     padding: 0 10px;
   }
   
   .scroll-progress-text{
     max-width: calc(100vw - 24px);
     text-align: center;
     white-space: normal;
   }
   
   @media (max-width: 420px){
     .badge{ font-size: 11px; }
     h2{ font-size: 30px; }
     .gold-title{ font-size: 34px; }
     .gold-title--small{ font-size: 32px; }
     .sub{ font-size: 15px; }
   
     .timebox{ width: 72px; }
     .timebox span{ font-size: 24px; }
   
     .logo{ height: 48px; }
   }
/* ===== PATCH RESULTADOS (GRID MENOR + MENOS ZOOM/CORTE) ===== */

/* deixa o grid centralizado e com largura máxima (não fica gigante em monitor grande) */
.gallery{
  width: min(1100px, calc(100% - 32px));
  margin: 40px auto 0;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
}

/* padroniza o “tamanho visual” dos cards */
.shot{
  aspect-ratio: 16 / 9; /* ajuste se quiser: 4/3 ou 3/2 */
}

/* garante que a imagem caiba dentro sem cortar */
.shot img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  transform: scale(1);
  transition: transform .35s ease;
}

/* zoom bem mais leve (quase imperceptível) */
.shot:hover img{
  transform: scale(1.02);
}

/* em celular (sem hover), não aplica zoom */
@media (hover: none){
  .shot:hover img{ transform: scale(1); }
}

/* =========================
   FOOTER PREMIUM (CORRIGIDO)
   ========================= */
   .footer{
    position: relative;
    z-index: 15;
    margin-top: 60px;
    border-top: 1px solid rgba(212,175,55,.22);
    background: radial-gradient(circle at 20% 10%, rgba(212,175,55,.10), transparent 45%),
                rgba(0,0,0,.65);
    backdrop-filter: blur(10px);
  }
  
  .footer-inner{
    width: min(1150px, calc(100% - 32px));
    margin: 0 auto;
    padding: 48px 0 26px;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1.2fr;
    gap: 28px;
  }
  
  .footer-logo{
    font-family: Cinzel, serif;
    font-size: 26px;
    letter-spacing: 2px;
    color: var(--gold3);
  }
  
  /* ===== CENTRALIZA BLOCO ESQUERDO ===== */
  .footer-brand{
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  
  .footer-desc{
    margin-top: 10px;
    opacity: .82;
    line-height: 1.6;
    font-size: 14px;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
  
  .footer-title{
    color: rgba(255,255,255,.92);
    font-weight: 700;
    margin-bottom: 12px;
  }
  
  .footer-links{
    display: grid;
    gap: 10px;
  }
  
  .footer-links a{
    color: rgba(255,255,255,.80);
    text-decoration: none;
    opacity: .9;
  }
  
  .footer-links a:hover{
    color: var(--gold3);
  }
  
  /* ===== CENTRALIZA PILLS ===== */
  .footer-pills{
    margin-top: 14px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .pill{
    border: 1px solid rgba(212,175,55,.25);
    background: rgba(0,0,0,.35);
    padding: 7px 10px;
    border-radius: 999px;
    font-size: 12px;
    color: rgba(255,255,255,.85);
  }
  
  /* ===== CENTRALIZA BLOCO DIREITO (ÍCONES + TEXTO) ===== */
  .footer-inner .footer-col:last-child{
    text-align: center;
  }
  
  .footer-icons{
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
  }
  
  .icon{
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    border: 1px solid rgba(212,175,55,.25);
    background: rgba(0,0,0,.35);
    color: rgba(255,255,255,.88);
    box-shadow: 0 10px 28px rgba(0,0,0,.35);
  }
  
  .icon svg{ color: rgba(255,255,255,.88); }
  
  .icon-link:hover{
    border-color: rgba(255,215,0,.55);
    transform: translateY(-1px);
  }
  
  .footer-note{
    margin-top: 12px;
    font-size: 13px;
    opacity: .78;
    line-height: 1.5;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }
  
  .footer-bottom{
    border-top: 1px solid rgba(212,175,55,.12);
    padding: 18px 16px;
    text-align: center;
    font-size: 13px;
    opacity: .78;
  }
  
  /* Responsivo */
  @media (max-width: 980px){
    .footer-inner{
      grid-template-columns: 1fr;
      padding: 36px 0 22px;
      text-align: center;
    }
  
    .footer-links{
      justify-items: center;
    }
  }

/* =========================
   HERO: PAINEL PROMO + CONTADOR (layout limpo)
   ========================= */
.hero-panels{
  margin:22px auto 0;
  display:flex;
  justify-content:center;
  align-items:stretch;
  gap:18px;
  flex-wrap:wrap;
}
.hero-panels .promo-wrap,
.hero-panels .countdown-wrap{
  margin:0;
}

/* PROMO */
.promo-wrap{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:16px 18px;
  border:1px solid rgba(212,175,55,.28);
  background:rgba(0,0,0,.35);
  border-radius:18px;
  min-width:280px;
}
.promo-main{
  font-weight:800;
  color:#ffdb5a;
  letter-spacing:.2px;
}
.promo-main s{opacity:.7;}
.promo-main strong{
  color:var(--gold1);
  text-shadow:0 0 18px rgba(255,215,0,.25);
}
.promo-sub{
  margin-top:8px;
  font-size:12px;
  opacity:.80;
  letter-spacing:1px;
}

/* VAGAS em baixo do hero */
.vagas-bottom{
  margin-top:22px;
}

/* ====== BANNER PROMO CENTRAL (não toma a tela) ====== */
#promoCenter, .promo-center{
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.65);
  padding: 18px;
  z-index: 99999;
}

/* controla o “zoom” do banner aqui */
:root{
  --promo-scale: .85;   /* 0.85 = parecido com você ter diminuído o zoom */
  --promo-maxW: 520px;  /* largura máxima no desktop */
  --promo-maxH: 78vh;   /* altura máxima na tela */
}

#promoCenter .promo-center__box,
.promo-center .promo-center__box,
#promoCenter .promo-box,
.promo-center .promo-box{
  transform: scale(var(--promo-scale));
  transform-origin: center;
  max-width: min(var(--promo-maxW), 92vw);
  max-height: var(--promo-maxH);
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(212,175,55,.25);
  box-shadow: 0 22px 80px rgba(0,0,0,.65);
  background: rgba(0,0,0,.35);
}
.promo-center, #promoCenter{
  z-index: 9998; /* abaixo do cinema (9999) */
}

#promoCenter img,
.promo-center img{
  display: block;
  max-width: 100%;
  max-height: var(--promo-maxH);
  width: auto;
  height: auto;
  object-fit: contain;
}
.promo-center__close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}
