/* ============================================
   ESTÁDIO DAS FIGURINHAS — Sistema de Design
   Portal independente de colecionismo esportivo
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Sora:wght@300;400;500;600;700;800&family=DM+Serif+Display&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  /* Paleta principal — azul de gramado profundo + dourado de troféu */
  --ink-900:#06121f;
  --ink-800:#0b1d33;
  --ink-700:#102a4c;
  --ink-600:#1a3b6b;
  --ink-500:#2a558f;

  --field-700:#0d4f3c;
  --field-500:#1a8a5e;

  --gold-700:#9a6e1a;
  --gold-500:#d4a437;
  --gold-300:#f0c95c;
  --gold-100:#fef3c7;

  --crimson:#c0392b;
  --emerald:#0e9f6e;

  --paper:#fbfaf7;
  --paper-2:#f4f1ea;
  --line:#e6e1d6;
  --line-2:#d8d1c2;
  --mute:#6b6358;
  --body:#23201c;

  /* Tipografia */
  --f-display:"Bebas Neue", "Arial Narrow", sans-serif;
  --f-serif:"DM Serif Display", "Georgia", serif;
  --f-sans:"Sora", -apple-system, sans-serif;
  --f-mono:"JetBrains Mono", "Courier New", monospace;

  --shadow-1:0 1px 2px rgba(6,18,31,.06), 0 2px 8px rgba(6,18,31,.04);
  --shadow-2:0 8px 24px -8px rgba(6,18,31,.18), 0 2px 6px rgba(6,18,31,.06);
  --shadow-3:0 24px 60px -20px rgba(6,18,31,.28);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-sans);
  color:var(--body);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}

/* ============================================
   ANNOUNCEMENT BAR
   ============================================ */
.announce{
  background:var(--ink-900);
  color:#f0c95c;
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.04em;
  padding:8px 0;
  text-align:center;
  border-bottom:1px solid rgba(240,201,92,.15);
}
.announce span{opacity:.7;margin:0 8px}

/* ============================================
   HEADER
   ============================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(251,250,247,.92);
  backdrop-filter:blur(12px) saturate(1.1);
  -webkit-backdrop-filter:blur(12px) saturate(1.1);
  border-bottom:1px solid var(--line);
}
.header-row{
  max-width:1320px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand-mark{
  width:42px;height:42px;border-radius:10px;
  background:linear-gradient(135deg,var(--ink-800),var(--ink-600));
  display:grid;place-items:center;color:var(--gold-300);
  font-family:var(--f-display);font-size:22px;
  box-shadow:inset 0 0 0 1px rgba(240,201,92,.22), var(--shadow-1);
  position:relative;overflow:hidden;
}
.brand-mark::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(240,201,92,.25), transparent 60%);
}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{
  font-family:var(--f-display);font-size:22px;letter-spacing:.04em;
  color:var(--ink-900);
}
.brand-tag{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;
  color:var(--mute);text-transform:uppercase;margin-top:4px;
}

.nav-primary{display:flex;gap:4px;align-items:center}
.nav-primary a{
  font-size:14px;font-weight:500;color:var(--ink-900);
  padding:10px 14px;border-radius:8px;
  transition:background .18s ease, color .18s ease;
  position:relative;
}
.nav-primary a:hover{background:var(--paper-2)}
.nav-primary a.active{color:var(--ink-800)}
.nav-primary a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;
  height:2px;background:var(--gold-500);
}
.nav-dd{position:relative}
.nav-dd > a::before{content:"";display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;margin-right:6px;vertical-align:middle;opacity:.5}
.nav-dd-menu{
  position:absolute;top:calc(100% + 6px);left:0;
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:10px;min-width:240px;box-shadow:var(--shadow-3);
  opacity:0;pointer-events:none;transform:translateY(-4px);
  transition:.2s ease;
}
.nav-dd:hover .nav-dd-menu{opacity:1;pointer-events:auto;transform:translateY(0)}
.nav-dd-menu a{display:block;padding:8px 12px;font-size:13.5px;border-radius:6px}
.nav-dd-menu a:hover{background:var(--paper-2)}

.header-actions{display:flex;align-items:center;gap:10px}
.search-trigger{
  display:flex;align-items:center;gap:8px;
  background:var(--paper-2);border:1px solid var(--line);
  padding:8px 12px;border-radius:8px;font-size:13px;
  color:var(--mute);min-width:240px;
  transition:.18s ease;
}
.search-trigger:hover{background:#fff;border-color:var(--line-2)}
.search-trigger kbd{
  margin-left:auto;font-family:var(--f-mono);font-size:10px;
  background:#fff;padding:2px 6px;border-radius:4px;
  border:1px solid var(--line);
}
.btn-cta{
  background:var(--ink-900);color:#fff;
  padding:10px 18px;border-radius:8px;font-size:13px;font-weight:600;
  letter-spacing:.02em;transition:.18s ease;
}
.btn-cta:hover{background:var(--ink-700)}
.mobile-toggle{display:none;width:42px;height:42px;border-radius:8px;background:var(--paper-2)}
.mobile-toggle span{display:block;width:18px;height:2px;background:var(--ink-900);margin:4px auto}

/* Mobile nav */
.mobile-nav{
  display:none;position:fixed;inset:0;z-index:200;background:rgba(6,18,31,.6);
  opacity:0;pointer-events:none;transition:.25s ease;
}
.mobile-nav.open{opacity:1;pointer-events:auto}
.mobile-nav-panel{
  position:absolute;right:0;top:0;bottom:0;width:min(360px,86vw);
  background:#fff;padding:24px;overflow-y:auto;
  transform:translateX(100%);transition:.3s ease;
}
.mobile-nav.open .mobile-nav-panel{transform:translateX(0)}
.mobile-nav a{display:block;padding:12px 0;font-size:16px;border-bottom:1px solid var(--line)}
.mobile-nav-close{position:absolute;top:18px;right:18px;font-size:22px}

