/* ── Copa Intro — Abertura Épica (PH World Cup 2026) ──────────────────────────
   Namespaced copa-* para remoção fácil ao fim da campanha.
   Port do CSS da simulação abertura-copa-simulacao.html (linhas 106-188),
   com IDs/classes prefixados copa- e keyframes prefixados copa-.
   Não inclui estilos do mock dashboard/álbum da simulação.
─────────────────────────────────────────────────────────────────────────── */

:root {
    --copa-br-green:  #00a14b;
    --copa-br-yellow: #ffd400;
    --copa-br-blue:   #1f44c9;
    --copa-br-deep:   #001b4d;
}

/* ── overlay principal ── */
#copa-epic {
    position: fixed; inset: 0; z-index: 100; display: none; overflow: hidden;
    background: radial-gradient(120% 90% at 50% 8%, #062a4a 0%, #04143a 45%, #020a22 100%);
}
#copa-epic.on { display: block; }
#copa-fx { position: absolute; inset: 0; width: 100%; height: 100%; }
.copa-stage {
    position: absolute; inset: 0; display: grid; place-items: center; pointer-events: none;
}

/* ── chant BRASIL ── */
#copa-brasil {
    font-weight: 900; font-style: italic; font-size: clamp(48px, 11vw, 150px);
    letter-spacing: -3px; opacity: 0; text-transform: uppercase;
    background: linear-gradient(180deg, #ffe24a 0%, var(--copa-br-yellow) 48%, #ffb300 52%, #ff9d00 100%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    filter: drop-shadow(0 4px 0 rgba(0,0,0,.25)) drop-shadow(0 0 30px rgba(255,210,0,.5));
}
#copa-brasil.beat { animation: copa-beat .42s ease; }
@keyframes copa-beat {
    0%   { transform: scale(1) }
    40%  { transform: scale(1.13) }
    100% { transform: scale(1) }
}

/* ── logo do sistema ── */
#copa-wc-logo {
    opacity: 0; transform: scale(.2);
    display: flex; flex-direction: column; align-items: center; gap: 20px;
}
.copa-logo-img {
    max-width: clamp(280px, 48vw, 420px); height: auto;
    filter: drop-shadow(0 0 28px rgba(255,220,80,.65)) drop-shadow(0 6px 22px rgba(0,0,0,.55));
}
#copa-wc-logo .copa-tag {
    color: #fff; font-weight: 800; letter-spacing: 5px;
    font-size: clamp(11px, 2vw, 16px);
    text-transform: uppercase; text-shadow: 0 2px 14px rgba(0,0,0,.6); opacity: .95;
}
#copa-wc-logo.pop   { animation: copa-logoPop 1s cubic-bezier(.18,1.5,.4,1) forwards; }
#copa-wc-logo.thump { animation: copa-thump .4s ease; }
@keyframes copa-logoPop {
    0%   { opacity: 0; transform: scale(.2) rotate(-12deg) }
    60%  { opacity: 1; transform: scale(1.12) rotate(3deg) }
    100% { opacity: 1; transform: scale(1) rotate(0) }
}
@keyframes copa-thump {
    0%   { transform: scale(1) }
    45%  { transform: scale(1.09) }
    100% { transform: scale(1) }
}

/* ── memes — central, em destaque ── */
#copa-meme {
    display: none; flex-direction: column; align-items: center; gap: 12px;
    background: rgba(255,255,255,.97); border-radius: 24px; padding: 18px;
    box-shadow: 0 30px 80px rgba(0,0,0,.55);
    border: 5px solid var(--copa-br-yellow); max-width: 88vw;
}
#copa-meme.show { display: flex; animation: copa-memePop .55s cubic-bezier(.2,1.6,.4,1); }
#copa-meme.img  { border-width: 6px; }
#copa-meme.img.show {
    animation: copa-memePop .55s cubic-bezier(.2,1.6,.4,1),
               copa-glowPulse 1.1s ease-in-out .55s infinite;
}
#copa-meme-img {
    display: none; max-width: min(420px, 80vw); max-height: 40vh;
    border-radius: 16px; object-fit: contain;
}
#copa-meme .copa-cap {
    font-weight: 900; font-size: clamp(18px, 3.6vw, 30px);
    color: #15233f; text-transform: uppercase; letter-spacing: .5px;
}
@keyframes copa-glowPulse {
    0%, 100% { box-shadow: 0 30px 80px rgba(0,0,0,.55), 0 0 0 0   rgba(255,212,0,.45) }
    50%       { box-shadow: 0 30px 80px rgba(0,0,0,.55), 0 0 44px 7px rgba(255,212,0,.8)  }
}
@keyframes copa-memePop {
    0%   { transform: scale(.4) rotate(-8deg); opacity: 0 }
    70%  { transform: scale(1.08) rotate(2deg) }
    100% { transform: scale(1) rotate(0); opacity: 1 }
}

