/* ============================================
   CIES 2026 — A Igreja Profetica
   Design imersivo com fogo, particulas e drama
   ============================================ */

:root {
  /* PRIMARY: Orange-dominant fire palette */
  --fire: #FF6B35;          /* Main orange — was red */
  --fire-deep: #D9532A;     /* Deep orange for hover/shadow */
  --ember: #FF8B3D;         /* Lighter orange accent */
  --amber: #F7A440;         /* Warm amber */
  --gold: #FFD166;          /* Highlight gold */
  --accent-red: #E63946;    /* Red accent (use sparingly) */
  --accent-red-deep: #9B1B30;

  /* ACTION BUTTONS: Emerald green */
  --btn: #16A34A;
  --btn-deep: #15803D;
  --btn-light: #22C55E;
  --btn-glow: rgba(34,197,94,.4);

  --bg: #080808;
  --bg-alt: #0E0A09;
  --surface: rgba(255,255,255,0.04);
  --surface-hover: rgba(255,255,255,0.07);
  --glass: rgba(20,10,5,0.65);
  --glass-border: rgba(255,107,53,0.15);
  --text: #F5F0EB;
  --text-mid: rgba(245,240,235,0.65);
  --text-dim: rgba(245,240,235,0.35);
  --font: 'Sora', system-ui, sans-serif;
  --script: 'Dancing Script', cursive;
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,0,.2,1);
}

/* RESET */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--fire-deep) transparent}
body{background:var(--bg);color:var(--text);font-family:var(--font);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--fire-deep);border-radius:5px}

/* ============================================
   SCROLL PROGRESS BAR
   ============================================ */
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--fire),var(--ember),var(--amber));z-index:200;transition:width .05s linear;box-shadow:0 0 10px rgba(255,107,53,.5)}

/* ============================================
   TOP COUNTDOWN BAR (fixed)
   ============================================ */
