/* ── Section shell ── */
#gallery { background: var(--navy-2); padding: 0; overflow: hidden; }

/* ══ SLIDERS BLOCK ══════════════════════════════════════════════════ */
.gal-sliders {
  padding: 3rem 0 2.5rem;
}
.gal-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.gal-header {
  text-align: center;
  margin-bottom: 2rem;
}

/* Swipeable slider carousel ── one visible at a time on mobile */
.slider-carousel-outer {
  position: relative;
  margin: 0 -1.5rem;
  max-width: calc(100% + 3rem);
}
.slider-carousel-track {
  display: flex;
  gap: 1.25rem;
  padding: 0 1.5rem 1rem;
  transition: transform .42s cubic-bezier(.22,1,.36,1);
  will-change: transform;
}
.slider-carousel-track.no-snap { transition: none; }
.slider-carousel-wrap {
  overflow: hidden;
  cursor: grab;
  padding-bottom: .5rem;
}
.slider-carousel-wrap.dragging { cursor: grabbing; }

/* Each slider card */
.slider-card {
  flex: 0 0 calc(50% - .625rem);
  display: flex;
  flex-direction: column;
  gap: .75rem;
  min-width: 0;
}
@media (max-width: 660px) {
  .slider-card { flex: 0 0 calc(100% - 3rem); }
}

/* Drag hint */
.slider-drag-hint {
  font-family: var(--font-ui);
  font-size: .58rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
  text-align: center;
  opacity: .75;
}

/* The comparison wrap */
.ba-wrap {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  cursor: ew-resize;
  user-select: none;
  -webkit-user-select: none;
  border: 1px solid rgba(200,168,75,.15);
  box-shadow: 0 16px 48px rgba(0,0,0,.5);
  aspect-ratio: 4 / 3;
}
.ba-wrap img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ba-after {
  position: absolute;
  inset: 0;
  overflow: hidden;
  width: 50%;
  transition: none;
}
.ba-after img {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.ba-divider {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 2px;
  background: linear-gradient(180deg, var(--gold), var(--gold-light));
  transform: translateX(-50%);
  z-index: 10;
}
.ba-handle {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--gold);
  border: 3px solid #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .85rem;
  font-weight: 900;
  color: #0a1a0a;
  box-shadow: 0 4px 20px rgba(0,0,0,.5);
  pointer-events: none;
  letter-spacing: -.05em;
}
.ba-label {
  position: absolute;
  bottom: .75rem;
  font-family: var(--font-ui);
  font-size: .55rem;
  letter-spacing: .2em;
  font-weight: 700;
  padding: .22rem .7rem;
  border-radius: 4px;
  text-transform: uppercase;
  z-index: 5;
}
.ba-label-before { left: .75rem; background: rgba(210,40,40,.85); color: #fff; }
.ba-label-after  { right: .75rem; background: rgba(22,163,74,.85); color: #fff; }

/* Slider caption */
.slider-caption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 .25rem;
}
.slider-caption-service {
  font-family: var(--font-ui);
  font-size: .78rem;
  color: var(--silver-dim);
  font-weight: 500;
}
.slider-caption-price {
  font-family: var(--font-ui);
  font-size: .75rem;
  color: var(--gold);
  font-weight: 700;
}

/* Prev/next arrows */
.slider-arrows {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin-top: 1.5rem;
}
.slider-arrow {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(200,168,75,.3);
  background: rgba(10,24,37,.88);
  color: var(--gold);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .2s, border-color .2s;
}
.slider-arrow:hover {
  background: rgba(200,168,75,.15);
  border-color: rgba(200,168,75,.6);
}
.slider-arrow:disabled { opacity: .25; pointer-events: none; }

/* Dots */
.slider-dots {
  display: flex;
  justify-content: center;
  gap: .45rem;
  margin-top: .75rem;
}
.slider-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(200,168,75,.22);
  border: none; cursor: pointer; padding: 0;
  transition: background .25s, transform .25s;
}
.slider-dot.active {
  background: var(--gold);
  transform: scale(1.5);
}

/* Geo line */
.gal-geo {
  text-align: center;
  font-family: var(--font-ui);
  font-size: .74rem;
  color: var(--silver-muted);
  margin-top: 1.75rem;
  padding: 0 1.5rem;
}

/* ══ GOLD DIVIDER ══════════════════════════════════════════════════ */
.gal-rule {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,168,75,.2) 30%, rgba(200,168,75,.2) 70%, transparent);
  margin: 0;
}

/* ══ PHOTO GRID BLOCK ══════════════════════════════════════════════ */
.gal-grid-block {
  background: var(--navy-3);
  padding: 2.5rem 0 0;
}
.gal-grid-header {
  text-align: center;
  margin-bottom: 2rem;
  padding: 0 1.5rem;
}
.gal-grid-sub {
  font-family: var(--font-ui);
  font-size: .8rem;
  color: var(--silver-muted);
  margin-top: .5rem;
}

