*{
  box-sizing:border-box;
}

/* ======================
   GRID
====================== */
.bag-grid{
  display:grid;
  gap:30px;
}

.bag-cols-2{
  grid-template-columns:repeat(2,1fr);
}

.bag-cols-3{
  grid-template-columns:repeat(3,1fr);
}

/* ======================
   CONTAINER
====================== */
.bag-container{
  position:relative;
  width:100%;
  height:480px;                 /* stable height for mixed images */
  overflow:hidden;
  border-radius:16px;
  background:#eaeaea;
}

/* ======================
   IMAGES
====================== */
.bag-img{
  position:absolute;
  inset:0;
  background-size:cover;        /* IMPORTANT: same scale for both */
  background-position:center;
  background-repeat:no-repeat;
}

/* BEFORE image mask */
.bag-fg{
  width:50%;
  overflow:hidden;
  z-index:2;
}

/* ======================
   RANGE SLIDER (INVISIBLE CONTROLLER)
====================== */
.bag-slider{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  appearance:none;
  -webkit-appearance:none;
  background:transparent;
  cursor:ew-resize;
  z-index:10;
}

/* Hide default track */
.bag-slider::-webkit-slider-runnable-track{
  background:transparent;
}
.bag-slider::-moz-range-track{
  background:transparent;
}

/* Hide thumb (we use custom divider) */
.bag-slider::-webkit-slider-thumb{
  appearance:none;
  width:1px;
  height:100%;
  background:transparent;
}
.bag-slider::-moz-range-thumb{
  width:1px;
  height:100%;
  background:transparent;
}

/* ======================
   CENTER DIVIDER LINE
====================== */
.bag-divider{
  position:absolute;
  top:0;
  bottom:0;
  width:4px;
  background:#fff;
  left:50%;
  transform:translateX(-50%);
  z-index:9;
  box-shadow:0 0 0 1px rgba(0,0,0,.25);
}

/* ======================
   CENTER BUTTON
====================== */
.bag-slider-btn{
  pointer-events:none;
  position:absolute;
  top:50%;
  left:50%;
  width:34px;
  height:34px;
  background:#fff;
  border-radius:50%;
  transform:translate(-50%,-50%);
  box-shadow:0 2px 8px rgba(0,0,0,.25);
  z-index:11;
}

/* arrows */
.bag-slider-btn:before,
.bag-slider-btn:after{
  content:'';
  position:absolute;
  top:50%;
  width:7px;
  height:7px;
  border:solid #444;
  border-width:0 2px 2px 0;
}
.bag-load-wrap {
    text-align: center;
    padding: 26px;
}
button.bag-load-more {
    padding: 15px 40px 15px 40px;
    background-color: #65B401;
    border: none;
    border-radius: 50px;
    color: #fff;
    font-size: 16px;
    font-weight: 900;
}
.bag-slider-btn:before{
  left:10px;
  transform:rotate(135deg) translateY(-50%);
}

.bag-slider-btn:after{
  right:10px;
  transform:rotate(-45deg) translateY(-50%);
}
h2.bag-location-title {
    margin-top: 25px;
}
/* ===== Before / After Labels ===== */
.bag-container:before,
.bag-container:after{
  position:absolute;
  top:14px;
  padding:6px 14px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:#fff;
  background:#65B401;
  border-radius:20px;
  z-index:12;
  pointer-events:none;
}

/* BEFORE label (left side) */
.bag-container:before{
  content:"Before";
  left:14px;
}

/* AFTER label (right side) */
.bag-container:after{
  content:"After";
  right:14px;
}

/* ===== Load More Animation ===== */
.bag-item{
  opacity:1;
  transform:translateY(0);
  transition:opacity .4s ease, transform .4s ease;
}

.bag-item.is-loading{
  opacity:0;
  transform:translateY(20px);
}
/* ======================
   LOAD MORE WRAPPER
====================== */
.bag-load-wrap{
  margin-top:40px;
  text-align:center;
  position:relative;
}

/* LOAD MORE BUTTON */
.bag-load-more{
  padding:12px 28px;
  border-radius:40px;
  border:0;
  cursor:pointer;
  font-size:15px;
  font-weight:600;
  background:#65B401;
  color:#fff;
  transition:.25s ease;
}

.bag-load-more:hover{
  background:#549800;
  transform:translateY(-2px);
}

/* ======================
   LOADER (GIF)
====================== */
.bag-loader{
  width:60px;
  height:60px;
  margin:25px auto 0;
  display:none;
  background-image:url('/wp-content/uploads/2026/02/loader.gif');
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
}

/* ======================
   RESPONSIVE
====================== */
@media (max-width: 1024px){
  .bag-container{
    height:420px;
  }
}

@media (max-width: 768px){
  .bag-grid{
    grid-template-columns:1fr !important;
  }

  .bag-container{
    height:360px;
  }
}


/* =============================
   ZOOM ICON AUTO INSERT STYLE
============================= */

.bag-container {
  position: relative;
}

.bag-zoom-icon {
  position: absolute;
  top: 10px;
  right: 95px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: 0.3s ease;
  z-index: 10;
}

.bag-zoom-icon svg {
  width: 18px;
  height: 18px;
  fill: #fff;
}

.bag-container:hover .bag-zoom-icon {
  opacity: 1;
}

/* =============================
   MODAL
============================= */

.bag-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.9);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bag-modal-inner {
  width: 90%;
  max-width: 1100px;
  position: relative;
}

.bag-modal-close {
  position: absolute;
  top: -45px;
  right: 0;
  font-size: 36px;
  color: #fff;
  cursor: pointer;
}

.bag-modal .bag-container {
  height: 600px;
}

/* =============================
   SPLIT MODAL STYLE
============================= */

.bag-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bag-modal-inner {
  width: 95%;
  max-width: 1200px;
  position: relative;
}

.bag-modal-close {
  position: absolute;
  top: -45px;
  right: 0;
  font-size: 36px;
  color: #fff;
  cursor: pointer;
}

.bag-modal-split {
  display: flex;
  gap: 20px;
}

.bag-modal-col {
  flex: 1;
  text-align: center;
}

.bag-modal-col h3 {
  color: #fff;
  margin-bottom: 15px;
}

.bag-modal-image {
  width: 100%;
  height: 650px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #000;
}

/* Responsive */
@media (max-width: 768px) {
  .bag-modal-split {
    flex-direction: column;
  }

  .bag-modal-image {
    height: 350px;
  }
}

/* =============================
   TAG FILTER
============================= */
.bag-tag-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 14px;
}

.bag-tag-filter-btn {
  border: 1px solid #d0d4d9;
  background: #fff;
  color: #1f2937;
  padding: 8px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
}

.bag-tag-filter-btn.active {
  background: #6fd000;
  border-color: #6fd000;
  color: #fff;
}

.bag-tag-filter-select-wrap {
  margin: 0 0 18px;
}

.bag-tag-filter-select {
  min-width: 220px;
  padding: 8px 12px;
  border: 1px solid #d0d4d9;
  border-radius: 6px;
  background: #fff;
}

.bag-tag-filter-select-wrap {
    display: none;
}
.bag-tag-filters button {background: transparent;color: #65B401;border: 1px solid #65B401;border-radius: 26px;}
.bag-tag-filters button:hover {background: #000 !important;border: 1px solid #fff;}
.bag-tag-filters button:focus {background: #65B401;}

.bag-no-results {
  margin: 8px 0 0;
  padding: 12px 14px;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  background: #f9fafb;
  color: #374151;
}

.bag-filter-loader {
  margin: 10px auto 16px;
}
