/* ═══════════════════════════════════════════════
   COPA DO MUNDO DO EBOL — HOMEPAGE TAKEOVER
   Broadcast de Copa · mobile-first · theme-aware
   Claro = gramado de dia · Escuro = estádio à noite
   Renderiza só enquanto a Copa está ativa; reverte
   pro landing normal quando ela termina.
   Namespace .cml-* — não colide com .landing-*.
   ═══════════════════════════════════════════════ */

.cml-home {
  --cml-gold: #E8B84B;          /* ouro — só legível em fundo ESCURO */
  --cml-gold-deep: #C9971F;     /* decoração (bordas, setas) */
  --cml-gold-ink: #8C6D00;      /* ouro-texto em fundo CLARO (AA 4.5:1+) */
  --cml-gold-soft: rgba(232, 184, 75, 0.14);
  --cml-gold-line: rgba(232, 184, 75, 0.32);

  /* Hero/CTA — defaults do tema CLARO (gramado de dia) */
  --cml-stage-bg: radial-gradient(135% 100% at 50% -12%, #ffffff 0%, var(--green-wash) 46%, #DCEAE1 100%);
  --cml-stage-ink: var(--text-primary);
  --cml-stage-ink-mut: var(--text-secondary);
  --cml-stage-title: #143026;        /* "ebol" / "seleção" no claro = verde profundo */
  --cml-stage-gold: var(--cml-gold-ink);
  --cml-stage-line: rgba(20, 48, 38, 0.045);
  --cml-stage-chip-bg: rgba(20, 48, 38, 0.04);
  --cml-stage-chip-bd: rgba(20, 48, 38, 0.10);

  margin: 0;
  padding: 0;
  overflow-x: hidden;
  font-family: var(--font-body);
  color: var(--text-primary);
}

[data-theme="dark"] .cml-home {
  --cml-stage-bg: radial-gradient(130% 95% at 50% -15%, #1f4a39 0%, #143026 42%, #0b1c15 100%);
  --cml-stage-ink: #F3F7F4;
  --cml-stage-ink-mut: #9FB6A8;
  --cml-stage-title: #ffffff;
  --cml-stage-gold: var(--cml-gold);
  --cml-stage-line: rgba(255, 255, 255, 0.025);
  --cml-stage-chip-bg: rgba(255, 255, 255, 0.03);
  --cml-stage-chip-bd: rgba(255, 255, 255, 0.10);
}

/* O body do landing tem textura; some pra leitura limpa do takeover. */
.landing-body:has(.cml-home) { background-image: none; }

.cml-home a { text-decoration: none; }
.cml-home strong { font-weight: 700; }

/* ═══ NAV ═══ */

.cml-nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  display: flex;
  justify-content: center;
  padding: 0.7rem 0.85rem;
}
.cml-nav-inner {
  width: 100%;
  max-width: 1180px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.5rem 0.6rem 0.5rem 1rem;
  border-radius: 999px;
  background: var(--cml-stage-chip-bg);
  border: 1px solid var(--border);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
[data-theme="dark"] .cml-nav-inner {
  background: rgba(11, 28, 21, 0.72);
  border-color: rgba(232, 184, 75, 0.18);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.25);
}

.cml-logo { display: inline-flex; align-items: baseline; gap: 0.5rem; color: var(--text-primary); min-width: 0; }
.cml-logo-text { font-family: var(--font-display); font-size: 1.25rem; font-weight: 800; letter-spacing: -0.02em; line-height: 1; }
.cml-logo-dot { display: inline-block; width: 6px; height: 6px; background: var(--accent); border-radius: 50%; margin-left: 1px; }
.cml-logo-tag {
  display: none;
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cml-gold-ink); padding-left: 0.55rem; border-left: 1px solid var(--cml-gold-line);
}
[data-theme="dark"] .cml-logo-tag { color: var(--cml-gold); }

.cml-nav-actions { display: flex; align-items: center; gap: 0.5rem; flex-shrink: 0; }

.cml-nav-toggle {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--bg-surface); color: var(--text-muted);
  cursor: pointer; transition: all 0.15s ease; flex-shrink: 0;
}
.cml-nav-toggle:hover { color: var(--green-primary); border-color: var(--green-primary); }
/* ícones sobrepostos, trocados pelo data-theme (mesma convenção do site) */
.cml-nav-toggle .icon-sun,
.cml-nav-toggle .icon-moon { position: absolute; transition: opacity 0.3s ease, transform 0.3s ease; }
.cml-nav-toggle .icon-sun  { opacity: 1; transform: rotate(0deg) scale(1); }
.cml-nav-toggle .icon-moon { opacity: 0; transform: rotate(-90deg) scale(0); }
[data-theme="light"] .cml-nav-toggle .icon-sun  { opacity: 0; transform: rotate(90deg) scale(0); }
[data-theme="light"] .cml-nav-toggle .icon-moon { opacity: 1; transform: rotate(0deg) scale(1); }

