:root{
    --brand-color-primary: #3f7a4a;
    --brand-color-primary-darker-1: #356437;
    --muted: #6b6b6b;
  --max-width: 1120px;
  --gutter: 24px;
  --radius: 6px;
  }
  
  /* Base */
  *{box-sizing:border-box}
  body {
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    line-height: 1.6;
    color: #333;
    background-color: #fff;
    -webkit-font-smoothing:antialiased;
  }
  
  .socialmedia_icons a {
      color: var(--brand-color-primary);
      transition: 0.3s;
  }
  
  .socialmedia_icons a:hover {
      color: var(--brand-color-primary-darker-1);
  }
  /* Header */
  #header { padding: 1rem 0; background-color: #fff; border-bottom: 1px solid #ddd; }
  #branding .club-badge img { width: 90px; height: 90px; object-fit: contain; }
  #header .club-name { color: var(--brand-color-primary); }
  



  .page-header {

      margin-bottom: 20px;
  }
  
  .page-header h1 {
      font-size: 3.5rem; /* Ajuste para o tamanho do título */
      font-weight: 600; /* Negrito */
      color: #333; /* Cor cinza escuro */
      margin: 0;
  }
  
  .page-header h1 p {
      margin: 0;
  }
  
  .page-header h1 span {
      display: block;
      font-size: 1.2rem; /* Tamanho para o slogan */
      font-weight: 400; /* Normal */
      color: #666; /* Cor cinza mais clara */
      margin-top: 5px;
  }
  
  /* Opcional: Para alinhar o texto com a imagem e formulário */
  #content {
      padding-top: 20px;
  }
  /* Navbar override leve para Bootstrap 5 */
  .navbar.bg-success { background-color: var(--brand-color-primary) !important; }
  .navbar .nav-link, .navbar .navbar-brand { color: #fff !important; }
  .navbar .nav-link:hover, .navbar .nav-link.active { color: #e0e0e0 !important; }
  
  /* Layout containers: mantenho .wrapper de forma não intrusiva */
  .container .wrapper { margin: 0; }
  .members_form {
    background: #ffffff;
    padding: 1rem;
    border-radius: 6px;
  }
  
  .members_form .block-header { margin-bottom: 1rem; }
  .members_form .block-title { color: var(--brand-color-primary); font-weight: 600; }
  
  .members_form .form-control,
  .members_form .form-select {
    border-radius: 4px;
    height: calc(1.6rem + 1rem);
    padding: .5rem .625rem;
  }
  
  .members_form .form-check-input { margin-top: .35rem; }

.sponsors-grid img { max-width:100%; height:auto; }
  
  /* Footer */
  #item-image {
  width: 30%;
  height: auto;
  border-radius: var(--radius);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  object-fit: cover;
}



  
  /* Responsividade */
  @media (max-width: 768px) {
      .footer-content {
          flex-direction: column;
          gap: 15px;
      }
      #item-image {
  width: 40vh;
  height: 50vh;
  margin-left: 20px;
  border-radius: var(--radius);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  object-fit: cover;
}
  }
  
  /* Responsividade (mantive os breakpoints do original) */
  @media (max-width: 992px) {
    /* somente ajustes visuais, sem mudar layout */
    .members_form { padding: .75rem; }
  }
  
  @media (max-width: 480px) {
    .members_form .form-control { font-size: 0.95rem; }
  }

/* Container que define o layout em grade */
/* Container que agrupa os cartões de cada posição */
/* Container Flexbox para a lista de jogadores (Centralização) */
/* 1. LAYOUT GRID (3 COLUNAS) */
/* 1. LAYOUT GRID (3 COLUNAS) */
.lista-jogadores {
    display: grid; /* Usa Grid para forçar 3 colunas */
    grid-template-columns: repeat(3, 1fr); 
    gap: 20px; /* Espaço entre os cartões */
    padding: 20px 0;
    max-width: 1200px; /* Limita a largura do container */
    margin: 0 auto; 
}

