/* index.css — CSS específico da página index */

/* =============================================
       HERO BANNER (Slider)
    ============================================= */
    .hero-slider {
      position:relative; width:100%; height:600px; overflow:hidden;
      background:var(--bg-surface);
    }
    .hero-slide {
      position:absolute; inset:0;
      opacity:0; transition:opacity 0.9s ease; pointer-events:none;
    }
    .hero-slide.active { opacity:1; pointer-events:auto; }
    .hero-slide-img {
      width:100%; height:100%; object-fit:cover;
      transform:scale(1.08); transition:transform 8s ease;
      filter:brightness(0.55);
    }
    .hero-slide.active .hero-slide-img { transform:scale(1); }

    .hero-overlay {
      position:absolute; inset:0; z-index:2;
      background:linear-gradient(to right, rgba(8,9,16,0.7) 0%, rgba(8,9,16,0.1) 60%, transparent 100%),
                 linear-gradient(to top, rgba(8,9,16,0.6) 0%, transparent 50%);
    }
    [data-theme="light"] .hero-overlay {
      background:linear-gradient(to right, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.1) 60%, transparent 100%),
                 linear-gradient(to top, rgba(0,0,0,0.4) 0%, transparent 50%);
    }

    .hero-content {
      position:absolute; bottom:0; left:0; right:0; z-index:3;
      max-width:1280px; margin:0 auto; padding:0 24px 60px;
    }
    .hero-eyebrow {
      display:inline-flex; align-items:center; gap:8px; margin-bottom:16px;
      padding:5px 14px; background:rgba(46,204,113,0.15); border:1px solid rgba(46,204,113,0.3);
      border-radius:99px; font-size:11px; font-weight:700; letter-spacing:0.15em;
      text-transform:uppercase; color:#2ECC71;
    }
    .hero-eyebrow-dot { width:6px; height:6px; border-radius:50%; background:#2ECC71; animation:pdot 2s ease-in-out infinite; }
    @keyframes pdot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.7)} }
    .hero-slide-title {
      font-family:'Bebas Neue',sans-serif; font-size:clamp(44px,7vw,88px);
      line-height:0.95; letter-spacing:0.01em; color:#fff; margin-bottom:16px;
      text-shadow:0 4px 32px rgba(0,0,0,0.5);
    }
    .hero-slide-desc {
      font-size:16px; color:rgba(255,255,255,0.75); max-width:520px;
      line-height:1.65; margin-bottom:28px;
    }
    .hero-slide-btn {
      display:inline-flex; align-items:center; gap:8px;
      padding:12px 28px; background:var(--accent); color:#fff;
      border-radius:10px; font-size:13px; font-weight:700; letter-spacing:0.08em;
      text-decoration:none; transition:all 0.25s;
      box-shadow:0 4px 20px var(--accent-glow);
    }
    .hero-slide-btn:hover { transform:translateY(-2px); box-shadow:0 8px 32px var(--accent-glow); }

    /* Slider controls */
    .slider-dots {
      position:absolute; bottom:24px; right:24px; z-index:4;
      display:flex; gap:8px;
    }
    .slider-dot {
      width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,0.3);
      cursor:pointer; transition:all 0.3s; border:none; padding:0;
    }
    .slider-dot.active { background:#fff; transform:scale(1.3); }
    .slider-arrows {
      position:absolute; top:50%; transform:translateY(-50%);
      width:100%; display:flex; justify-content:space-between; padding:0 16px;
      z-index:4; pointer-events:none;
    }
    .slider-arrow {
      width:44px; height:44px; border-radius:50%;
      background:rgba(255,255,255,0.1); backdrop-filter:blur(8px);
      border:1px solid rgba(255,255,255,0.15); color:#fff;
      cursor:pointer; display:flex; align-items:center; justify-content:center;
      transition:all 0.2s; pointer-events:auto;
    }
    .slider-arrow:hover { background:var(--accent); border-color:var(--accent); }

    /* =============================================
       SECTION COMMONS
    ============================================= */
    .section-wrap { padding:80px 24px; position:relative; z-index:1; }
    .section-wrap.alt { background:var(--bg-surface); transition:var(--transition-theme); }
    .section-inner { max-width:1280px; margin:0 auto; }

    .section-head { text-align:center; margin-bottom:48px; }
    .section-eyebrow {
      display:inline-flex; align-items:center; gap:8px; margin-bottom:12px;
      font-size:11px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--accent);
    }
    .section-eyebrow::before, .section-eyebrow::after { content:''; width:20px; height:1px; background:var(--accent); }
    .section-title { font-family:'Bebas Neue',sans-serif; font-size:clamp(36px,5vw,56px); color:var(--text-primary); line-height:1; margin-bottom:10px; transition:var(--transition-theme); }
    .section-sub { font-size:15px; color:var(--text-secondary); max-width:480px; margin:0 auto; transition:var(--transition-theme); }

    .view-all-btn {
      display:inline-flex; align-items:center; gap:6px;
      font-size:12px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase;
      color:var(--accent); text-decoration:none; transition:gap 0.2s;
    }
    .view-all-btn:hover { gap:10px; }
    .view-all-btn svg { transition:transform 0.2s; }
    .view-all-btn:hover svg { transform:translateX(3px); }

    /* =============================================
       REVISTAS
    ============================================= */
    .revistas-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }

    .revista-card {
      border-radius:14px; overflow:hidden; cursor:pointer;
      border:1px solid var(--border); background:var(--bg-card);
      transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.3s, border-color 0.3s, var(--transition-theme);
      box-shadow:var(--card-shadow);
    }
    .revista-card:hover { transform:translateY(-6px) scale(1.02); border-color:var(--accent); box-shadow:0 20px 60px rgba(0,0,0,0.35), 0 0 0 1px var(--accent); }
    [data-theme="light"] .revista-card:hover { box-shadow:0 12px 40px rgba(26,158,82,0.18), 0 0 0 1px var(--accent); }

    .revista-cover {
      width:100%; aspect-ratio:3/4; object-fit:cover;
      display:block; transition:transform 0.5s ease;
      background:var(--bg-surface);
    }
    .revista-card:hover .revista-cover { transform:scale(1.04); }

    .revista-info { padding:14px 16px 16px; }
    .revista-edition { font-size:10px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); margin-bottom:4px; transition:var(--transition-theme); }
    .revista-title { font-size:14px; font-weight:600; color:var(--text-primary); line-height:1.3; transition:var(--transition-theme); }
    .revista-sub { font-size:12px; color:var(--text-muted); margin-top:2px; transition:var(--transition-theme); }

    /* =============================================
       NOTÍCIAS
    ============================================= */
    .noticias-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

    .noticia-card {
      border-radius:16px; overflow:hidden; cursor:pointer;
      background:var(--bg-card); border:1px solid var(--border);
      transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.3s, border-color 0.3s, var(--transition-theme);
      box-shadow:var(--card-shadow); display:flex; flex-direction:column;
    }
    .noticia-card:hover { transform:translateY(-5px); border-color:var(--accent); box-shadow:0 20px 60px rgba(0,0,0,0.3); }
    [data-theme="light"] .noticia-card:hover { box-shadow:0 12px 40px rgba(26,158,82,0.15); }

    .noticia-img-wrap { width:100%; aspect-ratio:16/9; overflow:hidden; position:relative; }
    .noticia-img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; background:var(--bg-surface); }
    .noticia-card:hover .noticia-img { transform:scale(1.06); }
    .noticia-category {
      position:absolute; top:12px; left:12px;
      padding:4px 10px; background:var(--accent); color:#fff;
      border-radius:99px; font-size:10px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
    }

    .noticia-body { padding:20px 22px 24px; flex:1; display:flex; flex-direction:column; gap:10px; }
    .noticia-date { font-size:11px; font-family:'DM Mono',monospace; color:var(--text-muted); transition:var(--transition-theme); }
    .noticia-title { font-size:17px; font-weight:700; color:var(--text-primary); line-height:1.35; transition:color 0.2s, var(--transition-theme); }
    .noticia-card:hover .noticia-title { color:var(--accent); }
    .noticia-excerpt { font-size:13px; color:var(--text-secondary); line-height:1.6; flex:1; transition:var(--transition-theme); }
    .noticia-link { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; color:var(--accent); text-decoration:none; margin-top:4px; transition:gap 0.2s; }
    .noticia-link:hover { gap:10px; }

    /* =============================================
       TORNEIOS RECENTES
    ============================================= */
    .torneios-list { display:flex; flex-direction:column; gap:12px; }

    .torneio-row {
      display:grid; grid-template-columns:1fr auto auto auto;
      align-items:center; gap:16px;
      background:var(--bg-card); border:1px solid var(--border); border-radius:12px;
      padding:18px 24px; cursor:pointer;
      transition:transform 0.25s cubic-bezier(0.34,1.56,0.64,1), border-color 0.25s, background 0.25s, var(--transition-theme);
    }
    .torneio-row:hover { transform:translateX(4px); border-color:var(--accent); background:var(--bg-card-hover); }

    .torneio-row-info { min-width:0; }
    .torneio-row-genre { font-size:10px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); margin-bottom:3px; transition:var(--transition-theme); }
    .torneio-row-name { font-size:15px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; transition:var(--transition-theme); }
    .torneio-row-meta { font-size:12px; color:var(--text-muted); margin-top:2px; font-family:'DM Mono',monospace; transition:var(--transition-theme); }

    .torneio-row-vagas { text-align:center; }
    .torneio-row-vagas-num { font-family:'Bebas Neue',sans-serif; font-size:28px; color:var(--text-primary); line-height:1; transition:var(--transition-theme); }
    .torneio-row-vagas-label { font-size:10px; color:var(--text-muted); letter-spacing:0.1em; text-transform:uppercase; transition:var(--transition-theme); }

    .torneio-status-badge { padding:5px 12px; border-radius:99px; font-size:10px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; display:flex; align-items:center; gap:6px; white-space:nowrap; }
    .torneio-status-badge.em-andamento { background:rgba(46,204,113,0.12); border:1px solid rgba(46,204,113,0.3); color:#2ECC71; }
    .torneio-status-badge.inscricoes { background:rgba(52,152,219,0.12); border:1px solid rgba(52,152,219,0.3); color:#3498db; }
    .torneio-status-badge.planejamento { background:var(--border); border:1px solid var(--border-hover); color:var(--text-muted); }
    .torneio-status-badge.finalizado { background:rgba(231,76,60,0.1); border:1px solid rgba(231,76,60,0.2); color:#e74c3c; }
    .status-dot { width:5px; height:5px; border-radius:50%; background:currentColor; }
    .status-dot.pulse { animation:pdot 1.5s ease-in-out infinite; }

    .btn-ver-torneio {
      padding:9px 18px; background:var(--accent-subtle); border:1px solid rgba(46,204,113,0.2);
      color:var(--accent); border-radius:8px; font-size:12px; font-weight:600;
      font-family:'DM Sans',sans-serif; text-decoration:none; white-space:nowrap;
      transition:all 0.2s; display:inline-flex; align-items:center; gap:6px;
    }
    .btn-ver-torneio:hover { background:var(--accent); color:#fff; border-color:var(--accent); }

    /* =============================================
       INSTAGRAM MOSAIC
    ============================================= */
    .instagram-section { padding:80px 24px; position:relative; z-index:1; overflow:hidden; }
    .instagram-section::before {
      content:''; position:absolute; inset:0;
      background:radial-gradient(ellipse 80% 60% at 50% 50%, var(--accent-subtle) 0%, transparent 70%);
      pointer-events:none;
    }
    .insta-inner { max-width:1280px; margin:0 auto; }

    .insta-mosaic {
      display:grid;
      grid-template-columns:repeat(6,1fr);
      grid-template-rows:repeat(2,180px);
      gap:8px; margin-top:40px;
    }
    .insta-item {
      border-radius:12px; overflow:hidden; position:relative; cursor:pointer;
      background:var(--bg-card);
    }
    .insta-item:nth-child(1) { grid-column:1/3; grid-row:1/3; } /* item destaque */
    .insta-item:nth-child(2) { grid-column:3/5; }
    .insta-item:nth-child(3) { grid-column:5/7; }
    .insta-item:nth-child(4) { grid-column:3/4; }
    .insta-item:nth-child(5) { grid-column:4/5; }
    .insta-item:nth-child(6) { grid-column:5/6; }
    .insta-item:nth-child(7) { grid-column:6/7; }

    .insta-img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease, filter 0.3s; }
    .insta-item:hover .insta-img { transform:scale(1.08); filter:brightness(0.7); }
    .insta-overlay {
      position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
      background:rgba(46,204,113,0.15); opacity:0; transition:opacity 0.3s;
    }
    .insta-item:hover .insta-overlay { opacity:1; }
    .insta-overlay svg { color:#fff; filter:drop-shadow(0 2px 8px rgba(0,0,0,0.5)); }

    .insta-handle-bar {
      display:flex; align-items:center; justify-content:center; gap:12px; margin-top:28px; flex-wrap:wrap;
    }
    .insta-handle {
      display:flex; align-items:center; gap:8px; padding:10px 20px;
      background:var(--bg-card); border:1px solid var(--border); border-radius:99px;
      font-size:13px; font-weight:600; color:var(--text-primary); text-decoration:none;
      transition:all 0.2s;
    }
    .insta-handle:hover { border-color:var(--accent); color:var(--accent); transform:translateY(-2px); }

    /* Placeholder para imagens não carregadas */
    .insta-placeholder {
      width:100%; height:100%; display:flex; align-items:center; justify-content:center;
      background:linear-gradient(135deg, var(--bg-surface) 0%, var(--bg-card) 100%);
      color:var(--text-muted); font-size:28px;
    }