.form,
.form-solo,
.form-cm,
.form2 {
  padding: 1em;
  border: 1px solid #f1f1f1;
  box-shadow: 0 4px 6px 0 rgba(22, 22, 26, 0.18);
}


.panel,
.ayuda,
.ayuda2 {
  padding: 1em;
  border: 1px solid #f1f1f1;
  box-shadow: 0 4px 6px 0 rgba(22, 22, 26, 0.18);
}

@media only screen and (min-width: 768px) {
  .form {
    width: 70%;
  }

  .form2 {
    width: 65%;
  }

  .panel {
    width: 30%;
  }

  .ayuda {
    width: 28%;
  }

  .ayuda2 {
    width: 15%;
  }

  .form-solo {
    width: 90%;
  }

  .form-cm {
    width: 125%;
  }

  .form-100 {
    width: 100%;
  }
}

.help-block {
  font-size: 12px;
  line-height: 16px;
  position: relative;
  display: block;
  top: 5px;
  left: 5px;
  color: rgba(0, 0, 0, 0.6);
  box-sizing: inherit;
}

input.form-control {
  border: 0px !important;
  border-bottom: 1px solid #8f8f8f !important;
}

.file label {
  color: var(--body-fg);
  font-size: 11px;
  display: inline;
  float: none;
  padding: 4px 10px 0 0;
  width: 160px;
  word-wrap: break-word;
  line-height: 1;
  position: relative;
}

.form-file-label {
  position: absolute !important;
  top: 0;
  margin-top: -25px;
}


/* Estilo para el campo de comentarios en el subformulario de horarios */
.comentarios-formset {
  min-height: auto !important;
}

.trailing.clear {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  z-index: 5;
  color: #757575;
  transition: color 0.2s;
  padding: 5px;
  line-height:1;
  font-size: 14px;
}

.trailing.clear:hover {
  color: #3b71ca;
}

.trailing.clear:focus {
  color: #3b71ca;
  outline: none;
}

.btn {
  text-transform: none;
}

/* Compact utility classes - Mantener solo para el diseño denso aprobado previamente */
.mb-compact {
  margin-bottom: 0.5rem !important;
}

.p-compact {
  padding: 0.75rem !important;
}

.accordion-body-compact {
  padding: 1rem 1.25rem !important;
}

.form-outline-compact {
  margin-bottom: 0 !important;
}

/* Badge de categoría en panel de empleado */
.category-badge {
  background-color: #e3f2fd;
  color: #0d47a1;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.4em 1em;
  border-radius: 50px;
  display: inline-block;
  border: 1px solid #bbdefb;
}
/* Password visibility toggle */
.form-outline .password-toggle {
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
    cursor: pointer;
    color: #757575;
    z-index: 5;
    padding: 5px;
    line-height: 1;
}

.form-outline .password-toggle:hover {
    color: #3b71ca;
}

/* Fix for browser autofill overlapping labels */
.form-outline .form-control:-webkit-autofill ~ .form-label {
    transform: translateY(-1rem) translateY(0.1rem) scale(0.8);
}
