.twl-photos-archive {
  --twl-photos-accent-rgb: var(--twl-accent-rgb, var(--twl-color-gold-rgb, 201 172 140));
  --twl-photos-accent-color: rgb(var(--twl-photos-accent-rgb));
  display: grid;
  gap: 2rem;
  margin-top: clamp(2.25rem, 5vw, 3.5rem);
}

.twl-photos-year-section {
  padding: clamp(1rem, 2vw, 1.4rem);
  border: var(--twl-border-subtle);
  border-radius: calc(var(--twl-radius-lg) + 0.25rem);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.03)),
    rgba(10, 10, 10, 0.24);
  box-shadow: var(--twl-shadow-card);
  backdrop-filter: blur(18px);
}

.twl-photos-year-heading {
  margin: 0 0 1rem;
}

.twl-photos-year-heading h2 {
  margin: 0;
  font-size: clamp(1.9rem, 5vw, 3.2rem);
}

.twl-photos-gallery-grid,
.twl-photos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 257px));
  justify-content: center;
  gap: clamp(1rem, 2vw, 1.35rem);
}

.twl-photos-gallery-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 100%;
  border: 1px solid rgba(255, 253, 248, 0.14);
  border-radius: var(--twl-radius-lg);
  background: rgba(18, 18, 18, 0.94);
  box-shadow: var(--twl-shadow-card);
  color: var(--twl-color-paper);
  text-decoration: none;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.twl-photos-gallery-card:hover,
.twl-photos-gallery-card:focus-visible,
.twl-photos-item:hover,
.twl-photos-item:focus-visible {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 86%, #fff);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 74%, rgba(255, 255, 255, 0.16)),
    0 0 18px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 28%, rgba(255, 255, 255, 0.12)),
    0 14px 34px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 32%, rgba(0, 0, 0, 0.26));
}

.twl-photos-gallery-card__media,
.twl-photos-item {
  position: relative;
  overflow: hidden;
}

.twl-photos-gallery-card__media::after,
.twl-photos-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.42));
}

.twl-photos-gallery-card__media img,
.twl-photos-item img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  transition: transform 320ms ease;
}

.twl-photos-gallery-card:hover img,
.twl-photos-gallery-card:focus-visible img,
.twl-photos-item:hover img,
.twl-photos-item:focus-visible img {
  transform: scale(1.04);
}

.twl-photos-gallery-card__body {
  display: grid;
  gap: 0.35rem;
  padding: 1.35rem 1.25rem 1.5rem;
  background: rgba(78, 78, 78, 0.5);
}

.twl-photos-gallery-title {
  display: block;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.15;
}

.twl-photos-single-gallery h2 {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.twl-photos-single-gallery {
  margin-top: clamp(2.25rem, 5vw, 3.5rem);
}

.twl-photos-back-button {
  position: fixed;
  left: clamp(0.85rem, 2vw, 1.5rem);
  top: 50vh;
  transform: translateY(-50%);
  z-index: 40;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 9rem;
  padding: 1px;
  border: 1px solid rgb(var(--twl-photos-accent-rgb) / 0.78);
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.78);
  color: #fff;
  text-decoration: none;
  box-shadow:
    inset 0 0 22px rgb(var(--twl-photos-accent-rgb) / 0.14),
    0 0 0 1px rgba(255, 255, 255, 0.08),
    0 0 18px rgb(var(--twl-photos-accent-rgb) / 0.14),
    0 12px 28px rgba(0, 0, 0, 0.28);
}

.twl-photos-back-button:hover,
.twl-photos-back-button:focus-visible {
  border-color: color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 86%, #fff);
  background: rgb(var(--twl-photos-accent-rgb) / 0.16);
  color: #fff;
  box-shadow:
    inset 0 0 34px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 34%, rgba(255, 255, 255, 0.1)),
    0 0 0 1px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 74%, rgba(255, 255, 255, 0.16)),
    0 0 18px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 28%, rgba(255, 255, 255, 0.12)),
    0 14px 34px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 32%, rgba(0, 0, 0, 0.26));
}

