:root{
  --ivory:#F3EFD8;
  --paper:#FBF5E6;
  --sand:#DED5BA;
  --peach:#EFB37B;
  --patina:#7FA197;
  --sage:#B8C89F;
  --blue:#5576A8;
  --sky:#6BA6D8;
  --olive:#557A45;
  --brass:#806026;
  --brown:#4A3423;
  --burgundy:#963034;
  --plum:#3D2F3E;
  --rose:#AA7378;
  --coral:#DE7D84;
  --ink:#211B18;
  --muted:rgba(33,27,24,.68);
  --muted-dark:rgba(251,245,230,.68);
  --line:rgba(74,52,35,.16);
  --line-dark:rgba(251,245,230,.15);
  --shadow:0 18px 52px rgba(50,35,23,.14);
  --shadow-dark:0 22px 64px rgba(0,0,0,.34);
  --container:1120px;
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
  --font-title:'Cinzel', Georgia, serif;
  --font-serif:'Playfair Display', Georgia, serif;
  --font-ui:'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:15px}
body{
  color:var(--ink);
  font-family:var(--font-ui);
  background:
    radial-gradient(circle at 15% -10%, rgba(239,179,123,.28), transparent 30rem),
    radial-gradient(circle at 96% 5%, rgba(127,161,151,.22), transparent 32rem),
    linear-gradient(180deg,var(--paper),var(--ivory) 50%,#EFE2CF);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(74,52,35,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(74,52,35,.035) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 85%);
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-3;
  pointer-events:none;
  background:
    linear-gradient(110deg, transparent 0 72%, rgba(128,96,38,.09) 72% 100%),
    linear-gradient(20deg, rgba(150,48,52,.05), transparent 38%);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit}
.container{width:min(var(--container), calc(100% - 40px));margin-inline:auto}
.section{padding:70px 0}
.section-compact{padding:54px 0}
.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
  color:var(--burgundy);
  font-size:.68rem;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.section-kicker::before{content:"";width:28px;height:1px;background:linear-gradient(90deg,var(--brass),transparent)}
.section-title{
  max-width:720px;
  color:var(--brown);
  font-family:var(--font-title);
  font-size:clamp(1.75rem,3.7vw,3.4rem);
  line-height:1.02;
  letter-spacing:-.04em;
  font-weight:800;
}
.section-lead{
  max-width:580px;
  margin-top:14px;
  color:var(--muted);
  font-size:.98rem;
  line-height:1.62;
}
.section-head{margin-bottom:28px}

.topbar{
  background:linear-gradient(90deg,var(--plum),var(--burgundy),var(--brass));
  color:var(--ivory);
  font-size:.68rem;
  font-weight:850;
  letter-spacing:.07em;
  text-transform:uppercase;
}
.topbar-inner{min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.topbar b{color:#fff}.topbar span{white-space:nowrap}

.nav{
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid var(--line);
  background:rgba(251,245,230,.88);
  backdrop-filter:blur(18px);
  box-shadow:0 8px 24px rgba(50,35,23,.07);
}
.nav-inner{min-height:70px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand-mark{
  width:50px;height:50px;flex:0 0 auto;
  display:grid;place-items:center;border-radius:50%;padding:4px;
  background:linear-gradient(145deg,#fff,var(--sand));
  box-shadow:0 10px 26px rgba(128,96,38,.16), inset 0 0 0 1px rgba(74,52,35,.12);
}
.brand-mark img{width:100%;height:100%;object-fit:contain;border-radius:50%}
.brand-text{display:grid;gap:3px;min-width:0}
.brand-title{font-family:var(--font-title);font-weight:850;color:var(--brown);font-size:1.04rem;line-height:1}
.brand-sub{color:rgba(74,52,35,.62);font-size:.58rem;font-weight:850;letter-spacing:.13em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-links{display:flex;align-items:center;gap:3px;list-style:none}
.nav-links a{
  display:inline-flex;align-items:center;justify-content:center;height:36px;padding:0 11px;border-radius:999px;
  color:rgba(33,27,24,.72);font-size:.66rem;font-weight:850;letter-spacing:.075em;text-transform:uppercase;transition:.22s ease;
}
.nav-links a:hover{background:rgba(128,96,38,.10);color:var(--brown)}
.nav-links .nav-cta{margin-left:5px;background:linear-gradient(135deg,var(--brass),var(--burgundy));color:#fff;box-shadow:0 10px 22px rgba(128,96,38,.20)}
.nav-links .nav-cta:hover{color:#fff;transform:translateY(-1px)}
.nav-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.45);cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:18px;height:2px;background:var(--brown);border-radius:2px;transition:.22s ease}
.nav-toggle span::before{transform:translateY(-6px)}
.nav-toggle span::after{transform:translateY(4px)}
body.menu-open .nav-toggle span{background:transparent}
body.menu-open .nav-toggle span::before{transform:rotate(45deg)}
body.menu-open .nav-toggle span::after{transform:translateY(-2px) rotate(-45deg)}

.hero{
  position:relative;isolation:isolate;overflow:hidden;
  min-height:calc(100svh - 104px);display:flex;align-items:center;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    linear-gradient(90deg, rgba(251,245,230,.97) 0%, rgba(251,245,230,.86) 55%, rgba(127,161,151,.26) 100%),
    radial-gradient(circle at 80% 48%, rgba(170,115,120,.20), transparent 28rem),
    radial-gradient(circle at 18% 82%, rgba(128,96,38,.18), transparent 26rem);
}
.hero::after{content:"";position:absolute;inset:auto -20% 0 -20%;height:120px;z-index:-1;background:linear-gradient(180deg,transparent,rgba(251,245,230,.96))}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(310px,.72fr);align-items:center;gap:42px}
.hero-eyebrow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.pill{
  display:inline-flex;align-items:center;gap:8px;min-height:30px;padding:7px 12px;border-radius:999px;
  border:1px solid rgba(128,96,38,.20);background:rgba(255,255,255,.50);color:var(--brown);
  font-size:.64rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 8px 18px rgba(50,35,23,.04);
}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--burgundy);box-shadow:0 0 0 5px rgba(150,48,52,.11)}
.muted-pill::before{background:var(--patina);box-shadow:0 0 0 5px rgba(127,161,151,.14)}
.hero-title{
  max-width:780px;color:var(--brown);font-family:var(--font-title);font-weight:850;
  font-size:clamp(2.45rem,5.3vw,5.55rem);line-height:.92;letter-spacing:-.06em;
}
.hero-title span{display:block;color:var(--burgundy);text-shadow:0 10px 28px rgba(150,48,52,.10)}
.hero-subtitle{max-width:620px;margin-top:20px;color:var(--muted);font-size:clamp(.98rem,1.25vw,1.08rem);line-height:1.62}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border-radius:999px;border:1px solid transparent;font-size:.68rem;font-weight:900;letter-spacing:.11em;text-transform:uppercase;transition:.24s ease}
.btn.primary{background:linear-gradient(135deg,var(--burgundy),var(--brass));color:#fff;box-shadow:0 14px 30px rgba(128,96,38,.22)}
.btn.secondary{background:rgba(255,255,255,.52);border-color:var(--line);color:var(--brown)}
.btn:hover{transform:translateY(-2px)}

.countdown-panel{
  position:relative;overflow:hidden;padding:26px;border-radius:var(--radius-xl);
  border:1px solid rgba(251,245,230,.16);
  background:
    linear-gradient(145deg,rgba(61,47,62,.98),rgba(74,52,35,.95)),
    radial-gradient(circle at 50% 0%, rgba(239,179,123,.18), transparent 20rem);
  color:var(--ivory);box-shadow:var(--shadow-dark);
}
.countdown-panel::before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--brass),var(--peach),var(--patina),var(--burgundy))}
.countdown-panel::after{content:"";position:absolute;right:-75px;bottom:-95px;width:230px;height:230px;border:1px solid rgba(251,245,230,.08);border-radius:50%;box-shadow:0 0 0 24px rgba(251,245,230,.02)}
.countdown-head{position:relative;z-index:1;display:flex;align-items:center;gap:16px;margin-bottom:20px}
.countdown-seal{width:64px;height:64px;flex:0 0 auto;border-radius:50%;padding:5px;background:linear-gradient(145deg,#fff,var(--sand));box-shadow:0 12px 30px rgba(0,0,0,.22)}
.countdown-seal img{width:100%;height:100%;object-fit:contain;border-radius:50%}
.countdown-kicker{display:block;color:var(--peach);font-size:.66rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px}
.countdown-title{font-family:var(--font-title);font-size:clamp(1.25rem,2vw,1.95rem);line-height:1;letter-spacing:-.03em}
.countdown-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;position:relative;z-index:1}
.count-card{min-height:88px;display:grid;align-content:center;gap:5px;padding:12px;border-radius:18px;background:rgba(251,245,230,.08);border:1px solid rgba(251,245,230,.15);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.count-card strong{font-family:var(--font-title);font-size:clamp(1.55rem,2.8vw,2.45rem);line-height:.95;color:var(--peach);font-weight:850;font-variant-numeric:tabular-nums;letter-spacing:-.04em}
.count-card span{font-size:.58rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:rgba(251,245,230,.66)}
.countdown-date{position:relative;z-index:1;margin-top:16px;padding-top:14px;border-top:1px solid rgba(251,245,230,.12);color:rgba(251,245,230,.70);font-size:.85rem;line-height:1.45}

.essentials{border-block:1px solid var(--line);background:rgba(251,245,230,.58)}
.essentials-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(74,52,35,.10)}
.essential-item{padding:20px;background:rgba(251,245,230,.84)}
.essential-item span{display:block;color:var(--burgundy);font-size:.61rem;font-weight:900;letter-spacing:.15em;text-transform:uppercase;margin-bottom:7px}
.essential-item b{font-family:var(--font-serif);font-size:1rem;color:var(--brown)}

.split-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:42px;align-items:start}
.highlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.mini-card{min-height:178px;padding:22px;border-radius:var(--radius-lg);border:1px solid var(--line);background:rgba(251,245,230,.62);box-shadow:0 10px 28px rgba(50,35,23,.06);transition:.24s ease}
.mini-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.mini-card span{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:rgba(150,48,52,.10);color:var(--burgundy);font-weight:900;margin-bottom:16px;font-size:.78rem}
.mini-card h3{font-family:var(--font-title);font-size:1.1rem;color:var(--brown);margin-bottom:8px}
.mini-card p{color:var(--muted);line-height:1.55;font-size:.92rem}

.program,.gallery{background:linear-gradient(180deg,rgba(127,161,151,.13),rgba(251,245,230,.26))}
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.day-card{overflow:hidden;border-radius:var(--radius-lg);border:1px solid var(--line);background:rgba(251,245,230,.68);box-shadow:0 10px 28px rgba(50,35,23,.06);transition:.24s ease}
.day-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.day-head{display:flex;align-items:end;gap:10px;padding:18px;background:linear-gradient(135deg,rgba(128,96,38,.15),rgba(127,161,151,.15));border-bottom:1px solid var(--line)}
.day-head strong{font-family:var(--font-title);font-size:2.65rem;line-height:.82;color:var(--burgundy)}
.day-head span{color:var(--brown);font-weight:900;letter-spacing:.11em;text-transform:uppercase;font-size:.66rem}
.day-card ul{list-style:none;padding:18px 20px 20px;display:grid;gap:10px;color:var(--muted);line-height:1.38;font-size:.9rem}
.day-card li::before{content:"—";color:var(--brass);margin-right:7px}

.registration{border-block:1px solid var(--line);background:linear-gradient(180deg,rgba(170,115,120,.09),rgba(251,245,230,.42))}
.register-actions{display:grid;gap:10px}
.register-card{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:78px;padding:20px 22px;border-radius:21px;border:1px solid var(--line);background:rgba(251,245,230,.68);box-shadow:0 10px 28px rgba(50,35,23,.055);transition:.24s ease}
.register-card::after{content:"→";display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:rgba(128,96,38,.10);color:var(--brass);font-weight:900;flex:0 0 auto}
.register-card.main{border-color:rgba(150,48,52,.28);background:linear-gradient(135deg,rgba(150,48,52,.10),rgba(251,245,230,.72))}
.register-card:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.register-card b{display:block;font-family:var(--font-title);font-size:1.05rem;color:var(--brown);margin-bottom:5px}
.register-card span{display:block;color:var(--muted);font-size:.9rem}

.venue-grid{display:grid;grid-template-columns:1.14fr .86fr;gap:28px;align-items:stretch}
.venue-card{position:relative;min-height:300px;display:flex;align-items:flex-end;padding:28px;border-radius:var(--radius-xl);border:1px solid var(--line);background:
  linear-gradient(180deg,rgba(61,47,62,.10),rgba(33,27,24,.55)),
  radial-gradient(circle at 46% 38%, rgba(107,166,216,.34), transparent 5rem),
  linear-gradient(135deg,rgba(127,161,151,.38),rgba(222,213,186,.55));box-shadow:var(--shadow);overflow:hidden;color:#fff}
.venue-card::before{content:"";position:absolute;inset:0;background:linear-gradient(35deg, transparent 43%, rgba(251,245,230,.16) 44%, transparent 45%),linear-gradient(-25deg, transparent 57%, rgba(74,52,35,.12) 58%, transparent 59%);background-size:170px 170px,220px 220px;opacity:.75}
.venue-card > div{position:relative;z-index:1;max-width:620px}.venue-card .section-title{color:#fff}.venue-card .section-lead{color:rgba(255,255,255,.78)}.venue-card .section-kicker{color:var(--peach)}
.map-pin{position:absolute;left:48%;top:42%;width:72px;height:72px;transform:translate(-50%,-50%);border-radius:50%;background:rgba(150,48,52,.20);box-shadow:0 0 0 16px rgba(150,48,52,.10),0 0 0 30px rgba(150,48,52,.05)}
.map-pin::after{content:"";position:absolute;inset:24px;border-radius:50%;background:var(--burgundy);box-shadow:0 0 26px rgba(150,48,52,.75)}
.info-list{display:grid;align-content:start;gap:10px}.info-list div{display:grid;gap:5px;padding:16px 0;border-bottom:1px solid var(--line)}.info-list span{color:var(--burgundy);font-size:.62rem;font-weight:900;letter-spacing:.15em;text-transform:uppercase}.info-list b{font-family:var(--font-serif);font-size:1rem;color:var(--brown)}

.gallery-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;grid-auto-rows:172px;gap:12px}.gallery-item{position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:20px;border-radius:24px;border:1px solid var(--line);background:linear-gradient(135deg,rgba(85,122,69,.24),rgba(239,179,123,.20)),#D9D1BF;box-shadow:0 12px 32px rgba(50,35,23,.07)}.gallery-item.big{grid-row:span 2}.gallery-item::before{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 42%,rgba(255,255,255,.28) 50%,transparent 58%),linear-gradient(180deg,transparent,rgba(61,47,62,.48))}.gallery-item span{position:relative;z-index:1;color:#fff;font-size:.66rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;text-shadow:0 2px 10px rgba(0,0,0,.38)}

.partners{position:relative;overflow:hidden;border-top:1px solid var(--line-dark);background:
  radial-gradient(circle at 8% 0%, rgba(239,179,123,.12), transparent 24rem),
  radial-gradient(circle at 94% 36%, rgba(127,161,151,.10), transparent 28rem),
  linear-gradient(180deg,var(--plum),#2B2430 52%,#211B18);color:var(--ivory)}
.partners::before{content:"";position:absolute;inset:0;opacity:.12;background-image:linear-gradient(45deg, rgba(255,255,255,.05) 25%, transparent 25%, transparent 75%, rgba(255,255,255,.05) 75%),linear-gradient(45deg, rgba(255,255,255,.05) 25%, transparent 25%, transparent 75%, rgba(255,255,255,.05) 75%);background-position:0 0,18px 18px;background-size:36px 36px;mask-image:linear-gradient(to bottom,transparent,#000 16%,#000 88%,transparent)}
.partners::after{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(239,179,123,.65),transparent)}
.partners .container{position:relative;z-index:1}.partners .section-title{color:var(--ivory)}.partners .section-kicker{color:var(--peach)}.partners-header{margin-bottom:24px}
.partners-stack{
  position:relative;
  z-index:1;
  display:grid;
  gap:10px;
  width:min(var(--container), calc(100% - 40px));
  margin:0 auto;
  padding:6px 0 0;
}
.partner-carousel{position:relative;overflow:hidden;padding:8px 0 10px;border:0;border-radius:0;background:transparent;box-shadow:none}
.partner-carousel::before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:linear-gradient(90deg,transparent,rgba(251,245,230,.10),rgba(239,179,123,.22),rgba(251,245,230,.10),transparent);pointer-events:none}
.partner-carousel-head{
  width:100%;
  margin:0 0 8px;
  padding:0;
  color:rgba(239,179,123,.92);
  font-size:.58rem;
  font-weight:900;
  letter-spacing:.19em;
  text-transform:uppercase;
  line-height:1;
}
.partner-carousel-head span{display:inline-flex;align-items:center;gap:10px;padding:0;background:transparent}
.partner-carousel-head span::after{content:"";width:42px;height:1px;background:linear-gradient(90deg,rgba(239,179,123,.55),transparent)}
.marquee-mask{
  position:relative;
  overflow:hidden;
  padding-inline:2px;
  mask-image:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.logo-track{width:max-content;display:flex;flex-wrap:nowrap;align-items:center;animation:partner-marquee var(--duration,34s) linear infinite;will-change:transform}
.logo-set{display:flex;flex-wrap:nowrap;align-items:center;gap:10px;padding-inline:5px}
.partner-carousel.reverse .logo-track{animation-direction:reverse}.partner-carousel:hover .logo-track{animation-play-state:paused}
.logo-card{
  flex:0 0 144px;width:144px;height:72px;display:flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:16px;
  background:#fff;border:1px solid rgba(74,52,35,.10);
  box-shadow:0 8px 22px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.92);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.logo-card:hover{transform:translateY(-2px) scale(1.012);border-color:rgba(128,96,38,.32);background:#fff;box-shadow:0 14px 30px rgba(0,0,0,.20)}
.logo-card img{max-width:100%;max-height:42px;object-fit:contain;filter:none}
@keyframes partner-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.footer{padding:54px 0 28px;background:#211B18;color:var(--ivory);border-top:1px solid rgba(251,245,230,.12)}
.footer-grid{display:grid;grid-template-columns:1.35fr repeat(3,1fr);gap:36px;padding-bottom:34px;border-bottom:1px solid rgba(251,245,230,.10)}
.footer-brand{display:flex;align-items:center;gap:13px;margin-bottom:14px}.footer-brand img{width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.08)}.footer-brand strong{display:block;font-family:var(--font-title);font-size:1.35rem;line-height:1}.footer-brand span,.footer p,.footer-contact{color:rgba(251,245,230,.68);line-height:1.6;font-size:.9rem}.footer-desc{max-width:360px}.footer-contact{margin-top:14px}.footer h3{color:var(--peach);font-size:.66rem;font-weight:900;letter-spacing:.17em;text-transform:uppercase;margin-bottom:15px}.footer ul{list-style:none;display:grid;gap:9px}.footer a{color:rgba(251,245,230,.68);font-size:.9rem;transition:.2s ease}.footer a:hover{color:#fff}.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:22px;color:rgba(251,245,230,.52);font-size:.78rem}.socials{display:flex;gap:9px}.socials a{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;border:1px solid rgba(251,245,230,.15);font-size:.68rem;font-weight:900}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}.reveal.visible{opacity:1;transform:none}

@media (max-width:1050px){
  .hero-grid,.split-grid,.venue-grid{grid-template-columns:1fr}.countdown-panel{max-width:680px}.highlight-grid{grid-template-columns:1fr 1fr}.timeline{grid-template-columns:1fr 1fr}.essentials-grid{grid-template-columns:1fr 1fr}.footer-grid{grid-template-columns:1.2fr 1fr 1fr}.footer-grid>div:first-child{grid-column:1/-1}.topbar-inner{justify-content:center;flex-wrap:wrap;padding:7px 0}.topbar span:last-child{display:none}.hero{min-height:auto}
}
@media (max-width:860px){
  .nav-toggle{display:flex}.nav-links{position:fixed;left:20px;right:20px;top:84px;display:grid;gap:6px;padding:14px;border-radius:22px;border:1px solid var(--line);background:rgba(251,245,230,.98);box-shadow:var(--shadow);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.22s ease}.nav-links a{min-height:44px}.nav-links .nav-cta{margin-left:0}body.menu-open .nav-links{opacity:1;transform:none;pointer-events:auto}.gallery-grid{grid-template-columns:1fr 1fr}.gallery-item.big{grid-column:1/-1}.countdown-grid{grid-template-columns:repeat(4,1fr)}.count-card{min-height:82px}.logo-card{width:128px;flex-basis:128px;height:66px;padding:11px 14px;border-radius:15px}.logo-card img{max-height:38px}
}
@media (max-width:640px){
  html{font-size:14px}.container{width:min(100% - 28px,var(--container))}.section{padding:58px 0}.section-compact{padding:42px 0}.nav-inner{min-height:68px}.brand-mark{width:46px;height:46px}.brand-title{font-size:1rem}.brand-sub{font-size:.54rem;letter-spacing:.1em}.nav-links{top:78px}.hero-title{font-size:clamp(2.35rem,14vw,4.05rem)}.hero-actions .btn{width:100%}.countdown-panel{padding:22px;border-radius:24px}.countdown-head{align-items:flex-start}.countdown-seal{width:58px;height:58px}.countdown-grid{grid-template-columns:repeat(2,1fr)}.essentials-grid,.highlight-grid,.timeline,.gallery-grid{grid-template-columns:1fr}.gallery-item{min-height:180px}.register-card{align-items:flex-start}.topbar span:nth-child(2){display:none}.partner-carousel-head{padding-inline:0;width:100%;font-size:.54rem}.marquee-mask{mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}.logo-set{gap:9px}.logo-card{width:112px;flex-basis:112px;height:60px;padding:10px 12px;border-radius:14px}.logo-card img{max-height:34px}.footer-grid{grid-template-columns:1fr}.footer-bottom{display:grid;text-align:center;justify-items:center}
}
@media (prefers-reduced-motion:reduce){.logo-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}.logo-set{flex-wrap:wrap;justify-content:center}.logo-set[aria-hidden="true"]{display:none}.marquee-mask{mask-image:none;overflow:visible;padding-inline:14px}.reveal{transition:none}}


/* V2 — carrosséis integrados, fundo igual à navbar e logos soltas */
.partners{
  position:relative;
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(circle at 10% 0%, rgba(128,96,38,.08), transparent 22rem),
    radial-gradient(circle at 92% 30%, rgba(127,161,151,.10), transparent 26rem),
    rgba(251,245,230,.88);
  color:var(--ink);
}
.partners::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.18;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(74,52,35,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(74,52,35,.045) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:linear-gradient(to bottom, transparent, #000 16%, #000 88%, transparent);
}
.partners::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(128,96,38,.32), transparent);
}
.partners .container{position:relative;z-index:1}
.partners .section-title{color:var(--brown)}
.partners .section-kicker{color:var(--burgundy)}
.partners-header{margin-bottom:22px}
.partners-stack{
  position:relative;
  z-index:1;
  display:grid;
  gap:12px;
  width:100%;
  margin:0 auto;
  padding:4px 0 0;
}
.partner-carousel{
  position:relative;
  overflow:hidden;
  padding:9px 0 11px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.partner-carousel::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:50%;
  height:1px;
  pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(74,52,35,.06), rgba(128,96,38,.16), rgba(74,52,35,.06), transparent);
}
.partner-carousel-head{
  width:100%;
  margin:0 0 8px;
  padding:0;
  color:var(--brass);
  font-size:.58rem;
  font-weight:900;
  letter-spacing:.19em;
  text-transform:uppercase;
  line-height:1;
}
.partner-carousel-head span{display:inline-flex;align-items:center;gap:10px;padding:0;background:transparent}
.partner-carousel-head span::after{content:"";width:42px;height:1px;background:linear-gradient(90deg,rgba(128,96,38,.45),transparent)}
.marquee-mask{
  position:relative;
  overflow:hidden;
  padding-inline:2px;
  mask-image:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.logo-track{
  width:max-content;
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  animation:partner-marquee var(--duration,34s) linear infinite;
  will-change:transform;
}
.logo-set{display:flex;flex-wrap:nowrap;align-items:center;gap:24px;padding-inline:12px}
.partner-carousel.reverse .logo-track{animation-direction:reverse}
.partner-carousel:hover .logo-track{animation-play-state:paused}
.logo-card{
  flex:0 0 auto;
  width:auto;
  min-width:112px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 4px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  transition:transform .22s ease, filter .22s ease, opacity .22s ease;
}
.logo-card:hover{transform:translateY(-2px) scale(1.03);background:transparent;box-shadow:none;filter:drop-shadow(0 7px 12px rgba(74,52,35,.16))}
.logo-card img{
  max-width:132px;
  max-height:46px;
  object-fit:contain;
  filter:none;
}
@media (max-width:860px){
  .logo-set{gap:20px;padding-inline:10px}
  .logo-card{min-width:100px;height:50px}
  .logo-card img{max-width:118px;max-height:42px}
}
@media (max-width:640px){
  .partners-header{margin-bottom:18px}
  .partner-carousel-head{font-size:.54rem}
  .marquee-mask{mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
  .logo-set{gap:16px;padding-inline:8px}
  .logo-card{min-width:88px;height:46px}
  .logo-card img{max-width:102px;max-height:36px}
}
@media (prefers-reduced-motion:reduce){
  .logo-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}
  .logo-set{flex-wrap:wrap;justify-content:center}
  .logo-set[aria-hidden="true"]{display:none}
  .marquee-mask{mask-image:none;overflow:visible;padding-inline:14px}
}


/* V3 — carrossel infinito preenchido desde o carregamento */
.partners-stack{
  overflow:visible;
}
.partner-carousel{
  overflow:hidden;
}
.marquee-mask{
  width:100%;
  overflow:hidden;
}
.logo-track{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  width:max-content;
  min-width:100%;
  transform:translate3d(0,0,0);
  animation-name:partner-marquee;
  animation-duration:var(--duration, 34s);
  animation-timing-function:linear;
  animation-iteration-count:infinite;
  animation-delay:0s;
  will-change:transform;
}
.logo-set{
  flex:0 0 auto;
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:24px;
  padding-inline:12px;
}
.partner-carousel.reverse .logo-track{
  animation-direction:reverse;
}
.partner-carousel:hover .logo-track{
  animation-play-state:running;
}
@keyframes partner-marquee{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(calc(var(--scroll-distance, 50%) * -1),0,0)}
}
.logo-card{
  flex:0 0 auto;
  width:auto;
  min-width:112px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 4px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  transition:transform .22s ease, filter .22s ease, opacity .22s ease;
}
.logo-card:hover{
  transform:translateY(-2px) scale(1.03);
  background:transparent;
  box-shadow:none;
  filter:drop-shadow(0 7px 12px rgba(74,52,35,.16));
}
.logo-card img{
  display:block;
  max-width:132px;
  max-height:46px;
  object-fit:contain;
  filter:none;
}
@media (max-width:860px){
  .logo-set{gap:20px;padding-inline:10px}
  .logo-card{min-width:100px;height:50px}
  .logo-card img{max-width:118px;max-height:42px}
}
@media (max-width:640px){
  .logo-set{gap:16px;padding-inline:8px}
  .logo-card{min-width:88px;height:46px}
  .logo-card img{max-width:102px;max-height:36px}
}
@media (prefers-reduced-motion:reduce){
  .logo-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center;transform:none!important}
  .logo-set{flex-wrap:wrap;justify-content:center}
  .logo-set[aria-hidden="true"]{display:none}
  .marquee-mask{mask-image:none;overflow:visible;padding-inline:14px}
}

/* ===== Final carousel override - version 4 ===== */
.partners{
  background: rgba(251,245,230,.90);
  border-top: 1px solid var(--line);
  color: var(--ink);
}
.partners::before,
.partners::after{display:none}
.partners .section-title{color:var(--brown)}
.partners .section-kicker{color:var(--burgundy)}
.partners-header{margin-bottom:22px}
.partners-stack{
  display:grid;
  gap:18px;
  width:min(var(--container), calc(100% - 40px));
  margin:0 auto;
}
.partner-carousel{
  position:relative;
  overflow:hidden;
  padding:0;
  background:transparent;
}
.partner-carousel::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:50%;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(74,52,35,.10),rgba(128,96,38,.20),rgba(74,52,35,.10),transparent);
  pointer-events:none;
}
.partner-carousel-head{
  width:100%;
  margin:0 0 10px;
  padding:0;
  color:var(--brass);
  font-size:.62rem;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  line-height:1;
}
.partner-carousel-head span{display:inline-flex;align-items:center;gap:10px}
.partner-carousel-head span::after{
  content:"";
  width:48px;
  height:1px;
  background:linear-gradient(90deg,rgba(128,96,38,.55),transparent);
}
.marquee-mask{
  position:relative;
  overflow:hidden;
  padding:6px 0;
  mask-image:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.logo-track{
  width:max-content;
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:0;
  will-change:transform;
  animation-name:partner-marquee;
  animation-duration:var(--duration, 30s);
  animation-timing-function:linear;
  animation-iteration-count:infinite;
  animation-play-state:paused;
}
.partner-carousel.is-ready .logo-track{animation-play-state:running}
.partner-carousel.reverse .logo-track{animation-direction:reverse}
.partner-carousel:hover .logo-track{animation-play-state:paused}
.logo-set{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:24px;
  padding-right:24px;
}
.logo-card{
  min-width:112px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  transition:transform .22s ease, filter .22s ease;
}
.logo-card:hover{
  transform:translateY(-2px);
  filter:drop-shadow(0 8px 14px rgba(74,52,35,.12));
}
.logo-card img{
  display:block;
  max-width:122px;
  max-height:44px;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:none;
}
@keyframes partner-marquee{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(calc(-1 * var(--loop-distance, 50%)),0,0)}
}

@media (max-width:860px){
  .logo-set{gap:18px;padding-right:18px}
  .logo-card{min-width:100px;height:50px}
  .logo-card img{max-width:112px;max-height:40px}
}
@media (max-width:640px){
  .partners-stack{gap:16px;width:min(100% - 28px,var(--container))}
  .partner-carousel-head{font-size:.56rem}
  .marquee-mask{mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
  .logo-set{gap:16px;padding-right:16px}
  .logo-card{min-width:88px;height:44px}
  .logo-card img{max-width:100px;max-height:34px}
}
@media (prefers-reduced-motion:reduce){
  .logo-track{animation:none!important;transform:none!important;flex-wrap:wrap;width:auto;justify-content:center}
  .logo-set{flex-wrap:wrap;justify-content:center;padding-right:0}
  .logo-set[aria-hidden="true"]{display:none}
  .marquee-mask{mask-image:none;overflow:visible}
}


/* ===== v5 fix: image paths + filled infinite logo rows ===== */
.partner-carousel{min-height:82px;}
.logo-track{animation-play-state:running;}
.partner-carousel.is-ready .logo-track{animation-play-state:running;}
.partner-carousel:hover .logo-track{animation-play-state:paused;}
.logo-set{gap:28px;padding-right:28px;}
.logo-card{min-width:132px;width:auto;height:56px;overflow:visible;}
.logo-card img{display:block;max-width:132px;max-height:46px;width:auto;height:auto;object-fit:contain;}
@media (max-width:860px){.logo-set{gap:22px;padding-right:22px}.logo-card{min-width:112px;height:50px}.logo-card img{max-width:112px;max-height:40px}}
@media (max-width:640px){.logo-set{gap:18px;padding-right:18px}.logo-card{min-width:96px;height:44px}.logo-card img{max-width:96px;max-height:34px}}

/* ===== Version 6: clean navigation + premium map section ===== */
.nav-links{gap:8px}

.venue{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 8% 0%, rgba(127,161,151,.16), transparent 24rem),
    radial-gradient(circle at 92% 20%, rgba(239,179,123,.12), transparent 28rem),
    linear-gradient(180deg, rgba(251,245,230,.88), rgba(243,239,216,.96));
}
.venue-layout{
  display:grid;
  grid-template-columns:.78fr 1.22fr;
  gap:34px;
  align-items:stretch;
}
.local-copy{
  align-self:center;
}
.local-info-grid{
  margin-top:24px;
  display:grid;
  gap:10px;
}
.local-info-grid div{
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.local-info-grid span{
  display:block;
  margin-bottom:5px;
  color:var(--burgundy);
  font-size:.62rem;
  font-weight:900;
  letter-spacing:.15em;
  text-transform:uppercase;
}
.local-info-grid b{
  color:var(--brown);
  font-family:var(--font-serif);
  font-size:1.02rem;
  line-height:1.3;
}
.map-showcase{
  display:grid;
  gap:14px;
}
.vintage-map{
  position:relative;
  min-height:340px;
  overflow:hidden;
  border:1px solid rgba(74,52,35,.16);
  border-radius:var(--radius-xl);
  background:
    radial-gradient(circle at 52% 48%, rgba(107,166,216,.25), transparent 5.2rem),
    radial-gradient(circle at 22% 25%, rgba(127,161,151,.28), transparent 9rem),
    radial-gradient(circle at 82% 74%, rgba(239,179,123,.18), transparent 10rem),
    linear-gradient(135deg, #E8DDC5, #F8F1DD 48%, #DCCDB1);
  box-shadow:0 18px 52px rgba(50,35,23,.13), inset 0 1px 0 rgba(255,255,255,.44);
}
.vintage-map::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.42;
  background-image:
    linear-gradient(rgba(74,52,35,.065) 1px, transparent 1px),
    linear-gradient(90deg, rgba(74,52,35,.065) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.75), rgba(0,0,0,.22));
}
.vintage-map::after{
  content:"N";
  position:absolute;
  top:22px;
  right:22px;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:50%;
  border:1px solid rgba(74,52,35,.18);
  background:rgba(251,245,230,.62);
  color:var(--brass);
  font-family:var(--font-title);
  font-size:.86rem;
  font-weight:800;
  box-shadow:0 10px 24px rgba(50,35,23,.09);
}
.map-road{
  position:absolute;
  display:block;
  height:22px;
  border-radius:999px;
  background:rgba(251,245,230,.74);
  border:1px solid rgba(128,96,38,.18);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.32), 0 8px 16px rgba(74,52,35,.06);
}
.road-one{left:-10%;top:37%;width:78%;transform:rotate(-13deg)}
.road-two{right:-14%;top:58%;width:90%;transform:rotate(16deg)}
.road-three{left:32%;top:10%;width:26px;height:86%;transform:rotate(34deg);opacity:.82}
.map-lake{
  position:absolute;
  left:40%;
  top:31%;
  width:150px;
  height:92px;
  border-radius:56% 44% 58% 42%;
  background:linear-gradient(135deg, rgba(107,166,216,.56), rgba(85,118,168,.30));
  border:1px solid rgba(85,118,168,.20);
  box-shadow:inset 0 8px 18px rgba(255,255,255,.25), 0 12px 28px rgba(85,118,168,.12);
}
.map-park{
  position:absolute;
  display:block;
  border-radius:50%;
  background:rgba(127,161,151,.34);
  border:1px solid rgba(85,122,69,.12);
}
.park-one{left:12%;bottom:18%;width:118px;height:118px}
.park-two{right:13%;top:18%;width:86px;height:86px;background:rgba(184,200,159,.36)}
.map-pin-modern{
  position:absolute;
  left:52%;
  top:45%;
  width:38px;
  height:38px;
  transform:translate(-50%,-50%) rotate(45deg);
  border-radius:50% 50% 50% 8px;
  background:linear-gradient(135deg,var(--burgundy),var(--brass));
  box-shadow:0 0 0 12px rgba(150,48,52,.10), 0 14px 26px rgba(74,52,35,.24);
  z-index:3;
}
.map-pin-modern::after{
  content:"";
  position:absolute;
  inset:11px;
  border-radius:50%;
  background:var(--ivory);
}
.map-place-label{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:4;
  padding:18px 20px;
  border:1px solid rgba(74,52,35,.12);
  border-radius:22px;
  background:rgba(251,245,230,.78);
  backdrop-filter:blur(10px);
  box-shadow:0 16px 36px rgba(50,35,23,.13);
}
.map-place-label strong{
  display:block;
  color:var(--brown);
  font-family:var(--font-title);
  font-size:1.12rem;
  line-height:1.1;
}
.map-place-label span{
  display:block;
  margin-top:6px;
  color:var(--muted);
  font-size:.88rem;
}
.map-buttons{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.map-buttons a{
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(74,52,35,.14);
  background:rgba(251,245,230,.72);
  color:var(--brown);
  font-size:.68rem;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  box-shadow:0 10px 22px rgba(50,35,23,.055);
  transition:.22s ease;
}
.map-buttons a:hover{
  transform:translateY(-2px);
  color:#fff;
  border-color:transparent;
  background:linear-gradient(135deg,var(--brass),var(--burgundy));
  box-shadow:0 14px 28px rgba(128,96,38,.20);
}
.footer li{
  color:rgba(251,245,230,.68);
  font-size:.9rem;
  line-height:1.55;
}

@media (max-width:1050px){
  .venue-layout{grid-template-columns:1fr;gap:24px}
  .vintage-map{min-height:320px}
}
@media (max-width:720px){
  .map-buttons{grid-template-columns:1fr}
  .vintage-map{min-height:300px}
  .map-place-label{left:18px;right:18px;bottom:18px}
}

/* ===== Version 8: carousel logos larger, closer and without rail line ===== */
.partners .partner-carousel::before,
.partner-carousel::before{
  display:none !important;
  content:none !important;
}
.partner-carousel-head span::after{
  display:none !important;
  content:none !important;
}
.partners-stack{
  gap:16px !important;
}
.partner-carousel{
  padding:8px 0 14px !important;
}
.marquee-mask{
  padding:8px 0 !important;
  mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent) !important;
}
.logo-set{
  gap:18px !important;
  padding-right:18px !important;
  padding-left:0 !important;
}
.logo-card{
  min-width:156px !important;
  height:76px !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}
.logo-card img{
  max-width:158px !important;
  max-height:64px !important;
  width:auto !important;
  height:auto !important;
  object-fit:contain !important;
  filter:none !important;
}
.logo-card:hover{
  transform:translateY(-2px) scale(1.035) !important;
  filter:drop-shadow(0 8px 14px rgba(74,52,35,.16)) !important;
  background:transparent !important;
  box-shadow:none !important;
}
@media (max-width:860px){
  .logo-set{gap:15px !important;padding-right:15px !important;}
  .logo-card{min-width:136px !important;height:68px !important;}
  .logo-card img{max-width:138px !important;max-height:56px !important;}
}
@media (max-width:640px){
  .logo-set{gap:13px !important;padding-right:13px !important;}
  .logo-card{min-width:112px !important;height:58px !important;}
  .logo-card img{max-width:114px !important;max-height:46px !important;}
}


/* ===== Version 9: logos mais próximas, especialmente no mobile ===== */
.logo-set{
  gap:10px !important;
  padding-right:10px !important;
  padding-left:0 !important;
}

.logo-card{
  flex:0 0 auto !important;
  width:auto !important;
  min-width:0 !important;
  height:76px !important;
  padding:0 !important;
  margin:0 !important;
}

.logo-card img{
  max-width:158px !important;
  max-height:64px !important;
}

/* Tablet */
@media (max-width:860px){
  .logo-set{
    gap:8px !important;
    padding-right:8px !important;
  }

  .logo-card{
    width:auto !important;
    min-width:0 !important;
    height:68px !important;
  }

  .logo-card img{
    max-width:138px !important;
    max-height:56px !important;
  }
}

/* Celular */
@media (max-width:640px){
  .logo-set{
    gap:6px !important;
    padding-right:6px !important;
  }

  .logo-card{
    width:auto !important;
    min-width:0 !important;
    height:58px !important;
  }

  .logo-card img{
    max-width:116px !important;
    max-height:48px !important;
  }

  .partner-carousel{
    padding:6px 0 10px !important;
  }

  .partners-stack{
    gap:12px !important;
  }
}


/* ===== Version 10: tamanho do carrossel inspirado na primeira versão ===== */
/* Mantém: logos soltas, sem trilho, carrossel contínuo, pausa no hover e categorias. */
.logo-set{
  gap:18px !important;
  padding-right:18px !important;
  padding-left:0 !important;
}

.logo-card{
  flex:0 0 192px !important;
  width:192px !important;
  min-width:192px !important;
  height:104px !important;
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}

.logo-card img{
  max-width:168px !important;
  max-height:64px !important;
  width:auto !important;
  height:auto !important;
  object-fit:contain !important;
  filter:none !important;
}

.logo-card:hover{
  transform:translateY(-2px) scale(1.025) !important;
  filter:drop-shadow(0 8px 14px rgba(74,52,35,.16)) !important;
  background:transparent !important;
  box-shadow:none !important;
}

/* Tablet */
@media (max-width:860px){
  .logo-set{
    gap:16px !important;
    padding-right:16px !important;
  }

  .logo-card{
    flex-basis:168px !important;
    width:168px !important;
    min-width:168px !important;
    height:94px !important;
  }

  .logo-card img{
    max-width:148px !important;
    max-height:58px !important;
  }
}

/* Celular */
@media (max-width:640px){
  .logo-set{
    gap:14px !important;
    padding-right:14px !important;
  }

  .logo-card{
    flex-basis:146px !important;
    width:146px !important;
    min-width:146px !important;
    height:86px !important;
  }

  .logo-card img{
    max-width:128px !important;
    max-height:50px !important;
  }
}

/* ===== Version 11: imagens do carrossel maiores ===== */
/* Aumenta a presença das logos mantendo o carrossel solto, sem cards e sem trilho. */
.partners-stack{
  gap:22px !important;
}

.partner-carousel{
  min-height:142px !important;
  padding:10px 0 18px !important;
}

.marquee-mask{
  padding:14px 0 !important;
  overflow:hidden !important;
  mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent) !important;
}

