/* ===== Collateral (consolidated) ==================================== */
/* Layout */
.cm-wrap{max-width:1200px;margin:0 auto;padding:16px}
.cm-page-title{margin:0 0 12px;font-weight:600}

/* Filters grid */
.cm-filters{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:8px 0 20px}

/* Theme banner */
.cm-theme-banner{
  grid-column:1 / -1;display:grid;grid-template-columns:1fr 340px;gap:16px;
  align-items:center;background:#01253B;color:#fff;border-radius:10px;padding:12px 14px
}
.cm-theme-text{font-weight:700;line-height:1.35;color:#fff}

/* Multiselect control container */
.cm-theme-control.cm-theme-multi{
  position:relative;justify-self:end;width:100%;max-width:340px;min-width:240px;color:#fff
}

/* Button that opens the multiselect */
.cm-ms-btn{
  width:100%;text-align:left;background:#01253B;color:#fff;border:1.5px solid rgba(255,255,255,.7);
  border-radius:8px;padding:8px 34px 8px 10px;cursor:pointer;position:relative
}
.cm-ms-btn::after{
  content:"";position:absolute;right:10px;top:50%;width:14px;height:14px;margin-top:-7px;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-size:14px;transition:transform 150ms ease
}
.cm-ms-btn[aria-expanded="true"]::after{transform:rotate(180deg)}

/* Multiselect panel (single definition) */
.cm-ms-panel{
  position:absolute;z-index:30;right:0;left:auto;margin-top:6px;width:100%;max-width:420px;
  background:#fff;color:#01253B;border:1px solid #e5e7eb;border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);padding:0;display:none;max-height:360px;overflow:auto
}
.cm-ms-panel.open{display:block}
.cm-ms-toolbar{position:sticky;top:0;z-index:1;display:flex;gap:10px;align-items:center;padding:8px;background:#fff;border-bottom:1px solid #f0f2f4}
.cm-ms-search{flex:1 1 auto;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px}
.cm-ms-actions{white-space:nowrap;font-size:.9rem;color:#4b5563}
.cm-ms-actions .button-link{background:none;border:0;color:#2563eb;cursor:pointer;padding:0}
.cm-ms-actions .button-link:hover{text-decoration:underline}
.cm-ms-sep{margin:0 6px;color:#9ca3af}
.cm-ms-all-row{padding:8px 10px;border-bottom:1px solid #f3f4f6;margin:0}
.cm-ms-list{padding:8px;column-width:260px;column-gap:12px}
.cm-ms-option{break-inside:avoid;display:flex;align-items:center;gap:8px;padding:6px;border-radius:6px;cursor:pointer}
.cm-ms-option:hover{background:#f3f4f6}
.cm-ms-option input{accent-color:#01253B}
.cm-ms-empty{padding:16px;text-align:center;color:#6b7280}

/* “Inline checkbox” filter groups */
.cm-filters-row{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:12px}
.cm-filter.cm-filter-group{display:flex;flex-direction:column}
.cm-group-label{font-weight:600;color:#01253B;margin-bottom:6px}
.cm-checks{display:flex;flex-wrap:wrap;gap:10px 16px}
.cm-check{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;user-select:none}
.cm-check:hover{background:#f7fafc}
.cm-check input{accent-color:#01253B}

/* Reset button */
.cm-filters .cm-reset.button{
  background:#01253B;color:#fff;border:0;border-radius:8px;padding:8px 14px;line-height:1.2;
  font-weight:600;cursor:pointer;transition:background 160ms ease,transform 60ms ease;width:100px;margin-top:auto
}
.cm-filters .cm-reset.button:hover{background:#07324f}
.cm-filters .cm-reset.button:active{background:#001a2a;transform:translateY(1px)}
.cm-filters .cm-reset.button:focus-visible{outline:2px solid #7cc4ff;outline-offset:2px}
.cm-filters .cm-reset.button:disabled{background:#8093a0;color:#e7eef3;cursor:not-allowed;opacity:.8}

/* Chips under banner */
.cm-theme-chips{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}
.cm-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#e6f2ff;color:#0b3a66;border:1px solid #cfe4ff;cursor:pointer}
.cm-chip svg{width:14px;height:14px}
.cm-chip:hover{background:#d9ecff}

/* Cards grid */
#cm-grid.cm-loading{opacity:.55;pointer-events:none}
.cm-grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:16px}
.cm-card{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff;display:flex;flex-direction:column;height:100%}
.cm-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid #e5e7eb;background:#f7fafc}
.cm-logo img{display:block;height:28px;max-width:160px;object-fit:contain}
.cm-type{font-size:.9rem;opacity:.85;text-transform:uppercase;font-weight:600}
.cm-media{position:relative;aspect-ratio:16/9;background:#f3f4f6}
.cm-media img,.cm-media iframe{width:100%;height:100%;object-fit:cover;display:block}
.cm-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#6b7280}
.cm-card-footer{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-top:1px solid #e5e7eb;background:#fafafa}
.cm-month{font-size:.9rem;color:#374151}
.cm-download.button{text-decoration:none}
.cm-pagination{margin:20px 0}
.cm-pagination ul{display:flex;flex-wrap:wrap;gap:6px;list-style:none;padding:0}
.cm-pagination a,.cm-pagination span{display:inline-block;padding:6px 10px;border:1px solid #e5e7eb;border-radius:4px}
.cm-title{margin:10px 12px 0;font-size:1.05rem;font-weight:600;line-height:1.35;color:#80C342}

/* Description clamp + toggle (single variant uses .is-open) */
.cm-desc{
  position:relative;background:#01253B;color:#fff;padding:12px 14px;
  line-height:1.5;font-size:.95rem;flex:1 1 auto;
}
.cm-desc.has-toggle{
  overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:6;max-height:none
}
.cm-desc.has-toggle::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:40px;
  background:linear-gradient(180deg, rgba(1,37,59,0) 0%, rgba(1,37,59,.85) 60%, rgba(1,37,59,1) 100%);
  pointer-events:none
}
.cm-desc.has-toggle.is-open{display:block;-webkit-line-clamp:unset;overflow:visible}
.cm-desc.has-toggle.is-open::after{display:none}

.cm-desc-toggle{background:#01253B;padding:6px 14px 10px;margin-top:0}
.cm-desc-toggle .cm-toggle-desc{
  background:transparent;color:#fff;border:1px solid rgba(255,255,255,.6);
  border-radius:999px;padding:4px 10px;font-size:.85rem;line-height:1.2;cursor:pointer
}
.cm-desc-toggle .cm-toggle-desc:hover{border-color:#fff}
.cm-desc-toggle .cm-toggle-desc:focus-visible{outline:2px solid #7cc4ff;outline-offset:2px}

/* Native select (only used where you still use a <select>) */
.cm-theme-control select{
  color:#fff !important;background:#01253B;border:1.5px solid rgba(255,255,255,.7);
  border-radius:8px;padding:8px 34px 8px 20px;appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;background-size:14px
}
.cm-theme-control select:hover{border-color:#fff}
.cm-theme-control select:focus{border-color:#fff;outline:0}
.cm-theme-control select option{background:#01253B;color:#fff}
.cm-theme-control select::-ms-expand{display:none}

/* Responsive */
@media (max-width:1100px){
  .cm-theme-banner{grid-template-columns:1fr 300px}
  .cm-theme-control.cm-theme-multi{max-width:300px;min-width:220px}
}
@media (max-width:860px){
  .cm-theme-banner{grid-template-columns:1fr 260px}
  .cm-theme-control.cm-theme-multi{max-width:260px;min-width:200px}
}
@media (max-width:720px){
  .cm-filters{grid-template-columns:1fr}
  .cm-filters-row{grid-template-columns:1fr}
}
@media (max-width:680px){
  .cm-theme-banner{grid-template-columns:1fr}
  .cm-theme-control.cm-theme-multi{justify-self:stretch;max-width:none;min-width:0}
  .cm-ms-panel{right:0;left:0;max-width:none;width:100%}
}