/* ── flash de gol + cortina de hand-off ── */
#copa-flash {
    position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(circle, #fff 0%, #d8ffe6 40%, var(--copa-br-green) 100%);
    opacity: 0;
}
#copa-flash.go { animation: copa-flashAnim .6s ease; }
@keyframes copa-flashAnim {
    0%   { opacity: 0 }
    18%  { opacity: .95 }
    100% { opacity: 0 }
}

.copa-curtain {
    position: fixed; inset: 0; z-index: 120; pointer-events: none;
    background: linear-gradient(135deg, var(--copa-br-green), #007a3a 55%, var(--copa-br-deep));
    opacity: 0;
}

/* ── ondas concêntricas saindo do botão ── */
.copa-ripple {
    position: fixed; z-index: 118; border-radius: 50%; pointer-events: none;
    transform: translate(-50%, -50%) scale(.03); opacity: .85;
    box-shadow: 0 0 34px rgba(255,221,0,.45);
}
.copa-ripple.go { animation: copa-rippleGo 1s cubic-bezier(.22,.61,.36,1) forwards; }
@keyframes copa-rippleGo {
    0%   { transform: translate(-50%, -50%) scale(.03); opacity: .9 }
    100% { transform: translate(-50%, -50%) scale(1);   opacity: 0  }
}

/* ── botão Pular ── */
#copa-skip {
    position: absolute; top: 26px; right: 28px; z-index: 130;
    background: rgba(0,0,0,.4); color: #fff;
    border: 1.5px solid rgba(255,255,255,.5); border-radius: 30px;
    padding: 9px 20px; font-size: 13px; font-weight: 700;
    cursor: pointer; display: none; align-items: center; gap: 7px;
    backdrop-filter: blur(4px);
}
#copa-epic.on #copa-skip { display: flex; }
#copa-skip:hover { background: rgba(0,0,0,.65); }

#copa-hint-skip {
    position: absolute; bottom: 26px; left: 50%;
    transform: translateX(-50%); z-index: 130;
    color: rgba(255,255,255,.55); font-size: 12px; letter-spacing: .5px;
    display: none;
}
#copa-epic.on #copa-hint-skip { display: block; }

/* ── botão replay (dentro do álbum) ── */
#copa-replay-fab {
    position: fixed; bottom: 24px; left: 24px; z-index: 90;
    width: 38px; height: 38px; border-radius: 50%; border: none; cursor: pointer;
    background: linear-gradient(135deg, #ffe135, #ffb300);
    box-shadow: 0 2px 10px rgba(0,0,0,.3), 0 0 0 2.5px rgba(255,255,255,.25);
    display: flex; align-items: center; justify-content: center;
    animation: copa-replay-pulse 2.8s ease-in-out infinite;
    transition: transform .15s, box-shadow .15s;
}
#copa-replay-fab::after {
    content: '';
    display: block;
    width: 0; height: 0;
    border-top: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 12px solid #003a00;
    margin-left: 2px;
}
#copa-replay-fab:hover {
    transform: scale(1.18);
    box-shadow: 0 4px 16px rgba(0,0,0,.4), 0 0 0 3px rgba(255,220,0,.8);
    animation: none;
}
#copa-replay-fab:active { transform: scale(.92); }
@keyframes copa-replay-pulse {
    0%, 100% { box-shadow: 0 2px 10px rgba(0,0,0,.3), 0 0 0 2.5px rgba(255,255,255,.25); }
    50%       { box-shadow: 0 2px 10px rgba(0,0,0,.3), 0 0 0 6px rgba(255,210,0,.35); }
}

/* ── respeitar prefers-reduced-motion ── */
@media (prefers-reduced-motion: reduce) {
    #copa-epic * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
    .copa-ripple { display: none; }
}