.logo-set{
  gap:22px !important;
  padding-right:22px !important;
  padding-left:0 !important;
}

.logo-card{
  position:relative !important;
  z-index:1 !important;
  flex:0 0 238px !important;
  width:238px !important;
  min-width:238px !important;
  height:128px !important;
  padding:0 !important;
  margin:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}

.logo-card img{
  display:block !important;
  max-width:214px !important;
  max-height:86px !important;
  width:auto !important;
  height:auto !important;
  object-fit:contain !important;
  filter:none !important;
}

.logo-card:hover{
  z-index:5 !important;
  transform:translateY(-3px) scale(1.055) !important;
  filter:drop-shadow(0 12px 18px rgba(74,52,35,.18)) !important;
  background:transparent !important;
  box-shadow:none !important;
}

@media (max-width:860px){
  .partners-stack{gap:19px !important;}
  .partner-carousel{min-height:124px !important;padding:8px 0 15px !important;}
  .marquee-mask{padding:12px 0 !important;}
  .logo-set{gap:18px !important;padding-right:18px !important;}
  .logo-card{
    flex-basis:204px !important;
    width:204px !important;
    min-width:204px !important;
    height:112px !important;
  }
  .logo-card img{
    max-width:184px !important;
    max-height:74px !important;
  }
}