#top-countdown{position:sticky;top:0;left:0;right:0;z-index:150;background:radial-gradient(ellipse 55% 160% at 50% 120%,rgba(255,209,102,.35),transparent 70%),linear-gradient(90deg,#5A1212 0%,var(--accent-red-deep) 15%,#B8321F 32%,var(--fire-deep) 48%,var(--fire) 58%,var(--amber) 72%,#B8321F 85%,var(--accent-red-deep) 95%,#5A1212 100%);color:#fff;padding:.8rem 1rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 22px rgba(0,0,0,.45),inset 0 -1px 0 rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.08);border-bottom:1px solid rgba(0,0,0,.3)}
.tc-inner{display:flex;flex-direction:column;align-items:center;gap:.35rem;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.3)}
.tc-brand{font-weight:800;letter-spacing:.24em;text-transform:uppercase;font-size:.95rem;color:#fff;opacity:.98}
.tc-divider{display:block;width:36px;height:1px;background:rgba(255,255,255,.4)}
.tc-phrase{display:inline-flex;align-items:center;gap:.45rem;font-size:1.02rem;font-weight:500;color:rgba(255,255,255,.95);white-space:nowrap;letter-spacing:.02em}
.tc-num{font-weight:800;color:#fff;font-size:1.2rem;font-variant-numeric:tabular-nums;background:rgba(0,0,0,.38);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:.15rem .6rem;line-height:1;display:inline-block;min-width:2em;text-align:center}
.tc-unit{font-weight:600;text-transform:lowercase}
.tc-and{opacity:.55;font-weight:500;margin:0 .1rem}

body{padding-top:0}

@media (max-width:480px){
  #top-countdown{padding:.7rem .7rem}
  .tc-brand{font-size:.82rem;letter-spacing:.2em}
  .tc-divider{width:28px}
  .tc-phrase{font-size:.88rem;gap:.32rem}
  .tc-num{font-size:1.02rem;padding:.12rem .48rem}
}

/* ============================================
   UTILITIES
   ============================================ */
.container{max-width:1100px;margin:0 auto;padding:0 1.5rem;position:relative}
.tag{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--ember);border:1px solid rgba(255,107,53,.2);padding:.35rem 1rem;border-radius:50px;margin-bottom:1rem}
.heading-xl{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:800;line-height:1.05;margin-bottom:1.5rem}
.heading-lg{font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1;margin-bottom:.5rem}
.script-accent{font-family:var(--script);font-style:normal;color:var(--ember);font-weight:700}
.section-head{text-align:center;margin-bottom:3rem}
.section-desc{color:var(--text-mid);max-width:500px;margin:.5rem auto 0;font-size:.95rem}

/* Section number watermark */
.section-num{position:absolute;top:-1.5rem;right:2rem;font-size:clamp(6rem,12vw,10rem);font-weight:800;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(255,107,53,.06);pointer-events:none;user-select:none;z-index:0}

/* Reveal */
.anim-up{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.anim-up.visible{opacity:1;transform:translateY(0)}

/* Angle cuts */
.angle-cut{position:relative;z-index:2}
.angle-cut-top::before{content:'';position:absolute;top:-40px;left:0;right:0;height:40px;background:inherit;clip-path:polygon(0 100%,100% 0,100% 100%)}
.angle-cut-bottom::after{content:'';position:absolute;bottom:-40px;left:0;right:0;height:40px;background:inherit;clip-path:polygon(0 0,100% 0,0 100%);z-index:2}

/* Shared button */
.btn-fire{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;background:linear-gradient(135deg,var(--btn) 0%,var(--btn-light) 100%);color:#fff;font-family:var(--font);font-weight:700;font-size:.9rem;border:none;border-radius:50px;text-decoration:none;cursor:pointer;transition:transform .25s var(--ease),box-shadow .3s var(--ease)}
.btn-fire:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--btn-glow)}

/* ============================================
   NAVBAR
   ============================================ */
#navbar{position:fixed;top:62px;left:0;right:0;z-index:100;transform:translateY(-200%);transition:transform .45s var(--ease);background:rgba(8,8,8,.8);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--glass-border)}
@media (max-width:640px){#navbar{top:92px}}
#navbar.show{transform:translateY(0)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:56px;display:flex;align-items:center;gap:1rem}
.nav-logo{font-weight:800;font-size:1.1rem;color:var(--text);text-decoration:none;letter-spacing:.04em}
.nav-logo span{color:var(--fire);font-weight:400;font-size:.85em}
.nav-menu{display:flex;gap:1.5rem;margin:0 auto}
.nav-menu a{color:var(--text-mid);text-decoration:none;font-size:.8rem;font-weight:500;letter-spacing:.02em;transition:color .2s;position:relative}
.nav-menu a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--fire);border-radius:1px;transition:width .25s var(--ease)}
.nav-menu a:hover{color:var(--fire)}
.nav-menu a:hover::after{width:100%}
.nav-btn{padding:.45rem 1.2rem;background:var(--btn);color:#fff;font-family:var(--font);font-weight:600;font-size:.75rem;border-radius:50px;text-decoration:none;white-space:nowrap;transition:background .2s}
.nav-btn:hover{background:var(--btn-deep)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile CTA */
#mobile-cta{display:inline-flex;align-items:center;gap:.5rem;position:fixed;bottom:1rem;right:1rem;z-index:99;padding:.85rem 1.25rem;background:linear-gradient(135deg,var(--btn-light) 0%,var(--btn-deep) 100%);color:#fff;font-family:var(--font);font-weight:700;font-size:.88rem;border-radius:50px;text-decoration:none;box-shadow:0 10px 28px rgba(22,163,74,.45),0 0 0 0 rgba(34,197,94,.5);transition:transform .25s var(--ease),box-shadow .3s var(--ease);animation:fabPulse 2.4s ease-in-out infinite}
#mobile-cta:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(34,197,94,.6)}
#mobile-cta::after{content:'→';margin-left:.1rem;font-weight:800;transition:transform .25s var(--ease)}
#mobile-cta:hover::after{transform:translateX(3px)}
@keyframes fabPulse{0%,100%{box-shadow:0 10px 28px rgba(22,163,74,.45),0 0 0 0 rgba(34,197,94,.5)}50%{box-shadow:0 10px 28px rgba(22,163,74,.45),0 0 0 14px rgba(34,197,94,0)}}
@media (max-width:420px){#mobile-cta{padding:.8rem 1.05rem;font-size:.82rem;right:.75rem;bottom:.85rem}}

/* ============================================
   HERO — imersivo com brasas
   ============================================ */
#hero{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background:var(--bg);overflow:hidden}

/* Gradientes ambiente */
#hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 120%,rgba(255,107,53,.18) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 20% 20%,rgba(255,107,53,.08) 0%,transparent 50%),radial-gradient(ellipse 40% 40% at 85% 30%,rgba(217,83,42,.12) 0%,transparent 50%);pointer-events:none}

/* Noise texture */
#hero::after{content:'';position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}

/* ── Decorative lines ── */
.hero-lines{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-lines span{position:absolute;width:1px;height:100%;top:0;background:linear-gradient(180deg,transparent 0%,rgba(255,107,53,.06) 50%,transparent 100%);animation:line-drift 20s linear infinite}
.hero-lines span:nth-child(1){left:15%;animation-delay:0s}
.hero-lines span:nth-child(2){left:50%;animation-delay:-7s;opacity:.5}
.hero-lines span:nth-child(3){left:85%;animation-delay:-14s}

@keyframes line-drift{
  0%{transform:translateY(-100%)}
  100%{transform:translateY(100%)}
}

/* ── Ember particles ── */
.embers{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.embers span{position:absolute;display:block;border-radius:50%;opacity:0;animation:ember-rise linear infinite}

.embers span:nth-child(1){width:3px;height:3px;left:10%;background:var(--fire);animation-duration:6s;animation-delay:0s}
.embers span:nth-child(2){width:2px;height:2px;left:20%;background:var(--ember);animation-duration:8s;animation-delay:1s}
.embers span:nth-child(3){width:4px;height:4px;left:35%;background:var(--amber);animation-duration:7s;animation-delay:.5s}
.embers span:nth-child(4){width:2px;height:2px;left:50%;background:var(--fire);animation-duration:9s;animation-delay:2s}
.embers span:nth-child(5){width:3px;height:3px;left:65%;background:var(--ember);animation-duration:6.5s;animation-delay:1.5s}
.embers span:nth-child(6){width:2px;height:2px;left:75%;background:var(--amber);animation-duration:8.5s;animation-delay:0s}
.embers span:nth-child(7){width:3px;height:3px;left:88%;background:var(--fire);animation-duration:7.5s;animation-delay:3s}
.embers span:nth-child(8){width:2px;height:2px;left:5%;background:var(--ember);animation-duration:10s;animation-delay:2.5s}
.embers span:nth-child(9){width:4px;height:4px;left:42%;background:var(--fire);animation-duration:6s;animation-delay:4s}
.embers span:nth-child(10){width:2px;height:2px;left:58%;background:var(--amber);animation-duration:9s;animation-delay:.8s}
.embers span:nth-child(11){width:3px;height:3px;left:15%;background:var(--fire);animation-duration:7s;animation-delay:3.5s}
.embers span:nth-child(12){width:2px;height:2px;left:30%;background:var(--ember);animation-duration:8s;animation-delay:1.2s}
.embers span:nth-child(13){width:3px;height:3px;left:70%;background:var(--amber);animation-duration:6.8s;animation-delay:2.8s}
.embers span:nth-child(14){width:2px;height:2px;left:82%;background:var(--fire);animation-duration:9.5s;animation-delay:.3s}
.embers span:nth-child(15){width:4px;height:4px;left:48%;background:var(--ember);animation-duration:7.2s;animation-delay:3.2s}
.embers span:nth-child(16){width:2px;height:2px;left:92%;background:var(--amber);animation-duration:8.3s;animation-delay:1.8s}
.embers span:nth-child(17){width:3px;height:3px;left:25%;background:var(--fire);animation-duration:6.3s;animation-delay:4.5s}
.embers span:nth-child(18){width:2px;height:2px;left:55%;background:var(--ember);animation-duration:10.5s;animation-delay:.6s}
.embers span:nth-child(19){width:3px;height:3px;left:78%;background:var(--amber);animation-duration:7.8s;animation-delay:2.2s}
.embers span:nth-child(20){width:2px;height:2px;left:38%;background:var(--fire);animation-duration:8.8s;animation-delay:3.8s}

/* Sparse embers for other sections */
.embers-sparse{opacity:.4}

@keyframes ember-rise{
  0%{bottom:-5%;opacity:0;transform:translateX(0) scale(1)}
  10%{opacity:.9}
  50%{opacity:.6;transform:translateX(30px) scale(.8)}
  80%{opacity:.2}
  100%{bottom:105%;opacity:0;transform:translateX(-20px) scale(.3)}
}

/* Hero content */
.hero-wrap{position:relative;z-index:5;text-align:center;padding:0 2rem 2rem;width:100%;margin-top:-132px}
@media (min-width:768px){.hero-wrap{margin-top:0;padding:0}}

.hero-top-picture{display:block;align-self:stretch;width:100%;margin:0;position:relative;z-index:3}
.hero-top-img{display:block;width:100%;height:auto;max-width:none;margin:0}

.hero-badge{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.35em;text-transform:uppercase;color:var(--amber);border:1px solid rgba(247,164,64,.25);padding:.5rem 1.5rem;border-radius:50px;margin-bottom:2rem;backdrop-filter:blur(4px)}

/* CIES logo — letter by letter with glow */
.hero-logo{display:flex;justify-content:center;gap:.05em;font-size:clamp(5rem,18vw,12rem);font-weight:800;line-height:1;margin-bottom:.5rem;-webkit-user-select:none;user-select:none}
.hero-logo span{display:inline-block;background:linear-gradient(180deg,#fff 20%,var(--amber) 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 40px rgba(255,107,53,.3));animation:glow-pulse 3s ease-in-out infinite;position:relative}
.hero-logo span:nth-child(2){animation-delay:.2s}
.hero-logo span:nth-child(3){animation-delay:.4s}
.hero-logo span:nth-child(4){animation-delay:.6s}

@keyframes glow-pulse{
  0%,100%{filter:drop-shadow(0 0 30px rgba(255,107,53,.2))}
  50%{filter:drop-shadow(0 0 60px rgba(255,107,53,.45)) drop-shadow(0 0 100px rgba(255,107,53,.15))}
}

/* Fire line under CIES */
.hero-fire-line{width:120px;height:2px;margin:0 auto 1rem;background:linear-gradient(90deg,transparent,var(--fire),var(--ember),var(--fire),transparent);border-radius:1px;position:relative}
.hero-fire-line::after{content:'';position:absolute;inset:-3px -20px;background:linear-gradient(90deg,transparent,rgba(255,107,53,.3),transparent);filter:blur(6px);border-radius:4px}

/* Script text */
.hero-script{font-family:var(--script);font-size:clamp(3rem,8vw,5.5rem);color:var(--ember);font-weight:700;margin-bottom:1rem;opacity:0;animation:script-in 1s var(--ease-out) .8s forwards}

@keyframes script-in{
  from{opacity:0;transform:translateY(20px) scale(.9)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.hero-desc{font-size:clamp(.85rem,1.8vw,1.05rem);color:var(--text-mid);font-weight:300;margin-bottom:2.5rem;letter-spacing:.03em;line-height:1.8}

/* Countdown */
.countdown{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-bottom:3rem}
.cd-block{display:flex;flex-direction:column;align-items:center;background:var(--surface);border:1px solid var(--glass-border);border-radius:12px;padding:.8rem 1rem;min-width:68px;backdrop-filter:blur(8px)}
.cd-num{font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:700;font-variant-numeric:tabular-nums;color:var(--text)}
.cd-lbl{font-size:.55rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-dim);font-weight:600;margin-top:.15rem}
.cd-dot{width:4px;height:4px;background:var(--fire);border-radius:50%;opacity:.5;margin-top:-.8rem}

/* Hero button */
.hero-btn{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 2.5rem;background:linear-gradient(135deg,var(--btn-light) 0%,var(--btn-deep) 100%);color:#fff;font-family:var(--font);font-weight:700;font-size:.95rem;border-radius:50px;text-decoration:none;position:relative;overflow:hidden;transition:transform .25s var(--ease),box-shadow .35s var(--ease);box-shadow:0 8px 26px rgba(22,163,74,.35)}
.hero-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--btn-deep) 0%,var(--btn-light) 100%);opacity:0;transition:opacity .3s}
.hero-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 40px var(--btn-glow),0 0 80px rgba(34,197,94,.2)}
.hero-btn:hover::before{opacity:1}
.hero-btn span,.hero-btn svg{position:relative;z-index:1}
@media (min-width:768px){.hero-wrap .hero-btn{display:none}}

/* Scroll indicator */
.scroll-mouse{margin-top:3rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:float 3s ease-in-out infinite}
.mouse-body{width:22px;height:36px;border:2px solid var(--text-dim);border-radius:11px;position:relative}
.mouse-wheel{width:3px;height:7px;background:var(--ember);border-radius:2px;position:absolute;top:6px;left:50%;transform:translateX(-50%);animation:wheel-scroll 2s ease-in-out infinite}
.scroll-mouse span{font-size:.6rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.15em;font-weight:600}

@keyframes wheel-scroll{
  0%{opacity:1;transform:translateX(-50%) translateY(0)}
  100%{opacity:0;transform:translateX(-50%) translateY(12px)}
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

.hero-fade{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(transparent,var(--bg));pointer-events:none;z-index:3}

/* ============================================
   MARQUEE TICKER
   ============================================ */
.ticker{overflow:hidden;background:radial-gradient(ellipse 55% 160% at 50% 120%,rgba(255,209,102,.35),transparent 70%),linear-gradient(90deg,#5A1212 0%,var(--accent-red-deep) 15%,#B8321F 32%,var(--fire-deep) 48%,var(--fire) 58%,var(--amber) 72%,#B8321F 85%,var(--accent-red-deep) 95%,#5A1212 100%);padding:.85rem 0;position:relative;z-index:4;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(0,0,0,.3);box-shadow:inset 0 1px 0 rgba(255,255,255,.08),inset 0 -1px 0 rgba(0,0,0,.25),0 4px 18px rgba(0,0,0,.35);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%)}
.ticker-track{display:flex;align-items:center;gap:2.25rem;white-space:nowrap;animation:marquee 35s linear infinite;width:max-content}
.ticker-track span{font-size:.85rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.25)}
.ticker-dot{flex:none;width:6px;height:6px;background:#fff;border-radius:50%;box-shadow:0 0 8px rgba(255,255,255,.6);opacity:.85}

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

/* ============================================
   SOBRE
   ============================================ */
#sobre{background:var(--bg-alt);padding:4.5rem 0 3.5rem;position:relative;z-index:1}

.sobre-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start;margin-bottom:4rem}

.sobre-right p{color:var(--text-mid);font-size:.92rem;margin-bottom:1rem;line-height:1.85}
.sobre-right strong{color:var(--text)}

/* Verse glow blockquote */
.verse-glow{margin-top:.5rem;padding:1.2rem 1.5rem;border-left:3px solid var(--fire);background:linear-gradient(90deg,rgba(255,107,53,.06) 0%,transparent 100%);border-radius:0 10px 10px 0;font-size:.92rem;color:var(--text);font-style:italic;line-height:1.8;position:relative}
.verse-glow::before{content:'';position:absolute;left:-3px;top:0;bottom:0;width:3px;background:var(--fire);box-shadow:0 0 15px rgba(255,107,53,.5),0 0 30px rgba(255,107,53,.2);border-radius:2px}

.stats{display:flex;justify-content:center;gap:0;border:1px solid var(--glass-border);border-radius:16px;background:var(--glass);backdrop-filter:blur(12px);overflow:hidden}
.stat-item{flex:1;padding:2rem 1.5rem;text-align:center}
.stat-divider{width:1px;background:var(--glass-border);align-self:stretch}
.stat-big{display:block;font-size:3rem;font-weight:800;background:linear-gradient(180deg,var(--fire) 0%,var(--ember) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.stat-txt{font-size:.75rem;color:var(--text-mid);text-transform:uppercase;letter-spacing:.08em;line-height:1.4;margin-top:.3rem;display:block}

/* ============================================
   PRELETORES
   ============================================ */
#preletores{background:var(--bg);padding:0 0 4.5rem;position:relative}

/* Speakers carousel — focus on center card with side peeks */
.speakers-wrap{position:relative;width:100%;margin:0 auto}
.speakers-carousel{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:2rem 0 2.5rem;scrollbar-width:none}
.speakers-carousel::-webkit-scrollbar{display:none}

/* Right spacer to allow last card to center */
.speakers-carousel::after{content:'';flex:0 0 calc(50% - 200px);min-width:1rem}

.speakers-carousel .speaker-card{flex:0 0 400px;scroll-snap-align:center;min-width:0;opacity:.35;transform:scale(.9);transition:opacity .5s var(--ease),transform .5s var(--ease),filter .5s var(--ease);filter:blur(.5px)}
.speakers-carousel .speaker-card.is-active{opacity:1;transform:scale(1);filter:blur(0)}
.speakers-carousel .speaker-card.is-active:hover{transform:scale(1)}

/* Cyclic clones — visual peek only, not interactive */
.speakers-carousel .carousel-clone{pointer-events:none;scroll-snap-align:none}

/* Side fade gradients for premium edge effect */
.speakers-wrap::before,
.speakers-wrap::after{content:'';position:absolute;top:0;bottom:0;width:120px;pointer-events:none;z-index:5}
.speakers-wrap::before{left:0;background:linear-gradient(90deg,var(--bg) 0%,transparent 100%)}
.speakers-wrap::after{right:0;background:linear-gradient(-90deg,var(--bg) 0%,transparent 100%)}

/* Speakers arrows */
.speakers-prev{left:8px}
.speakers-next{right:8px}

.speaker-card{position:relative;padding:0;background:var(--glass);border:1px solid var(--glass-border);border-radius:18px;backdrop-filter:blur(8px);transition:transform .35s var(--ease),border-color .3s,box-shadow .3s;overflow:hidden;display:flex;flex-direction:column}
.speaker-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--fire),var(--ember),var(--fire),transparent);opacity:.4;transition:opacity .3s}
.speaker-card:hover{transform:translateY(-4px);border-color:rgba(255,107,53,.35);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.speaker-card:hover::before{opacity:1}
.speaker-card:hover .speaker-num{opacity:.15}

.speaker-num{position:absolute;top:.7rem;right:1rem;font-size:3rem;font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.2);line-height:1;transition:opacity .3s;pointer-events:none;opacity:.35;z-index:2}

/* Speaker photo (banner top) */
.speaker-photo{width:100%;height:260px;overflow:hidden;position:relative;background:linear-gradient(135deg,rgba(255,107,53,.3),rgba(217,83,42,.5),rgba(15,8,8,.9))}
.speaker-photo img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block;filter:saturate(1.05) contrast(1.02);transition:transform .5s var(--ease)}
.speaker-card:hover .speaker-photo img{transform:scale(1.04)}

/* Photo gradient overlay — smooth blend into card body */
.speaker-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,transparent 55%,rgba(20,8,8,.4) 80%,var(--glass) 100%);pointer-events:none}

/* Placeholder state (no photo) */
.speaker-photo-ph{display:flex;align-items:center;justify-content:center;color:rgba(255,107,53,.35)}
.speaker-photo-ph svg{width:72px;height:72px;opacity:.5}

/* Content area (padded) */
.speaker-content{padding:1.3rem 1.8rem 1.8rem;display:flex;flex-direction:column;flex:1}

.speaker-loc{display:inline-flex;align-items:center;gap:.35rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--amber);padding:.3rem .7rem;border:1px solid rgba(247,164,64,.2);border-radius:50px;margin-bottom:1rem}
.speaker-loc svg{color:var(--ember)}

.speaker-name{font-size:clamp(1.6rem,2.5vw,2rem);font-weight:800;line-height:1.1;margin-bottom:.4rem;letter-spacing:-.01em}
.speaker-name em{font-style:normal;background:linear-gradient(180deg,var(--ember) 0%,var(--fire) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.speaker-role{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-mid);margin-bottom:1.2rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}

.speaker-bio{font-size:.85rem;color:var(--text-mid);line-height:1.7}
.speaker-bio strong{color:var(--text)}

/* ============================================
   LOCAL
   ============================================ */
#local{background:var(--bg-alt);padding:2rem 0 0;position:relative}

.local-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:center}

.local-media{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--glass-border);aspect-ratio:16/9;background:#111;margin-top:22px}
.local-media video{width:100%;height:100%;object-fit:cover;display:block}

/* Coordinates badge */
.coords-badge{position:absolute;bottom:12px;left:12px;display:flex;align-items:center;gap:.4rem;padding:.35rem .8rem;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border-radius:20px;font-size:.6rem;font-weight:600;letter-spacing:.12em;color:var(--amber);border:1px solid rgba(247,164,64,.2)}

.local-info .tag{margin-bottom:.8rem}
.local-addr{display:flex;align-items:flex-start;gap:.5rem;color:var(--text-mid);font-size:.85rem;margin-bottom:1.2rem;line-height:1.6}
.local-addr svg{color:var(--ember);flex-shrink:0;margin-top:2px}

/* Info pills */
.local-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:20px;font-size:.8rem;font-weight:500;color:var(--text-mid)}
.pill svg{color:var(--ember)}

/* ============================================
   HOSPEDAGEM
   ============================================ */
#hospedagem{background:var(--bg);padding:4.5rem 0;position:relative}

.discount-card{display:flex;align-items:center;gap:2rem;padding:2rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;margin-bottom:2rem;position:relative;overflow:hidden;backdrop-filter:blur(12px)}
.discount-glow{position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(255,107,53,.15) 0%,transparent 70%);pointer-events:none}
.discount-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--fire),var(--ember));display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;animation:discount-pulse 3s ease-in-out infinite}
@keyframes discount-pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,107,53,.3)}50%{box-shadow:0 0 0 12px rgba(255,107,53,0)}}