/* ============================================
   SEARCH OVERLAY
   ============================================ */
.search-overlay{
  position:fixed;inset:0;z-index:300;background:rgba(6,18,31,.5);
  backdrop-filter:blur(6px);
  display:none;align-items:flex-start;justify-content:center;
  padding-top:12vh;
}
.search-overlay.open{display:flex}
.search-panel{
  width:min(640px,92vw);background:#fff;border-radius:16px;
  box-shadow:var(--shadow-3);overflow:hidden;
}
.search-input-wrap{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.search-input-wrap svg{width:20px;height:20px;color:var(--mute);flex-shrink:0}
.search-input{flex:1;font-size:18px;border:0;outline:0;font-family:var(--f-sans);color:var(--ink-900);background:transparent}
.search-input::placeholder{color:var(--mute)}
.search-close{font-family:var(--f-mono);font-size:11px;color:var(--mute);padding:4px 8px;border:1px solid var(--line);border-radius:4px}
.search-results{max-height:50vh;overflow-y:auto;padding:8px}
.search-result{
  display:block;padding:12px 14px;border-radius:8px;
  transition:background .15s ease;
}
.search-result:hover,.search-result.focus{background:var(--paper-2)}
.search-result-cat{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-700);margin-bottom:2px}
.search-result-title{font-weight:600;font-size:14px;color:var(--ink-900)}
.search-result-desc{font-size:12.5px;color:var(--mute);margin-top:2px}
.search-empty{padding:32px;text-align:center;color:var(--mute);font-size:14px}

/* ============================================
   CONTAINER + UTILITIES
   ============================================ */
.container{max-width:1320px;margin:0 auto;padding:0 28px}
.container-narrow{max-width:880px;margin:0 auto;padding:0 28px}

.breadcrumb{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;
  color:var(--mute);padding:24px 0 0;text-transform:uppercase;
}
.breadcrumb a{color:var(--mute);transition:color .15s}
.breadcrumb a:hover{color:var(--ink-700)}
.breadcrumb span{margin:0 8px;opacity:.5}

.page-header{padding:48px 0 32px;border-bottom:1px solid var(--line);margin-bottom:48px}
.page-eyebrow{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-700);margin-bottom:14px}
.page-title{font-family:var(--f-serif);font-size:clamp(40px,5vw,64px);line-height:1.02;color:var(--ink-900);margin:0 0 16px;letter-spacing:-.01em}
.page-sub{font-size:17px;color:var(--mute);max-width:680px;margin:0;line-height:1.6}

/* ============================================
   HERO (Home)
   ============================================ */
.hero{
  position:relative;overflow:hidden;
  background:
    linear-gradient(180deg, rgba(6,18,31,.78) 0%, rgba(6,18,31,.92) 100%),
    url('https://images.unsplash.com/photo-1551958219-acbc608c6377?w=1800&q=80') center/cover;
  color:#fff;padding:80px 0 120px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 80% 20%, rgba(240,201,92,.18), transparent 60%),
    radial-gradient(600px 300px at 10% 80%, rgba(26,138,94,.15), transparent 60%);
  pointer-events:none;
}
.hero-grid{
  max-width:1320px;margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:1.3fr 1fr;gap:80px;align-items:center;
  position:relative;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(240,201,92,.12);border:1px solid rgba(240,201,92,.32);
  padding:8px 16px;border-radius:100px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold-300);margin-bottom:28px;
}
.hero-eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--gold-300);
  box-shadow:0 0 0 4px rgba(240,201,92,.18);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(240,201,92,0)}}

.hero-title{
  font-family:var(--f-display);
  font-size:clamp(56px,8vw,108px);line-height:.92;letter-spacing:.01em;
  margin:0 0 24px;
}
.hero-title em{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--gold-300);letter-spacing:-.01em}
.hero-sub{font-size:18px;line-height:1.55;color:rgba(255,255,255,.78);max-width:520px;margin:0 0 36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{
  background:var(--gold-500);color:var(--ink-900);
  padding:14px 26px;border-radius:8px;font-weight:700;font-size:14px;letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:8px;transition:.18s ease;
}
.btn-primary:hover{background:var(--gold-300);transform:translateY(-1px)}
.btn-ghost{
  border:1px solid rgba(255,255,255,.25);color:#fff;
  padding:14px 26px;border-radius:8px;font-weight:600;font-size:14px;
  display:inline-flex;align-items:center;gap:8px;transition:.18s ease;
}
.btn-ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.4)}

.hero-stats{
  display:flex;gap:36px;margin-top:48px;padding-top:32px;
  border-top:1px solid rgba(255,255,255,.1);
}
.hero-stat-num{font-family:var(--f-display);font-size:38px;color:var(--gold-300);line-height:1}
.hero-stat-lbl{font-size:12px;color:rgba(255,255,255,.6);margin-top:6px;letter-spacing:.04em}

