.sp-hidden { display: none !important; }
.spm-gallery-section { width: 100%; position: relative; padding: 20px 0;}
.spm-gallery-tabs-bar {
    display: flex; align-items: flex-end; gap: 0;
    margin-bottom: 0; padding-bottom: 0;
    position: sticky; top: 0; z-index: 100;
    background: transparent;
}
.spm-rect { height: 28px; width: auto; flex-shrink: 0; margin-right: 8px; }
.spm-tabs-list {
    display: flex;
    gap: 10px;
    align-items: flex-end;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    border-bottom: 1.5px solid #b7653f;
    flex-grow: 1;
    overflow-y: visible;
}
.spm-tabs-list::-webkit-scrollbar { display: none; }
.spm-tab-item {
    font-size: 18px;
    font-weight: 700;
    color: #b7653f;
    font-family: avenirNextBold, sans-serif;
    padding: 0 0 2px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: 0;
    transition: border-color 0.25s, opacity 0.2s;
    white-space: nowrap;
    letter-spacing: 0.3px;
    font-family: inherit;
    flex-shrink: 0;
    line-height: 1.75rem;
    overflow: visible;
}
.spm-tab-item:hover { opacity: 0.7; }
.spm-tab-item.active { border-bottom-color: #b7653f; }
.spm-tab-sub { font-size: 13px; font-weight: 400; color: #b7653f; margin-left: 4px; }
.spm-scroll-track {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 16px;
}
.spm-scroll-track::-webkit-scrollbar { display: none; }
.spm-tab-panel {
    flex: 0 0 calc(60vw - 40px);
    min-width: 0;
    box-sizing: border-box;
    padding: 24px 0 32px;
    overflow: hidden;
}
.spm-slider-wrap { position: relative;  width: calc(60vw - 40px); }
.spm-slides-viewport {
    overflow: hidden;
    width: 100%;
    border-radius: 0;
}
.spm-slides-inner {
    display: flex;
    transition: transform 0.4s ease;
}
.spm-slide-img {
    flex: 0 0 100%;
    min-width: 100%;
    cursor: pointer;
    overflow: hidden;
}
.spm-slide-img img {
    width: 100%;
    height: 500px;
    object-fit: cover;
    display: block;
    transition: opacity 0.2s;
    -webkit-user-drag: none;
    user-select: none;
}
.spm-slide-img:hover img { opacity: 0.92; }
.spm-slider-dots {
    display: flex; gap: 6px;
    justify-content: flex-start;
    padding: 10px 4px 0;
}
.spm-dot {
    width: 9px; height: 9px; border-radius: 50%; border: none;
    background: #D9B8A8; cursor: pointer; padding: 0;
    transition: background 0.2s;
}
.spm-dot.active { background: #5C2D0E; }
.spm-video-wrap { display: flex; justify-content: flex-start; }
.spm-video-wrap iframe {  width: calc(60vw - 40px);  border-radius: 4px; height: 500px;}
.spm-sp-section { width: 100%; }
/* .sp-year-bar {
    display: block; width: 100%; padding: 13px 20px; margin-bottom: 3px;
    text-align: center; font-size: 15px; font-weight: 700; letter-spacing: 3px;
    cursor: pointer; background-color: #D9B8A8; color: #5C2D0E;
    transition: background-color 0.2s; user-select: none; box-sizing: border-box;
} */
 .spm-sp-section {
    width: 100%;
}
.spm-year-tabs {
    display: flex;
    flex-direction: row;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.sp-year-bar {
    display: inline-block;
    width: auto;
    padding: 8px 24px;
    margin-bottom: 0;
    text-align: center;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 3px;
    cursor: pointer;
    background-color: #D9B8A8;
    color: #5C2D0E;
    transition: background-color 0.2s;
    user-select: none;
    box-sizing: border-box;
    border-radius: 4px;
}
.sp-year-bar.selected { background-color: #5C2D0E; color: #fff; }
.sp-year-bar:not(.selected):hover { background-color: #C4A090; }
.site-progress-wrapper-desktop {
    display: none; flex-wrap: wrap; gap: 18px 24px;
    padding: 20px 0 24px; width: 100%; box-sizing: border-box;
}
.site-progress-wrapper-desktop.selected { display: flex; }
.site-progress-wrapper-desktop.selected {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 16px;
}
/* .sp-month-block { min-width: 0; cursor: pointer; } */
.sp-month-block {
    width: 100%;
    min-width: 0;
    cursor: pointer;
}
/* .sp-img { width: 100%; aspect-ratio: 3/2; object-fit: cover; display: block; border-radius: 0px; transition: opacity 0.2s, transform 0.15s; border: 4px solid #fff;min-width: 268px; height: 154px; } */
.sp-img {
    width: 100%;
    height: auto;
    aspect-ratio: 3/2;
    object-fit: cover;
    display: block;
    border-radius: 0;
    border: 4px solid #fff;
    transition: opacity 0.2s, transform 0.15s;
}


.sp-month-block a:hover .sp-img { opacity: 0.85; transform: scale(1.03); }
.sp-month { margin-top: 8px; text-align: center; font-size: 14px; font-weight: 700; color: #000000; }
div#spm-panel-4 .sp-month-block {
    flex: 0 0 calc((100% - 5 * 24px) / 6);
    min-width: 0;
}
div#spm-panel-4 {
    flex: 0 0 calc(90vw - 40px);
}
div#spm-panel-4 .sp-month-block {
    flex: 0 0 calc((100% - 5 * 24px) / 6);
    min-width: 120px;
}
/* ── Horizontal scroll indicator / scrollbar ── */
.spm-scroll-track {
    scrollbar-width: thin;
    scrollbar-color: #5C2D0E #F5EDE4;
}
.spm-scroll-track::-webkit-scrollbar {
    display: block;
    height: 4px;
}
.spm-scroll-track::-webkit-scrollbar-track {
    background: #F5EDE4;
    border-radius: 2px;
}
.spm-scroll-track::-webkit-scrollbar-thumb {
    background: #5C2D0E;
    border-radius: 2px;
}
.spm-scroll-track::-webkit-scrollbar-thumb:hover {
    background: #8B5A3C;
}


/* ── Responsive ── */
@media (max-width: 768px) {
    .spm-year-tabs {
        flex-direction: column;
        gap: 3px;
    }
    .sp-year-bar {
        display: block;
        width: 100%;
        border-radius: 0;
    }
    /* .site-progress-wrapper-desktop.selected { flex-wrap: nowrap; overflow-x: auto; gap: 12px; grid-template-columns: 1fr 1fr; } */
    /* .sp-month-block { flex: 0 0 130px; } */
    div#spm-panel-4 .sp-month-block {
    flex: 0 0 calc((100% - 5 * 24px) / 6);
}
    .sp-img { width: 100%; height: auto; min-width: 100%;  }
.spm-video-wrap iframe {
    width: 100%;
}
.spm-tab-panel {
    flex: none;
    width: 100%;
    min-width: 100%;
}
.spm-slide-img img, .spm-video-wrap iframe {
    height: 200px;
}
.spm-slider-wrap {
    width: 100%;
}

}

body.spm-modal-open { overflow: hidden; }
#spm-lightbox { display: none; position: fixed; inset: 0; z-index: 99999; background: rgba(0,0,0,0.93); flex-direction: column; }
#spm-lightbox.active { display: flex; }
#spm-lb-topbar { display: flex; align-items: center; justify-content: space-between; padding: 12px 20px; flex-shrink: 0; }
#spm-lb-counter { color: #fff; font-size: 14px; opacity: 0.9; letter-spacing: 1px; }
#spm-lb-actions { display: flex; align-items: center; gap: 18px; }
#spm-lb-actions button { background: none; border: none; color: #fff; cursor: pointer; opacity: 0.75; transition: opacity 0.2s; padding: 0; }
#spm-lb-actions button:hover { opacity: 1; }
#spm-lb-main { flex: 1; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; min-height: 0; }
#spm-lb-img {width: auto; height: auto; max-height: 100%; max-width: 100%; object-fit: contain; display: block; user-select: none; -webkit-user-drag: none; transition: transform 0.2s; }
#spm-lb-caption { position: absolute; bottom: 0; left: 0; right: 0; text-align: center; color: #fff; font-size: 14px; padding: 10px 20px 14px; background: linear-gradient(transparent, rgba(0,0,0,0.55)); pointer-events: none; }
.spm-lb-arrow { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,0.08); border: none; color: #fff; width: 48px; height: 48px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 26px; transition: background 0.2s; z-index: 2; }
.spm-lb-arrow:hover { background: rgba(255,255,255,0.2); }
#spm-lb-prev { left: 16px; }
#spm-lb-next { right: 16px; }
#spm-lb-thumbs { flex-shrink: 0; display: flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 16px 14px; overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; scrollbar-width: none; background: rgba(0,0,0,0.4); }
#spm-lb-thumbs::-webkit-scrollbar { display: none; }
.spm-lb-thumb { flex-shrink: 0; width: 90px; height: 60px; object-fit: cover; display: block; cursor: pointer; opacity: 0.5; border: 2px solid transparent; border-radius: 2px; transition: opacity 0.2s, border-color 0.2s; }
.spm-lb-thumb.active { opacity: 1; border-color: #00d4d4; }
.spm-lb-thumb:hover { opacity: 0.85; }
@media (max-width: 600px) {
    .spm-lb-arrow { width: 36px; height: 36px; font-size: 18px; }
    .spm-lb-thumb { width: 64px; height: 42px; }
}

.site-progress-wrapper-desktop {
    display: none;
    width: 100%;
    padding: 20px 0 24px;
    box-sizing: border-box;
}

/* .site-progress-wrapper-desktop.selected {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
} */

.site-progress-wrapper-desktop.selected {
    display: grid;
    grid-template-columns: repeat(auto-fill, 268px);
    gap: 16px;
    justify-content: flex-start;
}
.sp-img {
    width: 268px;
    height: 154px;
    object-fit: cover;
    display: block;
}


/* Laptop */
@media (max-width: 1200px) {
  .site-progress-wrapper-desktop.selected {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Tablet */
@media (max-width: 992px) {
  .site-progress-wrapper-desktop.selected {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Mobile */
@media (max-width: 600px) {
  .site-progress-wrapper-desktop.selected {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Small Mobile */
@media (max-width: 400px) {
  .site-progress-wrapper-desktop.selected {
    grid-template-columns: 1fr;
  }
}