/* ============================================================
   PESANTEZ RENTALS — Sistema de Diseño Principal
   Art direction: Construcción industrial → tono sólido, tierra,
   acero y naranja seguridad. Profesional, no genérico.
   Palette: Acero oscuro + Naranja seguridad + Arena cálida
   Fonts: Barlow Condensed (display) + Inter (body)
   ============================================================ */

/* ---- Design Tokens ---- */
:root {
  /* Colores principales — industria de construcción */
  --color-brand:          #D4580A;   /* Naranja seguridad (cascos, vallas) */
  --color-brand-dark:     #A8420A;
  --color-brand-light:    #F07330;
  --color-brand-bg:       #FDF1E8;

  --color-steel:          #1C2B3A;   /* Acero estructural oscuro */
  --color-steel-mid:      #2E4057;
  --color-steel-light:    #3D5470;

  /* Superficies — arena industrial cálida */
  --color-bg:             #F5F2EE;
  --color-surface:        #FAFAF8;
  --color-surface-2:      #FFFFFF;
  --color-surface-offset: #EDE9E3;
  --color-border:         #D9D5CE;
  --color-divider:        #E4E0D8;

  /* Texto */
  --color-text:           #1A1916;
  --color-text-muted:     #6B6860;
  --color-text-faint:     #A8A59E;
  --color-text-inverse:   #FAFAF8;

  /* Estados */
  --color-success:        #2E7D32;
  --color-success-bg:     #E8F5E9;
  --color-error:          #C62828;
  --color-error-bg:       #FFEBEE;
  --color-warning:        #E65100;
  --color-warning-bg:     #FFF3E0;
  --color-info:           #1565C0;
  --color-info-bg:        #E3F2FD;

  /* Tipografía */
  --font-display:  'Barlow Condensed', 'Impact', sans-serif;
  --font-body:     'Inter', 'Helvetica Neue', sans-serif;

  /* Escala tipográfica fluida */
  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);

  /* Espaciado */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;

  /* Radios */
  --radius-sm:   0.25rem;
  --radius-md:   0.5rem;
  --radius-lg:   0.75rem;
  --radius-xl:   1rem;
  --radius-full: 9999px;

  /* Sombras */
  --shadow-sm:  0 1px 3px rgba(26,25,22,.08);
  --shadow-md:  0 4px 12px rgba(26,25,22,.10);
  --shadow-lg:  0 12px 32px rgba(26,25,22,.14);

  /* Transiciones */
  --transition: 180ms cubic-bezier(0.16, 1, 0.3, 1);

  /* Layout */
  --sidebar-width:     240px;
  --topbar-height:     56px;
  --content-max:       1200px;
}

/* ---- Base Reset ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
}
body {
  min-height: 100dvh;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.6;
}
img, svg { display: block; max-width: 100%; }
ul[role="list"], ol[role="list"] { list-style: none; }
input, button, textarea, select { font: inherit; color: inherit; }
h1, h2, h3, h4, h5, h6 { text-wrap: balance; line-height: 1.15; font-family: var(--font-display); letter-spacing: .01em; }
p, li { text-wrap: pretty; max-width: 72ch; }
button { cursor: pointer; background: none; border: none; }
table { border-collapse: collapse; width: 100%; }
a { color: inherit; text-decoration: none; }

:focus-visible {
  outline: 2px solid var(--color-brand);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

/* ================================================================
   BOTONES
   ================================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  font-weight: 500;
  border-radius: var(--radius-md);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);
  white-space: nowrap;
  text-decoration: none;
  min-height: 40px;
}
.btn svg { flex-shrink: 0; }

.btn-primary {
  background: var(--color-brand);
  color: #fff;
  border-color: var(--color-brand);
}
.btn-primary:hover { background: var(--color-brand-dark); border-color: var(--color-brand-dark); }

.btn-secondary {
  background: var(--color-steel);
  color: #fff;
  border-color: var(--color-steel);
}
.btn-secondary:hover { background: var(--color-steel-mid); }

.btn-outline {
  background: transparent;
  color: var(--color-brand);
  border-color: var(--color-brand);
}
.btn-outline:hover { background: var(--color-brand-bg); }

.btn-ghost {
  background: transparent;
  color: var(--color-text-muted);
  border-color: var(--color-border);
}
.btn-ghost:hover { background: var(--color-surface-offset); color: var(--color-text); }

.btn-danger {
  background: var(--color-error);
  color: #fff;
  border-color: var(--color-error);
}
.btn-danger:hover { background: #a31c1c; }

.btn-sm {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  min-height: 32px;
}
.btn-lg {
  padding: var(--space-3) var(--space-8);
  font-size: var(--text-base);
  min-height: 48px;
}
.btn-icon {
  padding: var(--space-2);
  min-width: 40px;
  min-height: 40px;
  justify-content: center;
}
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ================================================================
   FORMULARIOS
   ================================================================ */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
}
.form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
}
.form-label .required { color: var(--color-brand); margin-left: 2px; }

