/* =========================================================
   Alumot — Gallery (Watercolor edition)
   Multi-view: Grid (block-color cards) / Masonry / List / Carousel
   ========================================================= */

.gallery-controls {
  position: sticky;
  top: var(--header-h);
  z-index: 50;
  background: rgba(252, 250, 245, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding-block: var(--space-6);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-12);
}
.gallery-controls-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.view-switcher {
  display: inline-flex;
  background: var(--color-cream-100);
  border-radius: var(--radius-pill);
  padding: 4px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}
.view-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-pill);
  color: var(--text-muted);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  transition: all var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}
.view-btn svg { width: 18px; height: 18px; }
.view-btn:hover { color: var(--text); }
.view-btn[aria-pressed="true"] {
  background: var(--color-sage-300);
  color: var(--color-ink-900);
  box-shadow: var(--shadow-sm);
}

.filter-chips {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.chip {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-pill);
  background: var(--color-cream-100);
  border: 1px solid var(--border);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-body);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}
.chip:hover { border-color: var(--color-sage-300); color: var(--text); }
.chip[aria-pressed="true"] {
  background: var(--color-sage-300);
  border-color: var(--color-sage-300);
  color: var(--color-ink-900);
}

/* Gallery item admin delete button (shared) */
.gallery-item .admin-delete,
.gallery-row .admin-delete {
  display: none;
  position: absolute;
  inset-inline-start: var(--space-3);
  top: var(--space-3);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(176, 112, 112, 0.95);
  color: var(--color-white);
  align-items: center;
  justify-content: center;
  z-index: 10;
  border: none;
  cursor: pointer;
}
.gallery-item .admin-delete:hover,
.gallery-row .admin-delete:hover { background: #B07070; transform: scale(1.08); }
body.admin-mode .gallery-item .admin-delete,
body.admin-mode .gallery-row .admin-delete { display: inline-flex; }

body.admin-mode .gallery-item,
body.admin-mode .gallery-row { position: relative; }

body.admin-mode .gallery-item::after {
  content: '✎ לחץ לעריכה';
  position: absolute;
  inset-inline-end: var(--space-3);
  top: var(--space-3);
  background: var(--color-sage-300);
  color: var(--color-ink-900);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: var(--font-medium);
  letter-spacing: 0.05em;
  z-index: 5;
  box-shadow: var(--shadow-sm);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--duration-fast) var(--ease-out);
}
body.admin-mode .gallery-item:hover::after { opacity: 1; }

/* ---------- Grid view (block-color card style from reference) ---------- */
.gallery[data-view="grid"] .gallery-list { display: none; }
.gallery[data-view="grid"] .gallery-stage {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: var(--space-6);
}
.gallery[data-view="grid"] .gallery-item {
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  background: var(--color-cream-100);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: all var(--duration-base) var(--ease-out);
  min-height: 220px;
}
.gallery[data-view="grid"] .gallery-item:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-card);
  border-color: var(--color-sage-300);
}
.gallery[data-view="grid"] .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}
.gallery[data-view="grid"] .gallery-item:hover img { transform: scale(1.04); }

/* Image side */
.gallery[data-view="grid"] .gallery-item-img {
  background: var(--color-cream-200);
  overflow: hidden;
}

/* Color block side - rotates by category */
.gallery[data-view="grid"] .gallery-meta {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-2);
  background: var(--color-sage-200);
  color: var(--color-ink-900);
}
.gallery[data-view="grid"] .gallery-item[data-category="residential"] .gallery-meta { background: var(--color-blue-200); }
.gallery[data-view="grid"] .gallery-item[data-category="boutique"] .gallery-meta { background: var(--color-sage-200); }
.gallery[data-view="grid"] .gallery-item[data-category="urban-renewal"] .gallery-meta { background: var(--color-sand-200); }
.gallery[data-view="grid"] .gallery-item[data-category="commercial"] .gallery-meta { background: var(--color-cream-200); }
.gallery[data-view="grid"] .gallery-item[data-category="preservation"] .gallery-meta { background: var(--color-rose-200); }

.gallery[data-view="grid"] .gallery-meta h3 {
  color: var(--color-ink-900);
  font-size: var(--text-xl);
  font-weight: var(--font-regular);
  margin-bottom: var(--space-2);
  font-family: var(--font-display);
}
.gallery[data-view="grid"] .gallery-meta-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-ink-700);
}
.gallery[data-view="grid"] .gallery-meta-row span {
  display: inline-flex;
  gap: var(--space-2);
}
.gallery[data-view="grid"] .gallery-meta-row .label {
  font-weight: var(--font-medium);
  color: var(--color-ink-900);
}