/* Hero card stack */
.hero-cards{position:relative;height:480px}
.hero-card{
  position:absolute;border-radius:14px;overflow:hidden;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.6), 0 0 0 1px rgba(240,201,92,.2);
  background:#fff;
}
.hc-1{top:0;right:0;width:240px;height:340px;transform:rotate(6deg);z-index:2}
.hc-2{top:40px;right:200px;width:220px;height:310px;transform:rotate(-8deg);z-index:1}
.hc-3{top:180px;right:60px;width:200px;height:280px;transform:rotate(3deg);z-index:3;background:linear-gradient(135deg,var(--ink-800),var(--ink-600));color:#fff;padding:24px;display:flex;flex-direction:column;justify-content:space-between}
.hc-3 .hc-badge{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-300)}
.hc-3 .hc-num{font-family:var(--f-display);font-size:56px;line-height:1;color:#fff}
.hc-3 .hc-name{font-size:14px;font-weight:600;margin-top:4px}
.hc-3 .hc-pos{font-size:11px;color:rgba(255,255,255,.6);font-family:var(--f-mono);letter-spacing:.08em}
.hc-shimmer{
  position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 30%,rgba(240,201,92,.35) 50%,transparent 70%);
  animation:shimmer 3s ease-in-out infinite;
  pointer-events:none;
}
@keyframes shimmer{0%,100%{transform:translateX(-100%)}50%{transform:translateX(100%)}}
.hc-1 img,.hc-2 img{width:100%;height:100%;object-fit:cover}

/* ============================================
   SECTIONS
   ============================================ */
section{padding:80px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.section-eyebrow{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-700);margin-bottom:14px}
.section-title{font-family:var(--f-serif);font-size:clamp(32px,4vw,48px);line-height:1.05;color:var(--ink-900);margin:0;letter-spacing:-.01em;max-width:680px}
.section-link{font-size:13px;font-weight:600;color:var(--ink-800);letter-spacing:.02em;display:inline-flex;align-items:center;gap:6px;padding-bottom:4px;border-bottom:1px solid var(--ink-800);transition:gap .2s ease}
.section-link:hover{gap:10px}

/* ============================================
   FEATURE CARDS (Home modules)
   ============================================ */
.modules{
  display:grid;grid-template-columns:repeat(12,1fr);gap:20px;
}
.module{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:32px;transition:.25s ease;position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.module:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:var(--line-2)}
.module-icon{
  width:48px;height:48px;border-radius:10px;
  background:linear-gradient(135deg,var(--ink-800),var(--ink-600));
  color:var(--gold-300);display:grid;place-items:center;
  margin-bottom:20px;font-family:var(--f-display);font-size:22px;
}
.module h3{font-family:var(--f-serif);font-size:22px;color:var(--ink-900);margin:0 0 8px;line-height:1.2}
.module p{font-size:14px;color:var(--mute);margin:0 0 20px;line-height:1.55;flex:1}
.module-link{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-800);display:inline-flex;align-items:center;gap:6px}
.module-link::after{content:"→";transition:transform .2s}
.module:hover .module-link::after{transform:translateX(3px)}

.m-wide{grid-column:span 6}
.m-half{grid-column:span 3}
@media(max-width:980px){.m-wide,.m-half{grid-column:span 6}}
@media(max-width:640px){.m-wide,.m-half{grid-column:span 12}}

/* Featured module variant */
.module-featured{
  background:linear-gradient(135deg,var(--ink-900) 0%,var(--ink-700) 100%);
  color:#fff;border-color:var(--ink-800);
}
.module-featured::before{
  content:"";position:absolute;top:-50%;right:-30%;width:80%;height:200%;
  background:radial-gradient(circle, rgba(240,201,92,.12), transparent 60%);
}
.module-featured h3{color:#fff}
.module-featured p{color:rgba(255,255,255,.7)}
.module-featured .module-icon{background:rgba(240,201,92,.15);color:var(--gold-300)}
.module-featured .module-link{color:var(--gold-300)}

/* ============================================
   COUNTDOWN STRIP
   ============================================ */
.countdown{
  background:linear-gradient(135deg,var(--ink-900),var(--ink-700));
  color:#fff;padding:48px 0;position:relative;overflow:hidden;
}
.countdown::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(45deg, rgba(240,201,92,.03) 0 2px, transparent 2px 14px);
}
.cd-grid{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;position:relative;flex-wrap:wrap}
@media(max-width:760px){.cd-grid{grid-template-columns:1fr}}
.cd-label{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-300);margin-bottom:8px}
.cd-title{font-family:var(--f-serif);font-size:32px;line-height:1.1;margin:0;max-width:520px}
.cd-clock{display:flex;gap:14px}
.cd-block{
  background:rgba(255,255,255,.05);border:1px solid rgba(240,201,92,.2);
  border-radius:10px;padding:16px 20px;min-width:80px;text-align:center;
  backdrop-filter:blur(6px);
}
.cd-num{font-family:var(--f-display);font-size:42px;line-height:1;color:var(--gold-300)}
.cd-unit{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.6);text-transform:uppercase;margin-top:6px}

/* ============================================
   STICKER GRID (Figurinhas)
   ============================================ */
