.card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: var(--space-2);
}

.card__title {
  font-size: 1.25rem;
}

.card__subtitle {
  font-size: 1rem;
  color: var(--color-muted);
  margin-bottom: var(--space-1);
}

.card__text {
  color: var(--color-muted);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: var(--radius-md);
  padding: 12px 20px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s ease;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn--primary {
  background: var(--color-primary);
  color: var(--color-white);
}

.btn--primary:hover:not(:disabled) {
  background: var(--color-primary-dark);
}

.btn--secondary {
  background: var(--color-white);
  color: var(--color-primary-dark);
  border: 1px solid var(--color-primary);
}

.btn--danger {
  background: var(--color-rechazada-bg);
  color: var(--color-rechazada-text);
}

.btn--full {
  width: 100%;
}

.day-strip {
  display: flex;
  gap: var(--space-1);
  overflow-x: auto;
  padding-bottom: var(--space-1);
  scrollbar-width: thin;
}

.day-chip {
  flex: 0 0 auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  background: var(--color-white);
  cursor: pointer;
  text-align: center;
  font-size: 0.85rem;
  color: var(--color-text);
}

.day-chip--active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}

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

@media (min-width: 480px) {
  .slot-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.slot-chip {
  border: none;
  border-radius: var(--radius-md);
  padding: 10px 6px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
}

.slot-chip[disabled] {
  cursor: not-allowed;
}

.slot-chip--disponible {
  background: var(--color-disponible-bg);
  color: var(--color-disponible-text);
}

.slot-chip--ocupado {
  background: var(--color-ocupado-bg);
  color: var(--color-ocupado-text);
}

.slot-chip--pendiente {
  background: var(--color-pendiente-bg);
  color: var(--color-pendiente-text);
}

.badge {
  display: inline-block;
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 0.8rem;
  font-weight: 600;
}

.badge--pendiente {
  background: var(--color-pendiente-bg);
  color: var(--color-pendiente-text);
}

.badge--confirmada {
  background: var(--color-confirmada-bg);
  color: var(--color-confirmada-text);
}

.badge--rechazada,
.badge--expirada,
.badge--cancelada {
  background: var(--color-rechazada-bg);
  color: var(--color-rechazada-text);
}

.field {
  margin-bottom: var(--space-2);
}

.field-label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--color-text);
}

.input {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  font-size: 1rem;
  background: var(--color-white);
}

.input:focus {
  outline: none;
  border-color: var(--color-primary);
}

.field-error {
  color: var(--color-rechazada-text);
  font-size: 0.85rem;
  margin-bottom: var(--space-1);
}

.select {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  font-size: 1rem;
  background: var(--color-white);
}

.summary-list {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px var(--space-1);
  margin: 0;
}

.summary-list dt {
  color: var(--color-muted);
}

.summary-list dd {
  margin: 0;
  font-weight: 600;
}

.yape-numero {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-primary-dark);
}

.toast-root {
  position: fixed;
  top: var(--space-2);
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.toast {
  background: var(--color-text);
  color: var(--color-white);
  padding: 10px 16px;
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  box-shadow: var(--shadow-card);
}

.toast--error {
  background: var(--color-rechazada-text);
}

.admin-fila {
  margin-bottom: 8px;
}

.admin-fila__acciones,
.form-acciones {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

.form-acciones {
  margin-top: var(--space-2);
}

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

@media (min-width: 600px) {
  .campodeps-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.campodep-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-text);
  box-shadow: var(--shadow-card);
  background: var(--color-white);
}

.campodep-card__imagen-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--color-ocupado-bg);
}

.campodep-card__imagen {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.campodep-card__imagen-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 0.85rem;
  font-weight: 600;
}

.campodep-card__imagen-placeholder::after {
  content: "Sin imagen";
}

.campodep-card__info {
  padding: var(--space-2);
}

.campodep-card__nombre {
  margin: 0 0 4px 0;
  font-size: 1.05rem;
}

.campodep-card__direccion {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.9rem;
}

.empty-state {
  text-align: center;
  color: var(--color-muted);
  padding: var(--space-3) 0;
}