@media (max-width: 480px) {
  .gallery[data-view="grid"] .gallery-item {
    grid-template-columns: 1fr;
    grid-template-rows: 200px auto;
  }
}

/* ---------- Masonry / Collage view ---------- */
.gallery[data-view="masonry"] .gallery-list { display: none; }
.gallery[data-view="masonry"] .gallery-stage {
  columns: 3 280px;
  column-gap: var(--space-6);
  display: block;
}
.gallery[data-view="masonry"] .gallery-item {
  break-inside: avoid;
  margin-bottom: var(--space-6);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-cream-100);
  position: relative !important;
  cursor: pointer;
  transition: all var(--duration-base) var(--ease-out);
  display: block;
  grid-template-columns: none;
  border: 1px solid var(--border);
}
.gallery[data-view="masonry"] .gallery-item-img {
  display: block;
  background: none;
}
.gallery[data-view="masonry"] .gallery-item:nth-child(3n) .gallery-item-img { aspect-ratio: 3/4; }
.gallery[data-view="masonry"] .gallery-item:nth-child(3n+1) .gallery-item-img { aspect-ratio: 4/3; }
.gallery[data-view="masonry"] .gallery-item:nth-child(3n+2) .gallery-item-img { aspect-ratio: 1/1; }
.gallery[data-view="masonry"] .gallery-item-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}
.gallery[data-view="masonry"] .gallery-item:hover {
  box-shadow: var(--shadow-card);
  transform: scale(1.005);
}
.gallery[data-view="masonry"] .gallery-item:hover img { transform: scale(1.04); }
.gallery[data-view="masonry"] .gallery-meta {
  padding: var(--space-4);
  background: var(--color-sage-200);
}
.gallery[data-view="masonry"] .gallery-item[data-category="residential"] .gallery-meta { background: var(--color-blue-200); }
.gallery[data-view="masonry"] .gallery-item[data-category="urban-renewal"] .gallery-meta { background: var(--color-sand-200); }
.gallery[data-view="masonry"] .gallery-item[data-category="commercial"] .gallery-meta { background: var(--color-cream-200); }
.gallery[data-view="masonry"] .gallery-item[data-category="preservation"] .gallery-meta { background: var(--color-rose-200); }

.gallery[data-view="masonry"] .gallery-meta h3 {
  color: var(--color-ink-900);
  font-size: var(--text-lg);
  font-weight: var(--font-regular);
  font-family: var(--font-display);
  margin-bottom: var(--space-1);
}
.gallery[data-view="masonry"] .gallery-meta-row {
  font-size: var(--text-xs);
  color: var(--color-ink-700);
  display: flex;
  gap: var(--space-2);
}

/* ---------- List view ---------- */
.gallery[data-view="list"] .gallery-stage { display: none; }
.gallery[data-view="list"] .gallery-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.gallery[data-view="list"] .gallery-row {
  display: grid;
  grid-template-columns: 240px 1fr auto;
  gap: var(--space-6);
  align-items: center;
  padding: var(--space-4);
  background: var(--color-cream-100);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--duration-base) var(--ease-out);
}
.gallery[data-view="list"] .gallery-row:hover {
  box-shadow: var(--shadow-card);
  border-color: var(--color-sage-300);
  transform: translateX(-4px);
}
.gallery[data-view="list"] .gallery-row-img {
  aspect-ratio: 16/10;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.gallery[data-view="list"] .gallery-row-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gallery[data-view="list"] .gallery-row-meta h3 {
  font-size: var(--text-2xl);
  font-weight: var(--font-light);
  margin-bottom: var(--space-2);
  font-family: var(--font-display);
}
.gallery[data-view="list"] .gallery-row-meta-tags {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}
.gallery[data-view="list"] .tag {
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-sage-700);
  font-weight: var(--font-medium);
}
.gallery[data-view="list"] .gallery-row-arrow {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--color-cream-200);
  color: var(--color-blue-700);
  transition: all var(--duration-base) var(--ease-out);
}
.gallery[data-view="list"] .gallery-row:hover .gallery-row-arrow {
  background: var(--color-sage-300);
  color: var(--color-white);
  transform: rotate(-180deg);
}
@media (max-width: 700px) {
  .gallery[data-view="list"] .gallery-row { grid-template-columns: 1fr; }
  .gallery[data-view="list"] .gallery-row-arrow { display: none; }
}