.sticker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px}
.sticker{
  background:#fff;border:1px solid var(--line);border-radius:12px;
  overflow:hidden;position:relative;transition:.2s ease;
  aspect-ratio:3/4;
}
.sticker:hover{transform:translateY(-4px) rotate(-1deg);box-shadow:var(--shadow-2);border-color:var(--gold-300)}
.sticker-img{
  height:62%;background:linear-gradient(135deg,var(--ink-800),var(--ink-600));
  position:relative;overflow:hidden;display:grid;place-items:center;
}
.sticker-img img{width:100%;height:100%;object-fit:cover}
.sticker-info{padding:12px 14px;background:#fff}
.sticker-num{font-family:var(--f-mono);font-size:10px;color:var(--mute);letter-spacing:.08em}
.sticker-name{font-weight:600;font-size:13.5px;color:var(--ink-900);margin-top:2px;line-height:1.2}
.sticker-team{font-size:11px;color:var(--mute);font-family:var(--f-mono);margin-top:3px;letter-spacing:.06em}
.sticker.rare::after{
  content:"RARA";position:absolute;top:10px;right:10px;
  background:var(--gold-500);color:var(--ink-900);
  font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;
  padding:4px 7px;border-radius:4px;font-weight:700;z-index:2;
}
.sticker.legend::after{
  content:"LENDÁRIA";background:linear-gradient(135deg,#f0c95c,#c0392b);color:#fff;
  position:absolute;top:10px;right:10px;
  font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;
  padding:4px 7px;border-radius:4px;font-weight:700;z-index:2;
}
.sticker.have .sticker-img::before{
  content:"✓";position:absolute;top:8px;left:8px;
  width:24px;height:24px;background:var(--emerald);color:#fff;
  border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:700;z-index:2;
}
.sticker.dup .sticker-info::after{
  content:"×2";font-family:var(--f-mono);font-size:11px;color:var(--crimson);float:right;font-weight:700;
}

/* ============================================
   NATIONAL TEAMS GRID
   ============================================ */
.teams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.team-card{
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:24px;text-align:center;transition:.2s ease;cursor:pointer;
  position:relative;overflow:hidden;
}
.team-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.team-flag{
  width:80px;height:54px;margin:0 auto 16px;border-radius:6px;
  background:var(--paper-2);overflow:hidden;
  box-shadow:0 4px 12px rgba(6,18,31,.12);
}
.team-flag img{width:100%;height:100%;object-fit:cover}
.team-name{font-family:var(--f-serif);font-size:20px;color:var(--ink-900);margin:0 0 4px}
.team-conf{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.team-stat{display:flex;justify-content:center;gap:18px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.team-stat-item{font-size:11px;color:var(--mute)}
.team-stat-num{font-family:var(--f-display);font-size:22px;color:var(--ink-800);line-height:1}

/* ============================================
   PACK OPENER
   ============================================ */
.pack-scene{
  background:linear-gradient(135deg,var(--ink-900),var(--ink-700));
  border-radius:24px;padding:64px 32px;color:#fff;
  position:relative;overflow:hidden;text-align:center;
  border:1px solid rgba(240,201,92,.18);
}
.pack-scene::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(600px 300px at 50% 30%, rgba(240,201,92,.15), transparent 60%),
    repeating-linear-gradient(45deg, rgba(240,201,92,.02) 0 2px, transparent 2px 12px);
}
.pack-visual{
  width:200px;height:280px;margin:0 auto 32px;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-700));
  border-radius:14px;position:relative;
  box-shadow:0 30px 60px -20px rgba(212,164,55,.5);
  display:grid;place-items:center;
  transition:.3s ease;
  cursor:pointer;
}
.pack-visual:hover{transform:translateY(-6px) rotate(-2deg)}
.pack-visual::before{
  content:"";position:absolute;inset:8px;border:1px dashed rgba(0,0,0,.2);border-radius:10px;
}
.pack-visual-inner{
  font-family:var(--f-display);font-size:42px;color:var(--ink-900);
  text-align:center;line-height:.9;letter-spacing:.04em;
}
.pack-visual-inner small{display:block;font-size:13px;font-family:var(--f-mono);letter-spacing:.2em;margin-top:8px;font-weight:400}
.pack-opening{animation:packShake .6s ease-in-out}
@keyframes packShake{
  0%,100%{transform:translateY(0) rotate(0)}
  25%{transform:translateY(-8px) rotate(-3deg)}
  75%{transform:translateY(-8px) rotate(3deg)}
}
.pack-revealed{display:none}
.pack-revealed.show{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;max-width:680px;margin:0 auto}
.pack-revealed .sticker{transform:scale(0);animation:revealCard .5s forwards}
.pack-revealed .sticker:nth-child(1){animation-delay:.1s}
.pack-revealed .sticker:nth-child(2){animation-delay:.2s}
.pack-revealed .sticker:nth-child(3){animation-delay:.3s}
.pack-revealed .sticker:nth-child(4){animation-delay:.4s}
.pack-revealed .sticker:nth-child(5){animation-delay:.5s}
@keyframes revealCard{
  0%{transform:scale(0) rotate(-10deg);opacity:0}
  60%{transform:scale(1.08) rotate(2deg)}
  100%{transform:scale(1) rotate(0);opacity:1}
}

/* ============================================
   PROGRESS / CHECKLIST
   ============================================ */
.progress-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px;
}
.progress-num{font-family:var(--f-display);font-size:64px;line-height:.9;color:var(--ink-900)}
.progress-num span{color:var(--gold-500);font-size:38px}
.progress-bar{height:8px;background:var(--paper-2);border-radius:100px;overflow:hidden;margin:16px 0 8px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--field-500),var(--gold-500));border-radius:100px;transition:width .8s ease}
.progress-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--mute);font-family:var(--f-mono);letter-spacing:.06em}

