.icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2xs);
  padding: var(--space-2xs);
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
}

.icon-button:hover,
.icon-button:focus-visible {
  background: var(--color-hover);
}

.close-icon {
  transition: transform var(--transition-fast), opacity var(--transition-fast);
}

.icon-button:hover .close-icon,
.icon-button:focus-visible .close-icon {
  transform: rotate(90deg);
  opacity: 0.7;
}

.menu-list button {
  font-size: var(--font-size-sm);
  color: var(--color-muted);
  transition: color var(--transition-fast);
  border-bottom: var(--border-thin) solid transparent;
  padding-bottom: var(--space-3xs);
}

.menu-list button:hover,
.menu-list button:focus-visible {
  color: var(--color-text);
}

.menu-list .is-active {
  color: var(--color-text);
  border-bottom-color: var(--color-text);
}

.product-card {
  display: grid;
  gap: var(--space-sm);
  text-align: center;
}

.product-card__image {
  background: var(--color-surface);
  aspect-ratio: 3 / 4;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.product-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium);
}

.product-card__image img,
.gallery__main img,
.gallery__thumbs button img {
  transition: opacity var(--transition-medium);
}

.product-card__image.is-loading img,
.gallery__main.is-loading img,
.gallery__thumbs button.is-loading img {
  opacity: 0;
}

.product-card__image.is-loading::after,
.gallery__main.is-loading::after,
.gallery__thumbs button.is-loading::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.04);
}

.modal-loading__info {
  display: grid;
  gap: var(--space-sm);
}

.loading-line {
  height: 0.7rem;
  background: rgba(0, 0, 0, 0.06);
  border-radius: var(--radius-sm);
}

.loading-line--xs {
  width: 30%;
}

.loading-line--sm {
  width: 45%;
}

.loading-line--md {
  width: 60%;
}

.loading-line--lg {
  width: 90%;
}

.loader {
  width: 1.5rem;
  height: 1.5rem;
  border: 1px solid var(--color-border);
  border-top-color: var(--color-text);
  border-radius: 50%;
  margin-top: var(--space-sm);
  animation: spin 1.1s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.product-card:hover .product-card__image img {
  transform: scale(1.02);
}

.product-card__brand {
  font-size: var(--font-size-card-brand);
  font-weight: 500;
  line-height: var(--line-height-snug);
  letter-spacing: var(--tracking-copy);
  color: var(--color-text);
  text-transform: none;
}

.product-card__name {
  font-size: var(--font-size-card-name);
  font-weight: 300;
  line-height: var(--line-height-snug);
  letter-spacing: var(--tracking-copy);
}

.product-card__price {
  font-family: var(--font-sans);
  font-size: var(--font-size-card-price);
  font-weight: 300;
  line-height: var(--line-height-snug);
  letter-spacing: var(--tracking-copy);
  color: var(--color-text);
}

.pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  padding-top: var(--space-lg);
  border-top: var(--border-thin) solid var(--color-border);
}

.pagination__pages {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.pagination__button {
  font-size: var(--font-size-sm);
  font-variant-numeric: tabular-nums lining-nums;
  text-transform: uppercase;
  letter-spacing: var(--tracking-xl);
  padding: var(--space-2xs) 0;
  color: var(--color-muted);
  transition: color var(--transition-fast);
}

.pagination__button:hover,
.pagination__button:focus-visible {
  color: var(--color-text);
}

.pagination__button[disabled] {
  color: var(--color-border);
  cursor: default;
}

.pagination__button.is-active {
  color: var(--color-text);
  border-bottom: var(--border-thin) solid var(--color-text);
}

.pagination__ellipsis {
  font-size: var(--font-size-sm);
  color: var(--color-muted);
  letter-spacing: var(--tracking-lg);
}

.catalog__empty {
  font-size: var(--font-size-sm);
  color: var(--color-muted);
}

.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--color-bg);
  padding: var(--space-lg) var(--container-padding);
  transform: translateX(-100%);
  transition: transform var(--transition-medium);
  z-index: 30;
  display: grid;
  gap: var(--space-2xl);
  grid-template-rows: auto 1fr auto;
}

.mobile-menu__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.menu-logo {
  font-size: var(--font-size-logo);
  letter-spacing: var(--tracking-logo);
  text-transform: none;
  line-height: var(--line-height-snug);
  font-weight: 400;
}

.menu-section-title {
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-xl);
  color: var(--color-muted);
  margin-bottom: var(--space-xs);
}

.menu-list {
  display: grid;
  gap: var(--space-md);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
}