/* ---------- Carousel / Story view ---------- */
.gallery[data-view="carousel"] .gallery-list { display: none; }
.gallery[data-view="carousel"] .gallery-stage {
  display: flex;
  gap: var(--space-6);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-inline-start: var(--gutter);
  padding: var(--space-4) 0 var(--space-12);
  scrollbar-width: thin;
  scrollbar-color: var(--color-sage-300) var(--color-cream-100);
  -webkit-overflow-scrolling: touch;
}
.gallery[data-view="carousel"] .gallery-stage::-webkit-scrollbar { height: 8px; }
.gallery[data-view="carousel"] .gallery-stage::-webkit-scrollbar-track { background: var(--color-cream-100); border-radius: 4px; }
.gallery[data-view="carousel"] .gallery-stage::-webkit-scrollbar-thumb { background: var(--color-sage-300); border-radius: 4px; }

.gallery[data-view="carousel"] .gallery-item {
  flex: 0 0 80%;
  max-width: 600px;
  scroll-snap-align: start;
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  cursor: pointer;
  transition: all var(--duration-slow) var(--ease-out);
  display: block;
  grid-template-columns: none;
  background: none;
  border: none;
}
@media (min-width: 768px) { .gallery[data-view="carousel"] .gallery-item { flex-basis: 50%; } }

.gallery[data-view="carousel"] .gallery-item-img {
  position: absolute;
  inset: 0;
  background: none;
}
.gallery[data-view="carousel"] .gallery-item-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease-out);
}
.gallery[data-view="carousel"] .gallery-item:hover img { transform: scale(1.05); }
.gallery[data-view="carousel"] .gallery-meta {
  position: absolute;
  inset: 0;
  padding: var(--space-12);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: linear-gradient(0deg, rgba(31,42,51,0.85) 0%, rgba(31,42,51,0.4) 35%, transparent 65%);
  color: var(--color-cream-50);
}
.gallery[data-view="carousel"] .gallery-meta h3 {
  color: var(--color-cream-50);
  font-size: var(--text-3xl);
  font-weight: var(--font-light);
  margin-bottom: var(--space-3);
  font-family: var(--font-display);
}
.gallery[data-view="carousel"] .gallery-meta-row {
  display: flex;
  gap: var(--space-3);
  color: var(--color-sage-200);
  font-size: var(--text-base);
  flex-direction: row;
}

/* Animated entrance */
.gallery-stage > .gallery-item,
.gallery-list > .gallery-row {
  animation: galleryItemIn 0.7s var(--ease-out) backwards;
}
.gallery-stage > .gallery-item:nth-child(2),
.gallery-list > .gallery-row:nth-child(2) { animation-delay: 0.06s; }
.gallery-stage > .gallery-item:nth-child(3),
.gallery-list > .gallery-row:nth-child(3) { animation-delay: 0.12s; }
.gallery-stage > .gallery-item:nth-child(4),
.gallery-list > .gallery-row:nth-child(4) { animation-delay: 0.18s; }
.gallery-stage > .gallery-item:nth-child(5),
.gallery-list > .gallery-row:nth-child(5) { animation-delay: 0.24s; }
.gallery-stage > .gallery-item:nth-child(6),
.gallery-list > .gallery-row:nth-child(6) { animation-delay: 0.30s; }
.gallery-stage > .gallery-item:nth-child(7),
.gallery-list > .gallery-row:nth-child(7) { animation-delay: 0.36s; }
.gallery-stage > .gallery-item:nth-child(8),
.gallery-list > .gallery-row:nth-child(8) { animation-delay: 0.42s; }