.cml-nav-cta {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 1rem; border-radius: 999px; font-weight: 700; font-size: 0.85rem;
  color: #fff; background: var(--accent); box-shadow: 0 6px 16px rgba(232, 98, 26, 0.3);
  transition: transform 0.15s ease, box-shadow 0.2s ease; white-space: nowrap;
}
.cml-nav-cta:hover { transform: translateY(-1px); box-shadow: 0 10px 22px rgba(232, 98, 26, 0.42); }

/* ═══ HERO (theme-aware) ═══ */

.cml-hero {
  position: relative;
  min-height: 100svh;
  display: flex; align-items: center; justify-content: center;
  padding: 6rem 1.25rem 3.5rem;
  background: var(--cml-stage-bg);
  overflow: hidden;
  isolation: isolate;
}
/* aura dourada da taça */
.cml-hero::before {
  content: "";
  position: absolute; top: -10%; left: 50%; transform: translateX(-50%);
  width: min(820px, 130vw); height: 760px;
  background: radial-gradient(circle, var(--cml-gold-soft) 0%, rgba(232, 184, 75, 0.05) 38%, transparent 64%);
  filter: blur(6px); z-index: -2; animation: wcAura 9s ease-in-out infinite;
}
/* listras de gramado */
.cml-hero::after {
  content: "";
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background-image: repeating-linear-gradient(115deg, var(--cml-stage-line) 0 1px, transparent 1px 60px);
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 28%, #000 72%, transparent);
          mask-image: linear-gradient(180deg, transparent, #000 28%, #000 72%, transparent);
}
@keyframes wcAura {
  0%, 100% { opacity: 0.8; transform: translateX(-50%) scale(1); }
  50%      { opacity: 1;   transform: translateX(-50%) scale(1.06); }
}

.cml-hero-inner { position: relative; width: 100%; max-width: 920px; text-align: center; z-index: 1; }

.cml-badge {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.38rem 0.85rem; border-radius: 999px;
  background: var(--cml-gold-soft); border: 1px solid var(--cml-gold-line); color: var(--cml-stage-gold);
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.13em; text-transform: uppercase;
  margin-bottom: 1.3rem; animation: wcRise 0.7s 0.05s both;
}
.cml-badge-pulse {
  width: 6px; height: 6px; border-radius: 50%; background: currentColor;
  box-shadow: 0 0 0 0 currentColor; animation: wcPulse 2s infinite;
}
@keyframes wcPulse {
  0%   { box-shadow: 0 0 0 0 rgba(200, 151, 31, 0.5); }
  70%  { box-shadow: 0 0 0 7px rgba(200, 151, 31, 0); }
  100% { box-shadow: 0 0 0 0 rgba(200, 151, 31, 0); }
}

.cml-eyebrow {
  margin: 0 0 0.8rem; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--cml-stage-gold); animation: wcRise 0.7s 0.12s both;
}