.twl-photos-back-button__icon {
  display: inline-flex;
  font-size: 7rem;
  font-weight: 700;
  opacity: 0.5;
  transform: scale(0.4, 1.4);
  line-height: 0.78;
}

.twl-photos-description {
  margin-bottom: 1.75rem;
  color: var(--twl-color-muted);
}

.twl-photos-item {
  display: block;
  padding: 0;
  border: 1px solid rgba(255, 253, 248, 0.14);
  border-radius: var(--twl-radius-lg);
  background: rgba(18, 18, 18, 0.94);
  box-shadow: var(--twl-shadow-card);
  cursor: pointer;
}

.twl-photos-modal-open {
  overflow: hidden;
}

.twl-photos-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
}

.twl-photos-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(0, 0, 0, 0.76);
}

.twl-photos-modal__dialog {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 1rem;
  width: min(92vw, 1320px);
  min-height: 100vh;
  margin: 0 auto;
  padding: clamp(1rem, 2vw, 1.5rem);
}

.twl-photos-modal__stage {
  border: var(--twl-border-subtle);
  border-radius: calc(var(--twl-radius-lg) + 0.25rem);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.03)),
    rgba(10, 10, 10, 0.88);
  box-shadow: var(--twl-shadow-card);
  backdrop-filter: blur(20px);
  overflow: hidden;
}

.twl-photos-modal__toolbar,
.twl-photos-modal__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
}

.twl-photos-modal__image-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1rem 1rem;
}

.twl-photos-modal__image-wrap img {
  max-width: 100%;
  max-height: 72vh;
  border-radius: var(--twl-radius-md);
  object-fit: contain;
}

.twl-photos-modal__meta {
  display: grid;
  gap: 0.35rem;
  justify-content: start;
}

.twl-photos-modal__meta h3,
.twl-photos-modal__meta p {
  margin: 0;
}

.twl-photos-modal__meta p,
.twl-photos-modal__counter {
  color: var(--twl-color-muted);
}

.twl-photos-modal__close,
.twl-photos-modal__nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3rem;
  min-height: 3rem;
  border: var(--twl-border-subtle);
  border-radius: var(--twl-radius-pill);
  background: rgba(18, 18, 18, 0.92);
  color: var(--twl-color-paper);
  cursor: pointer;
  border: 1px solid rgb(var(--twl-photos-accent-rgb) / 0.9);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.08),
    0 0 18px rgb(var(--twl-photos-accent-rgb) / 0.14),
    0 12px 28px rgba(0, 0, 0, 0.28);
  backdrop-filter: none;
  position: relative;
  z-index: 3;
}

.twl-photos-modal__close:hover,
.twl-photos-modal__close:focus-visible,
.twl-photos-modal__nav:hover,
.twl-photos-modal__nav:focus-visible {
  border-color: color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 86%, #fff);
  background: rgb(var(--twl-photos-accent-rgb) / 0.18);
  color: #fff;
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 74%, rgba(255, 255, 255, 0.16)),
    0 0 18px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 28%, rgba(255, 255, 255, 0.12)),
    0 14px 34px color-mix(in srgb, var(--twl-hover-color, var(--twl-photos-accent-color)) 32%, rgba(0, 0, 0, 0.26));
}

.twl-photos-modal__nav[disabled] {
  opacity: 0.35;
  cursor: default;
}

.twl-photos-modal__close {
  font-size: 1.6rem;
  line-height: 1;
}

.twl-photos-modal__nav {
  font-size: 2rem;
  font-weight: 700;
}

@media (max-width: 900px) {
  .twl-photos-gallery-grid,
  .twl-photos-grid {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  }

  .twl-photos-modal__dialog {
    grid-template-columns: 1fr;
    gap: 0.75rem;
    width: min(96vw, 96vw);
  }

  .twl-photos-modal__nav {
    position: fixed;
    bottom: 1.25rem;
    z-index: 2;
  }

  .twl-photos-modal__nav--prev {
    left: 1rem;
  }

  .twl-photos-modal__nav--next {
    right: 1rem;
  }

  .twl-photos-back-button {
    left: 0.75rem;
    min-height: 7rem;
    padding: 1px;
  }
}