.discount-val{font-size:1.6rem;font-weight:800;color:#fff;line-height:1}
.discount-val small{font-size:.6em}
.discount-info{text-align:left}
.discount-info h3{font-size:1.1rem;font-weight:700;margin-bottom:.4rem}
.discount-info p{color:var(--text-mid);font-size:.88rem;line-height:1.6}
.discount-info strong{color:var(--text)}

/* Fold / Accordion */
.fold{background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;margin-bottom:.75rem;overflow:hidden;backdrop-filter:blur(8px);transition:border-color .3s}
.fold:hover{border-color:rgba(255,107,53,.3)}
.fold summary{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;cursor:pointer;list-style:none;font-weight:600;font-size:.9rem;transition:background .2s}
.fold summary::-webkit-details-marker{display:none}
.fold summary:hover{background:var(--surface)}
.fold summary span:first-child{flex:1}
.fold-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ember);background:rgba(255,107,53,.1);padding:.2rem .6rem;border-radius:20px}
.fold-chevron{color:var(--text-dim);transition:transform .3s var(--ease);flex-shrink:0}
.fold[open] .fold-chevron{transform:rotate(180deg)}
.fold-body{padding:0 1.5rem 1.5rem}

.hotel-chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chip{padding:.7rem 1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:10px;display:flex;flex-direction:column;gap:.15rem;flex:1 1 200px;min-width:200px;transition:border-color .2s,transform .2s}
.chip:hover{border-color:rgba(255,107,53,.3);transform:translateY(-2px)}
.chip strong{font-size:.85rem}
.chip span{font-size:.75rem;color:var(--text-dim)}

