:root {
  --cloud:     #F0EEE9;
  --silhouette:#58514D;
  --naperon:   #DEAD95;
  --terracota: #D4654A;
  --teal:      #204F58;
  --cipo:      #767745;
  --mahogany:  #6D4741;
  --white:     #FAFAF7;

  /* Dois momentos */
  --almoco-bg:    #F5F0E8;
  --almoco-acc:   #767745;   /* cipó — dia, leveza */
  --hh-bg:        #1A1A1A;
  --hh-acc:       #D4654A;   /* terracota — noite, energia */
}
@font-face {
  font-family: 'ZT Glora Pro';
  src: url('ZTGloraPro-BoldExpanded.woff2') format('woff2'),
       url('ZTGloraPro-BoldExpanded.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Montserrat', sans-serif;
  background: var(--cloud);
  color: var(--silhouette);
  overflow-x: hidden;
}

/* noise texture */
body::after {
  content:'';
  position:fixed; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none; z-index:9999; opacity:.6;
}

/* ─────────────────────────────────────────
   DOBRA 1 — ABERTURA
───────────────────────────────────────── */
.hero {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr;
  position: relative;
  overflow: hidden;
}

/* background foto */
.hero-bg {
  position: absolute; inset:0;
  background-image: url('bg1.jpg');
  background-size: cover;
  background-position: center 30%;
}
.hero-bg::after {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(
    160deg,
    rgba(20,40,44,0.93) 0%,
    rgba(32,79,88,0.80) 45%,
    rgba(109,71,65,0.70) 100%
  );
  backdrop-filter: blur(5px);
}

/* nav */
.nav {
  position: relative; z-index:2;
  padding: 28px 64px;
  display: flex;
  align-items: center;
  justify-content: right;
      gap: 20px;
}

.nav-logo { height: 100px;}

.nav-cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 22px;
  background: var(--terracota);
  color: var(--white);
  font-size: 12px; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  text-decoration: none; border-radius: 3px;
  transition: background .2s;
}
.nav-cta:hover { background: var(--mahogany); }

/* hero content */
.hero-content {
  position: relative; z-index:2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px 32px 80px;
  gap: 32px;
}

.hero-tag {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 11px; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--naperon);
}
.hero-tag::before, .hero-tag::after {
  content:''; display:block;
  width: 24px; height: 1px;
  background: var(--naperon); opacity:.6;
}

.hero-title {
  font-size: clamp(36px, 6vw, 80px);
  font-weight: 900;
  line-height: .95;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: -.02em;
  max-width: 900px;
  font-family: 'ZT Glora Pro', serif;
}

.hero-title em {
  font-family: 'Montserrat', serif;
  font-style: normal;
  font-weight: 700;
  color: var(--naperon);
  text-transform: none;
  display: block;
  font-size: .30em;
  letter-spacing: 0;
  margin-top: 6px;
}

/* horários pill */
.hero-horarios {
  display: flex; gap: 12px; flex-wrap: wrap;
  justify-content: center;
}

.horario-pill {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 20px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 100px;
  backdrop-filter: blur(6px);
  background: rgba(255,255,255,.07);
  color: var(--white);
  font-size: 13px; font-weight: 600;
}

.pill-icon { font-size: 16px; }
.pill-sep { width:1px; height:16px; background:rgba(255,255,255,.2); }
.pill-label { font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; opacity:.6; }

/* hero CTAs */
.hero-ctas {
  display: flex; gap: 14px; flex-wrap: wrap;
  justify-content: center;
}

.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 16px 32px;
  background: var(--terracota);
  color: var(--white);
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  text-decoration: none; border: none;
  border-radius: 4px; cursor: pointer;
  transition: background .2s, transform .15s;
}
.btn-primary:hover { background: var(--mahogany); transform: translateY(-2px); }

.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 16px 32px;
  background: transparent;
  color: var(--white);
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  text-decoration: none; border: 1.5px solid rgba(255,255,255,.35);
  border-radius: 4px; cursor: pointer;
  transition: border-color .2s, background .2s;
  opacity: .5; cursor: not-allowed; /* placeholder estado */
}
.btn-outline.active {
  opacity:1; cursor:pointer;
}
.btn-outline.active:hover { border-color: var(--white); background: rgba(255,255,255,.08); }

.btn-note {
  font-size: 10px; color: rgba(255,255,255,.4);
  letter-spacing: .06em;
  display: block; margin-top: -20px;
}

/* scroll hint */
.scroll-hint {
  position: absolute; bottom: 28px; left:50%; transform:translateX(-50%);
  z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:6px;
  animation: bounce 2s infinite;
}
.scroll-hint span { font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.35); }
.scroll-hint svg { opacity:.3; }

@keyframes bounce {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(6px); }
}