.checklist-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.chip{
  background:#fff;border:1px solid var(--line);
  padding:8px 14px;border-radius:100px;font-size:13px;
  cursor:pointer;transition:.15s ease;color:var(--ink-800);
}
.chip:hover{border-color:var(--line-2)}
.chip.active{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.chip-count{font-family:var(--f-mono);font-size:11px;color:var(--mute);margin-left:6px}
.chip.active .chip-count{color:var(--gold-300)}

/* ============================================
   NEWS GRID
   ============================================ */
.news-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.news-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  transition:.2s ease;display:flex;flex-direction:column;
}
.news-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.news-img{aspect-ratio:16/10;overflow:hidden;background:var(--paper-2)}
.news-img img{width:100%;height:100%;object-fit:cover;transition:.4s ease}
.news-card:hover .news-img img{transform:scale(1.04)}
.news-body{padding:24px;display:flex;flex-direction:column;flex:1}
.news-cat{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-700);margin-bottom:10px}
.news-title{font-family:var(--f-serif);font-size:22px;line-height:1.2;color:var(--ink-900);margin:0 0 10px}
.news-excerpt{font-size:14px;color:var(--mute);line-height:1.55;margin:0 0 16px;flex:1}
.news-meta{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--mute);padding-top:16px;border-top:1px solid var(--line)}
.news-meta span{display:inline-flex;align-items:center;gap:6px}

.news-feat{grid-column:span 8}
.news-side{grid-column:span 4}
.news-half{grid-column:span 6}
.news-third{grid-column:span 4}
@media(max-width:980px){.news-feat,.news-side,.news-half,.news-third{grid-column:span 12}}

.news-feat .news-title{font-size:32px}
.news-feat .news-img{aspect-ratio:16/9}

/* ============================================
   TIMELINE
   ============================================ */
.timeline{position:relative;padding-left:40px}
.timeline::before{content:"";position:absolute;left:12px;top:8px;bottom:8px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:48px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{
  content:"";position:absolute;left:-34px;top:6px;width:18px;height:18px;
  border-radius:50%;background:#fff;border:2px solid var(--gold-500);
  box-shadow:0 0 0 4px var(--paper);
}
.tl-year{font-family:var(--f-display);font-size:38px;color:var(--ink-800);line-height:1;margin-bottom:8px}
.tl-host{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700);margin-bottom:14px}
.tl-title{font-family:var(--f-serif);font-size:22px;color:var(--ink-900);margin:0 0 8px}
.tl-text{color:var(--mute);font-size:14.5px;line-height:1.6;margin:0}

/* ============================================
   STATS BAR
   ============================================ */
.stats-bar{
  background:var(--paper-2);border-radius:14px;padding:40px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
@media(max-width:760px){.stats-bar{grid-template-columns:repeat(2,1fr)}}
.stat-item{text-align:center;border-right:1px solid var(--line-2)}
.stat-item:last-child{border-right:0}
@media(max-width:760px){.stat-item{border-right:0;border-bottom:1px solid var(--line-2);padding-bottom:24px}.stat-item:nth-child(n+3){padding-top:24px;padding-bottom:0;border-bottom:0}}
.stat-num{font-family:var(--f-display);font-size:48px;color:var(--ink-900);line-height:1}
.stat-lbl{font-size:12px;font-family:var(--f-mono);letter-spacing:.1em;color:var(--mute);text-transform:uppercase;margin-top:6px}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
  background:var(--ink-900);color:rgba(255,255,255,.7);
  padding:80px 0 32px;margin-top:80px;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:48px;
  max-width:1320px;margin:0 auto;padding:0 28px;
}
@media(max-width:980px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .brand-name{color:#fff}
.footer-brand .brand-tag{color:rgba(240,201,92,.6)}
.footer-about{font-size:13.5px;line-height:1.7;margin-top:20px;max-width:340px}
.footer-col h4{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-300);margin:0 0 18px}
.footer-col a{display:block;font-size:13.5px;padding:5px 0;color:rgba(255,255,255,.7);transition:color .15s ease}
.footer-col a:hover{color:var(--gold-300)}

.footer-legal{
  margin-top:64px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);
  font-size:12px;color:rgba(255,255,255,.4);line-height:1.7;
  max-width:1320px;margin-left:auto;margin-right:auto;padding-left:28px;padding-right:28px;
}
.footer-legal strong{color:rgba(255,255,255,.65)}
.footer-bottom{
  margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.06);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  max-width:1320px;margin-left:auto;margin-right:auto;padding-left:28px;padding-right:28px;
}
.footer-bottom .copy{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:rgba(255,255,255,.4)}
.footer-bottom .legal-links{display:flex;gap:20px;flex-wrap:wrap}
.footer-bottom .legal-links a{font-size:11.5px;color:rgba(255,255,255,.5)}
.footer-bottom .legal-links a:hover{color:var(--gold-300)}

.disclaimer-strip{
  background:var(--paper-2);padding:18px 0;
  font-size:12.5px;color:var(--mute);text-align:center;line-height:1.6;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.disclaimer-strip strong{color:var(--ink-800)}

/* ============================================
   FAQ ACCORDION
   ============================================ */
.faq-list{max-width:820px;margin:0 auto}
.faq{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{
  list-style:none;cursor:pointer;padding:22px 0;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--f-serif);font-size:20px;color:var(--ink-900);line-height:1.3;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:var(--f-display);font-size:28px;color:var(--gold-500);
  transition:transform .2s ease;
}
.faq[open] summary::after{transform:rotate(45deg)}
.faq-body{padding:0 0 24px;color:var(--mute);font-size:15px;line-height:1.7;max-width:680px}

/* ============================================
   FORM
   ============================================ */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:span 2}