.cond-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.cond-list li{font-size:.85rem;color:var(--text-mid);padding-left:1.2rem;position:relative}
.cond-list li::before{content:'';position:absolute;left:0;top:.55rem;width:5px;height:5px;background:var(--ember);border-radius:50%}

/* ============================================
   CRONOGRAMA
   ============================================ */
#cronograma{background:var(--bg-alt);padding:5rem 0 4rem;position:relative}

.day-tabs{display:flex;justify-content:center;gap:.6rem;margin-bottom:2.5rem}
.day-tab{display:flex;flex-direction:column;align-items:center;padding:.8rem 1.3rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:14px;cursor:pointer;font-family:var(--font);color:var(--text-dim);transition:all .3s var(--ease)}
.day-tab:hover{border-color:rgba(255,107,53,.4);color:var(--text-mid)}
.day-tab.active{background:linear-gradient(135deg,var(--fire),var(--fire-deep));border-color:var(--fire);color:#fff;box-shadow:0 4px 20px rgba(255,107,53,.3)}
.dt-num{font-size:1.5rem;font-weight:800;line-height:1}
.dt-label{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;opacity:.8;margin-top:.15rem}

/* Panels */
.day-panel{display:none}
.day-panel.active{display:block;animation:panelIn .35s var(--ease-out)}
@keyframes panelIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Timeline */
.tl{max-width:480px;margin:0 auto;position:relative;padding-left:2rem}
.tl::before{content:'';position:absolute;left:14px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--fire) 0%,var(--glass-border) 100%);border-radius:1px}

