/*
  utilities.css
  Helpers pequenos y reutilizables. Mantener esta capa concreta, no infinita.
*/

.sr-only {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.hidden { display: none !important; }
.block { display: block; }
.inline-block { display: inline-block; }
.inline-flex { display: inline-flex; }
.display-grid { display: grid; }
.w-full { inline-size: 100%; }
.h-full { block-size: 100%; }
.min-w-0 { min-inline-size: 0; }

.max-w-xs { max-inline-size: var(--container-xs); }
.max-w-sm { max-inline-size: var(--container-sm); }
.max-w-md { max-inline-size: var(--container-md); }
.max-w-lg { max-inline-size: var(--container-lg); }
.max-w-xl { max-inline-size: var(--container-xl); }
.max-w-2xl { max-inline-size: var(--container-2xl); }

.overflow-auto { overflow: auto; }
.overflow-hidden { overflow: hidden; }
.overflow-x-auto { overflow-x: auto; }
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.nowrap { white-space: nowrap; }
.break-anywhere { overflow-wrap: anywhere; }
.mx-auto { margin-inline: auto; }
.m-0 { margin: 0; }
.mt-auto { margin-block-start: auto; }

.p-0 { padding: var(--space-0); }
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-3); }
.p-4 { padding: var(--space-4); }
.p-5 { padding: var(--space-5); }
.p-6 { padding: var(--space-6); }
.px-3 { padding-inline: var(--space-3); }
.px-4 { padding-inline: var(--space-4); }
.px-5 { padding-inline: var(--space-5); }
.py-3 { padding-block: var(--space-3); }
.py-4 { padding-block: var(--space-4); }
.py-5 { padding-block: var(--space-5); }
.py-6 { padding-block: var(--space-6); }

.mt-1 { margin-block-start: var(--space-1); }
.mt-2 { margin-block-start: var(--space-2); }
.mt-3 { margin-block-start: var(--space-3); }
.mt-4 { margin-block-start: var(--space-4); }
.mt-5 { margin-block-start: var(--space-5); }
.mt-6 { margin-block-start: var(--space-6); }
.mb-1 { margin-block-end: var(--space-1); }
.mb-2 { margin-block-end: var(--space-2); }
.mb-3 { margin-block-end: var(--space-3); }
.mb-4 { margin-block-end: var(--space-4); }
.mb-5 { margin-block-end: var(--space-5); }
.mb-6 { margin-block-end: var(--space-6); }

.gap-1 { gap: var(--space-1); }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.gap-5 { gap: var(--space-5); }
.gap-6 { gap: var(--space-6); }

.text--1 { font-size: var(--fs--1); }
.text-0 { font-size: var(--fs-0); }
.text-1 { font-size: var(--fs-1); }
.text-2 { font-size: var(--fs-2); }
.text-3 { font-size: var(--fs-3); }
.text-4 { font-size: var(--fs-4); }
.text-5 { font-size: var(--fs-5); }
.text-start { text-align: start; }
.text-center { text-align: center; }
.text-end { text-align: end; }
.text-muted { color: var(--color-muted); }
.text-primary { color: var(--color-primary); }
.text-accent { color: var(--color-accent); }

.surface { background: var(--color-surface); }
.surface-strong { background: var(--color-surface-strong); }
.border { border: var(--line); }
.border-top { border-block-start: var(--line); }
.border-bottom { border-block-end: var(--line); }
.rounded { border-radius: var(--radius); }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded-lg { border-radius: var(--radius-lg); }
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }

.img-fluid {
  inline-size: 100%;
  block-size: auto;
}

.img-cover,
.object-cover {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.object-contain {
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.ratio {
  aspect-ratio: var(--ratio, 16 / 9);
  overflow: hidden;
}

.ratio > img,
.ratio > video,
.ratio > iframe,
.ratio > svg {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.ratio-1x1 { --ratio: 1 / 1; }
.ratio-4x3 { --ratio: 4 / 3; }
.ratio-16x9 { --ratio: 16 / 9; }
.ratio-21x9 { --ratio: 21 / 9; }

.show-mobile,
.show-tablet,
.show-desktop {
  display: none !important;
}

.show-mobile {
  display: revert !important;
}

.hide-mobile {
  display: none !important;
}
