/* ============================================================
   MLC Photo Gallery  –  gallery.css
   ============================================================ */

/* ── Section wrapper ─────────────────────────────────────── */
.mlc-gallery-section {
    padding: 2.5rem 0 4rem;
    background: #f4f7fb;
    min-height: 60vh;
}

/* ── Controls bar ─────────────────────────────────────────── */
.mlc-gallery-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1.75rem;
}
.mlc-gallery-stat-text {
    font-size: .9rem;
    color: #6b7f99;
    font-weight: 500;
}
.mlc-gallery-filters {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}
.mlc-filter-group {
    display: flex;
    align-items: center;
    gap: .4rem;
}
.mlc-filter-label {
    font-size: .85rem;
    font-weight: 600;
    color: var(--mlc-navy);
    white-space: nowrap;
    margin: 0;
}
.mlc-filter-select,
.mlc-filter-input {
    height: 38px;
    padding: .3rem .85rem;
    border: 1.5px solid #c5d3e0;
    border-radius: 8px;
    background: #fff;
    color: var(--mlc-navy);
    font-size: .9rem;
    outline: none;
    transition: border-color .2s;
}
.mlc-filter-select:focus,
.mlc-filter-input:focus {
    border-color: var(--mlc-gold);
    box-shadow: 0 0 0 3px rgba(212,175,55,.18);
}
.mlc-filter-input { width: 200px; }

/* ── Events grid ─────────────────────────────────────────── */
.mlc-events-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}
@media (max-width: 1024px) { .mlc-events-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px)  { .mlc-events-grid { grid-template-columns: 1fr; gap: 1rem; } }

/* ── Event card ──────────────────────────────────────────── */
.mlc-event-card {
    background: #fff;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,30,80,.08);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    transition: transform .22s cubic-bezier(.34,1.56,.64,1), box-shadow .22s;
    /* entrance animation */
    opacity: 0;
    transform: translateY(24px);
}
.mlc-event-card.mlc-card-visible {
    opacity: 1;
    transform: translateY(0);
    transition: opacity .35s ease, transform .35s cubic-bezier(.34,1.3,.64,1), box-shadow .22s;
}
.mlc-event-card:hover,
.mlc-event-card:focus-visible {
    transform: translateY(-7px) scale(1.025);
    box-shadow: 0 14px 36px rgba(20,60,120,.14);
    outline: none;
}
.mlc-event-card:focus-visible { outline: 3px solid var(--mlc-gold); outline-offset: 2px; }

/* ── Card media area ─────────────────────────────────────── */
.mlc-card-media {
    position: relative;
    overflow: hidden;
    background: #e8edf4;
    flex-shrink: 0;
}

/* Single thumbnail */
.mlc-event-thumb {
    width: 100%;
    height: 210px;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.mlc-event-card:hover .mlc-event-thumb { transform: scale(1.06); }

/* ── Collage layouts ─────────────────────────────────────── */
.mlc-collage {
    display: grid;
    width: 100%;
    height: 210px;
    gap: 2px;
    overflow: hidden;
}
/* 1 photo – full */
.mlc-collage-1 { grid-template-columns: 1fr; }
/* 2 photos – side by side */
.mlc-collage-2 { grid-template-columns: 1fr 1fr; }
/* 3 photos – big left + two stacked right */
.mlc-collage-3 {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
}
.mlc-collage-3 .mlc-collage-img:first-child { grid-row: 1 / 3; }
/* 4 photos – 2×2 grid */
.mlc-collage-4 {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
}

.mlc-collage-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease, filter .3s;
}
.mlc-event-card:hover .mlc-collage-img { transform: scale(1.06); filter: brightness(1.05); }

/* ── Overlay ─────────────────────────────────────────────── */
.mlc-card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(10,25,60,.72) 0%, transparent 60%);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 1.1rem;
    opacity: 0;
    transition: opacity .25s;
}
.mlc-event-card:hover .mlc-card-overlay,
.mlc-event-card:focus-visible .mlc-card-overlay { opacity: 1; }
.mlc-view-btn {
    background: var(--mlc-gold);
    color: #1a1000;
    font-size: .82rem;
    font-weight: 700;
    border-radius: 20px;
    padding: .35rem 1rem;
    letter-spacing: .03em;
    box-shadow: 0 2px 10px rgba(0,0,0,.25);
    display: flex;
    align-items: center;
    gap: .4rem;
}