/* ─────────────────────────────────────────
   TICKER
───────────────────────────────────────── */
.ticker {
  background: var(--mahogany);
  padding: 15px 0;
  overflow: hidden; white-space: nowrap;
}
.ticker-track {
  display: inline-flex; gap: 40px;
  animation: ticker 22s linear infinite;
}
.ticker-item {
  font-size: 11px; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--naperon); flex-shrink:0;
  display:flex; align-items:center; gap:14px;
}
.ticker-item::after { content:'✦'; color:var(--terracota); font-size:7px; }
@keyframes ticker {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ─────────────────────────────────────────
   DOBRA 2 — DOIS MOMENTOS
───────────────────────────────────────── */
.momentos {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

/* — ALMOÇO — */
.momento-almoco {
  background: var(--almoco-bg);
  padding: 80px 60px;
  position: relative;
  overflow: hidden;
}

.momento-almoco::before {
  content: 'DIA';
  position: absolute;
  bottom: -30px; right: -10px;
  font-size: 160px; font-weight: 900;
  color: rgba(118,119,69,.07);
  line-height:1; letter-spacing:-.05em;
  pointer-events:none;
}

.momento-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 10px; font-weight: 800;
  letter-spacing: .16em; text-transform: uppercase;
  margin-bottom: 24px;
}

.badge-almoco {
  background: rgba(118,119,69,.12);
  color: var(--cipo);
  border: 1px solid rgba(118,119,69,.25);
}

.badge-hh {
  background: rgba(212,101,74,.15);
  color: var(--terracota);
  border: 1px solid rgba(212,101,74,.3);
}

.momento-horario {
  font-size: 13px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  margin-bottom: 12px;
}

.almoco-color { color: var(--cipo); }
.hh-color     { color: var(--terracota); }

.momento-titulo {
  font-size: clamp(32px, 3.5vw, 52px);
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: -.02em;
  margin-bottom: 28px;
}

.almoco-titulo { color: var(--cipo); }
.hh-titulo     { color: var(--terracota); }

.momento-linha {
  width: 48px; height: 2px;
  margin-bottom: 28px;
}
.linha-almoco { background: var(--cipo); }
.linha-hh     { background: var(--terracota); }

.momento-items {
  display: flex; flex-direction: column; gap: 18px;
  margin-bottom: 36px;
}

.momento-item {
  display: flex; gap: 14px; align-items: flex-start;
}

.item-icon {
  width: 36px; height: 36px; flex-shrink:0;
  border-radius: 8px;
  display: flex; align-items:center; justify-content:center;
  font-size: 16px;
}

.icon-almoco { background: rgba(118,119,69,.12); }
.icon-hh     { background: rgba(212,101,74,.12); }

.item-text h4 {
  font-size: 14px; font-weight: 800;
  color: var(--mahogany);
  margin-bottom: 3px;
}

.item-text p {
  font-size: 13px; font-weight: 500;
  color: var(--silhouette); opacity: .7;
  line-height: 1.55;
}

.acesso-box {
  padding: 16px 20px;
  border-radius: 6px;
  font-size: 12px; font-weight: 700;
  letter-spacing: .06em;
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 32px;
}

.acesso-almoco {
  background: rgba(118,119,69,.1);
  color: var(--cipo);
  border-left: 3px solid var(--cipo);
}

.acesso-hh {
  background: rgba(212,101,74,.1);
  color: var(--terracota);
  border-left: 3px solid var(--terracota);
}

/* — HAPPY HOUR — */
.momento-hh {
  background: var(--hh-bg);
  padding: 80px 60px;
  position: relative;
  overflow: hidden;
}

.momento-hh::before {
  content: 'NOITE';
  position: absolute;
  bottom: -30px; right: -20px;
  font-size: 120px; font-weight: 900;
  color: rgba(212,101,74,.06);
  line-height:1; letter-spacing:-.04em;
  pointer-events:none;
}

.hh-titulo-cor { color: var(--terracota); }

.momento-hh .item-text h4 { color: var(--naperon); }
.momento-hh .item-text p  { color: rgba(255,255,255,.5); }
.momento-hh .momento-horario { color: rgba(255,255,255,.4); }

/* ─────────────────────────────────────────
   DOBRA 3 — VIP
───────────────────────────────────────── */
/*
.vip {
  background: var(--teal);

}
.vip::after {

}
*/
.vip {
  position: relative; inset:0;
  background-image: url('bg.jpg');
  background-size: cover;
  background-position: center 30%;
    padding: 100px 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.vip::after {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(
    160deg,
    rgba(20,40,44,0.93) 0%,
    rgba(32,79,88,0.80) 45%,
    rgba(109,71,65,0.70) 100%
  );
  backdrop-filter: blur(5px);
}




.vip > * { position: relative; z-index:1; }

.vip-tag {
  font-size: 11px; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--naperon); opacity: .8;
  margin-bottom: 14px;
}

.vip-titulo {
  font-size: clamp(30px, 3.5vw, 50px);
  font-weight: 900;
  line-height: 1.05;
  color: var(--white);
  margin-bottom: 16px;
}

.vip-titulo em {
  font-family: 'ZT Glora Pro', serif;
  font-style: normal;
  color: var(--naperon);
}

.vip-desc {
  font-size: 15px;
  color: rgba(255,255,255,.65);
  line-height: 1.7;
  margin-bottom: 36px;
}

.vip-beneficios {
  display: flex; flex-direction: column; gap: 14px;
  margin-bottom: 40px;
}

.vip-item {
  display: flex; align-items: flex-start; gap: 12px;
  color: rgba(255,255,255,.85);
  font-size: 14px; line-height: 1.5;
}

.vip-check {
  width: 20px; height: 20px; flex-shrink:0;
  border-radius: 50%;
  background: rgba(222,173,149,.2);
  display: flex; align-items:center; justify-content:center;
  margin-top: 2px;
}

.vip-check svg { width:10px; height:10px; }

/* FORM */
.vip-form-wrap {
  background: var(--white);
  padding: 48px 44px;
  border-radius: 4px;
  position: relative;
}

.form-eyebrow {
  font-size: 10px; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--terracota); margin-bottom: 10px;
}

