
:root{
  --bg:#0f1216;
  --panel:#171b20;
  --panel-soft:rgba(255,255,255,.04);
  --text:#ffffff;
  --muted:rgba(255,255,255,.62);
  --gold:#f3a62a;
  --border:rgba(255,255,255,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,sans-serif;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.section-dark{background:#101318;position:relative;overflow:hidden}
.content-section{padding:96px 0}
.centered-section{text-align:center}
.eyebrow{display:inline-block;color:var(--gold);font-size:11px;font-weight:800;letter-spacing:.28em;text-transform:uppercase}
.eyebrow.center{display:block;text-align:center}
.pill{padding:8px 14px;border-radius:999px;background:rgba(243,166,42,.1);border:1px solid rgba(243,166,42,.18)}
h1,h2,h3{margin:0;font-family:'Oswald','Inter',sans-serif;text-transform:uppercase}
h1{font-size:clamp(52px,7vw,94px);line-height:.9;letter-spacing:-.04em}
h2{font-size:clamp(42px,5vw,72px);line-height:.92;letter-spacing:-.04em}
.gold{color:var(--gold)}
.white{color:#fff}
.topbar{position:sticky;top:0;z-index:50;background:rgba(13,16,20,.82);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:16px}
.brand img{width:58px;height:58px;object-fit:contain;filter:drop-shadow(0 10px 30px rgba(0,0,0,.28))}
.menu{display:flex;gap:28px;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.menu a:hover{color:var(--gold)}
.ghost-btn{padding:11px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.12);font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.hero{padding:84px 0 64px;background-image:url('../img/hero-bg.jpg');background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,12,15,.88) 0%,rgba(10,12,15,.74) 40%,rgba(10,12,15,.45) 100%)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center;min-height:calc(100vh - 150px)}
.edition{margin:18px 0 0;color:var(--gold);font-size:clamp(18px,2.2vw,25px);font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.meta-lines{margin-top:26px;color:var(--muted);font-size:14px;line-height:1.9}
.meta-lines strong{color:#fff}
.countdown-wrap{margin-top:28px;display:grid;gap:14px}
.countdown-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.countdown-head small{color:rgba(255,255,255,.48);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.countdown-pill{background:rgba(243,166,42,.08);border:1px solid rgba(243,166,42,.2)}
.counter-row{display:flex;gap:14px;flex-wrap:wrap}
.counter-box{min-width:92px;padding:16px 18px;border-radius:22px;background:rgba(0,0,0,.34);border:1px solid rgba(243,166,42,.12);box-shadow:0 18px 46px rgba(0,0,0,.24);text-align:center}
.counter-box b{display:block;color:var(--gold);font-size:34px;font-family:'Oswald',sans-serif;line-height:1}
.counter-box span{display:block;margin-top:8px;color:rgba(255,255,255,.42);font-size:10px;font-weight:800;letter-spacing:.24em;text-transform:uppercase}
.hero-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.primary-btn,.secondary-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;border-radius:999px;font-size:13px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.primary-btn{background:var(--gold);color:#16110a;box-shadow:0 18px 50px rgba(243,166,42,.25)}
.secondary-btn{border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.86);background:rgba(255,255,255,.02)}
.hero-media{display:grid;grid-template-columns:1.08fr .92fr;grid-template-rows:1fr 1fr;gap:14px}
.media-card,.mosaic-card,.flavor-card,.timeline-card,.news-card,.map-card{border:1px solid var(--border);background:var(--panel-soft);box-shadow:0 20px 60px rgba(0,0,0,.24)}
.media-card{padding:0px;border-radius:30px;background:rgba(255,255,255,.04);backdrop-filter:blur(10px)}
.media-card img{width:100%;height:100%;object-fit:cover;border-radius:22px}
.media-tall{grid-row:span 2;min-height:50px}
.stats{padding:40px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat-item strong{display:block;font-family:'Oswald',sans-serif;color:var(--gold);font-size:56px;line-height:1}
.stat-item span{display:block;margin-top:8px;color:rgba(255,255,255,.44);font-size:13px}
.event-grid{display:grid;grid-template-columns:.98fr 1.02fr;gap:56px;align-items:center}
.event-mosaic{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.mosaic-large{grid-column:span 2}
.mosaic-card{padding:0px;border-radius:28px}
.mosaic-card img{width:100%;height:100%;object-fit:cover;border-radius:20px}
.mosaic-large img{height:280px}.mosaic-card:not(.mosaic-large) img{height:180px}
.event-copy p{margin:26px 0 0;color:var(--muted);font-size:16px;line-height:2}
.feature-list{list-style:none;padding:0;margin:30px 0 0;display:grid;gap:16px}
.feature-list li{position:relative;padding-left:26px;color:rgba(255,255,255,.74);line-height:1.9}
.feature-list li::before{content:'●';position:absolute;left:0;top:0;color:var(--gold);font-size:12px}
.gallery-strip{padding:18px 0 8px}
.flavor-carousel{overflow:hidden;position:relative;padding-bottom:8px}
.flavor-carousel::before,.flavor-carousel::after{content:'';position:absolute;top:0;bottom:8px;width:84px;z-index:2;pointer-events:none}
.flavor-carousel::before{left:0;background:linear-gradient(90deg,var(--bg) 0%,rgba(10,12,15,0) 100%)}
.flavor-carousel::after{right:0;background:linear-gradient(270deg,var(--bg) 0%,rgba(10,12,15,0) 100%)}
.flavor-carousel-track{display:flex;align-items:center;gap:16px;width:max-content;animation:carouselScroll 42s linear infinite;will-change:transform}
.flavor-carousel-track:hover{animation-play-state:paused}
.flavor-carousel-track img{min-width:270px;width:270px;height:154px;object-fit:cover;border-radius:24px;border:1px solid var(--border);box-shadow:0 18px 42px rgba(0,0,0,.24);flex-shrink:0}
@keyframes carouselScroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 8px))}}
.center-title{text-align:center}
.section-intro{max-width:720px;margin:22px auto 0;color:rgba(255,255,255,.56);font-size:15px;line-height:1.9}.section-intro.left{margin-left:0}
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px}
.flavor-card{overflow:hidden;border-radius:28px;background:var(--panel)}
.flavor-card img{width:100%;height:300px;object-fit:cover;border-bottom:1px solid var(--border)}
.card-copy{padding:18px 18px 20px}.card-copy h3{font-size:18px;line-height:1.05}.card-copy p{margin:8px 0 0;color:rgba(255,255,255,.5);font-size:13px;line-height:1.6}
.timeline-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.timeline-card{padding:34px 28px;border-radius:26px;background:#16191d;text-align:center}
.timeline-card strong{display:block;font-family:'Oswald',sans-serif;font-size:56px;line-height:1;color:rgba(255,255,255,.14)}
.timeline-card.active{border-color:rgba(243,166,42,.65);box-shadow:0 0 0 1px rgba(243,166,42,.18),0 22px 60px rgba(0,0,0,.28)}
.timeline-card.active strong{color:var(--gold)}
.timeline-card h3{font-size:18px;margin-top:12px}.timeline-card p{margin:14px 0 0;color:rgba(255,255,255,.54);font-size:14px;line-height:1.7}
.timeline-pill{display:inline-flex;margin-top:18px;padding:10px 16px;border-radius:999px;;color:var(--gold);font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px}
.news-card{padding:22px 22px 18px;border-radius:24px;background:#171b20}.news-card span{display:block;color:var(--gold);font-size:11px;font-weight:800;letter-spacing:.22em;text-transform:uppercase}
.news-card h3{margin-top:16px;font-size:21px;line-height:1.5;font-family:'Inter',sans-serif;text-transform:none;font-weight:700}
.news-card footer{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}
.news-card small{color:rgba(255,255,255,.36);font-size:12px}.news-card b{color:var(--gold);font-size:20px}
.location-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:56px;align-items:center}
.location-list{display:grid;gap:16px;margin:28px 0 0}.location-list strong{display:block;color:#fff;font-size:13px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.location-list span{display:block;margin-top:6px;color:rgba(255,255,255,.66);line-height:1.8;font-size:14px}
.map-card{padding:12px;border-radius:30px;background:#d7d3cc}
.map-placeholder{height:380px;border-radius:22px;background:linear-gradient(180deg,#f0ede7,#d7d3cc 42%,#c9c6be);position:relative;overflow:hidden}
.map-placeholder::before{content:'';position:absolute;inset:0;background:
linear-gradient(125deg, transparent 44%, rgba(134,145,153,.55) 44.4%, rgba(134,145,153,.55) 45%, transparent 45.3%),
linear-gradient(45deg, transparent 22%, rgba(134,145,153,.55) 22.4%, rgba(134,145,153,.55) 23%, transparent 23.3%),
linear-gradient(90deg, transparent 60%, rgba(90,105,116,.6) 60.2%, rgba(90,105,116,.6) 61%, transparent 61.2%),
radial-gradient(circle at 60% 50%, #c94a43 0 8px, transparent 9px),
radial-gradient(circle at 76% 34%, rgba(66,76,87,.3) 0 5px, transparent 6px),
radial-gradient(circle at 35% 70%, rgba(66,76,87,.3) 0 5px, transparent 6px);
opacity:.9}
.cta-final{position:relative;padding:120px 0 80px;background:url('../img/final.jpg') center/cover no-repeat}
.cta-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,12,15,.76) 0%,rgba(10,12,15,.46) 100%)}
.cta-inner{position:relative;z-index:1;text-align:center}
.cta-inner h2{margin-top:14px}.cta-inner p{max-width:650px;margin:22px auto 0;color:rgba(255,255,255,.62);line-height:1.9}
.supporters{display:flex;justify-content:center;gap:26px;flex-wrap:wrap;margin-top:54px;color:rgba(255,255,255,.28);font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase}
.reveal,.reveal-delay{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}.reveal-delay{transition-delay:.15s}.is-visible{opacity:1;transform:none}
.countdown-ended .counter-box{background:rgba(243,166,42,.1);border-color:rgba(243,166,42,.22)}
@media (max-width:980px){
 .menu,.ghost-btn{display:none}
 .hero-grid,.event-grid,.location-grid{grid-template-columns:1fr}
 .cards-grid,.news-grid,.timeline-grid,.stats-grid{grid-template-columns:1fr 1fr}
 .hero{padding-top:42px}
 .hero-media{order:-1}
 .media-tall{min-height:340px}
}
@media (max-width:640px){
 .container{width:min(100% - 28px,1180px)}
 .content-section{padding:72px 0}
 .hero-grid{gap:34px;min-height:auto}
 .counter-row{gap:10px}
 .counter-box{min-width:76px;padding:14px 10px;border-radius:18px}
 .counter-box b{font-size:28px}
 .hero-media{grid-template-columns:1fr 1fr}
 .media-tall{grid-row:span 2;min-height:280px}
 .stats-grid,.cards-grid,.news-grid,.timeline-grid{grid-template-columns:1fr}
 .flavor-carousel::before,.flavor-carousel::after{width:34px}
 .flavor-carousel-track img{min-width:220px;width:220px;height:132px}
 .supporters{gap:14px;font-size:10px}
}


/* Hover nos cards de notícias */
.news-grid > a{
  display:block;
  text-decoration:none;
  color:inherit;
  transition:transform .3s ease, box-shadow .3s ease;
  border-radius:24px;
}
.news-grid > a:hover{
  transform:translateY(-10px);
}
.news-grid > a:hover .news-card{
  box-shadow:0 22px 54px rgba(0,0,0,.32);
  border-color:rgba(243,166,42,.18);
}

/* Google Maps embed */
.map-card{
  padding:0;
  overflow:hidden;
  background:#11161b;
}
.map-card iframe{
  display:block;
  width:100%;
  height:380px;
  border:0;
  border-radius:30px;
}


/* ===== Mobile responsivo inspirado no vídeo ===== */
.menu-toggle{
  display:none;
  width:46px;
  height:46px;
  border:0;
  border-radius:14px;
  background:transparent;
  padding:0;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
}
.menu-toggle span{
  display:block;
  width:24px;
  height:2.5px;
  border-radius:999px;
  background:#fff;
  transition:transform .28s ease, opacity .28s ease;
}
.mobile-menu{
  display:none;
}
.supporters a{
  color:inherit;
}
.location-list > div{
  display:grid;
  grid-template-columns:54px 1fr;
  gap:14px;
  align-items:flex-start;
}
.location-list > div > i{
  width:46px;
  height:46px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-style:normal;
  font-size:20px;
  background:rgba(243,166,42,.1);
  border:1px solid rgba(243,166,42,.12);
  box-shadow:0 12px 30px rgba(0,0,0,.18);
}
.cta-inner .primary-btn{
  min-width:340px;
}
@media (max-width:980px){
  .topbar{
    position:sticky;
    top:0;
    background:rgba(13,16,20,.92);
  }
  .nav{
    padding:14px 0;
  }
  .brand img{
    width:74px;
    height:auto;
  }
  .menu-toggle{
    display:flex;
    margin-left:auto;
  }
  .mobile-menu{
    position:absolute;
    left:14px;
    right:14px;
    top:72px;
    z-index:55;
    padding:12px;
    border-radius:24px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(12,14,17,.97);
    box-shadow:0 20px 48px rgba(0,0,0,.34);
    backdrop-filter:blur(14px);
  }
  .mobile-menu.is-open{
    display:grid;
    gap:6px;
  }
  .mobile-menu a{
    padding:14px 16px;
    border-radius:16px;
    font-size:13px;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:rgba(255,255,255,.86);
  }
  .mobile-menu a:hover{
    background:rgba(255,255,255,.04);
    color:var(--gold);
  }
  body.menu-open{
    overflow:hidden;
  }
  .menu-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-toggle.is-open span:nth-child(2){opacity:0}
  .menu-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media (max-width:640px){
  body{
    background:#101318;
  }
  .topbar{
    border-bottom:1px solid rgba(255,255,255,.04);
  }
  .nav{
    gap:10px;
  }
  .content-section{
    padding:84px 0;
  }
  .hero{
    padding:26px 0 54px;
    min-height:auto;
    background-image:url('../img/final.jpg');
    background-position:center top;
  }
  .hero-overlay{
    background:linear-gradient(180deg,rgba(8,9,12,.78) 0%,rgba(8,9,12,.86) 34%,rgba(8,9,12,.96) 100%);
  }
  .hero-grid{
    grid-template-columns:1fr;
    gap:0;
    min-height:auto;
  }
  .hero-copy{
    text-align:center;
    max-width:420px;
    margin:0 auto;
    padding-top:10px;
  }
  .hero-copy .pill{
    margin-inline:auto;
  }
  h1{
    margin-top:14px;
    font-size:58px;
    line-height:.9;
  }
  .edition{
    font-size:16px;
    line-height:1.2;
    margin-top:14px;
  }
  .meta-lines{
    margin-top:18px;
    font-size:15px;
    line-height:1.7;
  }
  .hero-media{
    display:none;
  }
  .countdown-wrap{
    margin-top:26px;
  }
  .counter-row{
    justify-content:center;
    gap:12px;
    flex-wrap:nowrap;
  }
  .counter-box{
    min-width:0;
    width:76px;
    padding:14px 8px;
    border-radius:16px;
    background:rgba(10,12,15,.58);
    box-shadow:none;
  }
  .counter-box b{
    font-size:30px;
  }
  .counter-box span{
    font-size:10px;
    letter-spacing:.18em;
  }
  .hero-actions{
    margin-top:22px;
    flex-direction:column;
    align-items:center;
    gap:12px;
  }
  .primary-btn,.secondary-btn{
    width:100%;
    max-width:340px;
    min-height:58px;
    padding:16px 22px;
    font-size:14px;
  }
  .stats{
    padding:12px 0 32px;
  }
  .stats-grid{
    grid-template-columns:repeat(2,1fr);
    gap:24px 10px;
  }
  .stat-item strong{
    font-size:48px;
  }
  .stat-item span{
    font-size:12px;
    max-width:120px;
    margin-inline:auto;
  }
  .event-grid{
    gap:28px;
  }
  .event-mosaic{
    order:2;
    margin-top:10px;
  }
  .event-copy{
    text-align:left;
  }
  .event-copy h2,
  .location-copy h2{
    font-size:52px;
    line-height:.9;
  }
  .event-copy p{
    margin-top:18px;
    font-size:15px;
    line-height:1.8;
  }
  .feature-list{
    margin-top:18px;
    gap:12px;
  }
  .feature-list li{
    font-size:14px;
    line-height:1.7;
  }
  .gallery-strip{
    padding:0 0 16px;
  }
  .flavor-carousel{
    margin-inline:-14px;
    padding-inline:14px;
  }
  .flavor-carousel-track{
    gap:14px;
  }
  .flavor-carousel-track img{
    width:264px;
    min-width:264px;
    height:170px;
    border-radius:20px;
  }
  .center-title{
    font-size:52px;
    line-height:.92;
  }
  .section-intro{
    font-size:15px;
    line-height:1.85;
    max-width:390px;
  }
  .cards-grid{
    grid-template-columns:repeat(2,1fr);
    gap:16px;
    margin-top:30px;
  }
  .flavor-card{
    border-radius:24px;
  }
  .flavor-card img{
    height:170px;
  }
  .card-copy{
    padding:14px 14px 16px;
  }
  .card-copy h3{
    font-size:14px;
  }
  .card-copy p{
    font-size:12px;
    line-height:1.55;
  }
  .timeline-grid{
    grid-template-columns:1fr;
    gap:18px;
    margin-top:28px;
  }
  .timeline-card{
    padding:32px 22px;
    border-radius:26px;
  }
  .timeline-card strong{
    font-size:58px;
    color:rgba(243,166,42,.8);
  }
  .timeline-card h3{
    font-size:16px;
  }
  .timeline-card p{
    font-size:14px;
    line-height:1.7;
  }
  .news-grid{
    grid-template-columns:1fr;
    gap:16px;
    margin-top:28px;
  }
  .news-card{
    padding:22px 18px 18px;
    border-radius:22px;
  }
  .news-card h3{
    font-size:18px;
    line-height:1.45;
  }
  .location-grid{
    gap:24px;
  }
  .location-copy{
    text-align:left;
  }
  .location-list{
    gap:14px;
    margin-top:24px;
  }
  .location-list strong{
    font-size:12px;
  }
  .location-list span{
    margin-top:5px;
    font-size:15px;
    line-height:1.65;
  }
  .location-copy .primary-btn{
    max-width:none;
    margin-top:24px;
  }
  .map-card iframe{
    height:260px;
    border-radius:24px;
  }
  .cta-final{
    padding:90px 0 72px;
    background-position:center center;
  }
  .cta-overlay{
    background:linear-gradient(180deg,rgba(10,12,15,.74) 0%,rgba(10,12,15,.78) 100%);
  }
  .cta-inner h2{
    font-size:52px;
    line-height:.92;
  }
  .cta-inner p{
    font-size:15px;
    line-height:1.8;
    max-width:360px;
  }
  .cta-inner .primary-btn{
    min-width:0;
    max-width:none;
    width:100%;
    margin-top:18px;
  }
  .supporters{
    margin-top:56px;
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px 20px;
    text-align:center;
    font-size:10px;
    letter-spacing:.15em;
  }
  .supporters span:last-child{
    grid-column:1 / -1;
  }
}


/* ===== Ajustes finais mobile sem arrastar lateral ===== */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}
img, iframe, video {
  max-width: 100%;
  height: auto;
}
.container, .nav, .hero-grid, .event-grid, .timeline-grid, .news-grid, .location-grid, .cta-inner {
  max-width: 100%;
}
@media (max-width: 640px) {
  body {
    overflow-x: hidden;
  }

  .container {
    width: 100%;
    max-width: 100%;
    padding-left: 16px;
    padding-right: 16px;
    overflow-x: hidden;
  }

  .hero,
  .stats,
  .content-section,
  .cta-final {
    overflow-x: hidden;
  }

  .hero-copy,
  .event-copy,
  .location-copy,
  .cta-inner,
  .section-header,
  .section-intro {
    max-width: 100%;
  }

  h1,
  .center-title,
  .event-copy h2,
  .location-copy h2,
  .cta-inner h2 {
    word-break: break-word;
    overflow-wrap: anywhere;
  }

  /* remove qualquer arrasto lateral do carrossel no mobile */
  .gallery-strip,
  .flavor-carousel {
    overflow: visible !important;
    margin-inline: 0 !important;
    padding-inline: 0 !important;
  }

  .flavor-carousel-track {
    width: 100%;
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 14px;
    transform: none !important;
    animation: none !important;
  }

  .flavor-carousel-track img {
    width: 100% !important;
    min-width: 0 !important;
    height: 190px;
    object-fit: cover;
  }

  /* grids sempre dentro da tela */
  .cards-grid,
  .timeline-grid,
  .news-grid,
  .location-grid,
  .event-grid,
  .stats-grid {
    width: 100%;
    max-width: 100%;
  }

  .cards-grid {
    grid-template-columns: 1fr !important;
  }

  .stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .timeline-grid,
  .news-grid,
  .location-grid,
  .event-grid {
    grid-template-columns: 1fr !important;
  }

  .news-grid > a,
  .news-card,
  .timeline-card,
  .flavor-card,
  .map-card,
  .event-mosaic,
  .event-copy {
    min-width: 0;
    max-width: 100%;
  }

  .news-card h3,
  .card-copy h3,
  .timeline-card h3 {
    word-break: break-word;
    overflow-wrap: anywhere;
  }

  .map-card iframe {
    width: 100%;
    height: 240px;
  }

  .hero-actions,
  .cta-inner .primary-btn,
  .location-copy .primary-btn {
    width: 100%;
    max-width: 100%;
  }

  .primary-btn,
  .secondary-btn {
    width: 100%;
    max-width: 100%;
    min-width: 0 !important;
  }

  /* apoiadores organizados no final */
  .supporters {
    width: 100%;
    max-width: 100%;
    margin-top: 42px;
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    align-items: stretch;
  }

  .supporters span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 10px 12px;
    text-align: center;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
    background: rgba(255,255,255,.03);
    font-size: 10px;
    line-height: 1.4;
    letter-spacing: .12em;
  }

  .supporters span:last-child {
    grid-column: 1 / -1;
  }

  .supporters a {
    display: inline-block;
    width: 100%;
    text-align: center;
    word-break: break-word;
  }
}


/* ===== Ajustes mobile finais: carrossel, números equilibrados e apoiadores em linha ===== */
@media (max-width: 640px) {
  /* bloco dos números com mais respiro antes do letreiro */
  .stats {
    padding: 18px 0 58px !important;
  }

  .stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 30px 18px !important;
    align-items: start;
    justify-items: center;
  }

  .stat-item {
    width: 100%;
    text-align: center;
  }

  .stat-item strong {
    display: block;
    font-size: 52px !important;
    line-height: 0.95;
    margin-bottom: 8px;
  }

  .stat-item span {
    display: block;
    max-width: 120px;
    margin: 0 auto;
    font-size: 12px !important;
    line-height: 1.35;
  }

  /* deixa o título da próxima seção respirar sem ficar colado */
  #evento,
  .event-section,
  .content-section:first-of-type {
    scroll-margin-top: 90px;
  }

  .event-copy h2,
  .center-title,
  .location-copy h2,
  .cta-inner h2 {
    margin-top: 6px;
  }

  /* carrossel mobile em vez de lista vertical */
  .gallery-strip,
  .flavor-carousel {
    overflow: hidden !important;
    margin-inline: 0 !important;
    padding-inline: 0 !important;
  }

  .flavor-carousel {
    width: 100%;
  }

  .flavor-carousel-track {
    display: flex !important;
    width: max-content;
    gap: 12px !important;
    animation: mobileFlavorScroll 24s linear infinite !important;
    transform: none !important;
  }

  .flavor-carousel-track img {
    width: calc(100vw - 32px) !important;
    min-width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
    height: 210px !important;
    object-fit: cover;
    border-radius: 22px;
  }

  @keyframes mobileFlavorScroll {
    from { transform: translateX(0); }
    to { transform: translateX(calc(-1 * ((100vw - 32px) + 12px) * 4)); }
  }

  /* apoiadores sem balão, todos em linha reta no mobile */
  .supporters {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    margin-top: 44px !important;
    text-align: center;
  }

  .supporters span {
    display: block !important;
    min-height: auto !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    font-size: 11px !important;
    letter-spacing: 0.16em !important;
    line-height: 1.5 !important;
  }

  .supporters span:last-child {
    grid-column: auto !important;
  }

  .supporters a {
    display: inline-block !important;
    width: auto !important;
    text-align: center !important;
  }
}


/* ===== CTA final igual ao vídeo no desktop + responsivo no mobile ===== */
.cta-final{
  position:relative;
  padding:86px 0 70px;
  background:url('../img/final.jpg') center 18%/cover no-repeat;
  overflow:hidden;
}
.cta-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(10,12,15,.80) 0%, rgba(10,12,15,.70) 36%, rgba(10,12,15,.92) 100%);
}
.cta-inner{
  position:relative;
  z-index:1;
  text-align:center;
  max-width:1120px;
}
.cta-inner h2{
  margin-top:8px;
  font-size:clamp(64px, 6.7vw, 96px);
  line-height:.9;
  letter-spacing:-.04em;
}
.cta-inner p{
  max-width:760px;
  margin:18px auto 0;
  font-size:clamp(17px, 1.3vw, 24px);
  line-height:1.7;
  color:rgba(255,255,255,.78);
}
.instagram-btn{
  margin:34px auto 0;
  min-width:320px;
  padding:18px 28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  font-size:18px;
  font-weight:900;
  letter-spacing:.01em;
  box-shadow:0 18px 44px rgba(243,166,42,.24);
}
.instagram-btn .ig-icon{
  font-size:20px;
  line-height:1;
}
.supporters-wrap{
  margin-top:92px;
}
.supporters-heading{
  display:block;
  margin-bottom:34px;
}
.supporters.supporters-flat{
  display:flex !important;
  align-items:center;
  justify-content:center;
  gap:48px;
  flex-wrap:nowrap;
  margin-top:0;
  color:rgba(255,255,255,.48);
  font-size:12px;
  font-weight:800;
  letter-spacing:.17em;
  text-transform:uppercase;
}
.supporters.supporters-flat span{
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  min-height:auto !important;
  box-shadow:none !important;
  white-space:nowrap;
}
.supporters.supporters-flat a{
  display:inline-block;
  transition:color .25s ease, opacity .25s ease;
}
.supporters.supporters-flat a:hover{
  color:#fff;
}
.footer-credit{
  margin:56px auto 0;
  color:rgba(255,255,255,.28);
  font-size:14px;
  line-height:1.8;
  text-align:center;
}
.footer-credit strong{
  color:rgba(255,255,255,.58);
}

/* desktop refinado */
@media (min-width: 981px){
  .cta-final{
    min-height:760px;
    display:flex;
    align-items:flex-start;
  }
  .cta-inner{
    padding-top:8px;
  }
}

/* tablet */
@media (max-width: 980px){
  .supporters.supporters-flat{
    flex-wrap:wrap;
    gap:24px 32px;
  }
  .supporters.supporters-flat span{
    white-space:normal;
  }
}

/* mobile */
@media (max-width: 640px){
  .cta-final{
    padding:74px 0 58px;
    background-position:center center;
  }
  .cta-inner h2{
    font-size:54px;
    line-height:.92;
  }
  .cta-inner p{
    max-width:360px;
    font-size:15px;
    line-height:1.8;
  }
  .instagram-btn{
    width:100%;
    max-width:340px;
    min-width:0;
    padding:16px 22px;
    font-size:15px;
    gap:10px;
  }
  .supporters-wrap{
    margin-top:56px;
  }
  .supporters-heading{
    margin-bottom:22px;
  }
  .supporters.supporters-flat{
    flex-direction:column;
    gap:14px;
    font-size:11px;
    letter-spacing:.14em;
  }
  .supporters.supporters-flat span{
    white-space:normal;
  }
  .footer-credit{
    margin-top:32px;
    font-size:12px;
    line-height:1.7;
  }
}


/* ===== CTA separado + apoio abaixo ===== */
.cta-final{
  position:relative;
  padding:100px 0 80px;
  background:url('../img/final.jpg') center/cover no-repeat;
}
.cta-overlay{
  position:absolute;
  inset:0;
  background:rgba(10,12,15,.75);
}
.cta-inner{
  position:relative;
  z-index:2;
  text-align:center;
}
.cta-inner h2{
  font-size:clamp(64px,6vw,90px);
}
.instagram-btn{
  margin-top:30px;
}

/* apoio separado */
.apoio-section{
  background:#101318;
  padding:60px 0;
  text-align:center;
}
.apoio-title{
  display:block;
  color:#f3a62a;
  letter-spacing:.2em;
  font-size:12px;
  margin-bottom:30px;
}
.supporters-flat{
  display:flex;
  justify-content:center;
  gap:40px;
  flex-wrap:wrap;
  color:rgba(255,255,255,.5);
  font-size:12px;
  letter-spacing:.15em;
}
.supporters-flat a{
  color:inherit;
  text-decoration:none;
}
.supporters-flat a:hover{
  color:#fff;
}

/* mobile */
@media(max-width:640px){
  .cta-final{
    padding:80px 0 60px;
  }
  .cta-inner h2{
    font-size:48px;
  }
  .apoio-section{
    padding:40px 0;
  }
  .supporters-flat{
    flex-direction:column;
    gap:14px;
  }
}


/* ===== Ajuste CTA centralizado na imagem + mobile ===== */
.cta-final{
  min-height: 620px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-position: center center !important;
}

.cta-final .container{
  width: 100%;
  display: flex;
  justify-content: center;
}

.cta-inner{
  width: 100%;
  max-width: 860px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.cta-inner .eyebrow,
.cta-inner h2,
.cta-inner p,
.cta-inner .instagram-btn{
  margin-left: auto;
  margin-right: auto;
}

.cta-inner p{
  max-width: 680px;
}

@media (max-width: 980px){
  .cta-final{
    min-height: 540px;
    padding: 80px 0 70px !important;
  }

  .cta-inner{
    max-width: 720px;
    padding: 0 20px;
  }
}

@media (max-width: 640px){
  .cta-final{
    min-height: 460px;
    padding: 70px 0 56px !important;
    background-position: center center !important;
  }

  .cta-inner{
    max-width: 100%;
    padding: 0 16px;
  }

  .cta-inner h2{
    font-size: 46px !important;
    line-height: .95;
  }

  .cta-inner p{
    max-width: 340px;
    font-size: 15px;
    line-height: 1.75;
  }

  .instagram-btn{
    width: 100%;
    max-width: 320px;
    min-width: 0 !important;
  }
}


/* ===== Carrossel mobile funcional ===== */
@media (max-width:640px){
  .flavor-carousel{
    overflow:hidden !important;
    width:100%;
  }

  .flavor-carousel-track{
    display:flex !important;
    gap:12px;
    width:max-content;
    animation:carouselMobile 28s linear infinite;
  }

  .flavor-carousel-track img{
    width:85vw;
    min-width:85vw;
    height:200px;
    object-fit:cover;
    border-radius:20px;
  }

  @keyframes carouselMobile{
    from{ transform:translateX(0); }
    to{ transform:translateX(-50%); }
  }
}

/* footer */
.footer-final{
  background:#101318;
  text-align:center;
  padding:22px 16px;
  font-size:12px;
  color:rgba(255,255,255,.5);
  letter-spacing:.08em;
}


/* ===== Ajustes finais mobile: stats centralizados + carrossel automático ===== */
@media (max-width: 640px){
  .stats{
    padding: 24px 0 54px !important;
  }

  .stats-grid{
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 34px 28px !important;
    justify-items: center;
    align-items: start;
  }

  .stat-item{
    width: 100%;
    text-align: center !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
  }

  .stat-item strong{
    font-size: 50px !important;
    line-height: .92 !important;
    margin-bottom: 8px !important;
  }

  .stat-item span{
    max-width: 110px !important;
    margin: 0 auto !important;
    text-align: center !important;
    font-size: 12px !important;
    line-height: 1.3 !important;
  }

  /* carrossel automático real no mobile */
  .gallery-strip{
    overflow: hidden !important;
  }

  .flavor-carousel{
    width: 100%;
    overflow: hidden !important;
  }

  .flavor-carousel-track{
    display: flex !important;
    align-items: center;
    gap: 12px !important;
    width: max-content !important;
    animation: mobileAutoCarousel 26s linear infinite !important;
    will-change: transform;
  }

  .flavor-carousel:hover .flavor-carousel-track{
    animation-play-state: running !important;
  }

  .flavor-carousel-track img{
    width: calc(100vw - 32px) !important;
    min-width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
    height: 210px !important;
    object-fit: cover !important;
    border-radius: 22px !important;
    flex: 0 0 auto;
  }

  @keyframes mobileAutoCarousel{
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
  }
}


/* ===== Correção final mobile: dados centralizados de verdade + carrossel automático ===== */
@media (max-width: 640px) {
  .stats {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 26px 0 58px !important;
  }

  .stats .container {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
  }

  .stats-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(118px, 1fr)) !important;
    width: min(100%, 300px) !important;
    max-width: 300px !important;
    margin: 0 auto !important;
    gap: 28px 18px !important;
    justify-content: center !important;
    justify-items: center !important;
    align-items: start !important;
  }

  .stat-item {
    width: 118px !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
  }

  .stat-item strong {
    display: block !important;
    width: 100% !important;
    font-size: 52px !important;
    line-height: .92 !important;
    margin: 0 0 8px !important;
    text-align: center !important;
  }

  .stat-item span {
    display: block !important;
    width: 100% !important;
    max-width: 112px !important;
    margin: 0 auto !important;
    text-align: center !important;
    font-size: 12px !important;
    line-height: 1.3 !important;
  }

  .gallery-strip {
    overflow: hidden !important;
  }

  .gallery-strip .container,
  .flavor-carousel {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  .flavor-carousel-track {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    width: max-content !important;
    transform: translate3d(0, 0, 0);
    will-change: transform !important;
    animation: none !important;
  }

  .flavor-carousel-track img {
    flex: 0 0 auto !important;
    width: 78vw !important;
    min-width: 78vw !important;
    max-width: 78vw !important;
    height: 210px !important;
    object-fit: cover !important;
    border-radius: 22px !important;
  }

  .flavor-carousel::before,
  .flavor-carousel::after {
    width: 18px !important;
  }
}


/* ===== Ajuste fino mobile: stats no meio, cards mostrando rostos, carrossel contínuo ===== */
@media (max-width: 640px) {
  /* stats: volta ao layout em 2x2, centralizado e com espaço antes do título */
  .stats {
    padding: 18px 0 52px !important;
  }

  .stats .container {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }

  .stats-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: min(100%, 320px) !important;
    max-width: 320px !important;
    margin: 0 auto !important;
    gap: 28px 26px !important;
    justify-items: center !important;
    align-items: start !important;
  }

  .stat-item {
    width: 100% !important;
    max-width: 132px !important;
    min-width: 0 !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
  }

  .stat-item strong {
    display: block !important;
    font-size: 44px !important;
    line-height: .95 !important;
    margin: 0 0 6px !important;
    text-align: center !important;
    width: 100% !important;
    letter-spacing: -.03em !important;
  }

  .stat-item span {
    display: block !important;
    max-width: 112px !important;
    margin: 0 auto !important;
    text-align: center !important;
    font-size: 11px !important;
    line-height: 1.32 !important;
  }

  /* mais respiro até o letreiro abaixo */
  .stats + .content-section,
  .stats + section {
    margin-top: 6px !important;
  }

  /* receitas e sabores: enquadramento melhor para não cortar rostos */
  .flavor-card img,
  .flavor-carousel-track img,
  .event-mosaic img {
    object-fit: cover !important;
    object-position: center top !important;
  }

  .flavor-card img {
    height: 220px !important;
  }

  /* carrossel mobile contínuo e horizontal */
  .gallery-strip {
    overflow: hidden !important;
  }

  .gallery-strip .container {
    max-width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .flavor-carousel {
    width: 100% !important;
    overflow: hidden !important;
    position: relative !important;
  }

  .flavor-carousel-track {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    width: max-content !important;
    will-change: transform !important;
    animation: none !important;
  }

  .flavor-carousel-track img {
    flex: 0 0 auto !important;
    width: 76vw !important;
    min-width: 76vw !important;
    max-width: 76vw !important;
    height: 210px !important;
    border-radius: 22px !important;
    object-fit: cover !important;
    object-position: center top !important;
  }
}


/* ===== Correção final: stats mais abaixo e carrossel contínuo no mobile ===== */
@media (max-width: 640px) {
  /* sobe menos os botões e empurra os dados para baixo */
  .hero {
    padding-bottom: 28px !important;
  }

  .hero-actions {
    margin-bottom: 78px !important;
  }

  .stats {
    position: relative !important;
    margin-top: 0 !important;
    padding: 8px 0 56px !important;
  }

  .stats .container {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .stats-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    width: 100% !important;
    max-width: 420px !important;
    margin: 0 auto !important;
    gap: 8px !important;
    align-items: start !important;
    justify-items: center !important;
  }

  .stat-item {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 96px !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: center !important;
  }

  .stat-item strong {
    display: block !important;
    width: 100% !important;
    margin: 0 0 8px !important;
    font-size: 42px !important;
    line-height: .92 !important;
    letter-spacing: -.04em !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  .stat-item span {
    display: block !important;
    width: 100% !important;
    max-width: 88px !important;
    margin: 0 auto !important;
    font-size: 10px !important;
    line-height: 1.28 !important;
    text-align: center !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
  }

  /* evita bolinhas/pseudo-elementos perdidos nessa área */
  .stats::before,
  .stats::after,
  .hero::before,
  .hero::after {
    display: none !important;
    content: none !important;
  }

  /* carrossel mobile contínuo */
  .gallery-strip {
    overflow: hidden !important;
  }

  .flavor-carousel {
    width: 100% !important;
    overflow: hidden !important;
    position: relative !important;
  }

  .flavor-carousel-track {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    width: max-content !important;
    transform: translate3d(0,0,0);
    will-change: transform !important;
    animation: none !important;
  }

  .flavor-carousel-track img {
    flex: 0 0 auto !important;
    width: 72vw !important;
    min-width: 72vw !important;
    max-width: 72vw !important;
    height: 210px !important;
    border-radius: 22px !important;
    object-fit: cover !important;
    object-position: center top !important;
  }
}

@media (max-width:640px){
  .hero-actions{ margin-bottom:110px !important; }

  .stats{
    margin-top:-20px !important;
    padding-top:0 !important;
  }

  .stats-grid{
    margin-top:0 !important;
  }

  /* stronger positioning */
  .stats{
    transform: translateY(20px);
  }

  /* continuous CSS carousel (override JS issues) */
  .flavor-carousel-track{
    animation: autoSlide 28s linear infinite !important;
  }

  @keyframes autoSlide{
    0%{ transform:translateX(0);}
    100%{ transform:translateX(-50%);}
  }
}





/* ===== Ajuste fino final mobile ===== */
@media (max-width:640px){
  /* abaixa mais os dados */
  .hero-actions{
    margin-bottom: 138px !important;
  }
  .stats{
    margin-top: 96px !important;
    padding-top: 0 !important;
    padding-bottom: 44px !important;
    transform: none !important;
  }
  .stats .container{
    width:100% !important;
    max-width:100% !important;
    padding-left:16px !important;
    padding-right:16px !important;
  }
  .stats-grid{
    display:grid !important;
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:10px !important;
    width:100% !important;
    max-width:390px !important;
    margin:0 auto !important;
    justify-items:center !important;
    align-items:start !important;
  }
  .stat-item{
    width:100% !important;
    max-width:88px !important;
    min-width:0 !important;
    text-align:center !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
  }
  .stat-item strong{
    font-size:42px !important;
    line-height:.92 !important;
    margin:0 0 6px !important;
    white-space:nowrap !important;
  }
  .stat-item span{
    max-width:78px !important;
    margin:0 auto !important;
    font-size:10px !important;
    line-height:1.25 !important;
    text-align:center !important;
  }

  /* carrossel contínuo real via CSS */
  .gallery-strip,
  .flavor-carousel{
    overflow:hidden !important;
  }
  .flavor-carousel-track{
    --mobile-card-w: 72vw;
    --mobile-gap: 12px;
    display:flex !important;
    flex-wrap:nowrap !important;
    gap:var(--mobile-gap) !important;
    width:max-content !important;
    will-change:transform !important;
    animation: favelaMobileMarquee 36s linear infinite !important;
    transform: translateX(0) !important;
  }
  .flavor-carousel-track img{
    flex:0 0 auto !important;
    width:var(--mobile-card-w) !important;
    min-width:var(--mobile-card-w) !important;
    max-width:var(--mobile-card-w) !important;
    height:210px !important;
    border-radius:22px !important;
    object-fit:cover !important;
    object-position:center top !important;
  }
  .flavor-carousel:hover .flavor-carousel-track,
  .flavor-carousel:active .flavor-carousel-track{
    animation-play-state: running !important;
  }
  @keyframes favelaMobileMarquee{
    from{ transform: translateX(0) !important; }
    to{ transform: translateX(calc(-1 * ((var(--mobile-card-w) + var(--mobile-gap)) * 12))) !important; }
  }
}

@media (max-width:640px){
  .stats{
    margin-top:120px !important; /* leve ajuste fino */
  }
}


/* ===== CARROSSEL FUNCIONANDO MOBILE = */
@media (max-width:640px){

  .flavor-carousel{
    overflow:hidden !important;
    width:100%;
  }

  .flavor-carousel-track{
    display:flex !important;
    gap:12px !important;
    width:max-content !important;
    animation:carouselFix 20s linear infinite !important;
  }

  .flavor-carousel-track img{
    width:75vw !important;
    min-width:75vw !important;
    height:200px !important;
    object-fit:cover !important;
    border-radius:20px !important;
    flex:0 0 auto;
  }

  @keyframes carouselFix{
    0% { transform:translateX(0); }
    100% { transform:translateX(-50%); }
  }
}


/* ===== Carrossel mobile final ===== */
@media (max-width:640px){
  .flavor-carousel{
    width:100% !important;
    overflow:hidden !important;
    position:relative !important;
  }

  .flavor-carousel-track{
    display:flex !important;
    flex-wrap:nowrap !important;
    gap:12px !important;
    width:max-content !important;
    animation:none !important;
    transition:none !important;
    will-change:transform !important;
  }

  .flavor-carousel-track img{
    flex:0 0 auto !important;
    width:75vw !important;
    min-width:75vw !important;
    max-width:75vw !important;
    height:200px !important;
    object-fit:cover !important;
    object-position:center top !important;
    border-radius:20px !important;
  }
}


/* Carrossel mobile real com classes limpas */
.event-marquee{overflow:hidden;position:relative;padding-bottom:8px}
.event-marquee::before,.event-marquee::after{content:"";position:absolute;top:0;bottom:8px;width:40px;z-index:2;pointer-events:none}
.event-marquee::before{left:0;background:linear-gradient(90deg,var(--bg) 0%,rgba(10,12,15,0) 100%)}
.event-marquee::after{right:0;background:linear-gradient(270deg,var(--bg) 0%,rgba(10,12,15,0) 100%)}
.event-marquee-track{display:flex;align-items:center;gap:16px;width:max-content;will-change:transform;transform:translate3d(0,0,0)}
.event-marquee-track img{min-width:270px;width:270px;height:154px;object-fit:cover;object-position:center top;border-radius:24px;border:1px solid var(--border);box-shadow:0 18px 42px rgba(0,0,0,.24);flex-shrink:0}
@media (max-width:640px){
  .event-marquee{overflow:hidden !important}
  .event-marquee::before,.event-marquee::after{width:20px}
  .event-marquee-track{gap:12px !important}
  .event-marquee-track img{width:75vw !important;min-width:75vw !important;max-width:75vw !important;height:200px !important;border-radius:22px !important}
}


/* Ajustes de logo desktop e mobile */
.brand img,
.logo img,
.navbar-brand img,
header .brand img{
  width: 140px !important;
  max-width: none !important;
  height: auto !important;
  object-fit: contain !important;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.22));
}
@media (max-width: 640px){
  .brand img,
  .logo img,
  .navbar-brand img,
  header .brand img{
    width: 118px !important;
  }
}


/* Ajuste das cores do 01 e 02 em "Fique por dentro" */
.timeline-grid .timeline-card:first-child,
.steps-grid .step-card:first-child{
  background: rgba(255,255,255,0.02) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  box-shadow: none !important;
}
.timeline-grid .timeline-card:first-child strong,
.timeline-grid .timeline-card:first-child h3,
.steps-grid .step-card:first-child strong,
.steps-grid .step-card:first-child h3{
  color: #fff !important;
}

.timeline-grid .timeline-card:nth-child(2),
.steps-grid .step-card:nth-child(2){
  background: linear-gradient(180deg, rgba(243,166,42,.16), rgba(243,166,42,.06)) !important;
  border: 1px solid rgba(243,166,42,.28) !important;
  box-shadow: 0 16px 40px rgba(243,166,42,.08) !important;
}
.timeline-grid .timeline-card:nth-child(2) strong,
.timeline-grid .timeline-card:nth-child(2) h3,
.steps-grid .step-card:nth-child(2) strong,
.steps-grid .step-card:nth-child(2) h3{
  color: #f3a62a !important;
}


/* ===== Hero fullscreen mobile (sem corte) ===== */
@media (max-width:640px){

  .hero,
  .hero-banner,
  .hero-section{
    min-height:100vh !important;
    height:auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    background-size:cover !important;
    background-position:center center !important;
  }

  /* garantir que conteúdo não estoure */
  .hero .container,
  .hero-banner .container,
  .hero-section .container{
    width:100%;
  }

}


/* ===== Hero mobile ajustado para caber na primeira tela com header ===== */
@media (max-width:640px){

  .topbar,
  header,
  .header,
  .navbar{
    height: 90px;
  }

  .hero,
  .hero-banner,
  .hero-section{
    min-height: calc(100vh - 90px) !important;
    height: calc(100vh - 90px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background-size: cover !important;
    background-position: center center !important;
    padding-top: 16px !important;
    padding-bottom: 16px !important;
    overflow: hidden !important;
  }

  .hero .container,
  .hero-banner .container,
  .hero-section .container{
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
  }

  .hero-grid{
    min-height: auto !important;
    height: auto !important;
  }

  .hero-copy{
    width: 100%;
  }

  h1{
    font-size: 64px !important;
    line-height: .9 !important;
    margin-top: 10px !important;
  }

  .edition{
    font-size: 15px !important;
    margin-top: 10px !important;
  }

  .meta-lines{
    margin-top: 10px !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
  }

  .countdown-wrap{
    margin-top: 14px !important;
  }

  .counter-row{
    gap: 8px !important;
  }

  .counter-box{
    width: 72px !important;
    min-width: 72px !important;
    padding: 12px 6px !important;
  }

  .counter-box b{
    font-size: 24px !important;
  }

  .counter-box span{
    font-size: 9px !important;
  }

  .hero-actions{
    margin-top: 16px !important;
    gap: 10px !important;
  }

  .primary-btn,
  .secondary-btn{
    min-height: 52px !important;
    padding: 14px 18px !important;
    font-size: 14px !important;
  }

  .stats{
    margin-top: 0 !important;
    padding-top: 24px !important;
  }
}

/* ===== Ajuste fino espaçamento mobile ===== */
@media (max-width:640px){

  /* logo acima */
  .brand, .logo, .navbar-brand{
    margin-top:6px !important;
  }

  header{
    padding-top:10px !important;
  }

  /* desce um pouco os dados */
  .stats{
    margin-top:20px !important;
    padding-top:32px !important;
  }

}

/* ===== Ajuste header mobile (logo + menu alinhados e mais acima) ===== */
@media (max-width:640px){

  header,
  .navbar{
    padding-top:6px !important;
    padding-bottom:6px !important;
  }

  .navbar .container,
  header .container{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
  }

  /* logo mais acima */
  .brand, .logo, .navbar-brand{
    margin-top:-4px !important;
    display:flex !important;
    align-items:center !important;
  }

  .brand img, .logo img, .navbar-brand img{
    height:48px !important;
    max-height:48px !important;
  }

  /* menu alinhado na mesma altura */
  .menu-toggle,
  .menu-btn,
  .hamburger{
    margin-top:-4px !important;
    display:flex !important;
    align-items:center !important;
    height:48px !important;
  }

  .menu-toggle span,
  .hamburger span{
    width:24px !important;
    height:2px !important;
  }

}


/* ===== Correção do título no mobile ===== */
.hero-title-break{
  display:inline;
}

@media (max-width: 640px){
  h1,
  .hero-title,
  .main-title{
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    white-space: normal !important;
    hyphens: none !important;
    letter-spacing: -0.025em !important;
    line-height: 0.92 !important;
    text-wrap: initial !important;
  }

  .hero-title-break{
    display:block !important;
  }

  h1 br{
    display:none !important;
  }

  h1,
  .hero-title{
    font-size: 82px !important;
  }
}

@media (max-width: 430px){
  h1,
  .hero-title{
    font-size: 74px !important;
    line-height: 0.93 !important;
  }
}

@media (max-width: 390px){
  h1,
  .hero-title{
    font-size: 68px !important;
    line-height: 0.94 !important;
    letter-spacing: -0.02em !important;
  }
}

@media (max-width: 375px){
  h1,
  .hero-title{
    font-size: 62px !important;
  }
}


/* ===== Ajuste 01 mobile ===== */
.hero-title-break{
  display:inline;
}

@media (max-width: 640px){
  h1,
  .hero-title,
  .main-title{
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 auto !important;
    text-align: center !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    white-space: normal !important;
    hyphens: none !important;
    letter-spacing: -0.03em !important;
    line-height: 0.90 !important;
    text-wrap: initial !important;
  }

  .hero-title-break{
    display:block !important;
  }

  h1 br{
    display:none !important;
  }

  h1,
  .hero-title{
    font-size: 72px !important;
  }

  .hero-copy{
    max-width: 100% !important;
  }

  .edition{
    font-size: 15px !important;
    letter-spacing: .10em !important;
  }

  .meta-lines{
    font-size: 14px !important;
    line-height: 1.5 !important;
  }

  .countdown-wrap{
    margin-top: 14px !important;
  }

  .counter-box{
    width: 92px !important;
    min-width: 92px !important;
  }

  .primary-btn,
  .secondary-btn{
    max-width: 100% !important;
    width: 100% !important;
  }
}

@media (max-width: 430px){
  h1,
  .hero-title{
    font-size: 66px !important;
  }
}

@media (max-width: 390px){
  h1,
  .hero-title{
    font-size: 60px !important;
    line-height: 0.92 !important;
  }
}

@media (max-width: 375px){
  h1,
  .hero-title{
    font-size: 56px !important;
  }
}


/* ===== Ajuste 02 no mobile ===== */
.hero-title-exact .hero-line{
  display:block;
}
@media (max-width: 640px){
  .hero,
  .hero-banner,
  .hero-section{
    background-position:center center !important;
  }

  .hero-copy{
    max-width:100% !important;
    padding-inline:0 !important;
  }

  .hero-title-exact{
    width:100% !important;
    margin:0 auto !important;
    text-align:center !important;
    line-height:.88 !important;
    letter-spacing:-0.035em !important;
  }

  .hero-title-exact .hero-line-1{
    display:block !important;
    font-size:clamp(74px, 15vw, 96px) !important;
    color:#fff !important;
    font-weight:900 !important;
  }

  .hero-title-exact .hero-line-2{
    display:block !important;
    font-size:clamp(74px, 15vw, 96px) !important;
    color:#f3a62a !important;
    font-weight:900 !important;
  }

  .hero-title-exact .hero-line-3{
    display:block !important;
    font-size:clamp(74px, 15vw, 96px) !important;
    color:#f3a62a !important;
    font-weight:900 !important;
    margin-top:-0.06em !important;
  }

  .edition{
    margin-top:10px !important;
    font-size:15px !important;
    letter-spacing:.12em !important;
  }

  .meta-lines{
    margin-top:10px !important;
    font-size:14px !important;
    line-height:1.45 !important;
  }

  .countdown-wrap{
    margin-top:16px !important;
  }

  .counter-row{
    justify-content:center !important;
    gap:10px !important;
  }

  .counter-box{
    width:92px !important;
    min-width:92px !important;
    padding:12px 6px !important;
  }

  .hero-actions{
    margin-top:18px !important;
  }

  .primary-btn,
  .secondary-btn{
    width:100% !important;
    max-width:100% !important;
  }
}

@media (max-width: 430px){
  .hero-title-exact .hero-line-1,
  .hero-title-exact .hero-line-2,
  .hero-title-exact .hero-line-3{
    font-size:clamp(66px, 14.5vw, 88px) !important;
  }
}

@media (max-width: 390px){
  .hero-title-exact .hero-line-1,
  .hero-title-exact .hero-line-2,
  .hero-title-exact .hero-line-3{
    font-size:clamp(60px, 14vw, 80px) !important;
  }
}


/* ===== Correção real do título no mobile ===== */
@media (max-width: 640px){
  h1,
  .hero-title,
  .main-title{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    margin-left:auto !important;
    margin-right:auto !important;
    text-align:center !important;
    white-space:normal !important;
    word-break:normal !important;
    overflow-wrap:break-word !important;
    hyphens:none !important;
    letter-spacing:-0.025em !important;
    line-height:0.9 !important;
    font-size:clamp(54px, 13.2vw, 78px) !important;
  }

  .hero-copy{
    width:100% !important;
    max-width:100% !important;
    overflow:visible !important;
  }

  .hero-copy h1,
  .hero-content h1{
    max-width: 340px !important;
  }

  .hero-title-break,
  .hero-line{
    display:inline !important;
  }

  h1 br{
    display:none !important;
  }

  .edition{
    font-size:15px !important;
    letter-spacing:.08em !important;
  }

  .meta-lines{
    font-size:14px !important;
    line-height:1.45 !important;
  }

  .counter-row{
    gap:10px !important;
    flex-wrap:nowrap !important;
  }

  .counter-box{
    width:84px !important;
    min-width:84px !important;
  }
}

@media (max-width: 430px){
  h1,
  .hero-title,
  .main-title{
    font-size:clamp(50px, 12.8vw, 70px) !important;
    max-width: 332px !important;
  }
}

@media (max-width: 390px){
  h1,
  .hero-title,
  .main-title{
    font-size:clamp(46px, 12.2vw, 64px) !important;
    max-width: 316px !important;
    line-height:0.92 !important;
  }
}

@media (max-width: 375px){
  h1,
  .hero-title,
  .main-title{
    font-size:clamp(42px, 11.8vw, 58px) !important;
    max-width: 300px !important;
  }
}


/* ===== Título mobile em 2 linhas exatas ===== */
.hero-title-2lines span{
  display:block;
}
@media (max-width: 640px){
  .hero-title-2lines{
    width:100% !important;
    max-width:340px !important;
    margin:0 auto !important;
    text-align:center !important;
    line-height:.9 !important;
    letter-spacing:-0.025em !important;
  }
  .hero-title-2lines .hero-line-1{
    display:block !important;
    color:#fff !important;
    font-size:clamp(54px, 12.5vw, 74px) !important;
    font-weight:900 !important;
  }
  .hero-title-2lines .hero-line-2{
    display:block !important;
    color:#f3a62a !important;
    font-size:clamp(54px, 12.5vw, 74px) !important;
    font-weight:900 !important;
    margin-top:-0.04em !important;
  }

  h1:not(.hero-title-2lines),
  .hero-title:not(.hero-title-2lines),
  .main-title:not(.hero-title-2lines){
    white-space:normal !important;
    word-break:normal !important;
    overflow-wrap:normal !important;
  }
}

@media (max-width: 430px){
  .hero-title-2lines{
    max-width:326px !important;
  }
  .hero-title-2lines .hero-line-1,
  .hero-title-2lines .hero-line-2{
    font-size:clamp(50px, 12vw, 68px) !important;
  }
}

@media (max-width: 390px){
  .hero-title-2lines{
    max-width:310px !important;
  }
  .hero-title-2lines .hero-line-1,
  .hero-title-2lines .hero-line-2{
    font-size:clamp(46px, 11.6vw, 62px) !important;
  }
}

@media (max-width: 375px){
  .hero-title-2lines{
    max-width:296px !important;
  }
  .hero-title-2lines .hero-line-1,
  .hero-title-2lines .hero-line-2{
    font-size:clamp(43px, 11.1vw, 58px) !important;
  }
}


/* ===== Botão com hover ===== */
.pdf-link-btn{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  cursor:pointer !important;
  text-decoration:none !important;
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.pdf-link-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 0px 28px rgba(243,166,42,.18);
  filter:brightness(1.04);
}
.pdf-link-btn:active{
  transform:translateY(0);
}


/* ===== Link ===== */
.pdf-link-btn{
  position: relative !important;
  z-index: 50 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 210px !important;
  min-height: 58px !important;
  padding: 1px 26px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  user-select: none !important;
  -webkit-user-select: none !important;
}

.pdf-link-btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 0px 8px rgba(243,166,42,.18);
}

.pdf-link-btn *,
.timeline-card .pdf-link-btn,
.cards-grid .pdf-link-btn,
.content-section .pdf-link-btn{
  pointer-events: auto !important;
}

.timeline-card,
.flavor-card,
.card-copy,
.content-section,
.container{
  overflow: visible !important;
}

.timeline-card a,
.timeline-card .primary-btn{
  position: relative !important;
  z-index: 60 !important;
}


/* ===== PDF clicável  ===== */
.pdf-link-btn{
  position: relative !important;
  z-index: 60 !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.timeline-card .pdf-link-btn,
.content-section .pdf-link-btn{
  position: relative !important;
  z-index: 70 !important;
}


/* ===== VEJA AQUI ===== */
.pdf-link-btn{
  position: relative !important;
  z-index: 70 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 1px 16px !important;
  min-width: 20px !important;
  min-height: 28px !important;
  border-radius: 999px !important;
  background: rgba(243,166,42,.12) !important;
  border: 0px solid rgba(243,166,42,.10) !important;
  color: #f3a62a !important;
  text-decoration: none !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  box-shadow: none !important;
  transition: transform .2s ease, filter .2s ease;
}
.pdf-link-btn:hover{
  transform: translateY(-1px);
  filter: brightness(1.03);
}


.pdf-link-btn{
  position: relative !important;
  z-index: 80 !important;
  pointer-events: auto !important;
}
.timeline-card .pdf-link-btn,
.content-section .pdf-link-btn{
  position: relative !important;
  z-index: 90 !important;
}


/* ===== Destaque GASTRONÔMICA ===== */
.title-highlight-gastronomica{
  color:#f3a62a !important;
}


/* ===== GASTRONÔMICA dourado ===== */
.title-highlight-gastronomica{
  color:#f3a62a !important;
}