@media (max-width:640px){
  .partners-stack{gap:16px !important;width:min(100% - 28px,var(--container)) !important;}
  .partner-carousel{min-height:106px !important;padding:6px 0 12px !important;}
  .partner-carousel-head{margin-bottom:8px !important;}
  .marquee-mask{
    padding:10px 0 !important;
    mask-image:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent) !important;
  }
  .logo-set{gap:14px !important;padding-right:14px !important;}
  .logo-card{
    flex-basis:170px !important;
    width:170px !important;
    min-width:170px !important;
    height:94px !important;
  }
  .logo-card img{
    max-width:152px !important;
    max-height:62px !important;
  }
}

/* ===== Version 12: logos maiores com espaçamento mais próximo ===== */
/* Reduz o espaço real entre as imagens sem deixar o carrossel apertado demais. */
.logo-set{
  gap:12px !important;
  padding-right:12px !important;
  padding-left:0 !important;
}

.logo-card{
  flex:0 0 226px !important;
  width:226px !important;
  min-width:226px !important;
  height:128px !important;
}

.logo-card img{
  max-width:214px !important;
  max-height:86px !important;
}

@media (max-width:860px){
  .logo-set{
    gap:10px !important;
    padding-right:10px !important;
  }

  .logo-card{
    flex-basis:196px !important;
    width:196px !important;
    min-width:196px !important;
    height:112px !important;
  }

  .logo-card img{
    max-width:184px !important;
    max-height:74px !important;
  }
}