.tl-item{display:flex;align-items:flex-start;gap:1.2rem;padding:1rem 0;position:relative;animation:tl-appear .4s var(--ease-out) both}
.tl-item:nth-child(1){animation-delay:0s}
.tl-item:nth-child(2){animation-delay:.06s}
.tl-item:nth-child(3){animation-delay:.12s}
.tl-item:nth-child(4){animation-delay:.18s}
.tl-item:nth-child(5){animation-delay:.24s}
.tl-item:nth-child(6){animation-delay:.3s}

@keyframes tl-appear{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}

.tl-time{font-size:.85rem;font-weight:700;color:var(--ember);min-width:48px;margin-top:2px}
.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--surface);border:2px solid var(--glass-border);flex-shrink:0;margin-top:4px;position:absolute;left:-2rem;transform:translateX(-50%);margin-left:15px}
.tl-dot-fire{background:var(--fire);border-color:var(--fire);box-shadow:0 0 10px rgba(255,107,53,.4)}
.tl-dot-gold{background:var(--gold);border-color:var(--gold);box-shadow:0 0 10px rgba(255,209,102,.4)}
.tl-dot-end{background:var(--text-dim);border-color:var(--text-dim)}

.tl-body{display:flex;flex-direction:column;gap:.15rem}
.tl-body strong{font-size:.9rem}
.tl-body small{font-size:.75rem;color:var(--text-dim)}
.tl-tag{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}
.tl-checkin{color:var(--amber)}
.tl-end{color:var(--text-dim)}
.tl-special{color:var(--gold)}

/* ============================================
   INGRESSOS
   ============================================ */
#ingressos{background:var(--bg);padding:1.5rem 0 3rem;position:relative;overflow:hidden}
#ingressos .container{max-width:1280px;position:relative;z-index:2}

/* Grid pattern background */
#ingressos::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,107,53,.08) 1px,transparent 1px);background-size:32px 32px;opacity:.35;mask-image:radial-gradient(ellipse 70% 50% at 50% 50%,#000 40%,transparent 85%);-webkit-mask-image:radial-gradient(ellipse 70% 50% at 50% 50%,#000 40%,transparent 85%);pointer-events:none;z-index:1}

.pricing{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;align-items:stretch;padding-top:1.5rem}

