/* ============================================
   Components · Header, botones, cards
   ============================================ */

/* ============================================
   HEADER
   ============================================ */

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-header);
  padding: var(--space-4) var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: transparent;
  transition: background-color var(--duration-base) var(--ease-out),
              backdrop-filter var(--duration-base) var(--ease-out),
              padding var(--duration-base) var(--ease-out);
}

.site-header.is-scrolled {
  background-color: rgba(250, 248, 245, 0.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  padding: var(--space-3) var(--gutter);
  border-bottom: 1px solid var(--color-rule);
}

.site-header__brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.site-header__logo {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
}

.site-header__name {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  text-transform: uppercase;
  color: var(--color-text);
}

.site-header__nav {
  display: flex;
  gap: var(--space-6);
}

.site-header__nav-link {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  text-transform: uppercase;
  color: var(--color-text);
}

@media (max-width: 768px) {
  .site-header__nav {
    display: none;
  }
  .site-header__name {
    display: none;
  }
}

/* ============================================
   BOTONES
   ============================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-wider);
  text-transform: uppercase;
  border-radius: var(--radius-none);
  transition: all var(--duration-base) var(--ease-out);
  cursor: pointer;
  border: 1px solid transparent;
  text-align: center;
  min-height: 56px;
}

.btn--primary {
  background-color: var(--jch-charcoal);
  color: var(--jch-bone);
  border-color: var(--jch-charcoal);
}

.btn--primary:hover {
  background-color: transparent;
  color: var(--jch-charcoal);
  opacity: 1;
}

.btn--secondary {
  background-color: transparent;
  color: var(--jch-charcoal);
  border-color: var(--jch-charcoal);
}

.btn--secondary:hover {
  background-color: var(--jch-charcoal);
  color: var(--jch-bone);
  opacity: 1;
}

.btn__icon {
  width: 16px;
  height: 16px;
  transition: transform var(--duration-base) var(--ease-out);
}

.btn:hover .btn__icon {
  transform: translateX(4px);
}

/* ============================================
   CASO (Card de proyecto)
   ============================================ */

.case {
  border-bottom: 1px solid var(--color-rule);
  position: relative;
  transition: background-color var(--duration-base) var(--ease-out);
}

.case:last-child {
  border-bottom: none;
}

/* Trigger row — visible siempre */
.case__trigger {
  display: grid;
  grid-template-columns: 80px 1fr auto auto;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-6) 0;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: opacity var(--duration-fast) var(--ease-out);
  background: none;
  border: none;
  color: inherit;
}

.case__trigger:hover {
  opacity: 1;
}

.case__trigger:hover .case__title {
  transform: translateX(8px);
}

.case__trigger:hover .case__toggle {
  transform: rotate(90deg);
}

.case__index {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  color: var(--color-text-muted);
}

.case__title-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.case__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-light);
  line-height: var(--leading-tight);
  letter-spacing: var(--track-tight);
  color: var(--color-text);
  transition: transform var(--duration-base) var(--ease-out);
}

.case__category {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-lg);
  font-weight: var(--weight-regular);
  color: var(--jch-charcoal);
  letter-spacing: var(--track-tight);
  line-height: var(--leading-snug);
}

.case__year {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  color: var(--color-text-muted);
}

.case__toggle {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-rule-strong);
  border-radius: 50%;
  transition: transform var(--duration-base) var(--ease-out),
              background-color var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
}

.case__toggle::before,
.case__toggle::after {
  content: '';
  position: absolute;
  background-color: var(--color-text);
  transition: transform var(--duration-base) var(--ease-out),
              opacity var(--duration-base) var(--ease-out);
}

.case__toggle::before {
  width: 12px;
  height: 1px;
}

.case__toggle::after {
  width: 1px;
  height: 12px;
}

.case.is-open .case__toggle {
  background-color: var(--jch-charcoal);
  border-color: var(--jch-charcoal);
  transform: rotate(45deg);
}

.case.is-open .case__toggle::before,
.case.is-open .case__toggle::after {
  background-color: var(--jch-bone);
}