@media (max-width:640px){
  .logo-set{
    gap:8px !important;
    padding-right:8px !important;
  }

  .logo-card{
    flex-basis:160px !important;
    width:160px !important;
    min-width:160px !important;
    height:94px !important;
  }

  .logo-card img{
    max-width:152px !important;
    max-height:62px !important;
  }
}


/* ===== Version 13: logos ainda maiores e mais próximas ===== */
/* Aproxima mais as logos no carrossel, mas sem deixar colado, e amplia um pouco o tamanho para melhorar a leitura. */
.partners-stack{
  gap:20px !important;
}

.partner-carousel{
  min-height:146px !important;
  padding:10px 0 18px !important;
}

.marquee-mask{
  padding:14px 0 !important;
  overflow:hidden !important;
  mask-image:linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent) !important;
}

.logo-set{
  gap:9px !important;
  padding-right:9px !important;
  padding-left:0 !important;
}

.logo-card{
  position:relative !important;
  z-index:1 !important;
  flex:0 0 244px !important;
  width:244px !important;
  min-width:244px !important;
  height:132px !important;
  padding:0 !important;
  margin:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}

.logo-card img{
  display:block !important;
  max-width:224px !important;
  max-height:92px !important;
  width:auto !important;
  height:auto !important;
  object-fit:contain !important;
  filter:none !important;
}

