/* =========================
   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;
  padding: 30px 20px;
  min-height: 140px;
  display: flex; 
  flex-direction: column;
  align-items: flex-start; 
  justify-content: flex-start;
  position: relative;
  transition: box-shadow .2s ease, transform .2s ease;
}
.icciuk-card:hover { 
  box-shadow: 0 8px 18px rgba(5,80,134,.12); 
  transform: translateY(-2px); 
}

/* Card disabilitata */
.icciuk-card.is-disabled{ 
  opacity:.75; 
  cursor:default; 
}
.icciuk-card.is-disabled:hover{ 
  box-shadow:none; 
  transform:none; 
}

/* Nascondi il logo/immagine */
.icciuk-card-img {
  display: none !important;
}

/* Figura verticale: rimosso il gap dell'immagine */
.icciuk-card-figure {
  margin: 0;
  width: 100%;
  display: flex; 
  flex-direction: column;
  align-items: flex-start; 
  gap: 0; 
}

/* Nome: Titolo in alto a sinistra */
.icciuk-card-name {
  text-align: left;
  font: normal normal normal 20px Inter, system-ui, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: -0.7px;
  color: #024F86;
  opacity: 1;
  text-transform: none;
}

/* 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;
}
*/

/* 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;
}

/* Tipo di membro sopra "Visualizza il Sito" */
.icciuk-member-type {
  position: absolute;
  bottom: 48px;
  right: 12px;
  padding: 4px 12px;
  font: 500 12px/1.3 system-ui, Segoe UI, Roboto, Arial, sans-serif;
  color: #055086;
  text-align: right;
  text-transform: capitalize;
}

/* Bottone "Visualizza il Sito" in basso a destra */
.icciuk-visit-btn {
  position: absolute;
  bottom: 12px;
  right: 12px;
  padding: 8px 16px;
  color: #055086;
  font: 500 13px/1.2 system-ui, Segoe UI, Roboto, Arial, sans-serif;
  text-decoration: underline;
  transition: color .2s ease, text-decoration .2s ease;
  z-index: 10;
}
.icciuk-visit-btn:hover {
  color: #044070;
  text-decoration: none;
}
.icciuk-visit-btn:active {
  color: #033050;
}
.icciuk-visit-btn:focus-visible {
  outline: 2px solid #055086;
  outline-offset: 2px;
}

/* Card cliccabile */
.icciuk-card-clickable {
  cursor: pointer;
}
.icciuk-card-clickable:hover { 
  box-shadow: 0 8px 18px rgba(5,80,134,.12); 
  transform: translateY(-2px); 
}
.icciuk-card-clickable:focus-visible {
  outline: 2px solid #055086;
  outline-offset: 3px;
}


/* =========================
   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;
}