.case.is-open .case__title {
  font-weight: var(--weight-regular);
}

/* Body — expandible */
.case__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--duration-slower) var(--ease-in-out);
}

.case.is-open .case__body {
  max-height: 5000px;
}

.case__body-inner {
  padding-bottom: var(--space-9);
  padding-top: var(--space-3);
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-8);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--duration-slow) var(--ease-out) 100ms,
              transform var(--duration-slow) var(--ease-out) 100ms;
}

.case.is-open .case__body-inner {
  opacity: 1;
  transform: translateY(0);
}

.case__meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-top: var(--space-2);
}

.case__meta-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-rule);
}

.case__meta-row:last-child {
  border-bottom: none;
}

.case__meta-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.case__meta-value {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text);
}

.case__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-7);
}

.case__description {
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
  max-width: 56ch;
}

/* Galería de imágenes */
.case__hero-image {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  background-color: var(--jch-pearl);
}

/* Cuando el hero está dentro de un tour-item, el wrapper toma el margin */
.case__content > .case__tour-item:first-of-type {
  margin-top: var(--space-3);
}

.case__split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.case__split-image {
  aspect-ratio: 4 / 5;
  width: 100%;
  object-fit: cover;
  background-color: var(--jch-pearl);
}

.case__gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
}

.case__gallery-image {
  aspect-ratio: 1 / 1;
  width: 100%;
  object-fit: cover;
  background-color: var(--jch-pearl);
}

/* Imágenes reales (no placeholders) — hover sutil */
img.case__hero-image,
img.case__split-image,
img.case__gallery-image,
img.case__full-image {
  display: block;
  transition: opacity var(--duration-base) var(--ease-out);
}

img.case__hero-image:hover,
img.case__split-image:hover,
img.case__gallery-image:hover,
img.case__full-image:hover {
  opacity: 0.92;
}

/* ============================================
   VARIANTE — Tour vertical (full-width 16:9)
   Para casos con renders horizontales premium
   (ej: Apt 22) que se benefician de "less but bigger"
   ============================================ */

.case__tour {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.case__tour-item {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.case__full-image {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background-color: var(--jch-pearl);
  display: block;
}

/* Caption overlay sobre imagen */
.case__overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: var(--space-7) var(--space-6) var(--space-5);
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.72) 0%,
    rgba(0, 0, 0, 0.45) 50%,
    rgba(0, 0, 0, 0) 100%
  );
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  pointer-events: none;
  opacity: 0.95;
  transition: opacity var(--duration-base) var(--ease-out);
}

.case__overlay-number {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  color: var(--jch-taupe-light);
  flex-shrink: 0;
  padding-top: 4px;
}

.case__overlay-text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-md);
  font-weight: var(--weight-regular);
  line-height: var(--leading-snug);
  color: var(--jch-bone);
  letter-spacing: var(--track-tight);
  max-width: 60ch;
}

.case__tour-item:hover .case__overlay {
  opacity: 1;
}

/* Variante compacta para imágenes chicas (galería 1:1) */
.case__overlay--compact {
  padding: var(--space-5) var(--space-3) var(--space-3);
  gap: var(--space-2);
}

.case__overlay--compact .case__overlay-number {
  font-size: 0.7rem;
  letter-spacing: var(--track-wider);
}

.case__overlay--compact .case__overlay-text {
  font-size: var(--text-sm);
  letter-spacing: 0;
}

@media (max-width: 768px) {
  .case__tour {
    gap: var(--space-4);
  }
  .case__overlay {
    padding: var(--space-5) var(--space-4) var(--space-4);
    gap: var(--space-3);
  }
  .case__overlay-text {
    font-size: var(--text-base);
  }
  .case__overlay--compact {
    padding: var(--space-4) var(--space-3) var(--space-3);
  }
  .case__overlay--compact .case__overlay-text {
    font-size: var(--text-xs);
  }
}

/* ============================================
   Caption abajo (para galería de Fishport)
   ============================================ */

.case__figure {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.case__figcaption {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  color: var(--color-text-muted);
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  padding-top: var(--space-1);
}

.case__figcaption-number {
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.case__figcaption-text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text);
  letter-spacing: var(--track-tight);
}