.form-heading {
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 900; line-height: 1.15;
  color: var(--mahogany); margin-bottom: 6px;
}

.form-desc {
  font-size: 13px; color: var(--silhouette);
  opacity: .65; margin-bottom: 28px; line-height: 1.6;
}

.form-group { margin-bottom: 14px; }

.form-group label {
  display:block; font-size: 10px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--silhouette); opacity: .6; margin-bottom: 6px;
}

.form-group input,
.form-group select {
  width:100%; padding: 13px 16px;
  background: var(--cloud);
  border: 1.5px solid rgba(88,81,77,.12);
  border-radius: 4px;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px; font-weight: 500;
  color: var(--silhouette); outline:none;
  transition: border-color .2s, box-shadow .2s;
  appearance: none;
}

.form-group input:focus,
.form-group select:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(32,79,88,.1);
}

.form-group input::placeholder { color: rgba(88,81,77,.3); }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

.btn-submit {
  width:100%; padding: 17px 24px;
  background: var(--terracota); color: var(--white);
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 800;
  letter-spacing: .12em; text-transform: uppercase;
  border: none; border-radius: 4px;
  cursor: pointer; margin-top: 6px;
  transition: background .2s, transform .15s;
}
.btn-submit:hover { background: var(--mahogany); transform: translateY(-1px); }

.form-privacy {
  font-size: 10px; color: var(--silhouette);
  opacity: .4; text-align:center;
  margin-top: 12px; line-height: 1.6;
}

/* success */
.success-state {
  display:none; flex-direction:column;
  align-items:center; text-align:center;
  gap: 14px; padding: 32px 0;
}

.success-icon {
  width:56px; height:56px;
  background: var(--teal); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}

.success-title {
  font-size: 22px; font-weight: 900;
  color: var(--mahogany);
}

.success-text {
  font-size: 13px; opacity:.65;
  line-height: 1.6; max-width: 280px;
}

.btn-whatsapp {
  display:inline-flex; align-items:center; gap:8px;
  padding: 15px 26px;
  background: #25D366; color: white;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  text-decoration: none; border-radius: 4px;
  transition: opacity .2s;
}
.btn-whatsapp:hover { opacity:.88; }

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
footer {
  background: var(--silhouette);
  padding: 28px 64px;
  display:flex; justify-content:space-between; align-items:center;
}

.footer-logo { height:28px; }
.footer-credits { display:flex; gap:24px; }
.footer-by { font-size:11px; color:rgba(255,255,255,.28); letter-spacing:.07em; }

/* ─────────────────────────────────────────
   ANIMAÇÕES ENTRADA
───────────────────────────────────────── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}

.hero-tag     { animation: fadeUp .6s .1s ease forwards; opacity:0; }
.hero-title   { animation: fadeUp .6s .25s ease forwards; opacity:0; }
.hero-horarios{ animation: fadeUp .6s .4s ease forwards; opacity:0; }
.hero-ctas    { animation: fadeUp .6s .55s ease forwards; opacity:0; }

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 960px) {
  .nav { padding: 22px 28px; }
  .hero-content { padding: 40px 24px 72px; }

  .momentos { grid-template-columns: 1fr; }
  .momento-almoco,
  .momento-hh { padding: 60px 32px; }
  .momento-almoco::before,
  .momento-hh::before { font-size: 100px; }

  .vip { grid-template-columns: 1fr; padding: 64px 32px; gap: 48px; }

  footer { flex-direction:column; gap:12px; padding:24px 28px; text-align:center; }
  .footer-credits { flex-direction:column; gap:6px; align-items:center; }

  .form-row { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .hero-ctas { flex-direction: column; align-items: center; }
  .btn-primary, .btn-outline {width: 100%;justify-content: center;text-align: center;}
  .horario-pill { font-size: 12px; }
}


/* =================================================================
   FASE 2 — ESTILOS ADICIONAIS
   (hero com 3 camadas, programação, gastronomia, vídeo,
    galeria masonry, lightbox, patrocinadores)
================================================================= */

