/* -------------------------
   Styles Collection V2.5 2026
-------------------------- */


.cc-collection-hub { max-width: 1200px; margin: 0 auto; padding: 24px 16px; }
.cc-collection-hero { padding: 16px 0 24px; border-bottom: 1px solid rgba(0,0,0,.08); }
.cc-collection-hero h1 { margin: 0 0 8px; font-size: 2rem; }
.cc-collection-hero p { margin: 0 0 16px; opacity: .85; }

.cc-collection-controls { display: grid; gap: 12px; }
.cc-search { display: flex; gap: 8px; }
.cc-search input[type="search"] { flex: 1; padding: 10px 12px; border: 1px solid rgba(0,0,0,.2); border-radius: 10px; }
.cc-search button { padding: 10px 12px; border-radius: 10px; border: 1px solid rgba(0,0,0,.2); background: transparent; cursor: pointer; }

.cc-filters { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)) auto; gap: 10px; align-items: end; }
.cc-filters label span { display: block; font-size: .85rem; opacity: .75; margin-bottom: 6px; }
.cc-filters select { width: 100%; padding: 10px 12px; border: 1px solid rgba(0,0,0,.2); border-radius: 10px; }

.cc-view-toggle { display: flex; gap: 8px; justify-content: flex-end; }
.cc-view-toggle button { padding: 10px 12px; border-radius: 10px; border: 1px solid rgba(0,0,0,.2); background: transparent; cursor: pointer; }
.cc-view-toggle .is-active { font-weight: 700; }

.cc-section-head { margin: 22px 0 12px; }
.cc-section-head h2 { margin: 0 0 6px; }
.cc-section-head p { margin: 0; opacity: .8; }

.cc-tiles { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.cc-tile { display: block; padding: 14px; border: 1px solid rgba(0,0,0,.12); border-radius: 16px; text-decoration: none; }
.cc-tile strong { display: block; margin-bottom: 6px; }
.cc-tile span { opacity: .8; font-size: .9rem; }

/* Optionnel : si tu veux masquer visuellement l’espace résultats tant que pas filtré */
.cc-collection-results.is-hidden { display:none; }

.cc-results { display: grid; gap: 12px; }
.cc-view-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.cc-card { border: 1px solid rgba(0,0,0,.12); border-radius: 16px; overflow: hidden; }
.cc-card-link { display: block; text-decoration: none; padding: 12px; }
.cc-card-thumb img { width: 100%; height: auto; display: block; border-radius: 12px; }
.cc-card-title { margin: 10px 0 0; font-size: 1rem; }
.cc-card-meta { list-style: none; margin: 0; padding: 0 12px 12px; font-size: .9rem; opacity: .85; }
.cc-card-meta li { margin-top: 6px; }

.cc-pagination { margin: 18px 0 0; }
.cc-empty { padding: 12px; border: 1px dashed rgba(0,0,0,.25); border-radius: 12px; opacity: .8; }

.cc-collection-hubgrid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-top: 22px; }
.cc-box { border: 1px solid rgba(0,0,0,.12); border-radius: 16px; padding: 14px; }
.cc-box h2 { margin: 0 0 10px; font-size: 1.1rem; }

.cc-mini-list { margin: 0; padding-left: 18px; }
.cc-mini-list li { margin: 6px 0; }

.cc-feature h3 { margin: 0 0 8px; }
.cc-feature p { margin: 0 0 10px; opacity: .85; }
.cc-more { text-decoration: none; font-weight: 700; }

.cc-pill-list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.cc-pill { display: inline-block; padding: 8px 10px; border-radius: 999px; border: 1px solid rgba(0,0,0,.18); text-decoration: none; font-size: .9rem; }

.cc-stats { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.cc-stats li { border: 1px solid rgba(0,0,0,.12); border-radius: 14px; padding: 12px; text-align: center; }
.cc-stats strong { display: block; font-size: 1.4rem; }
.cc-stats span { display: block; opacity: .8; font-size: .9rem; }


/* Vue liste (quand .cc-view-list est présent) */
.cc-results.cc-view-list {
  display: block;
}

.cc-results.cc-view-list .cc-card {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  align-items: start;
  padding: 12px;
  margin-bottom: 12px;
}

.cc-results.cc-view-list .cc-card-link {
  padding: 0;
}

.cc-results.cc-view-list .cc-card-thumb img {
  border-radius: 12px;
}

.cc-results.cc-view-list .cc-card-title {
  margin: 0 0 6px;
  font-size: 1.05rem;
}
/* Par défaut is-grid */
.cc-collection-hub.is-list .cc-tiles {
  grid-template-columns: 1fr;
}

.cc-collection-hub.is-list .cc-tile {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.cc-collection-hub.is-grid .cc-tiles {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}




/*-- 
MOBILE
---*/
@media (max-width: 600px) {
  .cc-results.cc-view-list .cc-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 960px) {
  .cc-tiles { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cc-view-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cc-collection-hubgrid { grid-template-columns: 1fr; }
  .cc-filters { grid-template-columns: 1fr; }
  .cc-view-toggle { justify-content: flex-start; }
}