.price-card{background:linear-gradient(180deg,rgba(30,15,15,.7) 0%,rgba(15,8,8,.85) 100%);border:1px solid var(--glass-border);border-radius:20px;padding:2rem 1.2rem 1.6rem;text-align:center;position:relative;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .3s;backdrop-filter:blur(10px);transform-style:preserve-3d;perspective:800px;display:flex;flex-direction:column;box-shadow:0 4px 24px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.04)}

/* Top color accent bar per tier */
.price-card::before{content:'';position:absolute;top:0;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,var(--tier-accent,var(--fire)),transparent);border-radius:2px;opacity:.7}

/* Subtle radial glow from top per tier */
.price-card::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:140px;height:140px;background:radial-gradient(circle,var(--tier-glow,rgba(255,107,53,.18)) 0%,transparent 70%);pointer-events:none;opacity:.6;transition:opacity .3s}
.price-card:hover::after{opacity:1}
.price-card:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08);border-color:rgba(255,107,53,.4)}


.pc-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--amber),var(--ember));color:#0f0808;font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;padding:.4rem 1rem;border-radius:50px;white-space:nowrap;z-index:3;box-shadow:0 4px 20px rgba(247,164,64,.4)}

.pc-head{margin-bottom:1.4rem;min-height:82px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1}
.pc-tier{font-size:.56rem;text-transform:uppercase;letter-spacing:.18em;color:var(--text-dim);font-weight:700}
.pc-name{font-size:1.55rem;font-weight:800;margin:.3rem 0 0;line-height:1;letter-spacing:-.01em}
.pc-price{font-size:2rem;font-weight:800;margin-bottom:1.3rem;min-height:68px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;letter-spacing:-.02em}
.pc-price small{display:block;font-size:.6rem;font-weight:500;color:var(--text-dim);margin-top:.3rem;letter-spacing:.05em}