/* ─── HERO ─── */
.hero3 { min-height:90vh; display:flex; flex-direction:column; position:relative; overflow:hidden; }
.hero3-bg { position:absolute; inset:0; background-image:url('bg-hero.jpg'); background-size:cover; background-position:center; z-index:0; }
.hero3-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(10,20,22,0.45) 0%, rgba(10,20,22,0.08) 45%, rgba(10,20,22,0.38) 100%); z-index:1; }
.hero3-nav { position:relative; z-index:10; padding:28px 60px; display:flex; align-items:center; justify-content:space-between; }

/* logo: centralizado vertical e horizontal no espaço restante */
.hero3-content {
  position:relative; z-index:5;
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 0 60px;
}
.hero3-logo-wrap { display:flex; align-items:center; justify-content:center; }
.hero3-logo-wrap img {width: 100%;max-width: 500px;height:auto;filter:drop-shadow(0 4px 32px rgba(0,0,0,0.28));z-index: 10;}

/* atracoes: fixo no canto inferior direito do hero */
.hero3-atracoes-wrap {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 6;
  pointer-events: none;
}
.hero3-atracoes-wrap img {
  width: auto;
  max-width: 40vw;
  max-height: 75vh;
  height: auto;
  display: block;
  filter: drop-shadow(0 8px 32px rgba(0,0,0,0.3));
}

.hero3-ctas {position: absolute;z-index:10;display:flex;gap:12px;flex-wrap:wrap;padding:20px 60px 32px;align-items:center;bottom: 0;}