.logo-card:hover{
  z-index:5 !important;
  transform:translateY(-3px) scale(1.05) !important;
  filter:drop-shadow(0 12px 18px rgba(74,52,35,.18)) !important;
  background:transparent !important;
  box-shadow:none !important;
}

@media (max-width:860px){
  .partners-stack{gap:18px !important;}
  .partner-carousel{min-height:126px !important;padding:8px 0 15px !important;}
  .marquee-mask{padding:12px 0 !important;}
  .logo-set{gap:8px !important;padding-right:8px !important;}
  .logo-card{
    flex-basis:212px !important;
    width:212px !important;
    min-width:212px !important;
    height:116px !important;
  }
  .logo-card img{
    max-width:194px !important;
    max-height:78px !important;
  }
}

@media (max-width:640px){
  .partners-stack{gap:15px !important;width:min(100% - 28px,var(--container)) !important;}
  .partner-carousel{min-height:108px !important;padding:6px 0 12px !important;}
  .partner-carousel-head{margin-bottom:8px !important;}
  .marquee-mask{
    padding:10px 0 !important;
    mask-image:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent) !important;
  }
  .logo-set{gap:7px !important;padding-right:7px !important;}
  .logo-card{
    flex-basis:178px !important;
    width:178px !important;
    min-width:178px !important;
    height:98px !important;
  }
  .logo-card img{
    max-width:160px !important;
    max-height:64px !important;
  }
}