@media(max-width:640px){.field.full{grid-column:span 1}}
.field label{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-800)}
.field input,.field textarea,.field select{
  padding:14px 16px;border:1px solid var(--line);border-radius:10px;
  font-family:var(--f-sans);font-size:14.5px;background:#fff;
  color:var(--ink-900);outline:none;transition:.15s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:var(--ink-700);box-shadow:0 0 0 3px rgba(26,59,107,.1);
}
.field textarea{min-height:140px;resize:vertical;font-family:var(--f-sans)}

.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink-900);color:#fff;padding:14px 22px;border-radius:8px;
  font-size:14px;box-shadow:var(--shadow-3);
  opacity:0;pointer-events:none;transition:.3s ease;z-index:400;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================================
   PLAYER PROFILE
   ============================================ */
.player-hero{
  display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:center;
  background:linear-gradient(135deg,var(--ink-900),var(--ink-700));
  color:#fff;border-radius:18px;padding:48px;position:relative;overflow:hidden;
}
@media(max-width:760px){.player-hero{grid-template-columns:1fr;text-align:center}}
.player-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(500px 300px at 90% 50%, rgba(240,201,92,.15), transparent 60%);
}
.player-img{
  aspect-ratio:1;border-radius:14px;overflow:hidden;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-700));
  box-shadow:0 24px 60px -20px rgba(0,0,0,.5);
  position:relative;z-index:1;
}
.player-img img{width:100%;height:100%;object-fit:cover}
.player-info{position:relative;z-index:1}
.player-num{font-family:var(--f-display);font-size:80px;line-height:.9;color:var(--gold-300)}
.player-name{font-family:var(--f-serif);font-size:48px;line-height:1.05;margin:8px 0 4px;letter-spacing:-.01em}
.player-pos{font-family:var(--f-mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.player-meta{display:flex;gap:36px;margin-top:28px;padding-top:28px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap}
@media(max-width:760px){.player-meta{justify-content:center}}
.pm-num{font-family:var(--f-display);font-size:30px;color:var(--gold-300);line-height:1}
.pm-lbl{font-size:11px;font-family:var(--f-mono);letter-spacing:.1em;color:rgba(255,255,255,.5);margin-top:4px;text-transform:uppercase}

/* ============================================
   STADIUM CARD
   ============================================ */
.stadium-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  transition:.2s ease;
}
.stadium-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.stadium-img{aspect-ratio:16/10;overflow:hidden;background:var(--paper-2)}
.stadium-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.stadium-card:hover .stadium-img img{transform:scale(1.06)}
.stadium-body{padding:24px}
.stadium-city{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700);margin-bottom:6px}
.stadium-name{font-family:var(--f-serif);font-size:24px;color:var(--ink-900);margin:0 0 10px;line-height:1.2}
.stadium-cap{font-size:13.5px;color:var(--mute);font-family:var(--f-mono);letter-spacing:.04em}
.stadium-meta{display:flex;gap:18px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);font-size:12px;color:var(--mute)}

/* ============================================
   CALENDAR / MATCHES
   ============================================ */
.match{
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:20px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;
  transition:.2s ease;
}
.match:hover{box-shadow:var(--shadow-1);border-color:var(--line-2)}
.match-team{display:flex;align-items:center;gap:12px}
.match-team.right{flex-direction:row-reverse;text-align:right}
.match-flag{width:36px;height:24px;border-radius:4px;overflow:hidden;background:var(--paper-2);flex-shrink:0}
.match-flag img{width:100%;height:100%;object-fit:cover}
.match-name{font-weight:600;font-size:15px;color:var(--ink-900)}
.match-center{text-align:center;font-family:var(--f-display);font-size:24px;color:var(--ink-800);letter-spacing:.04em}
.match-when{font-family:var(--f-mono);font-size:11px;color:var(--mute);letter-spacing:.06em;margin-top:4px;text-transform:uppercase}
.match-stadium{font-size:11px;color:var(--mute);margin-top:2px}

/* ============================================
   TRADE / EXCHANGE
   ============================================ */
.trade-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;
  margin-bottom:18px;transition:box-shadow .2s,border-color .2s;
}
.trade-card:hover{box-shadow:var(--shadow-1);border-color:var(--line-2)}
.trade-user{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.trade-avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--ink-800),var(--ink-600));
  color:var(--gold-300);display:grid;place-items:center;
  font-family:var(--f-display);font-size:16px;flex-shrink:0;
}
.trade-name{font-weight:600;font-size:15px;color:var(--ink-900)}
.trade-meta{font-size:12px;color:var(--mute);font-family:var(--f-mono);letter-spacing:.04em;margin-top:3px}
.trade-stars{color:var(--gold-500);font-family:var(--f-sans);letter-spacing:0}
.trade-score{margin-left:auto;text-align:center;padding:8px 14px;background:var(--gold-100);border-radius:8px}
.trade-score span{font-family:var(--f-display);font-size:22px;color:var(--gold-700);display:block;line-height:1}
.trade-score label{font-family:var(--f-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-700);display:block;margin-top:2px}
.trade-exchange{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;padding:20px 0}
.trade-side{}
.trade-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-bottom:8px}
.trade-card-mini{display:flex;align-items:center;gap:12px;background:var(--paper);padding:14px;border-radius:10px;border:1px solid var(--line)}
.tcm-num{font-family:var(--f-display);font-size:28px;color:var(--ink-900);min-width:34px;line-height:1}
.tcm-name{font-size:14px;font-weight:600;color:var(--ink-900);line-height:1.2}
.tcm-team{font-size:12px;color:var(--mute);margin-top:3px}
.trade-arrow{font-size:24px;color:var(--gold-500);font-family:var(--f-display);text-align:center}
.trade-actions{display:flex;gap:10px;padding-top:18px;border-top:1px solid var(--line);justify-content:flex-end}
@media(max-width:640px){.trade-exchange{grid-template-columns:1fr;gap:10px}.trade-arrow{transform:rotate(90deg);padding:4px 0}.trade-score{margin-left:0;margin-top:10px}.trade-user{flex-wrap:wrap}}