/* 2. ESTILO DO CARTÃO (Poster/Borda) */
.cartao-jogador {
    position: relative; /* Necessário para posicionar o número e o nome na imagem */
    width: 100%; /* Ocupa a largura total da coluna do Grid */
    height: auto;
    overflow: hidden; 
    
    background-color: white; /* Fundo branco */
    border-radius: 0; /* Remova o arredondamento */
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.1); /* Sombra suave */
    text-align: left;
    padding: 0;
}

/* 3. IMAGEM */
.jogador-imagem {
    display: block;
    line-height: 0; /* Remove espaço extra abaixo da imagem */
}

.jogador-imagem img {
    display: block;
    width: 100%;
    height: auto;
}
p{
    margin-top: 5px;
    margin-bottom: 5px;
    font-size: 1.2rem; /* Título da seção (Guarda-redes/Defesa) */
    color: #333;
    /* Alinha à esquerda na mesma margem dos cartões */
    max-width: 1200px;
}

/* 4. POSICIONAMENTO E ESTILO DO TEXTO */

.info-box {
    /* Usar uma div wrapper para o texto se precisar de um padding na base. */
    /* Se não for usar wrapper, ajuste padding: 10px 15px; */
}

.jogador-numero {
    /* Número grande, posicionado sobre a imagem */
    position: absolute;
    bottom: 55px; /* Ajuste a altura em que o número aparece sobre a imagem */
    left: 10px; 
    font-size: 2.5rem; 
    font-weight: 700;
    color: white; 
    line-height: 1;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5); /* Sombra para destacar */
    z-index: 10; /* Garante que o número fique sobre a imagem */
}

/* Texto de nome e idade na base branca */
.jogador-nome {
    font-size: 0.9rem; /* Nome menor */
    font-weight: bold;
    color: #333;
    text-transform: uppercase;
    margin: 0;
    padding: 5px 10px 0 10px; /* Padding na parte de texto branco */
}
.jogador-idade {
    font-size: 0.8rem;
    color: #666;
    margin: 0;
    padding: 0 10px 10px 10px;
}
.jogador-posicao {
    display: none; /* Posição não visível no cartão Poster */
}

/* 5. TÍTULOS E SEÇÃO */
.secao-posicao h2 {
    margin-top: 20px;
    margin-bottom: 5px;
    font-size: 1.2rem; /* Título da seção (Guarda-redes/Defesa) */
    color: #333;
    /* Alinha à esquerda na mesma margem dos cartões */
    margin-left: auto;
    max-width: 1200px;
}
.players-section .players-grid,.players-section .staff-grid,.staff-section .players-grid,.staff-section .staff-grid {
    margin-left: -15px;
    margin-right: -15px
}

.players-section .players-grid:before,.players-section .players-grid:after,.players-section .staff-grid:before,.players-section .staff-grid:after,.staff-section .players-grid:before,.staff-section .players-grid:after,.staff-section .staff-grid:before,.staff-section .staff-grid:after {
    content: " ";
    display: table
}

.players-section .players-grid:after,.players-section .staff-grid:after,.staff-section .players-grid:after,.staff-section .staff-grid:after {
    clear: both
}

.players-section .players-grid .players-by-position,.players-section .staff-grid .players-by-position,.staff-section .players-grid .players-by-position,.staff-section .staff-grid .players-by-position {
    float: left;
    margin-bottom: 15px;
    width: 100%;
    margin-top: 45px;
}

.players-section .players-grid .player-position,.players-section .staff-grid .player-position,.staff-section .players-grid .player-position,.staff-section .staff-grid .player-position {
    position: relative;
    float: left;
    width: 100%;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px
}

.players-section .players-grid .players-wrapper,.players-section .players-grid .staff-wrapper,.players-section .staff-grid .players-wrapper,.players-section .staff-grid .staff-wrapper,.staff-section .players-grid .players-wrapper,.staff-section .players-grid .staff-wrapper,.staff-section .staff-grid .players-wrapper,.staff-section .staff-grid .staff-wrapper {
    margin: 0 5px
}

.players-section .players-grid h2,.players-section .staff-grid h2,.staff-section .players-grid h3,.staff-section .staff-grid h3 {
    margin-top: 0;
    margin-left: 15px;
}