/* ===== Version 14: mapa real da praça ===== */
.real-map-card{
  position:relative;
  min-height:340px;
  overflow:hidden;
  border:1px solid rgba(74,52,35,.16);
  border-radius:var(--radius-xl);
  background:rgba(251,245,230,.82);
  box-shadow:0 18px 52px rgba(50,35,23,.13), inset 0 1px 0 rgba(255,255,255,.44);
}

.real-map-image{
  display:block;
  width:100%;
  height:100%;
  min-height:340px;
  object-fit:cover;
  object-position:center;
}

.real-map-card::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(33,27,24,0) 56%, rgba(33,27,24,.18) 100%);
}

.real-map-card .map-place-label{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:2;
}

@media (max-width:1050px){
  .real-map-card,
  .real-map-image{min-height:320px;}
}

@media (max-width:720px){
  .real-map-card,
  .real-map-image{min-height:300px;}
  .real-map-card .map-place-label{left:18px;right:18px;bottom:18px;}
}


/* ===== Version 15: mapa estilizado integrado ao visual do site ===== */
.map-showcase{
  display:grid;
  gap:14px;
  align-content:start;
}

.stylized-map-card{
  position:relative;
  width:100%;
  aspect-ratio:4 / 3;
  overflow:hidden;
  border:1px solid rgba(74,52,35,.16);
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg, rgba(251,245,230,.92), rgba(243,239,216,.98));
  box-shadow:0 18px 52px rgba(50,35,23,.13), inset 0 1px 0 rgba(255,255,255,.44);
}