/* ============================================
   ARTICLE / CONTENT PAGES
   ============================================ */
.prose{max-width:760px;margin:0 auto;font-size:16px;line-height:1.75;color:var(--body)}
.prose h2{font-family:var(--f-serif);font-size:32px;color:var(--ink-900);margin:48px 0 16px;line-height:1.2}
.prose h3{font-family:var(--f-serif);font-size:22px;color:var(--ink-900);margin:32px 0 12px}
.prose p{margin:0 0 20px}
.prose strong{color:var(--ink-900);font-weight:600}
.prose ul,.prose ol{padding-left:24px;margin:0 0 24px}
.prose li{margin-bottom:8px}
.prose a{color:var(--ink-700);text-decoration:underline;text-decoration-color:var(--gold-500);text-underline-offset:3px}
.prose blockquote{
  border-left:3px solid var(--gold-500);padding:8px 24px;margin:24px 0;
  font-style:italic;color:var(--mute);font-family:var(--f-serif);font-size:20px;line-height:1.5;
}
.prose hr{border:0;height:1px;background:var(--line);margin:48px 0}

.callout{
  background:var(--paper-2);border-left:3px solid var(--gold-500);
  padding:20px 24px;border-radius:0 10px 10px 0;margin:24px 0;
}
.callout strong{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700);margin-bottom:8px}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:960px){
  .nav-primary{display:none}
  .search-trigger{display:none}
  .mobile-toggle{display:block}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-cards{height:320px;max-width:380px}
  .news-feat .news-title{font-size:24px}
  .player-hero{padding:32px}
  .player-name{font-size:36px}
}
@media(max-width:560px){
  section{padding:56px 0}
  .hero{padding:56px 0 80px}
  .hero-stats{flex-wrap:wrap;gap:24px}
  .container,.container-narrow{padding:0 18px}
  .header-row{padding:14px 18px}
}

/* utilities */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mt-3{margin-top:24px}
.mt-5{margin-top:48px}
.divider{height:1px;background:var(--line);margin:48px 0}
.tag-pill{display:inline-block;font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700);background:var(--gold-100);padding:4px 10px;border-radius:100px}

/* Print friendliness */
@media print{.site-header,.site-footer,.announce{display:none}}

/* ============================================
   PLAYER CARDS — perfis de jogadores
   ============================================ */
.player-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.player-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;
  position:relative;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.player-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:var(--line-2)}