/* ─── BOTÕES UNITICKET ─── */
.btn-almoco {display:inline-flex;align-items:center;gap:8px;padding:16px 28px;background:var(--cipo);color:var(--white);font-family:'Montserrat',sans-serif;font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;border-radius:4px;transition:background .2s,transform .15s;border:none;cursor:pointer;text-align: center;}
.btn-almoco:hover { background:#5a5c33; transform:translateY(-2px); }
.btn-hh {display:inline-flex;align-items:center;gap:8px;padding:16px 28px;background:var(--terracota);color:var(--white);font-family:'Montserrat',sans-serif;font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;border-radius:4px;transition:background .2s,transform .15s;border:none;cursor:pointer;text-align: center;}
.btn-hh:hover { background:var(--mahogany); transform:translateY(-2px); }

/* ─── TICKER ─── */
.ticker { background:var(--mahogany); padding:15px 0; overflow:hidden; white-space:nowrap; }
.ticker-track { display:inline-flex; gap:40px; animation:ticker 22s linear infinite; }
.ticker-item { font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--naperon); flex-shrink:0; display:flex; align-items:center; gap:14px; }
.ticker-item::after { content:'✦'; color:var(--terracota); font-size:7px; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ─── PROGRAMAÇÃO (boxed) ─── */
.programacao { background:var(--cloud); padding:80px 0 0; overflow:hidden; }
.prog-inner { max-width:1100px; margin:0 auto; padding:0 40px; }
.prog-header { padding-bottom:48px; }
.prog-eyebrow { font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--terracota); margin-bottom:12px; }
.prog-titulo { font-size:clamp(28px,3.5vw,44px); font-weight:900; line-height:1.05; color:var(--mahogany); }
.prog-titulo em { font-family:'Playfair Display',serif; font-style:italic; color:var(--teal); }
.prog-tabs { display:flex; border-bottom:2px solid rgba(88,81,77,.1); overflow-x:auto; scrollbar-width:none; }
.prog-tabs::-webkit-scrollbar { display:none; }
.prog-tab { padding:14px 28px; font-size:13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--silhouette); opacity:.4; cursor:pointer; border:none; background:transparent; border-bottom:3px solid transparent; margin-bottom:-2px; white-space:nowrap; transition:opacity .2s,border-color .2s; font-family:'Montserrat',sans-serif; }
.prog-tab:hover { opacity:.7; }
.prog-tab.active { opacity:1; color:var(--mahogany); border-bottom-color:var(--terracota); }
.prog-panels { padding:48px 0 80px; }
.prog-panel { display:none; }
.prog-panel.active { display:block; }
.prog-day-badge { display:inline-flex; align-items:center; gap:10px; margin-bottom:32px; }
.day-num { font-size:clamp(48px,6vw,72px); font-weight:900; line-height:1; color:var(--mahogany); }
.day-info { display:flex; flex-direction:column; gap:4px; }
.day-month { font-size:13px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--terracota); }
.day-weekday { font-size:12px; font-weight:600; color:var(--silhouette); opacity:.5; letter-spacing:.08em; text-transform:uppercase; }
.prog-momentos { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
.prog-momentos.hh-only { grid-template-columns:1fr; max-width:560px; }
.prog-card { position:relative; overflow:hidden; }
.prog-card-almoco { background:var(--almoco-bg); }
.prog-card-hh { background:var(--hh-bg); }

/* artista card */
.prog-card-artist {position:relative;overflow:hidden;min-height: 40vh;display:flex;align-items:flex-end;background:#111;}
.prog-artist-img { width:100%; height:100%; object-fit:cover; object-position:top center; position:absolute; inset:0; transition:transform .4s; }
.prog-card-hh:hover .prog-artist-img { transform:scale(1.04); }
.prog-artist-overlay { position:relative; z-index:1; width:100%; padding:80px 28px 20px; background:linear-gradient(to top, rgba(0,0,0,0.88) 0%, rgba(0,0,0,0) 100%); }
.prog-artist-badge { display:inline-flex; align-items:center; gap:6px; padding:4px 10px; background:var(--terracota); border-radius:100px; font-size:9px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:white; margin-bottom:8px; }
.prog-artist-name { font-size:clamp(22px,2.5vw,32px); font-weight:900; color:var(--white); line-height:1; }
.prog-artist-horario { font-size:11px; font-weight:600; color:rgba(255,255,255,.5); letter-spacing:.08em; margin-top:4px; }

.prog-card-body { padding:24px 28px 28px; }
.prog-card-label { font-size:10px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; margin-bottom:8px; }
.label-almoco { color:var(--cipo); }
.label-hh { color:var(--terracota); }
.prog-card-items { display:flex; flex-direction:column; gap:7px; margin-top:10px; }
.prog-item { font-size:13px; font-weight:500; display:flex; align-items:center; gap:8px; }
.almoco-item { color:var(--silhouette); opacity:.75; }
.hh-item { color:rgba(255,255,255,.55); }
.prog-item::before { content:''; display:block; width:4px; height:4px; border-radius:50%; flex-shrink:0; }
.almoco-item::before { background:var(--cipo); }
.hh-item::before { background:var(--terracota); opacity:.6; }
.prog-cta { margin-top:36px; display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

/* ─── GASTRONOMIA ─── */
.gastronomia { background:var(--mahogany); padding:100px 80px; position:relative; overflow:hidden; }
.gastro-bg-text { position:absolute; bottom:-40px; right:-20px; font-size:200px; font-weight:900; color:rgba(255,255,255,.03); line-height:1; pointer-events:none; }
.gastro-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.gastro-eyebrow { font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--naperon); opacity:.7; margin-bottom:14px; }
.gastro-titulo { font-size:clamp(28px,3.5vw,48px); font-weight:900; line-height:1.05; color:var(--white); margin-bottom:14px; }
.gastro-sub { font-size:15px; color:rgba(255,255,255,.6); line-height:1.7; margin-bottom:36px; }
.chefs-grid {display:grid;grid-template-columns:1fr 1fr;gap:2px;/* max-height: 80vh; */}
.chef-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); padding:0; display:flex; flex-direction:column; align-items:center; text-align:center; gap:0; overflow:hidden; }
.chef-foto {width:100%;aspect-ratio: 2/3;overflow:hidden;background:rgba(222,173,149,.1);display:flex;align-items:center;justify-content:center;max-height: 50vh;}
.chef-foto img {width:100%;height:100%;object-fit: cover;object-position: top center;transition:transform .3s;}
.chef-card:hover .chef-foto img { transform:scale(1.05); }
.chef-name { font-size:15px; font-weight:800; color:var(--naperon); padding:16px 16px 4px; }
.chef-desc { font-size:12px; color:rgba(255,255,255,.45); line-height:1.55; padding:0 16px 20px; }

/* ─── VÍDEO ─── */
.video-section { background:var(--silhouette); padding:80px; text-align:center; }
.video-eyebrow { font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--naperon); opacity:.6; margin-bottom:12px; }
.video-titulo { font-size:clamp(24px,3vw,40px); font-weight:900; color:var(--white); margin-bottom:40px; }
.video-titulo em { font-family:'Playfair Display',serif; font-style:italic; color:var(--naperon); }
.video-wrap { max-width:900px; margin:0 auto; border-radius:6px; overflow:hidden; box-shadow:0 24px 64px rgba(0,0,0,0.4); }
.video-wrap video { width:100%; display:block; background:#000; }

/* ─── HISTÓRIA + GALERIA MASONRY ─── */
.historia { background:var(--cloud); padding:100px 80px; }
.historia-header { text-align:center; margin-bottom:56px; }
.historia-eyebrow { font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--terracota); margin-bottom:12px; }
.historia-titulo { font-size:clamp(28px,3.5vw,48px); font-weight:900; line-height:1.05; color:var(--mahogany); margin-bottom:16px; }
.historia-titulo em { font-family:'Playfair Display',serif; font-style:italic; color:var(--teal); }
.historia-texto { font-size:15px; color:var(--silhouette); opacity:.7; line-height:1.7; max-width:600px; margin:0 auto; }