/* ── Photo count badge ───────────────────────────────────── */
.mlc-photo-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(10,25,60,.72);
    color: #fff;
    font-size: .75rem;
    font-weight: 700;
    border-radius: 20px;
    padding: .2rem .65rem;
    display: flex;
    align-items: center;
    gap: .3rem;
    backdrop-filter: blur(4px);
    pointer-events: none;
}

/* ── Card body ───────────────────────────────────────────── */
.mlc-card-body {
    padding: 1rem 1.1rem .95rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    flex: 1;
}
.mlc-card-title {
    font-size: .98rem;
    font-weight: 700;
    color: var(--mlc-navy);
    margin: 0;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.mlc-card-date {
    font-size: .82rem;
    color: #7a8fa8;
    display: flex;
    align-items: center;
    gap: .35rem;
}

/* ── Skeleton loaders ────────────────────────────────────── */
.mlc-skeleton-card { pointer-events: none; }
.mlc-skeleton {
    background: linear-gradient(90deg, #e4eaf2 25%, #f0f4f8 50%, #e4eaf2 75%);
    background-size: 200% 100%;
    animation: mlcSkeleton 1.5s infinite;
    border-radius: 6px;
}
@keyframes mlcSkeleton {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}
.mlc-skeleton-img   { height: 210px; border-radius: 0; }
.mlc-skeleton-title { height: 16px; width: 80%; margin: 1rem 1rem .5rem; }
.mlc-skeleton-date  { height: 12px; width: 45%; margin: 0 1rem 1rem; }

/* ── Empty state ─────────────────────────────────────────── */
.mlc-gallery-empty {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 4rem 1rem;
    color: #8fa3bc;
    text-align: center;
}
.mlc-gallery-empty i { font-size: 3rem; }
.mlc-gallery-empty p { font-size: 1.05rem; margin: 0; }

/* ── Pagination ──────────────────────────────────────────── */
.mlc-gallery-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}
.mlc-page-numbers {
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-wrap: wrap;
}
.mlc-page-btn {
    min-width: 38px;
    height: 38px;
    border: 1.5px solid #c5d3e0;
    background: #fff;
    color: var(--mlc-navy);
    font-size: .88rem;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    padding: 0 .7rem;
    transition: background .18s, border-color .18s, color .18s, transform .15s;
    display: flex;
    align-items: center;
    gap: .25rem;
}
.mlc-page-btn:hover:not(:disabled):not(.mlc-page-btn-active) {
    background: var(--mlc-navy);
    border-color: var(--mlc-navy);
    color: #fff;
    transform: scale(1.06);
}
.mlc-page-btn-active {
    background: var(--mlc-gold);
    border-color: var(--mlc-gold);
    color: #1a1000;
    pointer-events: none;
    box-shadow: 0 2px 8px rgba(212,175,55,.35);
}
.mlc-page-btn-nav { padding: 0 1rem; min-width: 80px; }
.mlc-page-btn:disabled { opacity: .4; cursor: not-allowed; }
.mlc-page-ellipsis { font-size: .95rem; color: #8fa3bc; padding: 0 .2rem; line-height: 38px; }

/* ── GLightbox extra caption styling ─────────────────────── */
.glightbox-event-name { font-weight: 700; color: #fff; }
.glightbox-date { color: #d4af37; }

/* ── Lazy image fade-in ──────────────────────────────────── */
.mlc-lazy {
    opacity: 0;
    transition: opacity .4s ease;
    background: #e4eaf2;
}
.mlc-img-loaded {
    opacity: 1;
}

/* ── Responsive controls ─────────────────────────────────── */
@media (max-width: 640px) {
    .mlc-gallery-controls { flex-direction: column; align-items: flex-start; }
    .mlc-filter-input { width: 150px; }
    .mlc-gallery-section { padding: 1.5rem 0 3rem; }
}