/* Placeholder para imágenes (mientras no llegan) */
.image-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--jch-pearl);
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  text-transform: uppercase;
  position: relative;
  overflow: hidden;
}

.image-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 12px,
      rgba(122, 122, 122, 0.08) 12px,
      rgba(122, 122, 122, 0.08) 13px
    );
  pointer-events: none;
}

.image-placeholder__label {
  position: relative;
  z-index: 1;
  background-color: var(--jch-pearl);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-rule);
  text-align: center;
  max-width: 80%;
}

/* Variantes tonales para placeholders por caso (sutil) */
.image-placeholder--warm {
  background-color: rgba(166, 159, 149, 0.18);
}
.image-placeholder--warm .image-placeholder__label {
  background-color: rgba(166, 159, 149, 0.25);
  border-color: rgba(166, 159, 149, 0.4);
}

.image-placeholder--cool {
  background-color: rgba(96, 107, 115, 0.12);
}
.image-placeholder--cool .image-placeholder__label {
  background-color: rgba(96, 107, 115, 0.18);
  border-color: rgba(96, 107, 115, 0.35);
}

.image-placeholder--neutral {
  background-color: var(--jch-pearl);
}

/* PM Block para Villa 27 */
.case__pm-block {
  margin-top: var(--space-5);
  padding: var(--space-6);
  background-color: var(--jch-pearl);
  border-left: 2px solid var(--jch-charcoal);
}

.case__pm-title {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}

.case__pm-content {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
}

/* Caption para imágenes */
.case__caption {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  color: var(--color-text-muted);
  margin-top: var(--space-2);
  font-style: normal;
}

/* Responsive del caso */
@media (max-width: 1024px) {
  .case__body-inner {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
  .case__meta {
    order: 2;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3) var(--space-5);
  }
  .case__content {
    order: 1;
  }
}

@media (max-width: 768px) {
  .case__trigger {
    grid-template-columns: 32px 1fr 32px;
    gap: var(--space-3);
    padding: var(--space-5) 0;
  }
  .case__year {
    display: none;
  }
  .case__title {
    font-size: var(--text-xl);
  }
  .case__category {
    font-size: var(--text-sm);
  }
  .case__index {
    font-size: 0.7rem;
  }
  .case__split {
    grid-template-columns: 1fr;
  }
  .case__gallery {
    grid-template-columns: 1fr 1fr;
  }
  .case__meta {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   VILLA 27 — Caso diferenciador, 4 bloques
   ============================================ */

.case__content--villa27 {
  display: flex;
  flex-direction: column;
  gap: var(--space-7);
}

.villa27-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.villa27-block__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}

.villa27-block__index {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  text-transform: uppercase;
  color: var(--jch-taupe);
}

.villa27-block__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-regular);
  letter-spacing: var(--track-tight);
  line-height: var(--leading-tight);
  color: var(--color-text);
  margin: 0;
}

.villa27-block__subtitle {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  max-width: 60ch;
  margin: 0;
  text-wrap: balance;
}

.villa27-block--text .case__description {
  margin: 0;
}

/* ---------- Bloque 1 - Planos ---------- */

.villa27-planos {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.villa27-planos__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.villa27-plano {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  background: var(--jch-bone);
  border: 1px solid var(--color-border);
  cursor: zoom-in;
  overflow: hidden;
  transition: border-color var(--duration-base) var(--ease-out),
              transform var(--duration-base) var(--ease-out);
  font-family: inherit;
}

.villa27-plano img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 2;
  object-fit: contain;
  background: white;
}

.villa27-plano:hover {
  border-color: var(--jch-charcoal);
}

.villa27-plano:hover .villa27-plano__zoom {
  opacity: 1;
}

.villa27-plano__label {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.45) 70%, transparent 100%);
  color: var(--jch-bone);
  pointer-events: none;
}

.villa27-plano__number {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-widest);
  color: var(--jch-taupe-light);
  font-weight: var(--weight-medium);
}

