/* =========================
   Surface / Container
   ========================= */
.icciuk-surface{
  background:#d8e7ff;
  padding:24px;
  border:1px solid #d9e3f5;
}

/* =========================
   Layout base
   ========================= */
.icciuk-row{display:flex;flex-wrap:wrap;gap:12px}
.icciuk-col{flex:1 1 200px}
.icciuk-col-25{flex:1 1 calc(25% - 12px)}
@media (max-width:1024px){ .icciuk-col-25{flex:1 1 calc(50% - 12px)} }
@media (max-width:640px){ .icciuk-col-25{flex:1 1 100%} }

/* =========================
   Filtri “pill”
   ========================= */
#icciuk-member-filter input,
#icciuk-member-filter select{
  appearance:none; -webkit-appearance:none;
  width:100%; height:42px;
  padding:0 40px 0 14px;
  border:1px solid #9bb4d9;
  background:#fff;
  border-radius:6px;
  font:400 14px/42px system-ui,Segoe UI,Roboto,Arial,sans-serif;
  position:relative;
}
#icciuk-member-filter select,
#icciuk-member-filter input{
  background-image:
    radial-gradient(circle at center, transparent 45%, transparent 46%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24'%3E%3Cpath d='M8 10l4 4 4-4' fill='none' stroke='%23055086' stroke-width='2'/%3E%3C/svg%3E");
  background-repeat:no-repeat,no-repeat;
  background-size:22px 22px, 11px 11px;
  background-position: right 10px center, right 16px center;
}

/* opzionale: spinner sugli input con .loading */
#icciuk-member-filter .loading{
  background-image:
    radial-gradient(circle at center, transparent 45%, transparent 46%),
    url('/glueup/member_list/images/loading.gif');
  background-repeat:no-repeat,no-repeat;
  background-size:22px 22px, 18px 18px;
  background-position:right 10px center, right 10px center;
}

/* =========================
   Grid a 4 colonne
   ========================= */
#memberlistcontent .icciuk-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:28px 28px;
  padding:20px 12px 8px;
}
@media (max-width:1200px){ #memberlistcontent .icciuk-grid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:900px){  #memberlistcontent .icciuk-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:560px){  #memberlistcontent .icciuk-grid{grid-template-columns:1fr} }

/* =========================
   Card (nome sotto immagine)
   ========================= */
.icciuk-card{
  background:#fff;
  border:1px solid #253141;
  border-radius:28px 0 0 0;      /* angolo TL grande */
  padding:22px 18px;
  min-height:160px;
  display:flex; align-items:center; justify-content:center;
  transition:box-shadow .2s ease, transform .2s ease;
}
.icciuk-card:hover{ box-shadow:0 8px 18px rgba(5,80,134,.12); transform:translateY(-2px); }

/* figura verticale (immagine/logo + nome sotto) */
.icciuk-card-figure{
  margin:0;
  display:flex; flex-direction:column;
  align-items:center; gap:12px;
}

/* contenitore immagine/logo con fallback icona SVG */
.icciuk-card-img{
  --size: 64px;
  width:var(--size); height:var(--size);
  display:grid; place-items:center;
  border:1px solid #cfd8e3; border-radius:10px;
  background:#fff; overflow:hidden;
}
.icciuk-card-img img{
  width:100%; height:100%;
  object-fit:contain; display:block;
}

/* nome sotto l'immagine */
.icciuk-card-name{
  font:600 15px/1.2 system-ui,Segoe UI,Roboto,Arial,sans-serif;
  color:#2a2f3a; text-align:center;
}

/* dettagli opzionali sotto il nome (se usi RENDER_DETAILED) */
.icciuk-card-meta{
  font:400 13px/1.4 system-ui,Segoe UI,Roboto,Arial,sans-serif;
  color:#5a6575; text-align:center;
}

/* Card come link a pieno blocco */
.icciuk-card-link{
  display:block; height:100%;
  color:inherit; text-decoration:none;
}
.icciuk-card-link:hover .icciuk-card,
.icciuk-card-link:focus-visible .icciuk-card{
  box-shadow:0 8px 18px rgba(5,80,134,.12);
  transform:translateY(-2px);
}
.icciuk-card.is-disabled{ opacity:.75; cursor:default; }
.icciuk-card.is-disabled:hover{ box-shadow:none; transform:none; }
.icciuk-card-link:focus-visible{ outline:2px solid #055086; outline-offset:3px; border-radius:30px; }


/* =========================
   Paginazione
   ========================= */
.icciuk-pagination{
  display:flex; justify-content:center; align-items:center; gap:8px;
  padding:18px 0 6px;
}
.icciuk-pagebtn{
  min-width:34px; height:34px; padding:0 10px;
  border:1px solid #9bb4d9; background:#fff; border-radius:18px;
  display:inline-flex; align-items:center; justify-content:center;
  font:500 14px/1 system-ui,Segoe UI,Roboto,Arial,sans-serif; color:#055086;
  cursor:pointer; user-select:none;
}
.icciuk-pagebtn[aria-current="page"],
.icciuk-pagebtn.is-active{ background:#055086; color:#fff; border-color:#055086; }
.icciuk-pagebtn:disabled{ opacity:.5; cursor:not-allowed }
.icciuk-ellipsis{ padding:0 6px; color:#6e7f96 }
.icciuk-pagebtn:focus-visible{ outline:2px solid #055086; outline-offset:2px }

/* =========================
   Stato loading del contenitore
   ========================= */
#memberlistcontent.is-loading{
  position:relative; min-height:120px;
}
#memberlistcontent.is-loading::after{
  content:"Loading…";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-style:italic; color:#055086;
}

/* =========================
   Avvisi/empty state
   ========================= */
.icciuk-alert{
  background:#fff; border:1px solid #d9e3f5; color:#2a2f3a;
  border-radius:8px; padding:14px 16px; text-align:center;
}
.icciuk-alert--error{
  border-color:#de6161; color:#8b1a1a; background:#fff6f6;
}
