/* =========================================================
   Giosport Players – Frontend Styles (Grid 4x2 + Card style)
   ========================================================= */

.gsp-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:5px;
  width:100%;
}

/* Team grid: 3 columns on desktop */
.gsp-team-grid{
  grid-template-columns: repeat(3, 1fr);
}


.gsp-card{
  background: linear-gradient(180deg, #6b7d00 0%, #1f3b00 100%);
  border-radius:28px;
  padding:8px;
  overflow:hidden;
}

.gsp-card-inner{
  background:#ffffff;
  border-radius:22px;
  overflow:hidden;
  height:100%;
  display:flex;
  flex-direction:column;
}

.gsp-img-wrap{
  width:100%;
  height:435px;
  max-height:435px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
}

.gsp-img{
  width:100%;
  height:100%;
  /* Uniform thumbnails (same size across cards) */
  object-fit:cover;
  object-position:center top;
  display:block;
}

.gsp-info{
  background:#000;
  color:#fff;
  text-align:center;
  padding:18px 10px 0;
}

.gsp-name{
  font-size:18px;
  letter-spacing:2px;
  text-transform:uppercase;
  margin:0 0 6px 0;
  line-height:1.2;
  font-family:'Roboto', sans-serif;
  color:#ffffff;
}

/* Archive filters (all assistiti) */
.gsp-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 14px 0;
  align-items:flex-end;
}
.gsp-filter{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:180px;
}
.gsp-filter label{
  font-size:12px;
  letter-spacing:1px;
  text-transform:uppercase;
  opacity:.9;
  font-family:'Roboto', sans-serif;
  color:#ffffff;
}
.gsp-filter select{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.55);
  color:#ffffff;
  font-family:'Roboto', sans-serif;
  outline:none;
}
.gsp-filter button{
  padding:11px 16px;
  border-radius:14px;
  border:0;
  cursor:pointer;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  background:linear-gradient(180deg,#d6b41f 0%, #6a7c14 100%);
  color:#111;
}
.gsp-filter .gsp-reset{
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:600;
}

.gsp-role{
  font-size:14px;
  opacity:0.85;
  margin:0 0 12px 0;
}

.gsp-btn{
  display:block;
  width:100%;
  background: linear-gradient(180deg, #c4c900 0%, #6b7d00 100%);
  color:#fff;
  font-weight:700;
  text-decoration:none;
  padding:12px 0;
  border-radius:0 0 18px 18px;
  letter-spacing:1px;
  margin-top:0;
}

@media (max-width: 1200px){
  .gsp-grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width: 980px){
  .gsp-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 480px){
  .gsp-grid{ grid-template-columns:1fr; }
}

/* Transfermarkt module */
.gspd-tm-module{display:grid;gap:16px}
.gspd-tm-block{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:16px}
.gspd-tm-title{margin:0 0 10px;font-size:16px}
.gspd-tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:980px){.gspd-tm-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.gspd-tm-grid{grid-template-columns:1fr}}
.gspd-tm-item{border-radius:12px;background:rgba(0,0,0,.04);padding:10px}
.gspd-tm-label{font-size:12px;opacity:.7}
.gspd-tm-value{font-size:18px;font-weight:700}
.gspd-tm-info-list{display:grid;gap:8px}
.gspd-tm-row{display:flex;justify-content:space-between;gap:14px;border-bottom:1px dashed rgba(0,0,0,.12);padding-bottom:6px}
.gspd-tm-k{font-weight:600}
.gspd-tm-v{opacity:.85}

.gspd-tm-empty{padding:14px;border:1px dashed rgba(0,0,0,.25);border-radius:14px;opacity:.85}

.gspd-tm-updated{font-size:12px;opacity:.7;margin-bottom:10px}

/* Assistiti archive filters (shortcode) */
.gsp-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 18px 0;
}
.gsp-filter{
  flex:1 1 180px;
  min-width:180px;
}
.gsp-filter select{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.35);
  color:#fff;
  outline:none;
}
.gsp-filter select:focus{
  border-color:rgba(240,212,74,.6);
  box-shadow:0 0 0 3px rgba(240,212,74,.2);
}
.gsp-filter option{color:#111}

.gsp-filters-actions{flex:0 0 auto;display:flex;gap:10px;align-items:stretch}
.gsp-filters-actions .gsp-btn-mini{
  padding:10px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.35);
  color:#fff;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  cursor:pointer;
}
.gsp-filters-actions .gsp-btn-mini:hover{border-color:rgba(240,212,74,.6)}