.players-section .players-grid article,.players-section .staff-grid article,.staff-section .players-grid article,.staff-section .staff-grid article {
    position: relative;
    float: left;
    width: 100%;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
    position: relative;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
    padding: 0 10px;
    max-width: 400px
}


@media(min-width: 768px) {
    .players-section .players-grid article,.players-section .staff-grid article,.staff-section .players-grid article,.staff-section .staff-grid article {
        float:left;
        width: 33.3333333333%
    }
}

.players-section .players-grid article .thumbnail,.players-section .staff-grid article .thumbnail,.staff-section .players-grid article .thumbnail,.staff-section .staff-grid article .thumbnail {
    border: 1px solid #eee;
    border-top: 2px solid var(--brand-color-primary, #000000);
    margin-bottom: 0;
    color: #333;
    margin-top: 25px;
    
}

.players-section .players-grid article .thumbnail img,.players-section .staff-grid article .thumbnail img,.staff-section .players-grid article .thumbnail img,.staff-section .staff-grid article .thumbnail img {
    display: block;
    width: 100%;
    aspect-ratio: 3 / 4; /* Mantém proporção retrato */
    overflow: hidden;
}

.players-section .players-grid article .thumbnail .caption,.players-section .staff-grid article .thumbnail .caption,.staff-section .players-grid article .thumbnail .caption,.staff-section .staff-grid article .thumbnail .caption {
    display: table;
    padding: 0;
    position: relative;
    background-color: rgba(0,0,0,0);
    color: #333;
    margin-left: 15px;
}

.players-section .players-grid article .player-nr,.players-section .staff-grid article .player-nr,.staff-section .players-grid article .player-nr,.staff-section .staff-grid article .player-nr {
    border-right: 1px solid #eee;
    display: table-cell;
    font-size: 2em;
    line-height: 1em;
    width: 45px;
    padding: 10px 0;
    text-align: center;
    vertical-align: middle;
    margin-left: 25px;

}

.players-section .players-grid article .player-info,.players-section .players-grid article .staff-info,.players-section .staff-grid article .player-info,.players-section .staff-grid article .staff-info,.staff-section .players-grid article .player-info,.staff-section .players-grid article .staff-info,.staff-section .staff-grid article .player-info,.staff-section .staff-grid article .staff-info {
    text-transform: uppercase;
    display: table-cell;
    padding: 10px 5px;
    vertical-align: middle;
    margin-left: 25px;
}

.players-section .players-grid article .player-info span,.players-section .players-grid article .staff-info span,.players-section .staff-grid article .player-info span,.players-section .staff-grid article .staff-info span,.staff-section .players-grid article .player-info span,.staff-section .players-grid article .staff-info span,.staff-section .staff-grid article .player-info span,.staff-section .staff-grid article .staff-info span {
    display: block;
    color: #595959;
    font-size: .8em;
    text-transform: none
}

@media only screen and (max-width: 991px) {
    .soccer_team_resume_matches .match_teams {
        text-align:left
    }
}
/* 6. RESPONSIVIDADE */
@media (max-width: 992px) {
    .lista-jogadores {
        grid-template-columns: repeat(2, 1fr); /* 2 colunas em telas menores */
    }
}

@media (max-width: 576px) {
    .lista-jogadores {
        grid-template-columns: 1fr; /* 1 coluna em celular */
    }
}
/* Container principal da secção (Horário + Staff) */
.players-section .players-grid,
.staff-section .staff-grid {
  display: flex;
  flex-direction: column;  /* Empilha os elementos verticalmente */
  align-items: flex-start; /* Alinha tudo à esquerda */
  gap: 30px;               /* Espaço entre a imagem e o staff */
}

/* Imagem do horário */
#item-image {
  width: 100%;
  max-width: 450px;        /* Mantém proporção agradável */
  height: auto;
  border-radius: 8px;
  object-fit: cover;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.1);
  margin: 0;
}

/* Cards do staff */
.staff-section .staff-grid {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 20px;
}

/* Ajuste dos artigos individuais */
.staff-section .staff-grid article {
  flex: 0 0 auto;
}