.player-card.rarity-legend{background:linear-gradient(180deg,#fff 60%,rgba(212,164,55,.06));border-color:rgba(212,164,55,.45)}
.player-card.rarity-rare{border-color:rgba(31,82,156,.3)}
.pc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.pc-num{font-family:var(--f-display);font-size:42px;line-height:1;color:var(--ink-900);letter-spacing:.02em}
.player-card.rarity-legend .pc-num{color:var(--gold-700)}
.pc-rarity{font-family:var(--f-mono);font-size:9px;letter-spacing:.16em;padding:4px 8px;border-radius:100px;background:var(--paper-2);color:var(--mute)}
.player-card.rarity-legend .pc-rarity{background:var(--gold-100);color:var(--gold-700)}
.player-card.rarity-rare .pc-rarity{background:rgba(31,82,156,.08);color:var(--ink-700)}
.pc-flag{font-size:32px;line-height:1;margin-bottom:10px}
.pc-name{font-family:var(--f-serif);font-size:22px;line-height:1.15;color:var(--ink-900);margin-bottom:6px}
.pc-team{font-size:13px;color:var(--mute);margin-bottom:18px}
.pc-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:14px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pc-stats > div{text-align:center}
.pc-stats span{display:block;font-family:var(--f-display);font-size:22px;color:var(--ink-900);line-height:1}
.pc-stats label{display:block;font-family:var(--f-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-top:6px}
.pc-club{font-size:12px;color:var(--ink-700);text-align:center;font-style:italic}

.legend-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.legend-card{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid rgba(212,164,55,.4);border-radius:12px;padding:18px;background:linear-gradient(135deg,#fff 50%,rgba(212,164,55,.07))}
.legend-num{font-family:var(--f-display);font-size:44px;color:var(--gold-700);line-height:1;min-width:50px}
.legend-name{font-family:var(--f-serif);font-size:17px;color:var(--ink-900);line-height:1.2}
.legend-team{font-size:13px;color:var(--mute);margin-top:4px}
.legend-meta{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-700);margin-top:6px}

/* ============================================
   GRIDS GENÉRICOS
   ============================================ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
@media(max-width:560px){.grid-3,.grid-4{grid-template-columns:1fr}}

/* ============================================
   GROUP CARDS — fase de grupos
   ============================================ */
.group-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px}
.group-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.group-title{font-family:var(--f-display);font-size:32px;color:var(--ink-900);letter-spacing:.04em}
.group-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}
.group-team{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line)}
.group-team:last-child{border-bottom:none}
.group-team .gt-flag{width:32px;height:22px;border-radius:3px;overflow:hidden;background:var(--paper-2)}
.group-team .gt-flag img{width:100%;height:100%;object-fit:cover}
.gt-name{font-weight:600;font-size:14px;color:var(--ink-900);flex:1}
.gt-rank{font-family:var(--f-mono);font-size:11px;color:var(--mute)}

/* ============================================
   RANKING TABLE
   ============================================ */
.rank-table{width:100%;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;border-collapse:collapse}
.rank-table th{background:var(--ink-900);color:#fff;font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;text-align:left;padding:16px 18px;font-weight:500}
.rank-table td{padding:14px 18px;border-top:1px solid var(--line);font-size:14px;color:var(--ink-900)}
.rank-table tr:hover td{background:var(--paper)}
.rank-table .rk-pos{font-family:var(--f-display);font-size:22px;color:var(--gold-700);width:60px}
.rank-table .rk-team{font-weight:600}
.rank-table .rk-flag{display:inline-block;margin-right:8px;font-size:20px;vertical-align:middle}

/* ============================================
   FATO/CURIOSIDADE CARDS
   ============================================ */
.fact-card{background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold-500);border-radius:8px;padding:22px}
.fact-num{font-family:var(--f-display);font-size:14px;color:var(--gold-700);letter-spacing:.16em;margin-bottom:10px}
.fact-title{font-family:var(--f-serif);font-size:20px;color:var(--ink-900);margin-bottom:10px;line-height:1.25}
.fact-text{color:var(--ink-700);font-size:14px;line-height:1.55}

/* ============================================
   STAT BIG NUMBERS
   ============================================ */
.big-stat{background:linear-gradient(135deg,var(--ink-900),var(--ink-800));color:#fff;padding:30px;border-radius:14px;position:relative;overflow:hidden}
.big-stat-num{font-family:var(--f-display);font-size:72px;line-height:.95;color:var(--gold-300);letter-spacing:.02em}
.big-stat-label{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:8px}
.big-stat-desc{margin-top:14px;color:rgba(255,255,255,.85);font-size:14px;line-height:1.5}

/* ============================================
   MOMENT — momentos históricos
   ============================================ */
.moment{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.moment-img{height:200px;background:linear-gradient(135deg,var(--ink-800),var(--ink-700));position:relative;overflow:hidden}
.moment-img img{width:100%;height:100%;object-fit:cover;opacity:.85}
.moment-year{position:absolute;top:14px;left:14px;background:var(--gold-500);color:var(--ink-900);font-family:var(--f-display);font-size:14px;padding:6px 12px;letter-spacing:.08em;border-radius:4px}
.moment-body{padding:22px}
.moment-title{font-family:var(--f-serif);font-size:22px;color:var(--ink-900);margin-bottom:8px;line-height:1.2}
.moment-text{font-size:14px;color:var(--ink-700);line-height:1.6}

/* ============================================
   FORM (contato)
   ============================================ */
.form-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:32px}
.field label{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-700);margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:8px;
  font-family:var(--f-sans);font-size:14px;color:var(--ink-900);background:var(--paper);
  transition:border-color .2s,background .2s
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-500);background:#fff}
.field textarea{min-height:140px;resize:vertical}
.field.full{grid-column:1/-1}
.field-help{font-size:12px;color:var(--mute);margin-top:6px}

/* ============================================
   CONTACT INFO CARD
   ============================================ */
.contact-info{background:var(--ink-900);color:#fff;padding:32px;border-radius:14px}
.contact-info h3{font-family:var(--f-display);font-size:24px;color:var(--gold-300);letter-spacing:.04em;margin-bottom:18px}
.contact-info dt{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:18px}
.contact-info dt:first-child{margin-top:0}
.contact-info dd{font-size:14px;color:rgba(255,255,255,.95);margin-top:4px;line-height:1.5}

/* ============================================
   TIPS / GUIDE LIST
   ============================================ */
.tip{display:flex;gap:18px;padding:20px;background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:14px}
.tip-num{font-family:var(--f-display);font-size:36px;color:var(--gold-500);line-height:1;min-width:50px}
.tip-body h4{font-family:var(--f-serif);font-size:18px;color:var(--ink-900);margin-bottom:6px}
.tip-body p{font-size:14px;color:var(--ink-700);line-height:1.55}

/* ============================================
   RESPONSIVE adjustments for new components
   ============================================ */
@media(max-width:640px){
  .player-grid{grid-template-columns:1fr}
  .big-stat-num{font-size:54px}
  .group-title{font-size:26px}
}

/* stadium extra refinements */
.stadium-country{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-bottom:4px}
.stadium-cap span{font-family:var(--f-display);font-size:22px;color:var(--ink-900);display:block;letter-spacing:.02em}
.stadium-cap label{font-family:var(--f-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-top:4px;display:block}
.stadium-final{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700);background:var(--gold-100);padding:6px 12px;border-radius:100px;align-self:center;height:fit-content}

/* table wrapper for horizontal scroll on mobile */
.table-wrap{overflow-x:auto;border-radius:14px}
.table-wrap .rank-table{min-width:600px}