.cml-title {
  margin: 0 0 1.2rem; font-family: var(--font-display); font-weight: 800;
  letter-spacing: -0.03em; line-height: 0.92; color: var(--cml-stage-ink);
  font-size: clamp(3rem, 17vw, 6rem); animation: wcRise 0.8s 0.18s both;
}
.cml-title-sm {
  display: block; font-size: clamp(1rem, 4.4vw, 1.7rem); font-weight: 700;
  letter-spacing: 0.01em; color: var(--cml-stage-ink-mut); margin-bottom: 0.4rem;
}
.cml-title-gold { color: var(--cml-stage-title); }
[data-theme="dark"] .cml-title-gold {
  background: linear-gradient(135deg, #F6D784 0%, var(--cml-gold) 45%, var(--cml-gold-deep) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  text-shadow: 0 2px 40px rgba(232, 184, 75, 0.22);
}

.cml-lede {
  max-width: 600px; margin: 0 auto 1.5rem; font-size: clamp(0.98rem, 4vw, 1.18rem);
  line-height: 1.6; color: var(--cml-stage-ink-mut); animation: wcRise 0.8s 0.26s both;
}
.cml-lede strong { color: var(--cml-stage-ink); font-weight: 700; }

.cml-hero-stats {
  display: inline-flex; flex-wrap: wrap; justify-content: center;
  margin: 0 0 1.8rem; border: 1px solid var(--cml-stage-chip-bd); border-radius: 16px;
  background: var(--cml-stage-chip-bg); overflow: hidden; animation: wcRise 0.8s 0.34s both;
}
.cml-stat { padding: 0.8rem 1.2rem; text-align: center; flex: 1 0 auto; min-width: 92px; }
.cml-stat + .cml-stat { border-left: 1px solid var(--cml-stage-chip-bd); }
.cml-stat-num {
  display: block; font-family: var(--font-display); font-size: clamp(1.45rem, 7vw, 2.3rem);
  font-weight: 800; line-height: 1; color: var(--cml-stage-gold); letter-spacing: -0.02em;
}
.cml-stat-label {
  display: block; margin-top: 0.3rem; font-size: 0.62rem; font-weight: 600;
  letter-spacing: 0.09em; text-transform: uppercase; color: var(--cml-stage-ink-mut);
}

.cml-hero-cta { display: flex; flex-direction: column; align-items: center; gap: 0.9rem; animation: wcRise 0.8s 0.42s both; }
.cml-cta-row { display: flex; flex-direction: column; align-items: stretch; gap: 0.7rem; width: 100%; max-width: 340px; }

.cml-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding: 0.95rem 1.8rem; border-radius: 12px; font-family: var(--font-display);
  font-size: 1.02rem; font-weight: 700; color: #fff;
  background: linear-gradient(135deg, var(--accent-glow) 0%, var(--accent) 60%, var(--accent-dark) 100%);
  box-shadow: 0 10px 28px rgba(232, 98, 26, 0.36); transition: transform 0.16s ease, box-shadow 0.2s ease;
}
.cml-cta:hover { transform: translateY(-2px); box-shadow: 0 16px 38px rgba(232, 98, 26, 0.48); }
.cml-cta-arrow { transition: transform 0.2s ease; }
.cml-cta:hover .cml-cta-arrow { transform: translateX(4px); }

.cml-ghost {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.45rem;
  padding: 0.95rem 1.4rem; border-radius: 12px; font-weight: 600; font-size: 0.95rem;
  color: var(--cml-stage-ink); border: 1px solid var(--cml-stage-chip-bd); transition: all 0.2s ease;
}
.cml-ghost:hover { background: var(--cml-stage-chip-bg); border-color: var(--cml-gold-line); }

.cml-cta-hint { margin: 0; font-size: 0.8rem; color: var(--cml-stage-ink-mut); }
.cml-cta-hint b { color: var(--cml-stage-gold); font-weight: 700; }

.cml-scroll {
  position: absolute; bottom: 1.3rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 0.45rem;
  color: var(--cml-stage-ink-mut); font-size: 0.58rem; letter-spacing: 0.24em; text-transform: uppercase;
}
.cml-scroll-line { width: 1px; height: 34px; background: linear-gradient(180deg, var(--cml-stage-gold), transparent); animation: wcScroll 1.8s ease-in-out infinite; }
@keyframes wcScroll {
  0%, 100% { opacity: 0.3; transform: scaleY(0.6); transform-origin: top; }
  50%      { opacity: 1;   transform: scaleY(1);   transform-origin: top; }
}
@keyframes wcRise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }

/* ═══ SEÇÕES ═══ */

.cml-section { padding: 3.75rem 1.25rem; background: var(--bg-surface); }
.cml-section--alt { background: var(--bg-card); }
/* emenda hero→conteúdo (lower-third de transmissão) */
.cml-section:first-of-type { border-top: 1px solid var(--cml-gold-line); box-shadow: 0 -1px 32px rgba(232, 184, 75, 0.10); }
.cml-section-inner { max-width: 1080px; margin: 0 auto; }

.cml-section-head { text-align: center; max-width: 640px; margin: 0 auto 2.4rem; }
.cml-tag {
  display: inline-block; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--cml-gold-ink); margin-bottom: 0.8rem;
}
[data-theme="dark"] .cml-tag { color: var(--cml-gold); }
.cml-section-title {
  margin: 0; font-family: var(--font-display); font-weight: 800; letter-spacing: -0.02em;
  line-height: 1.08; font-size: clamp(1.7rem, 7vw, 2.7rem); color: var(--text-primary);
}
.cml-section-title .cml-accent { color: var(--accent); }
.cml-section-sub { margin: 0.9rem auto 0; max-width: 540px; color: var(--text-secondary); font-size: 1rem; line-height: 1.6; }