/* masonry com CSS columns */
.galeria-masonry {
  column-count: 3;
  column-gap: 6px;
  margin-bottom: 56px;
}
.galeria-item {
  break-inside: avoid;
  margin-bottom: 6px;
  overflow: hidden;
  border-radius: 3px;
  cursor: pointer;
  position: relative;
  background: rgba(88,81,77,.1);
  display: block;
}
.galeria-item img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .4s, filter .3s;
  filter: brightness(.95);
}
.galeria-item:hover img {
  transform: scale(1.04);
  filter: brightness(1.05);
}
/* placeholder sem foto */
.galeria-item-placeholder {
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 8px;
  background: rgba(88,81,77,.08);
  color: rgba(88,81,77,.3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.galeria-item-placeholder span { font-size: 28px; opacity: .4; }

/* overlay hover */
.galeria-item::after {
  content: '🔍';
  position: absolute;
  inset: 0;
  background: rgba(32,79,88,0.0);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  opacity: 0;
  transition: opacity .3s, background .3s;
}
.galeria-item:hover::after {
  opacity: 1;
  background: rgba(32,79,88,0.25);
}

.historia-cta { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

/* ─── LIGHTBOX ─── */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,0.92);
  align-items: center;
  justify-content: center;
  padding: 40px;
  cursor: zoom-out;
}
.lightbox.open { display: flex; }
.lightbox-img {
  max-width: 90vw;
  max-height: 88vh;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 32px 80px rgba(0,0,0,0.5);
  cursor: default;
  animation: lbIn .2s ease;
}
@keyframes lbIn {
  from { opacity:0; transform:scale(.96); }
  to   { opacity:1; transform:scale(1); }
}
.lightbox-close {
  position: absolute;
  top: 20px; right: 24px;
  font-size: 32px;
  color: rgba(255,255,255,.6);
  cursor: pointer;
  line-height: 1;
  transition: color .2s;
  background: none; border: none;
}
.lightbox-close:hover { color: white; }
.lightbox-nav {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.1);
  border: none; cursor: pointer;
  color: white; font-size: 28px;
  padding: 16px 14px;
  border-radius: 4px;
  transition: background .2s;
  line-height: 1;
}
.lightbox-nav:hover { background: rgba(255,255,255,.2); }
.lightbox-prev { left: 16px; }
.lightbox-next { right: 16px; }
.lightbox-counter {
  position: absolute;
  bottom: 20px; left: 50%; transform: translateX(-50%);
  font-size: 12px; font-weight: 600;
  color: rgba(255,255,255,.4);
  letter-spacing: .1em;
  font-family: 'Montserrat', sans-serif;
}

/* ─── PATROCINADORES ─── */
.patrocinadores {background:var(--silhouette);padding:36px 80px;border-top:1px solid rgba(255,255,255,.07);display: flex;flex-direction: row;justify-content: center;max-width: 100vw;flex-wrap: wrap;}
.patrocinadores img {max-width:157px;margin:0 auto;opacity:.8;}

/* ─── RESPONSIVE ─── */
@media (max-width:960px) {
  .hero3-atracoes-wrap img { max-width:280px; max-height:50vh; }
  .hero3-logo-wrap img {max-width: 270px;}
  .hero3-nav { padding:22px 28px; }
  .hero3-ctas { padding:16px 28px 28px; }
  .prog-inner { padding:0 24px; }
  .prog-panels { padding:36px 0 60px; }
  .prog-momentos { grid-template-columns:1fr; }
  .prog-momentos.hh-only { max-width:100%; }
  .gastronomia { padding:64px 32px; }
  .gastro-inner { grid-template-columns:1fr; gap:48px; }
  .video-section { padding:60px 32px; }
  .historia { padding:64px 32px; }
  .galeria-masonry { column-count:2; }
  .patrocinadores { padding:28px 32px; }
  footer { flex-direction:column; gap:12px; padding:24px 32px; text-align:center; }
}
@media (max-width:480px) {
  .chefs-grid { grid-template-columns:1fr; }
  .galeria-masonry { column-count:1; }
  .prog-cta { flex-direction:column; align-items:flex-start; }
  .hero3-nav > div { gap:6px; }
  .hero3-nav .btn-almoco, .hero3-nav .btn-hh { font-size:10px; padding:8px 12px; }
  .hero3-atracoes-wrap img {max-width: 0;}
}
/* =================================================================
   AJUSTES FINAIS — 02/04
================================================================= */

/* ─── HERO: tagline abaixo do logo ─── */
.hero3-logo-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin-bottom: 190px;
}
.hero3-tagline {
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 700;
  color: var(--white);
  text-align: center;
  line-height: 1.4;
  letter-spacing: .01em;
  max-width: 480px;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}

/* ─── HERO: CTAs como âncoras ─── */
.hero3-ctas {
  position: absolute;
  z-index: 10;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding: 20px 60px 32px;
  align-items: center;
  bottom: 0;
}

/* ─── MOMENTOS: sem acesso-box ─── */
.acesso-box { display: none; }