.mobile-menu .menu-list {
  max-height: calc(100vh - 12rem);
  padding-right: var(--space-2xs);
}

.menu-list::-webkit-scrollbar {
  width: 0.25rem;
}

.menu-list::-webkit-scrollbar-thumb {
  background-color: var(--color-border);
  border-radius: var(--radius-sm);
}

.menu-list::-webkit-scrollbar-track {
  background: transparent;
}

.mobile-menu__section {
  min-height: 0;
}

.mobile-menu__footer {
  padding-top: var(--space-md);
  border-top: var(--border-thin) solid var(--color-border);
}

.social-links {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  align-items: center;
}

.social-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  font-family: var(--font-sans);
  font-size: var(--font-size-xs);
  color: var(--color-text);
  transition: opacity var(--transition-fast);
  line-height: 0;
  position: relative;
  padding: var(--space-3xs);
}

.social-link:hover,
.social-link:focus-visible {
  opacity: 0.7;
}

.social-link svg {
  width: 1.25rem;
  height: 1.25rem;
  stroke: currentColor;
  fill: none;
  stroke-width: 0.75;
}

.social-link--prive::after {
  content: "";
  position: absolute;
  top: 0.2rem;
  right: 0.2rem;
  width: 0.3rem;
  height: 0.3rem;
  border-radius: 50%;
  background: var(--color-text);
}

.menu-list button {
  font-size: var(--font-size-md);
  text-transform: uppercase;
  letter-spacing: var(--tracking-lg);
  padding: var(--space-2xs) 0;
}

body.menu-open {
  overflow: hidden;
}

body.menu-open .mobile-menu {
  transform: translateX(0);
}

.modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  z-index: 40;
}

.modal.is-open {
  display: flex;
}

.modal__backdrop {
  position: absolute;
  inset: 0;
  background: var(--color-overlay);
}

.modal__dialog {
  position: relative;
  background: var(--color-bg);
  padding: var(--space-xl);
  max-width: var(--modal-max-width);
  width: 100%;
  box-shadow: var(--shadow-soft);
  max-height: 85vh;
  height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal__close {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-sm);
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  z-index: 2;
}

.modal__content {
  display: grid;
  gap: var(--space-lg);
  flex: 1;
  min-height: 0;
}

.gallery {
  display: grid;
  gap: var(--space-md);
  justify-content: center;
}

.gallery__main {
  background: var(--color-surface);
  aspect-ratio: 3 / 4;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}

.gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(5rem, 1fr));
  gap: var(--space-sm);
}

.gallery__thumbs button {
  background: var(--color-surface);
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border: var(--border-thin) solid transparent;
  position: relative;
}

.gallery__thumbs button.is-active {
  border-color: var(--color-text);
}

.product-detail__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  min-height: 0;
}

.product-detail__brand {
  font-size: var(--font-size-card-brand);
  font-weight: 500;
  line-height: var(--line-height-snug);
  letter-spacing: var(--tracking-copy);
  color: var(--color-text);
  text-align: center;
}

.product-detail__name {
  font-size: var(--font-size-card-name);
  font-weight: 300;
  line-height: var(--line-height-snug);
  letter-spacing: var(--tracking-copy);
  text-align: center;
}

.product-detail__price {
  font-family: var(--font-sans);
  font-size: var(--font-size-card-price);
  font-weight: 300;
  line-height: var(--line-height-snug);
  letter-spacing: var(--tracking-copy);
  text-align: center;
}

.product-detail__description {
  color: var(--color-text);
  max-width: var(--text-max-width);
  font-size: var(--font-size-detail-body);
  font-weight: 300;
  line-height: var(--line-height-snug);
  letter-spacing: var(--tracking-copy);
  text-align: center;
  overflow-y: auto;
  min-height: 0;
  padding-right: var(--space-2xs);
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
}

.product-detail__description::-webkit-scrollbar {
  width: 0.25rem;
}

.product-detail__description::-webkit-scrollbar-thumb {
  background-color: var(--color-border);
  border-radius: var(--radius-sm);
}

.product-detail__description::-webkit-scrollbar-track {
  background: transparent;
}

.product-detail__actions {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  padding-top: var(--space-sm);
  margin-top: auto;
}

.action-button {
  border: var(--border-thin) solid var(--color-text);
  padding: var(--space-xs) var(--space-md);
  text-transform: uppercase;
  letter-spacing: var(--tracking-xl);
  font-size: var(--font-size-xs);
  transition: background var(--transition-fast), color var(--transition-fast);
  height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  width: 100%;
}

.action-button:hover,
.action-button:focus-visible {
  background: var(--color-text);
  color: var(--color-bg);
}