.pc-btn{display:block;padding:.7rem 1rem;font-family:var(--font);font-weight:700;font-size:.78rem;border-radius:50px;text-decoration:none;border:1.5px solid var(--tier-accent,var(--btn));color:var(--text);background:transparent;transition:all .25s var(--ease);margin-bottom:1.4rem;cursor:pointer;white-space:nowrap;position:relative;z-index:1;letter-spacing:.02em}
.pc-btn:hover{background:var(--tier-accent,var(--btn));color:#fff;box-shadow:0 4px 18px var(--tier-glow,var(--btn-glow));transform:translateY(-1px)}

/* Featured card gets filled button */
.pc-featured .pc-btn{background:linear-gradient(135deg,var(--amber),var(--ember));color:#fff;border-color:transparent;box-shadow:0 4px 18px rgba(247,164,64,.3)}
.pc-featured .pc-btn:hover{background:linear-gradient(135deg,var(--ember),var(--amber));box-shadow:0 6px 24px rgba(247,164,64,.45)}

/* VIP gets filled fire button */
.pc-vip .pc-btn{background:linear-gradient(135deg,var(--accent-red),var(--accent-red-deep));color:#fff;border-color:transparent;box-shadow:0 4px 18px rgba(230,57,70,.3)}
.pc-vip .pc-btn:hover{background:linear-gradient(135deg,var(--accent-red-deep),var(--accent-red));box-shadow:0 6px 24px rgba(230,57,70,.45)}

.pc-btn-fill{border-color:transparent}

.pc-perks{list-style:none;text-align:left;border-top:1px solid var(--glass-border);padding-top:.9rem;margin-top:auto}
.pc-perks li{font-size:.75rem;color:var(--text-mid);padding:.25rem 0 .25rem 1.1rem;position:relative;line-height:1.4}
.pc-perks li::before{content:'';position:absolute;left:0;top:.6rem;width:4px;height:4px;border-radius:50%;background:var(--fire)}

/* ─── Variant: Comum (silver/neutral) ─── */
.price-card:first-child{--tier-accent:rgba(200,200,200,.3);--tier-glow:rgba(200,200,200,.08)}

/* ─── Variant: Gold (FEATURED - elevated) ─── */
.pc-featured{--tier-accent:var(--amber);--tier-glow:rgba(247,164,64,.25);border-color:rgba(247,164,64,.35);background:linear-gradient(180deg,rgba(247,164,64,.12) 0%,rgba(30,15,8,.9) 55%,rgba(15,8,8,.95) 100%);transform:translateY(-20px);box-shadow:0 12px 40px rgba(247,164,64,.15),0 4px 20px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,220,180,.1);z-index:2}
.pc-featured:hover{transform:translateY(-28px);box-shadow:0 24px 60px rgba(247,164,64,.25),0 8px 24px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,220,180,.15)}
.pc-featured .pc-name{background:linear-gradient(180deg,var(--gold) 0%,var(--amber) 60%,var(--ember) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pc-featured .pc-price{background:linear-gradient(180deg,#fff 20%,var(--amber) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pc-featured::before{background:linear-gradient(90deg,transparent,var(--amber),transparent);height:3px;opacity:1}

/* ─── Variant: VIP (deep red for distinction) ─── */
.pc-vip{--tier-accent:var(--accent-red);--tier-glow:rgba(230,57,70,.22);border-color:rgba(230,57,70,.3);background:linear-gradient(180deg,rgba(230,57,70,.08) 0%,rgba(20,8,8,.85) 55%,rgba(15,8,8,.95) 100%)}
.pc-vip .pc-name{background:linear-gradient(180deg,#fff 20%,var(--accent-red) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ─── Variant: Premium (deep gold) ─── */
.pc-premium{--tier-accent:var(--gold);--tier-glow:rgba(255,209,102,.18);border-color:rgba(255,209,102,.25);background:linear-gradient(180deg,rgba(255,209,102,.06) 0%,rgba(20,15,8,.85) 55%,rgba(15,8,8,.95) 100%)}
.pc-premium .pc-name{background:linear-gradient(180deg,#fff 20%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Carousel wrap (mobile) — contains pricing + arrows */
.tickets-cta{display:flex;flex-direction:column;align-items:center;padding:0}
.tickets-btn{font-size:1.05rem;padding:1.1rem 2.8rem}
#ingressos .section-head{margin-bottom:1.25rem}

.pricing-wrap{position:relative}

/* Carousel arrows (mobile only) */
.carousel-arrow{display:none;position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(20,8,8,.85);backdrop-filter:blur(10px);border:1px solid rgba(255,107,53,.4);color:var(--text);align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background .2s,transform .2s,opacity .2s;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.carousel-arrow:active{transform:translateY(-50%) scale(.92)}
.carousel-arrow:hover{background:var(--fire);border-color:var(--fire)}
.carousel-arrow[disabled]{opacity:.35;pointer-events:none}

/* Speakers arrows always visible (desktop + mobile) */
.speakers-prev,.speakers-next{display:flex}
.carousel-prev{left:-4px}
.carousel-next{right:-4px}

/* Carousel dots (mobile) */
.carousel-dots{display:none;justify-content:center;gap:.4rem;margin-top:1.5rem}
.carousel-dots span{width:8px;height:8px;border-radius:50%;background:var(--glass-border);transition:background .2s,transform .2s;cursor:pointer}
.carousel-dots span.active{background:var(--fire);transform:scale(1.3)}

/* ============================================
   FAQ
   ============================================ */
#faq{background:var(--bg-alt);padding:5rem 0 4rem;position:relative}

.faq-list{max-width:700px;margin:0 auto}

.faq{border-bottom:1px solid var(--glass-border);transition:background .2s}
.faq:hover{background:rgba(255,107,53,.02)}
.faq summary{padding:1.2rem 0;cursor:pointer;font-weight:600;font-size:.95rem;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.3rem;color:var(--fire);font-weight:300;transition:transform .3s var(--ease)}
.faq[open] summary::after{transform:rotate(45deg)}
.faq summary:hover{color:var(--ember)}

.faq-body{padding:0 0 1.5rem;color:var(--text-mid);font-size:.88rem;line-height:1.7;animation:faq-open .3s var(--ease-out)}
@keyframes faq-open{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.faq-body p{margin-bottom:.7rem}
.faq-body strong{color:var(--text)}
.faq-body ul{list-style:disc;margin-left:1.5rem;margin-bottom:.7rem}
.faq-body li{margin-bottom:.2rem}

/* FAQ contact */
.faq-contact{text-align:center;margin-top:3rem;padding:2.5rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;backdrop-filter:blur(12px)}
.faq-contact p{color:var(--text-mid);margin-bottom:1rem;font-size:.95rem}
.btn-whatsapp{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 2rem;background:#25D366;color:#fff;font-family:var(--font);font-weight:600;font-size:.85rem;border-radius:50px;text-decoration:none;transition:transform .2s,box-shadow .3s}
.btn-whatsapp:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(37,211,102,.3)}
.faq-phone{display:block;margin-top:.8rem;font-size:.8rem;color:var(--text-dim)}

/* ============================================
   FINAL CTA
   ============================================ */
#final-cta{background:var(--bg);padding:4.5rem 0;position:relative;overflow:hidden;text-align:center}
#final-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 80%,rgba(255,107,53,.12) 0%,transparent 60%);pointer-events:none}

.final-cta-wrap{position:relative;z-index:2}
.final-pre{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.3em;color:var(--ember);margin-bottom:.5rem}
.final-desc{color:var(--text-mid);font-size:.95rem;margin-bottom:2rem}

/* ============================================
   FOOTER
   ============================================ */
#footer{background:#050505;border-top:1px solid var(--glass-border);padding:3rem 0 2rem}
.footer-top{display:flex;justify-content:space-between;gap:3rem;margin-bottom:2rem}
.footer-brand p{color:var(--text-dim);font-size:.78rem;margin-top:.3rem;line-height:1.5}
.foot-logo{font-size:1.3rem}
.footer-col{display:flex;flex-direction:column;gap:.4rem}
.footer-col h4{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--text-mid);margin-bottom:.3rem}
.footer-col a{color:var(--text-dim);text-decoration:none;font-size:.8rem;transition:color .2s}
.footer-col a:hover{color:var(--fire)}
.footer-bottom{border-top:1px solid var(--glass-border);padding-top:1.5rem;text-align:center}
.footer-bottom p{font-size:.7rem;color:var(--text-dim)}

/* ============================================
   RESPONSIVE
   ============================================ */
/* Tablet — 3 colunas com 5o card centralizado */
@media(max-width:1024px) and (min-width:769px){
  .pricing{grid-template-columns:repeat(3,1fr)}
  .pricing .price-card:nth-child(4){grid-column:1 / span 1}
  .pricing .price-card:nth-child(5){grid-column:2 / span 1}

  /* Speakers tablet: maintain spotlight but smaller cards */
  .speakers-carousel{padding:1.5rem 0 2rem}
  .speakers-carousel::after{flex:0 0 calc(50% - 175px)}
  .speakers-carousel .speaker-card{flex:0 0 350px}
}

@media(max-width:768px){
  /* Nav */
  .hamburger{display:flex}
  .nav-menu{display:none;position:absolute;top:56px;left:0;right:0;background:rgba(8,8,8,.95);backdrop-filter:blur(20px);flex-direction:column;padding:1rem 1.5rem 1.5rem;border-bottom:1px solid var(--glass-border);margin:0}
  .nav-menu.open{display:flex}
  .nav-menu a{padding:.6rem 0;font-size:.95rem}
  .nav-menu a::after{display:none}
  .nav-btn{display:none}

  /* Section nums */
  .section-num{font-size:6rem;right:1rem;top:-1rem}

  /* Hero */
  .hero-logo{font-size:clamp(4rem,20vw,6rem)}
  .hero-lines{display:none}
  .countdown{gap:.4rem}
  .cd-block{min-width:55px;padding:.6rem .7rem}
  .scroll-mouse{margin-top:2rem}

  /* Sobre */
  .sobre-grid{grid-template-columns:1fr;gap:2rem}
  .stats{flex-direction:column}
  .stat-divider{width:100%;height:1px}

  /* Local */
  .local-grid{grid-template-columns:1fr;gap:2rem}

  /* Speakers mobile: 1 card focus, no blur, hide clones/spacers */
  .speakers-carousel{gap:1rem;padding:1rem 5% 1.5rem}
  .speakers-carousel::after{display:none}
  .speakers-carousel .speaker-card{flex:0 0 90%;opacity:1;transform:none;filter:none}
  .speakers-carousel .carousel-clone{display:none}
  .speakers-wrap::before,.speakers-wrap::after{display:none}
  .speakers-prev{left:4px}
  .speakers-next{right:4px}
  .speaker-photo{height:260px}
  .speaker-photo img{object-position:center 15%}
  .speaker-content{padding:1.2rem 1.4rem 1.4rem}
  .speaker-num{font-size:2.4rem;top:.5rem;right:.9rem}

  /* Pricing — carousel */
  .pricing{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:1rem;padding-bottom:1rem;scrollbar-width:none}
  .pricing::-webkit-scrollbar{display:none}
  .price-card{min-width:270px;scroll-snap-align:center;flex-shrink:0}
  .carousel-dots{display:flex}
  .carousel-arrow{display:flex}

  /* Hosp */
  .discount-card{flex-direction:column;text-align:center}
  .discount-info{text-align:center}

  /* Footer */
  .footer-top{flex-direction:column;align-items:center;text-align:center}
  .footer-col{align-items:center}

  /* Angle cuts smaller */
  .angle-cut-top::before,.angle-cut-bottom::after{height:24px}
  .angle-cut-top::before{top:-24px}
  .angle-cut-bottom::after{bottom:-24px}

  /* Tighter section padding on mobile */
  #sobre{padding:3.5rem 0 0}
  #preletores,#hospedagem,#ingressos,#final-cta{padding:2rem 0 1.5rem}
  #cronograma,#faq{padding:1.5rem 0 3rem}
  #local{padding:.5rem 0 1rem}
}

@media(max-width:480px){
  .hero-logo{gap:0}
  .speaker-content{padding:1rem 1.2rem 1.2rem}
  .speaker-name{font-size:1.4rem}
  .speaker-bio{font-size:.8rem}
  .day-tabs{gap:.3rem}
  .day-tab{padding:.6rem .9rem}
  .dt-num{font-size:1.2rem}
  .local-pills{flex-direction:column;align-items:flex-start}
}

/* ============================================
   LEAD CAPTURE MODAL
   ============================================ */
#ingressos.lead-locked{display:none}

.lead-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:1rem}
.lead-modal.is-open{display:flex}
.lead-backdrop{position:absolute;inset:0;background:rgba(5,3,3,.78);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:leadFadeIn .25s ease}
.lead-panel{position:relative;width:100%;max-width:440px;background:linear-gradient(180deg,#1a1210 0%,#0d0807 100%);border:1px solid rgba(255,107,53,.18);border-radius:20px;padding:2.2rem 1.75rem 1.75rem;box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 80px rgba(255,107,53,.08);animation:leadSlideUp .35s var(--ease-out)}
.lead-close{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text-mid);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.lead-close:hover{background:rgba(255,107,53,.15);color:var(--fire);border-color:rgba(255,107,53,.3)}
.lead-progress{height:3px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;margin-bottom:1.6rem}
.lead-progress-bar{display:block;height:100%;width:50%;background:linear-gradient(90deg,var(--btn-light),var(--btn));border-radius:3px;transition:width .35s var(--ease)}
.lead-modal[data-step="2"] .lead-progress-bar{width:100%}
.lead-modal[data-step="3"] .lead-progress-bar{width:100%;background:linear-gradient(90deg,var(--btn),var(--btn-deep))}
.lead-modal[data-step="3"] .lead-progress{opacity:.5}

.lead-step-success{text-align:center;padding:.5rem 0}
.lead-check{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto 1rem;border-radius:50%;background:linear-gradient(135deg,var(--btn-light),var(--btn-deep));color:#fff;box-shadow:0 8px 28px rgba(34,197,94,.35);animation:leadCheckPop .4s var(--ease-out)}
.lead-step-success .lead-title{font-size:1.55rem;margin-bottom:.5rem}
.lead-success-sub{color:var(--text-mid);font-size:.88rem;line-height:1.55;max-width:340px;margin:0 auto 1.25rem}
@keyframes leadCheckPop{0%{opacity:0;transform:scale(.4)}60%{transform:scale(1.12)}100%{opacity:1;transform:scale(1)}}

.lead-form{position:relative}
.lead-step{display:none;animation:leadFadeIn .3s ease}
.lead-step.is-active{display:block}
.lead-step-tag{display:inline-block;font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--btn-light);margin-bottom:.5rem;opacity:.9}
.lead-title{font-size:1.45rem;font-weight:800;color:var(--text);line-height:1.2;margin-bottom:.45rem}
.lead-sub{color:var(--text-mid);font-size:.88rem;margin-bottom:1.2rem;line-height:1.5}
.lead-input{width:100%;padding:.95rem 1.1rem;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.1);border-radius:12px;color:var(--text);font-family:var(--font);font-size:1rem;transition:all .2s;outline:none}
.lead-input::placeholder{color:var(--text-dim)}
.lead-input:focus{border-color:var(--btn-light);background:rgba(22,163,74,.05);box-shadow:0 0 0 4px rgba(34,197,94,.12)}
.lead-input.is-invalid{border-color:var(--accent-red);box-shadow:0 0 0 4px rgba(230,57,70,.12)}
.lead-error{display:block;min-height:18px;font-size:.78rem;color:var(--accent-red);margin-top:.4rem;opacity:0;transition:opacity .2s}
.lead-error.is-visible{opacity:1}
.lead-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:1rem;padding:.95rem 1.5rem;background:linear-gradient(135deg,var(--btn-light) 0%,var(--btn-deep) 100%);color:#fff;font-family:var(--font);font-weight:700;font-size:.95rem;border:none;border-radius:50px;cursor:pointer;transition:transform .2s,box-shadow .3s;box-shadow:0 6px 20px rgba(22,163,74,.28)}
.lead-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 28px rgba(34,197,94,.4)}
.lead-btn:disabled{opacity:.6;cursor:wait}
.lead-btn.is-loading .lead-btn-label::after{content:' ...';animation:leadDots 1.2s infinite}
.lead-back{display:block;margin:.8rem auto 0;background:none;border:none;color:var(--text-dim);font-family:var(--font);font-size:.8rem;cursor:pointer;padding:.4rem .8rem;transition:color .2s}
.lead-back:hover{color:var(--fire)}

@keyframes leadFadeIn{from{opacity:0}to{opacity:1}}
@keyframes leadSlideUp{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes leadDots{0%,20%{content:''}40%{content:' .'}60%{content:' ..'}80%,100%{content:' ...'}}

body.lead-open{overflow:hidden}

@media (max-width:480px){
  .lead-panel{padding:2rem 1.3rem 1.3rem;border-radius:16px}
  .lead-title{font-size:1.25rem}
}