@keyframes galleryItemIn {
  from { opacity: 0; transform: translateY(28px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Image count badge on cards (when multiple images) */
.gallery-item-img .img-count {
  position: absolute;
  inset-inline-end: var(--space-3);
  bottom: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background: rgba(31, 42, 51, 0.78);
  color: var(--color-cream-50);
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: var(--font-semibold);
  letter-spacing: 0.05em;
  z-index: 4;
  pointer-events: none;
}
.gallery-item-img { position: relative; }

/* ---------- Image slots in Edit modal ---------- */
.image-slots {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  margin-top: var(--space-2);
}
@media (max-width: 480px) {
  .image-slots { grid-template-columns: repeat(2, 1fr); }
}
.image-slot {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--surface-alt);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  display: grid;
  place-items: center;
}
.image-slot.empty {
  background: var(--color-cream-100);
  border: 2px dashed var(--color-sage-300);
  color: var(--color-sage-700);
}
.image-slot.empty:hover {
  background: var(--color-sage-50);
  border-color: var(--color-sage-500);
  transform: scale(1.02);
}
.image-slot.filled img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.image-slot.filled:hover { box-shadow: var(--shadow-md); transform: scale(1.02); }
.image-slot.is-main {
  outline: 3px solid var(--color-sage-500);
  outline-offset: -3px;
}
.image-slot .main-badge {
  position: absolute;
  inset-inline-start: 6px;
  bottom: 6px;
  padding: 2px 8px;
  background: var(--color-sage-500);
  color: var(--color-white);
  border-radius: var(--radius-pill);
  font-size: 10px;
  font-weight: var(--font-semibold);
  letter-spacing: 0.05em;
}
.image-slot .slot-remove {
  position: absolute;
  inset-inline-end: 4px;
  top: 4px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(176, 112, 112, 0.95);
  color: var(--color-white);
  display: grid;
  place-items: center;
  border: none;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  z-index: 2;
}
.image-slot .slot-remove:hover { background: #B07070; transform: scale(1.1); }
.image-slots-hint {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: var(--space-2);
  line-height: 1.5;
}

/* ---------- Lightbox ---------- */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(31, 42, 51, 0.85);
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.lightbox.is-open { display: flex; animation: fadeIn 0.3s var(--ease-out); }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.lightbox-content {
  position: relative;
  background: var(--color-cream-50);
  border-radius: var(--radius-lg);
  max-width: 1100px;
  width: 100%;
  max-height: 92vh;
  overflow-y: auto;
  display: grid;
  grid-template-columns: 1fr;
  box-shadow: var(--shadow-xl);
}
@media (min-width: 900px) {
  .lightbox-content { grid-template-columns: 1.4fr 1fr; }
}
.lightbox-image {
  position: relative;
  aspect-ratio: 4/3;
  background: var(--color-cream-100);
  overflow: hidden;
  user-select: none;
  -webkit-user-select: none;
  touch-action: pan-y;
}
@media (min-width: 900px) { .lightbox-image { aspect-ratio: auto; } }
.lightbox-image img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
  transition: opacity var(--duration-fast) var(--ease-out);
  -webkit-user-drag: none;
  user-drag: none;
}

/* Carousel arrows */
.lb-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(252, 250, 245, 0.92);
  color: var(--color-ink-900);
  display: grid;
  place-items: center;
  border: none;
  cursor: pointer;
  z-index: 4;
  box-shadow: var(--shadow-md);
  transition: all var(--duration-fast) var(--ease-out);
}
.lb-arrow:hover {
  background: var(--color-sage-300);
  color: var(--color-white);
  transform: translateY(-50%) scale(1.08);
}
.lb-prev { inset-inline-end: var(--space-4); }   /* RTL: "previous" appears on the right */
.lb-next { inset-inline-start: var(--space-4); } /* RTL: "next" appears on the left */

/* Image counter (top-right of image area) */
.lb-counter {
  position: absolute;
  top: var(--space-4);
  inset-inline-end: var(--space-4);
  padding: 4px 12px;
  background: rgba(31, 42, 51, 0.78);
  color: var(--color-cream-50);
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: var(--font-medium);
  letter-spacing: 0.05em;
  z-index: 4;
  pointer-events: none;
}

/* Dots */
.lb-dots {
  position: absolute;
  inset-inline: 0;
  bottom: var(--space-4);
  display: flex;
  justify-content: center;
  gap: 8px;
  z-index: 4;
  padding: var(--space-2);
}
.lb-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(252, 250, 245, 0.5);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: all var(--duration-fast) var(--ease-out);
}
.lb-dot:hover { background: rgba(252, 250, 245, 0.8); transform: scale(1.2); }
.lb-dot.is-active {
  background: var(--color-sage-300);
  width: 24px;
  border-radius: 4px;
}
.lightbox-body {
  padding: var(--space-12);
  display: flex;
  flex-direction: column;
}
.lightbox-body h2 {
  font-weight: var(--font-light);
  margin-bottom: var(--space-3);
}
.lightbox-tags {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.lightbox-tags .tag {
  font-size: var(--text-xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-sage-700);
}
.lightbox-body p {
  color: var(--text-body);
  line-height: var(--leading-loose);
  margin-bottom: var(--space-6);
}
.lightbox-specs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border);
}
.lightbox-spec dt {
  font-size: var(--text-xs);
  color: var(--text-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.lightbox-spec dd {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--text);
  margin-top: var(--space-1);
}
.lightbox-close {
  position: absolute;
  inset-inline-end: var(--space-6);
  top: var(--space-6);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-white);
  display: grid;
  place-items: center;
  color: var(--text);
  z-index: 2;
  box-shadow: var(--shadow-md);
}
.lightbox-close:hover {
  background: var(--color-sage-300);
  color: var(--color-white);
  transform: rotate(90deg);
  transition: all var(--duration-base) var(--ease-out);
}