.villa27-plano__text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-md);
  letter-spacing: var(--track-tight);
  flex: 1;
}

.villa27-plano__zoom {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wider);
  text-transform: uppercase;
  color: var(--jch-bone);
  opacity: 0.6;
  transition: opacity var(--duration-base) var(--ease-out);
  padding-left: var(--space-3);
  border-left: 1px solid rgba(250, 248, 245, 0.3);
}

/* ---------- Bloque 3 - Obra real ---------- */

.villa27-obra {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.villa27-obra__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin: 0;
}

.villa27-obra__photo {
  display: block;
  width: 100%;
  padding: 0;
  border: none;
  background: var(--jch-pearl);
  cursor: zoom-in;
  overflow: hidden;
  font-family: inherit;
  transition: opacity var(--duration-base) var(--ease-out);
}

.villa27-obra__photo img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
}

.villa27-obra__photo:hover {
  opacity: 0.92;
}

.villa27-obra__caption {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.villa27-obra__number {
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.villa27-obra__caption span:last-child {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text);
  letter-spacing: var(--track-tight);
}

/* ---------- Bloque 4 - Reportes PM ---------- */

.villa27-pm {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.villa27-pm__doc {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  background: white;
  border: 1px solid var(--color-border);
  cursor: zoom-in;
  overflow: hidden;
  font-family: inherit;
  transition: border-color var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
}

.villa27-pm__doc img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1.41;
  object-fit: cover;
  object-position: top center;
}

.villa27-pm__doc:hover {
  border-color: var(--jch-charcoal);
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}

.villa27-pm__tag {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: var(--weight-medium);
  letter-spacing: var(--track-widest);
  color: var(--jch-bone);
  background: var(--jch-charcoal);
  padding: 4px 8px;
}

.villa27-pm__caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: var(--space-3) var(--space-4);
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.45) 70%, transparent 100%);
  color: var(--jch-bone);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  letter-spacing: var(--track-tight);
}

/* ---------- Responsive Villa 27 ---------- */

@media (max-width: 768px) {
  .villa27-planos__row {
    grid-template-columns: 1fr;
  }
  .villa27-obra {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }
  .villa27-pm {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }
  .villa27-plano__zoom {
    display: none;
  }
}

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

.modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(10, 10, 10, 0.94);
  padding: var(--space-5);
  overflow: hidden;
}

.modal.is-open {
  display: flex;
  animation: modalFadeIn 200ms var(--ease-out);
}

@keyframes modalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.modal__content {
  position: relative;
  max-width: 95vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.modal__image {
  max-width: 95vw;
  max-height: 80vh;
  width: auto;
  height: auto;
  object-fit: contain;
  background: white;
  box-shadow: 0 8px 48px rgba(0,0,0,0.5);
}

.modal__caption {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-md);
  color: var(--jch-bone);
  letter-spacing: var(--track-tight);
  text-align: center;
  margin: 0;
  max-width: 60ch;
}

.modal__close,
.modal__nav {
  position: absolute;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: var(--jch-bone);
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
  z-index: 1;
}

.modal__close:hover,
.modal__nav:hover {
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.32);
}

.modal__close {
  top: var(--space-5);
  right: var(--space-5);
}

.modal__nav--prev {
  left: var(--space-5);
  top: 50%;
  transform: translateY(-50%);
}

.modal__nav--next {
  right: var(--space-5);
  top: 50%;
  transform: translateY(-50%);
}

.modal__nav[hidden] {
  display: none;
}

@media (max-width: 768px) {
  .modal {
    padding: var(--space-3);
  }
  .modal__close {
    top: var(--space-3);
    right: var(--space-3);
  }
  .modal__nav {
    width: 40px;
    height: 40px;
  }
  .modal__nav--prev { left: var(--space-3); }
  .modal__nav--next { right: var(--space-3); }
  .modal__image {
    max-height: 75vh;
  }
  .modal__caption {
    font-size: var(--text-sm);
  }
}

/* Bloquear scroll del body cuando modal abierto */
body.modal-open {
  overflow: hidden;
}