.form-control {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: var(--color-surface-2);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text);
  transition: border-color var(--transition), box-shadow var(--transition);
  min-height: 40px;
}
.form-control:focus {
  outline: none;
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px rgba(212,88,10,.12);
}
.form-control::placeholder { color: var(--color-text-faint); }

textarea.form-control { resize: vertical; min-height: 80px; }
select.form-control { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B6860' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: var(--space-8); }

.form-hint  { font-size: var(--text-xs); color: var(--color-text-muted); }
.form-error { font-size: var(--text-xs); color: var(--color-error); }
.form-control.is-error { border-color: var(--color-error); }

.form-row {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .form-row.cols-2 { grid-template-columns: 1fr 1fr; }
  .form-row.cols-3 { grid-template-columns: 1fr 1fr 1fr; }
}

/* ================================================================
   CARDS
   ================================================================ */
.card {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.card-header {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.card-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-steel);
  letter-spacing: .03em;
  text-transform: uppercase;
}
.card-body { padding: var(--space-6); }
.card-footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-divider);
  background: var(--color-surface-offset);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

/* ================================================================
   TABLAS
   ================================================================ */
.table-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.data-table thead {
  background: var(--color-steel);
  color: var(--color-text-inverse);
}
.data-table thead th {
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-display);
  font-weight: 600;
  text-align: left;
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.data-table tbody tr {
  border-bottom: 1px solid var(--color-divider);
  transition: background var(--transition);
}
.data-table tbody tr:hover { background: var(--color-brand-bg); }
.data-table tbody td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-text);
  vertical-align: middle;
}
.data-table tfoot td {
  padding: var(--space-3) var(--space-4);
  font-weight: 600;
  border-top: 2px solid var(--color-border);
  background: var(--color-surface-offset);
}

/* Números alineados */
.num { font-variant-numeric: tabular-nums lining-nums; text-align: right; }

/* ================================================================
   BADGES / ESTADOS
   ================================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: uppercase;
  white-space: nowrap;
}
.badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; flex-shrink: 0; }

.badge-active,   .badge-pagada     { background: var(--color-success-bg); color: var(--color-success); }
.badge-inactive, .badge-cancelado  { background: var(--color-error-bg);   color: var(--color-error);   }
.badge-pending,  .badge-pendiente  { background: var(--color-warning-bg); color: var(--color-warning); }
.badge-info,     .badge-aprobada   { background: var(--color-info-bg);    color: var(--color-info);    }
.badge-draft,    .badge-borrador   { background: var(--color-surface-offset); color: var(--color-text-muted); }
.badge-vencido,  .badge-vencida    { background: var(--color-error-bg);   color: var(--color-error);   }
.badge-devuelto                    { background: var(--color-info-bg);    color: var(--color-info);    }

/* ================================================================
   ALERTAS
   ================================================================ */
.alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  border: 1px solid transparent;
}
.alert-success { background: var(--color-success-bg); color: var(--color-success); border-color: #a5d6a7; }
.alert-error   { background: var(--color-error-bg);   color: var(--color-error);   border-color: #ef9a9a; }
.alert-warning { background: var(--color-warning-bg); color: var(--color-warning); border-color: #ffcc80; }
.alert-info    { background: var(--color-info-bg);    color: var(--color-info);    border-color: #90caf9; }

.page-flash { padding: 0 var(--space-6); margin-top: var(--space-4); }
.page-flash .alert + .alert { margin-top: var(--space-2); }

/* ================================================================
   KPI CARDS
   ================================================================ */
.kpi-grid {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: repeat(auto-fill, minmax(min(160px, 100%), 1fr));
}
.kpi-card {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: box-shadow var(--transition), transform var(--transition);
  position: relative;
  overflow: hidden;
}
.kpi-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--color-brand);
}
.kpi-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.kpi-icon {
  width: 40px; height: 40px;
  border-radius: var(--radius-md);
  background: var(--color-brand-bg);
  color: var(--color-brand);
  display: flex; align-items: center; justify-content: center;
}
.kpi-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.kpi-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-steel);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.kpi-card.kpi-warning .kpi-value { color: var(--color-warning); }
.kpi-card.kpi-success .kpi-value { color: var(--color-success); }
.kpi-card.kpi-brand   .kpi-value { color: var(--color-brand);   }

/* ================================================================
   SIDEBAR
   ================================================================ */
.sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidebar-width);
  background: var(--color-steel);
  color: var(--color-text-inverse);
  display: flex;
  flex-direction: column;
  z-index: 100;
  transition: transform var(--transition);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.15) transparent;
}

.sidebar-brand {
  padding: var(--space-5) var(--space-5);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.brand-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text-inverse);
  text-decoration: none;
}
.brand-logo {
  width: 36px; height: 36px;
  flex-shrink: 0;
  color: var(--color-brand-light);
}
.brand-name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  line-height: 1.1;
}

.sidebar-nav { flex: 1; padding: var(--space-4) var(--space-3); }
.sidebar-nav ul { list-style: none; display: flex; flex-direction: column; gap: 2px; }

.nav-group-label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
  padding: var(--space-4) var(--space-3) var(--space-1);
}

.nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: rgba(255,255,255,.7);
  text-decoration: none;
  transition: background var(--transition), color var(--transition);
  min-height: 40px;
}
.nav-item:hover  { background: rgba(255,255,255,.08); color: #fff; }
.nav-item.active { background: var(--color-brand); color: #fff; }
.nav-item svg    { flex-shrink: 0; opacity: .8; }
.nav-item.active svg { opacity: 1; }

.sidebar-footer {
  padding: var(--space-4) var(--space-4);
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.user-avatar {
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  background: var(--color-brand);
  color: #fff;
  font-weight: 700;
  font-size: var(--text-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.user-info { flex: 1; min-width: 0; }
.user-name { font-size: var(--text-sm); font-weight: 600; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-role { font-size: var(--text-xs); color: rgba(255,255,255,.45); }
.btn-logout {
  color: rgba(255,255,255,.5);
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  transition: color var(--transition), background var(--transition);
  min-width: 32px; min-height: 32px;
  display: flex; align-items: center; justify-content: center;
}
.btn-logout:hover { color: #fff; background: rgba(255,255,255,.1); }

/* ================================================================
   LAYOUT ADMIN
   ================================================================ */
.layout-admin { display: flex; min-height: 100dvh; }

.topbar {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--topbar-height);
  background: var(--color-steel);
  color: var(--color-text-inverse);
  align-items: center;
  padding: 0 var(--space-4);
  gap: var(--space-3);
  z-index: 90;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.topbar-title { font-family: var(--font-display); font-weight: 700; letter-spacing: .03em; flex: 1; font-size: var(--text-base); }

.hamburger {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  color: rgba(255,255,255,.7);
  transition: color var(--transition), background var(--transition);
  min-width: 40px; min-height: 40px;
}
.hamburger:hover { color: #fff; background: rgba(255,255,255,.1); }

.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 95;
}

.main-content {
  margin-left: var(--sidebar-width);
  flex: 1;
  min-height: 100dvh;
  padding-bottom: var(--space-12);
}

/* ================================================================
   PÁGINA INTERIOR — encabezado + contenido
   ================================================================ */
.page-header {
  padding: var(--space-8) var(--space-8) var(--space-6);
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.page-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-steel);
  letter-spacing: .03em;
  text-transform: uppercase;
}
.page-subtitle { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1); }

.page-content { padding: var(--space-6) var(--space-8); }

/* ================================================================
   SEARCH / FILTER BAR
   ================================================================ */
.filter-bar {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: flex-end;
  margin-bottom: var(--space-5);
}
.filter-bar .form-group { margin-bottom: 0; }
.search-input-wrap { position: relative; }
.search-input-wrap svg {
  position: absolute;
  left: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-faint);
  pointer-events: none;
}
.search-input-wrap .form-control { padding-left: var(--space-8); min-width: 220px; }

/* ================================================================
   PAGINACIÓN
   ================================================================ */
.pagination {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-divider);
}
.page-link {
  min-width: 36px; min-height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: background var(--transition), color var(--transition);
  border: 1px solid transparent;
}
.page-link:hover  { background: var(--color-surface-offset); color: var(--color-text); }
.page-link.active { background: var(--color-brand); color: #fff; border-color: var(--color-brand); }

/* ================================================================
   MODAL
   ================================================================ */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(26,25,22,.6);
  backdrop-filter: blur(3px);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition);
}
.modal-backdrop.open { opacity: 1; pointer-events: all; }

.modal {
  background: var(--color-surface-2);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  width: 100%;
  max-width: 560px;
  max-height: 90dvh;
  overflow-y: auto;
  transform: translateY(16px) scale(.98);
  transition: transform var(--transition);
}
.modal-backdrop.open .modal { transform: none; }
.modal-header {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.modal-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--color-steel);
  letter-spacing: .03em;
  text-transform: uppercase;
}
.modal-close {
  padding: var(--space-2);
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
  transition: color var(--transition), background var(--transition);
}
.modal-close:hover { color: var(--color-text); background: var(--color-surface-offset); }
.modal-body   { padding: var(--space-6); }
.modal-footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-divider);
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
}