.btn-large {
  width: 100%;
  justify-content: center;
  padding: 18px 28px;
  font-size: 14px;
}
.btn-sub-note {
  font-size: 11px;
  color: var(--cipo);
  opacity: .7;
  margin-top: 10px;
  letter-spacing: .04em;
  line-height: 1.5;
}

/* ─── CARROSSEL ARTISTAS (Happy Hour) ─── */
.artistas-carrossel-wrap {
  position: relative;
  margin-bottom: 20px;
  overflow: hidden;
}
.artistas-carrossel {
  display: flex;
  transition: transform .45s ease;
  will-change: transform;
}
.artista-slide {
  min-width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 6px;
  overflow: hidden;
  background: #111;
  min-height: 320px;
}
.artista-col-info {
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}
.artista-col-img {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.artista-col-img img {
  width: 100%;
  /* max-height: 300px; */
  object-fit: contain;
  object-position: bottom center;
  display: flex;
  margin: 0 auto;
  display: block;
}
.artista-itens {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 4px;
}
.artista-itens li {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,.55);
  display: flex;
  align-items: center;
  gap: 8px;
}
.artista-itens li::before {
  content: '';
  display: block;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--terracota);
  opacity: .6;
  flex-shrink: 0;
}

/* mobile: empilha (info em cima, foto embaixo) */
@media (max-width: 600px) {
  .artista-slide {
    grid-template-columns: 1fr;
    grid-template-rows: auto 220px;
  }
  .artista-col-info { padding: 20px 18px; }
  .artista-col-img { min-height: 220px; }
}
.artista-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--terracota);
  border-radius: 100px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: white;
  margin-bottom: 8px;
}
.artista-nome {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 900;
  color: var(--white);
  line-height: 1;
  margin-bottom: 4px;
}
.artista-data {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.5);
  letter-spacing: .08em;
}

/* setas do carrossel */
.artistas-prev,
.artistas-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  background: rgba(0,0,0,.45);
  border: none;
  color: white;
  font-size: 28px;
  width: 40px; height: 40px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background .2s;
  padding-bottom: 2px;
}
.artistas-prev:hover,
.artistas-next:hover { background: rgba(0,0,0,.7); }
.artistas-prev { left: 10px; }
.artistas-next { right: 10px; }

/* dots */
.artistas-dots {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-bottom: 24px;
}
.artista-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  cursor: pointer;
  transition: background .2s, transform .2s;
}
.artista-dot.active {
  background: var(--terracota);
  transform: scale(1.3);
}

/* ─── GALERIA: grid quadrado desktop ─── */
.galeria-wrap {
  position: relative;
  margin-bottom: 56px;
}
.galeria-grid-quad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.galeria-grid-quad .galeria-item {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 3px;
  cursor: pointer;
  position: relative;
  background: rgba(88,81,77,.1);
  margin-bottom: 0;
}
.galeria-grid-quad .galeria-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s, filter .3s;
  filter: brightness(.95);
}
.galeria-grid-quad .galeria-item:hover img {
  transform: scale(1.04);
  filter: brightness(1.05);
}
.galeria-grid-quad .galeria-item::after {
  content: '🔍';
  position: absolute; inset: 0;
  background: rgba(32,79,88,0);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; opacity: 0;
  transition: opacity .3s, background .3s;
}
.galeria-grid-quad .galeria-item:hover::after {
  opacity: 1;
  background: rgba(32,79,88,.25);
}

/* setas galeria — só mobile */
.galeria-arrow {
  display: none;
}

/* ─── MOBILE ─── */
@media (max-width: 768px) {

  /* galeria vira carrossel */
  .galeria-grid-quad {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 8px;
    padding-bottom: 8px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .galeria-grid-quad::-webkit-scrollbar { display: none; }
  .galeria-grid-quad .galeria-item {
    flex: 0 0 75vw;
    aspect-ratio: 1 / 1;
    scroll-snap-align: start;
    border-radius: 6px;
  }

  /* setas visíveis no mobile */
  .galeria-arrow {
    display: flex;
    position: absolute;
    top: 50%; transform: translateY(-50%);
    z-index: 5;
    background: rgba(88,81,77,.7);
    border: none;
    color: white;
    font-size: 28px;
    width: 36px; height: 36px;
    border-radius: 50%;
    align-items: center; justify-content: center;
    cursor: pointer;
    line-height: 1;
    padding-bottom: 2px;
  }
  .galeria-arrow-left { left: 4px; }
  .galeria-arrow-right { right: 4px; }

  /* hero tagline menor */
  .hero3-tagline { font-size: 13px; max-width: 260px; }
  .hero3-ctas { padding: 16px 28px 28px; flex-wrap: wrap; gap: 8px; }
  .btn-large { font-size: 13px; padding: 16px 20px; }
}

@media (max-width: 480px) {
  .hero3-ctas { flex-direction: column; align-items: stretch; }
  .hero3-ctas a { text-align: center; justify-content: center; }
  .galeria-grid-quad .galeria-item { flex: 0 0 85vw; }
}

/* =================================================================
   PROGRAMAÇÃO COMPLETA + PARCEIROS GASTRONÔMICOS
================================================================= */

/* ─── PROGRAMAÇÃO COMPLETA ─── */
.programacao-completa {
  background: var(--cloud);
  padding: 80px 0;
}
.prog-completa-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}
.prog-completa-header {
  text-align: center;
  margin-bottom: 56px;
}
.prog-completa-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--terracota);
  margin-bottom: 12px;
}
.prog-completa-titulo {
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 900;
  line-height: 1.05;
  color: var(--mahogany);
  margin-bottom: 12px;
}
.prog-completa-titulo em {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  color: var(--teal);
}
.prog-completa-sub {
  font-size: 14px;
  color: var(--silhouette);
  opacity: .65;
  letter-spacing: .04em;
}