.stylized-map-card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.22);
  z-index:2;
}

.stylized-map-image{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

@media (max-width:1050px){
  .stylized-map-card{aspect-ratio:4 / 3;}
}

@media (max-width:720px){
  .map-showcase{gap:12px;}
  .stylized-map-card{aspect-ratio:1.1 / 1;}
}


/* ===== Version 16: logos nos botões de rota ===== */
.map-buttons{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:10px !important;
  align-items:stretch !important;
}

.map-buttons a.map-button-logo-link{
  min-height:54px !important;
  padding:0 16px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:999px !important;
  border:1px solid rgba(74,52,35,.14) !important;
  background:rgba(251,245,230,.76) !important;
  box-shadow:0 10px 22px rgba(50,35,23,.055), inset 0 1px 0 rgba(255,255,255,.42) !important;
  transition:transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease !important;
}

.map-buttons a.map-button-logo-link:hover{
  transform:translateY(-2px) !important;
  border-color:rgba(128,96,38,.24) !important;
  background:rgba(251,245,230,.94) !important;
  box-shadow:0 14px 28px rgba(128,96,38,.16), inset 0 1px 0 rgba(255,255,255,.5) !important;
}

.map-button-logo{
  display:block !important;
  width:auto !important;
  height:auto !important;
  max-width:38px !important;
  max-height:34px !important;
  object-fit:contain !important;
  filter:drop-shadow(0 4px 8px rgba(74,52,35,.12)) !important;
  transition:transform .22s ease, filter .22s ease !important;
}

.map-button-logo-apple{
  max-width:40px !important;
  max-height:36px !important;
}

.map-button-logo-waze{
  max-width:39px !important;
  max-height:35px !important;
}

.map-buttons a.map-button-logo-link:hover .map-button-logo{
  transform:scale(1.06) !important;
  filter:drop-shadow(0 6px 10px rgba(74,52,35,.18)) !important;
}

@media (max-width:720px){
  .map-buttons{
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
    gap:8px !important;
  }

  .map-buttons a.map-button-logo-link{
    min-height:50px !important;
    padding:0 10px !important;
  }

  .map-button-logo{
    max-width:34px !important;
    max-height:30px !important;
  }

  .map-button-logo-apple{
    max-width:36px !important;
    max-height:32px !important;
  }

  .map-button-logo-waze{
    max-width:35px !important;
    max-height:31px !important;
  }
}


/* ===== Version 17: EBAA logo limpa, sem moldura ===== */
.brand{
  gap:0 !important;
  align-items:center !important;
}

.brand-logo{
  display:block !important;
  width:72px !important;
  height:72px !important;
  object-fit:contain !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  filter:drop-shadow(0 7px 14px rgba(74,52,35,.12)) !important;
  transition:transform .22s ease, filter .22s ease !important;
}

.brand:hover .brand-logo{
  transform:translateY(-1px) scale(1.025) !important;
  filter:drop-shadow(0 10px 18px rgba(74,52,35,.16)) !important;
}

.countdown-logo{
  width:70px !important;
  height:70px !important;
  flex:0 0 auto !important;
  display:block !important;
  object-fit:contain !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.20)) !important;
}

.footer-brand img{
  width:68px !important;
  height:68px !important;
  border-radius:0 !important;
  background:transparent !important;
  object-fit:contain !important;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.24)) !important;
}

@media (max-width:860px){
  .brand-logo{
    width:66px !important;
    height:66px !important;
  }
}

@media (max-width:640px){
  .brand-logo{
    width:60px !important;
    height:60px !important;
  }

  .countdown-logo{
    width:62px !important;
    height:62px !important;
  }

  .footer-brand img{
    width:62px !important;
    height:62px !important;
  }
}

/* ===== Version 22: linha dos subtítulos do carrossel ao lado do texto ===== */
/* Mantém a linha junto do subtítulo de cada carrossel e remove qualquer divisória abaixo dele. */
.partner-carousel-head{
  display:flex !important;
  align-items:center !important;
  width:100% !important;
  margin:0 0 10px !important;
  padding:0 !important;
  border:0 !important;
  box-shadow:none !important;
  color:var(--burgundy) !important;
}

.partner-carousel-head::before,
.partner-carousel-head::after{
  display:none !important;
  content:none !important;
}

.partner-carousel-head span{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  width:100% !important;
  padding:0 !important;
  background:transparent !important;
  color:var(--burgundy) !important;
  font-weight:950 !important;
  letter-spacing:.18em !important;
}

.partner-carousel-head span::after{
  content:"" !important;
  display:block !important;
  flex:1 1 auto !important;
  min-width:54px !important;
  height:1px !important;
  background:linear-gradient(90deg, rgba(150,48,52,.58), rgba(128,96,38,.34), transparent) !important;
}

@media (max-width:640px){
  .partner-carousel-head span{
    gap:10px !important;
  }

  .partner-carousel-head span::after{
    min-width:34px !important;
  }
}


/* ===== Ajuste pontual: imagens reais na galeria ===== */
.gallery-item{
  background-size:cover !important;
  background-position:center !important;
  background-repeat:no-repeat !important;
}