/* ================================================================
   RESPONSIVE — Mobile first
   ================================================================ */
@media (max-width: 1023px) {
  .sidebar {
    transform: translateX(calc(-1 * var(--sidebar-width)));
  }
  .sidebar.open {
    transform: translateX(0);
    box-shadow: var(--shadow-lg);
  }
  .sidebar-overlay.open { display: block; }
  .topbar  { display: flex; }
  .main-content { margin-left: 0; padding-top: var(--topbar-height); }

  .page-header  { padding: var(--space-5) var(--space-4) var(--space-4); }
  .page-content { padding: var(--space-4); }
  .card-header  { padding: var(--space-4); }
  .card-body    { padding: var(--space-4); }

  .topbar-title { display: block; }
}

@media (max-width: 639px) {
  .kpi-grid { grid-template-columns: 1fr 1fr; }
  .filter-bar { flex-direction: column; }
  .filter-bar .search-input-wrap .form-control { min-width: 100%; }
  .page-header { flex-direction: column; }
  .modal { max-width: 100%; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .modal-backdrop { align-items: flex-end; padding: 0; }
}

/* ================================================================
   UTILIDADES
   ================================================================ */
.text-muted   { color: var(--color-text-muted); }
.text-faint   { color: var(--color-text-faint); }
.text-brand   { color: var(--color-brand); }
.text-success { color: var(--color-success); }
.text-error   { color: var(--color-error); }
.font-display { font-family: var(--font-display); }
.fw-700 { font-weight: 700; }
.fw-600 { font-weight: 600; }
.mt-4   { margin-top: var(--space-4); }
.mb-4   { margin-bottom: var(--space-4); }
.d-flex { display: flex; }
.gap-3  { gap: var(--space-3); }
.gap-2  { gap: var(--space-2); }
.align-center { align-items: center; }
.justify-between { justify-content: space-between; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

/* Skeleton loader */
@keyframes shimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
.skeleton {
  background: linear-gradient(90deg, var(--color-surface-offset) 25%, var(--color-divider) 50%, var(--color-surface-offset) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius-sm);
}