.prog-completa-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  margin-bottom: 48px;
}
.prog-dia {
  background: var(--white);
  padding: 28px 24px;
  border-top: 3px solid var(--terracota);
}
.prog-dia-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(88,81,77,.08);
}
.prog-dia-num {
  font-size: 44px;
  font-weight: 900;
  line-height: 1;
  color: var(--mahogany);
}
.prog-dia-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.prog-dia-mes {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--terracota);
}
.prog-dia-semana {
  font-size: 11px;
  font-weight: 600;
  color: var(--silhouette);
  opacity: .55;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.prog-dia-lista {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 0;
  margin: 0;
}
.prog-dia-lista li {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 8px;
  align-items: baseline;
  padding: 8px 10px;
  border-radius: 4px;
  transition: background .2s;
}
.prog-dia-lista li:hover {
  background: rgba(212,101,74,.06);
}
.prog-h {
  font-size: 11px;
  font-weight: 800;
  color: var(--terracota);
  letter-spacing: .04em;
}
.prog-atr {
  font-size: 13px;
  font-weight: 600;
  color: var(--silhouette);
  line-height: 1.35;
}
.prog-destaque {
  background: rgba(212,101,74,.1);
  border-left: 3px solid var(--terracota);
}
.prog-destaque .prog-atr {
  font-weight: 800;
  color: var(--mahogany);
  font-size: 14px;
}

.prog-completa-cta {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* ─── PARCEIROS GASTRONÔMICOS ─── */
.parceiros {
  background: var(--white);
  padding: 80px 0;
  border-top: 1px solid rgba(88,81,77,.06);
}
.parceiros-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}
.parceiros-header {
  text-align: center;
  margin-bottom: 64px;
}
.parceiros-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--terracota);
  margin-bottom: 12px;
}
.parceiros-titulo {
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 900;
  line-height: 1.05;
  color: var(--mahogany);
}
.parceiros-titulo em {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  color: var(--teal);
}

.parceiros-bloco {
  margin-bottom: 56px;
}
.parceiros-bloco:last-child {
  margin-bottom: 0;
}
.parceiros-bloco-titulo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 28px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(88,81,77,.1);
}
.parceiros-icon {
  font-size: 24px;
}
.parceiros-bloco-titulo h3 {
  font-size: 20px;
  font-weight: 900;
  color: var(--mahogany);
  letter-spacing: .01em;
}
.parceiros-bloco-sub {
  font-size: 13px;
  font-weight: 500;
  color: var(--silhouette);
  opacity: .6;
  letter-spacing: 0;
}

.parceiros-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}
.parceiro-item {
  background: var(--cloud);
  border-radius: 4px;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  transition: transform .2s, box-shadow .2s;
}
.parceiro-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(88,81,77,.08);
}
.parceiro-item img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
  filter: drop-shadow(2px 4px 6px black);
}
.parceiro-item.placeholder {
  background: rgba(88,81,77,.05);
  border: 1px dashed rgba(88,81,77,.15);
}
.parceiro-item.placeholder span {
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  color: var(--silhouette);
  opacity: .55;
  letter-spacing: .04em;
  line-height: 1.3;
  padding: 4px;
}

/* footer: classificação 18 */
.footer-by.classificacao {
  font-weight: 700;
  letter-spacing: .12em;
  opacity: .7;
}

/* ─── RESPONSIVE ─── */
@media (max-width: 960px) {
  .prog-completa-inner,
  .parceiros-inner {
    padding: 0 24px;
  }
  .prog-completa-grid {
    grid-template-columns: 1fr 1fr;
  }
  .parceiros-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 600px) {
  .programacao-completa,
  .parceiros {
    padding: 60px 0;
  }
  .prog-completa-grid {
    grid-template-columns: 1fr;
  }
  .parceiros-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  .parceiro-item {
    padding: 12px;
  }
  .prog-completa-cta {
    flex-direction: column;
    align-items: stretch;
  }
}
@media (max-width: 380px) {
  .parceiros-grid {
    grid-template-columns: 1fr 1fr;
  }
}