/* Filter pills */
.gal-filters {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: .4rem;
  padding: 0 1.5rem 1.25rem;
}
.gal-filter-btn {
  font-family: var(--font-ui);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 600;
  padding: .44rem 1rem;
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,.08);
  color: var(--silver-muted);
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(20px);
  cursor: pointer;
  transition: all .22s;
  min-height: 36px;
}
.gal-filter-btn:hover { color: var(--gold); border-color: rgba(200,168,75,.3); }
.gal-filter-btn.active {
  background: rgba(200,168,75,.12);
  border-color: rgba(200,168,75,.5);
  color: var(--gold-light);
}

/* The grid — masonry-like 3-col with no gap */
.gal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
}
@media (max-width: 480px) {
  .gal-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Grid item */
.gi {
  position: relative;
  overflow: hidden;
  height: 240px;
  cursor: pointer;
}
.gi.gi-tall { height: 320px; }
.gi img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .7s cubic-bezier(.22,1,.36,1), filter .4s;
  filter: brightness(.88) saturate(.9);
}
.gi:hover img {
  transform: scale(1.06);
  filter: brightness(1.05) saturate(1.08);
}
.gi-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(transparent 45%, rgba(2,6,12,.92));
  opacity: 0;
  transition: opacity .32s;
}
.gi:hover .gi-overlay { opacity: 1; }
.gi-label {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: .9rem .85rem .75rem;
  transform: translateY(5px);
  transition: transform .32s cubic-bezier(.22,1,.36,1);
}
.gi:hover .gi-label { transform: none; }
.gi-name {
  font-family: var(--font-display);
  font-size: .82rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: .1rem;
}
.gi-tag {
  font-family: var(--font-ui);
  font-size: .55rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gold-light);
}
.gi-badge {
  position: absolute;
  top: .6rem; left: .6rem;
  font-family: var(--font-ui);
  font-size: .5rem;
  font-weight: 700;
  letter-spacing: .18em;
  padding: .18rem .55rem;
  border-radius: 4px;
  text-transform: uppercase;
  z-index: 3;
}
.gi-badge-before { background: rgba(210,40,40,.88); color: #fff; }

/* Hidden items (filtered out) */
.gi.hidden { display: none; }

/* ── Gallery CTA ── */
.gal-cta-block {
  text-align: center;
  padding: 3rem 1.5rem 4rem;
  background: var(--navy-3);
}
.gal-cta-text {
  font-family: var(--font-ui);
  font-size: .82rem;
  color: var(--silver-muted);
  margin-bottom: 1.25rem;
  line-height: 1.6;
}
.gal-social-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: .45rem;
  margin-top: 1.1rem;
}
.gal-social-link {
  font-family: var(--font-ui);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--silver-muted);
  text-decoration: none;
  padding: .34rem .85rem;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 50px;
  transition: color .2s, border-color .2s;
}
.gal-social-link:hover { color: var(--gold); border-color: rgba(200,168,75,.3); }

/* ── Video block ── */
.gal-vid-block {
  background: var(--navy-2);
  border-top: 1px solid rgba(200,168,75,.08);
  padding: 4.5rem 1.5rem 5rem;
}
.gal-vid-inner {
  max-width: 1100px;
  margin: 0 auto;
}
.gal-vid-header {
  text-align: center;
  margin-bottom: 2.5rem;
}
.vid-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
@media (max-width: 700px) {
  .vid-grid { grid-template-columns: 1fr; }
}
.vid-card {
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: rgba(13,30,46,.8);
  border: 1px solid rgba(197,210,220,.08);
}
.vid-wrap {
  position: relative;
  cursor: pointer;
}
.vid-wrap video {
  display: block;
  width: 100%;
  height: 220px;
  object-fit: cover;
}
.vid-play-btn {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(200,168,75,.92);
  border: 3px solid rgba(255,255,255,.85);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  pointer-events: none;
  transition: transform .25s, background .25s;
}
.vid-wrap:hover .vid-play-btn {
  transform: translate(-50%,-50%) scale(1.08);
  background: var(--gold-light);
}
.vid-title-bar {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: .5rem .8rem;
  background: linear-gradient(transparent, rgba(2,6,12,.75));
  font-family: var(--font-ui);
  font-size: .58rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold-light);
}
.vid-card-footer {
  padding: .8rem 1rem;
  border-top: 1px solid rgba(197,210,220,.07);
}
.vid-card-title {
  font-family: var(--font-accent);
  font-size: .72rem;
  color: #f0cc6a;
  letter-spacing: .06em;
  margin-bottom: .12rem;
}
.vid-card-sub {
  font-size: .62rem;
  color: var(--silver-muted);
  letter-spacing: .1em;
  text-transform: uppercase;
}