.gallery-photo-encontro{
  background-image:linear-gradient(180deg, transparent 45%, rgba(61,47,62,.56) 100%), url("assets/Galeria/galeria-encontro.webp") !important;
}

.gallery-photo-classicos{
  background-image:linear-gradient(180deg, transparent 45%, rgba(61,47,62,.56) 100%), url("assets/Galeria/galeria-classicos.webp") !important;
}

.gallery-photo-clubes{
  background-image:linear-gradient(180deg, transparent 45%, rgba(61,47,62,.56) 100%), url("assets/Galeria/galeria-clubes.webp") !important;
}

.gallery-photo-praca{
  background-image:linear-gradient(180deg, transparent 45%, rgba(61,47,62,.56) 100%), url("assets/Galeria/galeria-praca.webp") !important;
}

.gallery-photo-premiacao{
  background-image:linear-gradient(180deg, transparent 45%, rgba(61,47,62,.56) 100%), url("assets/Galeria/galeria-premiacao.webp") !important;
}

/* ===== Ajuste final: navbar mobile à direita e logos locais sem fundo ===== */
@media (max-width:860px){
  .nav .nav-inner{
    position:relative !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
  }

  .nav .brand{
    margin-right:auto !important;
  }

  .nav .nav-toggle{
    position:absolute !important;
    right:0 !important;
    top:50% !important;
    margin:0 !important;
    transform:translateY(-50%) !important;
    display:flex !important;
    flex:0 0 42px !important;
    z-index:3 !important;
  }

  .nav .nav-inner > nav{
    margin-left:auto !important;
  }
}

.map-buttons a.map-button-logo-link{
  background:transparent !important;
  box-shadow:none !important;
}

.map-buttons a.map-button-logo-link:hover{
  background:transparent !important;
}

.map-button-logo{
  background:transparent !important;
}


/* ===== Ajuste pontual: centralização do botão da programação ===== */
.program-actions{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  width:100% !important;
  margin-top:30px !important;
}

.program-actions .btn{
  width:auto !important;
}

@media (max-width:640px){
  .program-actions .btn{
    width:100% !important;
  }
}


/* ===== Ajuste pontual: botão programação menor no mobile ===== */
@media (max-width:640px){
  .program-actions{
    padding-inline:18px !important;
  }

  .program-actions .btn{
    width:auto !important;
    max-width:calc(100% - 24px) !important;
    min-height:44px !important;
    padding-inline:18px !important;
    margin-inline:auto !important;
    text-align:center !important;
  }
}


/* ===== Ajuste pontual: contagem zerada com transição e confete ===== */
#confetti-canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:10;
  border-radius:var(--radius-xl);
  opacity:0;
  transition:opacity .3s ease;
}

#confetti-canvas.active{
  opacity:1;
}

.countdown-panel.is-zeroing .count-card{
  background:rgba(150,48,52,.18) !important;
  border-color:rgba(150,48,52,.35) !important;
  transition:background .4s ease, border-color .4s ease;
}

.countdown-panel.is-zeroing .count-card strong{
  color:#F4A5A8 !important;
  transition:color .4s ease;
}

.countdown-panel.event-started .countdown-kicker{
  color:rgba(239,179,123,.92) !important;
}

.countdown-panel.event-started .countdown-title{
  color:var(--ivory) !important;
}

.countdown-panel.event-started .countdown-grid{
  display:block !important;
  position:relative !important;
  z-index:1 !important;
}

.countdown-panel.event-started .count-card,
.countdown-panel.event-started .countdown-slot-word,
.countdown-panel.event-started .countdown-finished{
  display:none !important;
}

.countdown-jumbo-started{
  position:relative;
  z-index:1;
  min-height:clamp(118px, 19vw, 156px);
  display:flex !important;
  align-items:center;
  justify-content:center;
  padding:clamp(16px, 3vw, 22px);
  border-radius:24px;
  border:1px solid rgba(251,245,230,.13);
  background:
    radial-gradient(circle at 50% 34%, rgba(239,179,123,.13), transparent 10rem),
    linear-gradient(135deg, rgba(251,245,230,.075), rgba(251,245,230,.035));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07);
  overflow:hidden;
}

.countdown-jumbo-started::before{
  content:"";
  position:absolute;
  inset:-45%;
  background:
    radial-gradient(circle at 50% 50%, rgba(239,179,123,.12), transparent 28%),
    conic-gradient(from 0deg, transparent, rgba(239,179,123,.10), transparent, rgba(127,161,151,.08), transparent);
  animation:jumboStartedGlow 8s linear infinite;
  opacity:.55;
}

.countdown-jumbo-started span{
  position:relative;
  z-index:1;
  display:block;
  max-width:100%;
  color:var(--ivory);
  font-family:var(--font-title);
  font-size:clamp(1.25rem, 2.8vw, 2.15rem);
  font-weight:800;
  line-height:1.02;
  letter-spacing:-.03em;
  text-align:center;
  text-transform:none;
  text-wrap:balance;
  text-shadow:
    0 2px 0 rgba(74,52,35,.18),
    0 8px 22px rgba(0,0,0,.18);
  animation:jumboStartedPulse 2.4s ease-in-out infinite;
}

@keyframes jumboStartedPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.018);opacity:.86}
}

@keyframes jumboStartedGlow{
  to{transform:rotate(360deg)}
}

@media (max-width:1050px){
  .countdown-jumbo-started span{
    font-size:clamp(1.2rem, 4.5vw, 2rem);
  }
}

@media (max-width:640px){
  .countdown-jumbo-started{
    min-height:120px;
    padding:18px 14px;
  }

  .countdown-jumbo-started span{
    font-size:clamp(1.15rem, 6.5vw, 1.7rem);
    line-height:1.05;
  }
}


/* ===== Ajuste pontual: aparência do botão adicionar à agenda ===== */
.event-row{
  position:relative !important;
}

.event-expand{
  grid-column:1 / -1 !important;
  overflow:hidden !important;
  max-height:0;
  opacity:0;
  display:block !important;
  transition:max-height .38s cubic-bezier(.4,0,.2,1), opacity .28s ease !important;
}

.event-row.is-open .event-expand{
  opacity:1 !important;
}

.event-expand-inner{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:10px !important;
  padding:10px 20px 14px 20px !important;
  border-top:1px solid rgba(128,96,38,.15) !important;
  background:linear-gradient(90deg, rgba(128,96,38,.05) 0%, rgba(150,48,52,.04) 100%) !important;
}

.btn-cal{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:7px !important;
  width:auto !important;
  min-width:auto !important;
  max-width:max-content !important;
  min-height:36px !important;
  padding:8px 16px !important;
  border:0 !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,var(--plum),var(--burgundy)) !important;
  color:#fff !important;
  font-family:var(--font-ui) !important;
  font-size:.72rem !important;
  font-weight:700 !important;
  line-height:1 !important;
  letter-spacing:.06em !important;
  text-transform:uppercase !important;
  cursor:pointer !important;
  box-shadow:0 4px 14px rgba(150,48,52,.22) !important;
  white-space:nowrap !important;
  transition:transform .15s ease, box-shadow .15s ease, opacity .15s ease !important;
  appearance:none !important;
  -webkit-appearance:none !important;
}

.btn-cal:hover{
  transform:translateY(-1px) !important;
  box-shadow:0 6px 20px rgba(150,48,52,.32) !important;
}

.btn-cal:active{
  transform:translateY(0) !important;
}

.btn-cal svg{
  flex:0 0 14px !important;
  width:14px !important;
  height:14px !important;
}

@media(max-width:640px){
  .event-expand-inner{
    justify-content:center !important;
    padding:10px 14px 14px 14px !important;
  }

  .btn-cal{
    max-width:100% !important;
    padding:8px 14px !important;
    font-size:.66rem !important;
    white-space:normal !important;
    text-align:center !important;
  }
}