/* reveal — escondido só quando o controller marca a seção com .sr-ready (no
   connect). Sem JS, .sr-ready nunca entra e o conteúdo fica visível. */
.cml-home [data-scroll-reveal-target="item"] { transition: opacity 0.7s ease, transform 0.7s ease; }
.cml-home .sr-ready [data-scroll-reveal-target="item"] { opacity: 0; transform: translateY(22px); }
.cml-home .sr-ready [data-scroll-reveal-target="item"].revealed { opacity: 1; transform: translateY(0); }

/* ═══ PRÊMIOS ═══ */

.cml-prizes { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.cml-prize { position: relative; border-radius: 18px; padding: 1.8rem 1.5rem; overflow: hidden; }
.cml-prize-kicker {
  display: inline-flex; align-items: center; gap: 0.45rem; font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 1rem;
}
.cml-prize-headline { font-family: var(--font-display); font-weight: 800; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(1.6rem, 6vw, 2.3rem); margin: 0 0 0.8rem; }
.cml-prize-headline em { font-style: normal; }
.cml-prize-body { font-size: 0.96rem; line-height: 1.6; margin: 0; }
.cml-prize-foot { margin-top: 1.2rem; padding-top: 1rem; font-size: 0.8rem; font-weight: 600; border-top: 1px solid; }

/* Card 1 — premium escuro (sempre, em ambos os temas: é a "vitrine da taça") */
.cml-prize--gold { background: linear-gradient(150deg, #163528 0%, #0e241b 100%); border: 1px solid rgba(232, 184, 75, 0.28); }
.cml-prize--gold::before { content: ""; position: absolute; top: -40%; right: -20%; width: 300px; height: 300px; background: radial-gradient(circle, rgba(232, 184, 75, 0.18), transparent 65%); pointer-events: none; }
.cml-prize--gold .cml-prize-kicker { color: var(--cml-gold); }
.cml-prize--gold .cml-prize-headline { color: #fff; }
.cml-prize--gold .cml-prize-headline em { color: var(--cml-gold); }
.cml-prize--gold .cml-prize-body { color: #C9D8CE; }
.cml-prize--gold .cml-prize-foot { color: var(--cml-gold); border-color: rgba(232, 184, 75, 0.25); }

/* Card 2 — claro, segue o tema */
.cml-prize--light { background: var(--bg-surface); border: 1px solid var(--border); }
.cml-prize--light .cml-prize-kicker { color: var(--cml-gold-ink); }
[data-theme="dark"] .cml-prize--light .cml-prize-kicker { color: var(--cml-gold); }
.cml-prize--light .cml-prize-headline { color: var(--text-primary); }
.cml-prize--light .cml-prize-headline em { color: var(--accent); }
.cml-prize--light .cml-prize-body { color: var(--text-secondary); }
.cml-prize--light .cml-prize-foot { color: var(--text-muted); border-color: var(--border); }

.cml-prizes-note { text-align: center; margin: 1.4rem auto 0; max-width: 540px; font-size: 0.84rem; color: var(--text-muted); }

/* ═══ COMO FUNCIONA ═══ */

.cml-steps { display: grid; grid-template-columns: 1fr; gap: 0.9rem; }
.cml-step { background: var(--bg-card); border: 1px solid var(--border); border-radius: 16px; padding: 1.6rem 1.4rem; transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease; }
.cml-step:hover { transform: translateY(-3px); border-color: var(--cml-gold-line); box-shadow: 0 14px 32px rgba(27, 67, 50, 0.10); }
.cml-step-num {
  display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px;
  border-radius: 10px; font-family: var(--font-display); font-weight: 800; font-size: 0.95rem;
  color: var(--cml-gold-ink); background: var(--cml-gold-soft); border: 1px solid var(--cml-gold-line); margin-bottom: 1rem;
}
[data-theme="dark"] .cml-step-num { color: var(--cml-gold); }
.cml-step-title { margin: 0 0 0.45rem; font-family: var(--font-display); font-size: 1.12rem; font-weight: 700; color: var(--text-primary); }
.cml-step-desc { margin: 0; font-size: 0.93rem; line-height: 1.6; color: var(--text-secondary); }
.cml-step-desc strong { color: var(--text-primary); }

/* ═══ O CAMINHO ═══ */

.cml-path { display: flex; flex-direction: column; align-items: stretch; gap: 0.5rem; margin: 0 auto 1.3rem; max-width: 520px; }
.cml-path-step {
  display: flex; flex-direction: column; align-items: center; gap: 0.25rem;
  padding: 0.95rem 1.3rem; border-radius: 14px; background: var(--bg-card); border: 1px solid var(--border);
}
.cml-path-step--final { border-color: var(--cml-gold-line); background: var(--cml-gold-soft); box-shadow: 0 0 26px var(--cml-gold-soft); }
.cml-path-step-name { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; color: var(--text-primary); }
.cml-path-step--final .cml-path-step-name { color: var(--cml-gold-ink); }
[data-theme="dark"] .cml-path-step--final .cml-path-step-name { color: var(--cml-gold); }
.cml-path-step-meta { font-size: 0.66rem; font-weight: 600; letter-spacing: 0.07em; text-transform: uppercase; color: var(--text-muted); }
.cml-path-arrow { align-self: center; color: var(--cml-gold-deep); font-size: 1.1rem; transform: rotate(90deg); }
[data-theme="dark"] .cml-path-arrow { color: var(--cml-gold); }
.cml-path-note { text-align: center; margin: 0; color: var(--text-muted); font-size: 0.88rem; }
.cml-path-note strong { color: var(--text-secondary); }

/* ═══ CTA FINAL (theme-aware, bookend do hero) ═══ */

.cml-final { position: relative; padding: 4rem 1.25rem; text-align: center; background: var(--cml-stage-bg); overflow: hidden; border-top: 1px solid var(--border); }
.cml-final::before { content: ""; position: absolute; top: -30%; left: 50%; transform: translateX(-50%); width: 620px; height: 620px; background: radial-gradient(circle, var(--cml-gold-soft), transparent 60%); pointer-events: none; }
.cml-final-inner { position: relative; max-width: 640px; margin: 0 auto; }
.cml-final-title { font-family: var(--font-display); font-weight: 800; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(1.9rem, 8vw, 3rem); color: var(--cml-stage-ink); margin: 0 0 0.9rem; }
.cml-final-sub { color: var(--cml-stage-ink-mut); font-size: 1.02rem; line-height: 1.6; margin: 0 0 1.8rem; }

/* ═══ FOOTER ═══ */

.cml-footer { background: var(--bg-card); border-top: 1px solid var(--border); padding: 2.2rem 1.25rem; text-align: center; color: var(--text-muted); }
.cml-footer-logo { font-family: var(--font-display); font-size: 1.3rem; font-weight: 800; color: var(--text-primary); letter-spacing: -0.02em; display: inline-block; margin-bottom: 0.5rem; }
.cml-footer-tagline { font-size: 0.88rem; margin: 0 0 0.35rem; }
.cml-footer-copy { font-size: 0.76rem; color: var(--text-muted); opacity: 0.7; margin: 0; }

/* ═══════════════════════════════════════════════
   ESCALA — min-width (mobile-first → up)
   ═══════════════════════════════════════════════ */

@media (min-width: 480px) {
  .cml-logo-tag { display: inline; }
  .cml-cta-row { flex-direction: row; justify-content: center; max-width: none; }
  .cml-cta-row > * { flex: 0 1 auto; }
}

@media (min-width: 640px) {
  .cml-nav { padding: 0.85rem 1.25rem; }
  .cml-nav-inner { padding: 0.55rem 0.6rem 0.55rem 1.25rem; }
  .cml-logo-text { font-size: 1.4rem; }
  .cml-hero { padding: 7rem 2rem 4rem; }
  .cml-section { padding: 5rem 2rem; }
  .cml-prizes { grid-template-columns: 1.15fr 1fr; gap: 1.25rem; }
  .cml-prize { padding: 2.2rem 2rem; }
  .cml-path { flex-direction: row; align-items: center; justify-content: center; max-width: none; gap: 0.5rem; }
  .cml-path-step { min-width: 140px; }
  .cml-path-arrow { transform: none; }
  .cml-final { padding: 5.5rem 2rem; }
}

@media (min-width: 960px) {
  .cml-steps { grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
  .cml-section { padding: 5.5rem 2rem; }
  .cml-section-head { margin-bottom: 3rem; }
}

@media (prefers-reduced-motion: reduce) {
  .cml-home *, .cml-hero::before, .cml-badge-pulse, .cml-scroll-line { animation: none !important; }
  .cml-home [data-scroll-reveal-target="item"] { opacity: 1; transform: none; }
}