/* Swipe row (Assistiti) */
.gsp-swipe{
  width:100%;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;
  padding-bottom:6px;
}
.gsp-swipe__track{
  display:flex;
  gap:5px;
  align-items:stretch;
}
.gsp-swipe__item{
  flex:0 0 280px;
  scroll-snap-align:start;
}
@media (min-width:768px){
  .gsp-swipe__item{ flex-basis:320px; }
}
@media (min-width:1200px){
  .gsp-swipe__item{ flex-basis:360px; }
}


/* Reset filtri */
.gsp-reset-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border:1px solid rgba(255,255,255,.25);color:#fff;text-decoration:none;font-family:Roboto,sans-serif;font-size:12px;letter-spacing:.12em;text-transform:uppercase;transition:all .25s ease}
.gsp-reset-btn:hover{background:#fff;color:#000}

/* =====================================================
   NEWS LIST (DIVI MODULE)
   ===================================================== */
.gspd-news-list{ width:100%; }
.gspd-news-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:18px 0;
  border-bottom:1px solid rgba(255,255,255,0.15);
}
.gspd-news-left{ flex:1 1 auto; min-width:0; }
.gspd-news-title{
  margin:0;
  font-size:18px;
  letter-spacing:0.04em;
  text-transform:uppercase;
}
.gspd-news-subtitle{
  margin:6px 0 0;
  opacity:0.8;
}
.gspd-news-date{
  margin-top:8px;
  font-size:13px;
  opacity:0.65;
}
.gspd-news-right{ flex:0 0 auto; }
.gspd-news-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 26px;
  border:1px solid rgba(255,255,255,0.35);
  border-radius:999px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-size:12px;
  text-decoration:none;
  transition:all .25s ease;
}
.gspd-news-btn:hover{
  background:#ffffff;
  color:#000000;
}
@media (max-width:768px){
  .gspd-news-row{ flex-direction:column; align-items:flex-start; }
  .gspd-news-right{ width:100%; }
  .gspd-news-btn{ width:100%; }
}

/* === 5.15.1 FIX: force filter styling + keep images inside cards === */
.gsp-img-wrap{ overflow:hidden !important; }
.gsp-img{ display:block !important; width:100% !important; height:100% !important; object-fit:cover !important; }

.gsp-filters select,
.gsp-filters button,
.gsp-filters .gsp-filter-btn,
.gsp-filters .gsp-reset-btn{
  background: rgba(255,255,255,0.10) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.30) !important;
  border-radius: 0 !important;
  padding: 10px 12px !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;
}

.gsp-filters select{
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  background-image: linear-gradient(45deg, transparent 50%, rgba(255,255,255,0.85) 50%),
                    linear-gradient(135deg, rgba(255,255,255,0.85) 50%, transparent 50%);
  background-position: calc(100% - 16px) 50%, calc(100% - 11px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 34px !important;
}

.gsp-filters .gsp-reset-btn{
  margin-left: 10px;
}

/* === GIOSPORT IMAGE INSIDE BLOCK FIX === */
.gspd-card,
.giosport-card{
  position:relative;
  overflow:hidden;
}
.gspd-img-wrap,
.giosport-img-wrap{
  width:100%;
  height:435px;
  overflow:hidden;
}
.gspd-img-wrap img,
.giosport-img-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
