@font-face {
  font-family: "Roboto Flex";
  src: url("../fonts/RobotoFlex-VariableFont_GRAD,XOPQ,XTRA,YOPQ,YTAS,YTDE,YTFI,YTLC,YTUC,opsz,slnt,wdth,wght.ttf") format("woff2");
  font-weight: 100 1000;
  font-style: normal;
}
* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-size: 1rem;
  font-family: "Roboto Flex", sans-serif;
  font-weight: 400;
  color: #fcfcfc;
  padding-bottom: 4rem;
  background: url("../../assets/images/fondo.gif") repeat;
}

a {
  color: inherit;
  text-decoration: none;
}

h1 {
  font-size: 1.45rem;
  color: #fcfcfc;
  font-weight: normal;
  border-bottom: 1px solid;
  padding-bottom: 0.6rem;
}

header {
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border-bottom: 1px solid #242424;
  position: sticky;
  top: 0;
  z-index: 3;
  box-shadow: 2px 0 3px #242424;
}
header .content {
  display: none;
}
header .header-logout {
  display: flex;
  align-items: center;
  cursor: pointer;
}
header .wrapper {
  display: flex;
  justify-content: space-between;
  color: #fcfcfc;
}

button {
  width: -moz-max-content;
  width: max-content;
  text-transform: uppercase;
  border: 0;
  border-radius: 0.3rem;
  font-size: 0.75rem;
  padding: 0.3rem 0.5rem;
  cursor: pointer;
}
button:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

fieldset {
  border: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.3rem;
}
fieldset label {
  flex: 1;
  white-space: nowrap;
  min-width: 14ch;
}
fieldset input,
fieldset textarea,
fieldset select {
  flex: 1;
  padding: 0.5rem;
  border-radius: 0.3rem;
  border: 0;
  background-color: #dadada;
}
fieldset input[type=file] {
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
}

fieldset:has([required]) label::after {
  content: "*";
  color: #c44540;
  margin-left: 0.5rem;
}

.wrapper {
  width: min(95vw, 1600px);
  margin: 0 auto;
}

.hidden {
  display: none !important;
}

.row-listado {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border: 1px solid rgb(18.9594594595, 22.0675675676, 27.0405405405);
  box-shadow: 0 0 0.25rem rgb(8.4493243243, 9.8344594595, 12.0506756757);
  color: #fcfcfc;
  display: grid;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}

.resultados-busqueda {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border: 1px solid rgb(18.9594594595, 22.0675675676, 27.0405405405);
  box-shadow: 0 0 0.25rem rgb(8.4493243243, 9.8344594595, 12.0506756757);
  color: #fcfcfc;
  margin-bottom: 1rem;
}

.panel {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border: 1px solid rgb(18.9594594595, 22.0675675676, 27.0405405405);
  box-shadow: 0 0 0.25rem rgb(8.4493243243, 9.8344594595, 12.0506756757);
  color: #fcfcfc;
}

.barra-acciones {
  position: sticky;
  top: 56px;
  z-index: 1;
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  flex-flow: row wrap;
  gap: 0.75rem;
  margin-bottom: 1rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border: 1px solid #242424;
  padding: 0.5rem;
  border-radius: 0.5rem;
  box-shadow: 0 0px 5px #242424;
  color: #fcfcfc;
}
.barra-acciones.barra-acciones-nuevo {
  justify-content: flex-start;
  gap: 0.5rem;
  width: 100%;
}
.barra-acciones .contenedor-acciones-buscador {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
}
.barra-acciones .contenedor-acciones-buscador input, .barra-acciones .contenedor-acciones-buscador .input-buscador {
  border: 0;
  padding: 0.3rem;
  border-radius: 0.3rem;
  background-color: #dadada;
}
.barra-acciones .contenedor-acciones-buscador label {
  white-space: nowrap;
}
.barra-acciones .contenedor-filtros {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.barra-acciones .contenedor-filtros input {
  border: 0;
}
.barra-acciones .fieldset-buscador {
  display: flex;
  gap: 0.75rem;
}
.barra-acciones .barra-acciones-botones {
  display: flex;
  gap: 1rem;
  padding: 0.3rem;
}

.tabla-resultados {
  width: 100%;
  background-color: black;
}
.tabla-resultados .tabla-resultados-cabecera {
  background-color: black;
  color: #fcfcfc;
  text-transform: uppercase;
  text-align: center;
}
.tabla-resultados .tabla-resultados-cabecera th {
  padding: 0.5rem;
}
.tabla-resultados .tabla-resultados-fila {
  background-color: #3d4757;
}
.tabla-resultados .tabla-resultados-fila:nth-of-type(even) {
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
}
.tabla-resultados .tabla-resultados-fila td {
  padding: 0.5rem;
}
.tabla-resultados .tabla-resultados-fila td.td-acciones {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
}

.aviso {
  background-color: #c44540;
  gap: 0.5rem;
}
.aviso::before {
  content: "";
  display: block;
  background: url("../images/iconmonstr-bell-17-24.png");
  background-position: center;
  background-size: 90%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.moneda {
  text-align: left;
}

.nohay {
  color: grey;
  font-style: italic;
  font-size: 85%;
}

body > footer {
  background-color: #2a3847;
  width: 100%;
  height: 3rem;
  margin-top: 2rem;
}

.iniciada {
  color: #fcfcfc;
  background-color: #c44540;
}

.enviada {
  color: #fcfcfc;
  background-color: #dd8f21;
}

.aceptada {
  color: #fcfcfc;
  background-color: #4d9402;
}

.encurso {
  color: #fcfcfc;
  background-color: rgb(11, 148, 158);
}

.rechazada {
  color: #fcfcfc;
  background-color: #101010;
}

.facturada {
  color: #fcfcfc;
  background-color: rgb(143, 20, 214);
}

.aplazada {
  color: #fcfcfc;
  background-color: rgb(11, 148, 158);
}

.no-rentable {
  color: #c44540;
}

.aceptable {
  color: #dd8f21;
}

.rentable {
  color: #4d9402;
}

.muy-rentable {
  color: rgb(143, 20, 214);
}

.porcentaje {
  font-size: 0.8rem;
  padding: 0.3rem;
  border-radius: 50%;
  color: #fcfcfc;
  height: 42px;
  width: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.porcentaje.no-rentable {
  background-color: #c44540;
}
.porcentaje.aceptable {
  background-color: #dd8f21;
}
.porcentaje.rentable {
  background-color: #4d9402;
}
.porcentaje.muy-rentable {
  background-color: rgb(143, 20, 214);
}

.cliente {
  font-size: 1.5rem;
  font-weight: 100;
  color: rgb(231.6791338583, 176.5570866142, 98.8208661417);
}

/*
.email,
.contacto,
.telefono,
.cliente {
  display: flex;
  align-items: center;

  &::before {
    content: "";
    display: inline-block;
    width: 25px;
    height: 18px;
    margin-right: .3rem;
    background-repeat: no-repeat;
    background-position: center;
  }
}

.email {
  &::before {
    background-image: url("../../assets/images/email_icon.svg");
  }
}

.contacto {
  &::before {
    width: 25px;
    height: 25px;
    background-image: url("../../assets/images/formador.svg");
  }
}

.telefono {
  &::before {
    background-image: url("../../assets/images/phone_icon.svg");
  }
}

.cliente {
  &::before {
    width: 20px;
    height: 20px;
    background-size: contain;
    background-image: url("../../assets/images/customer.svg");
  }
}
*/
@media only screen and (max-width: 768px) {
  .toggle-content {
    display: flex;
    flex-flow: column;
    gap: 0.5rem;
  }
  fieldset {
    gap: 0;
  }
}
button {
  width: -moz-max-content;
  width: max-content;
  text-transform: uppercase;
  border: 0;
  border-radius: 0.3rem;
  font-size: 0.75rem;
  padding: 0.3rem 0.5rem;
  cursor: pointer;
}
button:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

[class^=boton-] {
  display: flex;
  align-items: center;
  width: -moz-max-content;
  width: max-content;
  white-space: nowrap;
  padding: 0.6rem 0.7rem;
  border: 0;
  border-radius: 0.3rem;
  color: #fcfcfc;
  font-size: 0.75rem;
  text-transform: uppercase;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.6);
  cursor: pointer;
  transition: all 0.5s ease;
}
[class^=boton-]:hover:not(:disabled) {
  filter: brightness(1.1);
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4666666667);
}
[class^=boton-]:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.boton-nuevo {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-nuevo:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}
.boton-nuevo {
  gap: 0.5rem;
}
.boton-nuevo::before {
  content: "";
  display: block;
  background: url("../images/iconmonstr-plus-4-24.png");
  background-position: center;
  background-size: 90%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.boton-editar {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-editar:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}
.boton-editar {
  gap: 0.5rem;
}
.boton-editar::before {
  content: "";
  display: block;
  background: url("../images/iconmonstr-edit-10-24.png");
  background-position: center;
  background-size: 90%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.boton-mostrar {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-mostrar:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}
.boton-mostrar {
  gap: 0.5rem;
}
.boton-mostrar::before {
  content: "";
  display: block;
  background: url("../images/iconmonstr-eye-filled-24.png");
  background-position: center;
  background-size: 90%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.boton-ocultar {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-ocultar:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}
.boton-ocultar {
  gap: 0.5rem;
}
.boton-ocultar::before {
  content: "";
  display: block;
  background: url("../images/iconmonstr-eye-off-filled-24.png");
  background-position: center;
  background-size: 90%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.boton-duplicar {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-duplicar:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}
.boton-duplicar {
  gap: 0.5rem;
}
.boton-duplicar::before {
  content: "";
  display: block;
  background: url("../images/iconmonstr-duplicate-filled-24.png");
  background-position: center;
  background-size: 100%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.boton-vincular {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-vincular:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}
.boton-vincular {
  gap: 0.5rem;
}
.boton-vincular::before {
  content: "";
  display: block;
  background: url("../images/iconmonstr-link-2-24.png");
  background-position: center;
  background-size: 90%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.boton-eliminar {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-eliminar:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}
.boton-eliminar {
  gap: 0.5rem;
}
.boton-eliminar::before {
  content: "";
  display: block;
  background: url("iconmonstr-trash-can-filled-24.png");
  background-position: center;
  background-size: 90%;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
}

.boton-azul {
  background-color: #2372cc;
  box-shadow: 0 0 0 transparent;
}
.boton-azul:hover {
  background-color: rgb(27.5313807531, 89.6736401674, 160.4686192469);
  box-shadow: 1px 1px 3px #242424;
}

.boton-guardar,
.boton-verde {
  background-color: #4d9402;
  box-shadow: 0 0 0 transparent;
}
.boton-guardar:hover,
.boton-verde:hover {
  background-color: rgb(50.82, 97.68, 1.32);
  box-shadow: 1px 1px 3px #242424;
}

.boton-cancelar,
.boton-negro {
  background-color: #101010;
  box-shadow: 0 0 0 transparent;
}
.boton-cancelar:hover,
.boton-negro:hover {
  background-color: hsl(0, 0%, -3.7254901961%);
  box-shadow: 1px 1px 3px #242424;
}

.boton-facturar,
.boton-morado {
  background-color: rgb(143, 20, 214);
  box-shadow: 0 0 0 transparent;
}
.boton-facturar:hover,
.boton-morado:hover {
  background-color: rgb(111.8333333333, 15.641025641, 167.358974359);
  box-shadow: 1px 1px 3px #242424;
}

.boton-aplazar,
.boton-celeste {
  background-color: rgb(11, 148, 158);
  box-shadow: 0 0 0 transparent;
}
.boton-aplazar:hover,
.boton-celeste:hover {
  background-color: rgb(7.6804733728, 103.3372781065, 110.3195266272);
  box-shadow: 1px 1px 3px #242424;
}

.boton-eliminar,
.boton-rojo {
  background-color: #c44540;
  box-shadow: 0 0 0 transparent;
}
.boton-eliminar:hover,
.boton-rojo:hover {
  background-color: rgb(159.676, 53.504, 49.324);
  box-shadow: 1px 1px 3px #242424;
}

#navegacion-principal {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
}
#navegacion-principal a {
  padding: 0.3rem 0.5rem;
  text-transform: capitalize;
  background-color: transparent;
  transition: all 0.5s;
  border-radius: 0.3rem;
  color: whitesmoke;
}
#navegacion-principal a:hover {
  background-color: #2a3847;
}

@media only screen and (max-width: 768px) {
  #navegacion-principal {
    font-size: 1.1rem;
  }
}
.paginacion {
  position: sticky;
  top: 115px;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border: 1px solid #242424;
  padding: 0.5rem;
  border-radius: 0.5rem;
  box-shadow: 0 0px 5px #242424;
  color: #fcfcfc;
  margin-bottom: 1rem;
}
.paginacion .paginacion-elemento {
  display: flex;
  align-items: center;
  padding: 0.5rem 0.75rem;
  border-radius: 0.3rem;
  background-color: #3d4757;
  color: #fcfcfc;
  cursor: pointer;
}
.paginacion .paginacion-elemento.current-page {
  background-color: #242424;
  color: #fcfcfc;
}

.ventana {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 20px;
  border-radius: 0.3rem;
  z-index: 3;
  width: 300px;
  text-align: center;
  background-color: #3d4757;
}

.ventana-informacion {
  box-shadow: 0 0px 12px 3px #242424;
  border: 6px solid #2372cc;
}
.ventana-informacion .mensaje-contenido {
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
}

.ventana-error {
  box-shadow: 0 2px 10px #242424;
  border: 6px solid #c44540;
}

.ventana-advertencia {
  box-shadow: 0 2px 10px #242424;
  border: 6px solid #dd8f21;
}

.ventana-confirmacion {
  box-shadow: 0 2px 10px #4d9402;
}

.mensaje-contenido {
  margin-bottom: 15px;
  padding: 1rem;
}

.btn-cerrar,
.btn-confirmar {
  padding: 10px;
  margin: 5px;
  cursor: pointer;
}

.btn-cerrar {
  background-color: #242424;
  color: white;
}

.btn-confirmar {
  background-color: #4d9402;
  color: white;
}

.bloqueador {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 2;
}
.bloqueador .ventana-contenido {
  position: absolute;
  min-width: 50%;
  max-height: 80vh;
  overflow-y: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 1rem;
  background-color: #3d4757;
  border-radius: 0.5rem;
}
.bloqueador .ventana-contenido fieldset label {
  min-width: 25%;
}
.bloqueador .ventana-contenido fieldset input, .bloqueador .ventana-contenido fieldset textarea {
  min-width: 70%;
}
.bloqueador .ventana-contenido .botones-formulario {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
  border-top: 1px solid;
  padding-top: 1rem;
}

.contenedor-materias {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1rem;
}
.contenedor-materias.toggle {
  display: flex;
  flex-direction: column;
}
.contenedor-materias fieldset {
  flex: 0 1 calc(20% - 1rem);
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  justify-content: flex-end;
  background-color: rgb(29.4695945946, 34.3006756757, 42.0304054054);
  border-radius: 0.3rem;
  box-shadow: 1px 1px 2px #242424;
}
.contenedor-materias fieldset label {
  white-space: wrap;
  max-width: 18ch;
}
.contenedor-materias fieldset input {
  flex: 0 1;
}
.contenedor-materias {
  /*  .lista-materias {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      gap: 0.5rem;
      padding: 1rem;
      max-height: 60vh;
      overflow-y: auto;
      font-size: 0.8rem;
    }
  */
}
.contenedor-materias .materias-seleccionadas,
.contenedor-materias .otras-materias {
  width: 100%;
  padding: 0.5rem;
  border-radius: 0.5rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
}
.contenedor-materias .materias-seleccionadas h3,
.contenedor-materias .otras-materias h3 {
  margin-top: 0;
  margin-bottom: 10px;
  width: 100%;
}
.contenedor-materias .materias-seleccionadas .materias-lista,
.contenedor-materias .otras-materias .materias-lista {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: repeat(4, calc(25% - 0.5rem));
  max-height: 45vh;
  overflow-y: scroll;
}

.contenedor-nueva-materia {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 0.3rem;
  box-shadow: 1px 1px 8px #242424;
  width: min(550px, 90vw);
  max-height: 80vh;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border: 1px solid #242424;
  padding: 1.5rem;
}
.contenedor-nueva-materia .boton-cerrar {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 22px;
  width: 22px;
  font-size: 12px;
  background-color: #101010;
  color: #fcfcfc;
  cursor: pointer;
  border: 3px solid #101010;
  font-weight: bold;
}
.contenedor-nueva-materia fieldset {
  margin: 1rem auto;
  justify-content: center;
  padding: 0.5rem;
  background-color: transparent;
}

.buscador-materias {
  background-color: #3d4757;
  margin-top: -10px;
}
.buscador-materias .lista-materias {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 1rem;
  max-height: 60vh;
  overflow-y: auto;
  font-size: 0.8rem;
}
.buscador-materias .lista-materias fieldset {
  flex: 0 1 calc(25% - 1rem);
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  justify-content: flex-end;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border-radius: 0.3rem;
  box-shadow: 1px 1px 2px #242424;
}
.buscador-materias .lista-materias fieldset:has([type=checkbox]:checked) {
  background-color: #2372cc;
}
.buscador-materias .lista-materias fieldset label {
  white-space: wrap;
  max-width: 18ch;
}
.buscador-materias .lista-materias fieldset input {
  flex: 0 1;
}
.buscador-materias .lista-materias fieldset input[type=checkbox] {
  accent-color: rgb(143, 20, 214);
}
.buscador-materias button {
  margin: 1rem;
}

.contenedor-nueva-materia {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 0.3rem;
  box-shadow: 0 0 6px #242424;
  width: min(550px, 90vw);
  max-height: 80vh;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  padding: 1.5rem;
}
.contenedor-nueva-materia fieldset {
  margin: 1rem auto;
  justify-content: center;
  background: #3d4757;
  padding: 1rem;
}
.contenedor-nueva-materia .boton-cerrar {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 22px;
  width: 22px;
  font-size: 12px;
  cursor: pointer;
  border: 3px solid black;
  font-weight: bold;
}

@media only screen and (max-width: 768px) {
  .contenedor-materias {
    -moz-column-count: 2;
         column-count: 2;
  }
}
.ventana-bloqueador {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 3;
}

.ventana {
  position: fixed;
  background-color: #3d4757;
  border: 1px solid #242424;
  top: 0;
  left: 50%;
  z-index: 3;
  transform: translateX(-50%);
  padding: 1.5rem;
  box-shadow: 0 0 2rem rgba(0, 0, 0, 0.6);
  border-bottom-left-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  width: auto;
  min-width: 25vw;
  max-width: 80vw;
  max-height: 80vh;
  padding-top: 4.25rem;
  overflow: hidden;
}
.ventana .ventana-header {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background-color: #2a3847;
  color: #fcfcfc;
  padding: 0.5rem 1rem;
}
.ventana .ventana-header p {
  margin: 0;
  font-size: 1.3rem;
  font-weight: 100;
}
.ventana .ventana-header .ventana-boton-cerrar {
  width: 24px;
  height: 24px;
  background-color: #101010;
  font-weight: bold;
  border-radius: 0.3rem;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.ventana-comunicaciones .lista-resultados {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 0.5rem;
  max-height: 38vh;
  overflow-y: auto;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  padding: 0.5rem;
  border-radius: 0.5rem;
}
.ventana-comunicaciones .lista-resultados .fila-resultado {
  flex: 1;
  display: flex;
  gap: 0.5rem;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  background-color: rgb(29.4695945946, 34.3006756757, 42.0304054054);
  padding: 0.5rem;
  border-radius: 0.3rem;
}
.ventana-comunicaciones .lista-resultados .fila-resultado input[type=radio] {
  margin: 0;
  cursor: pointer;
}
.ventana-comunicaciones .lista-resultados .fila-resultado .nombre-contacto {
  display: flex;
  flex-direction: column;
  align-items: self-start;
  gap: 0.5rem;
}
.ventana-comunicaciones fieldSet {
  width: 100%;
  align-items: self-start;
  text-align: left;
}
.ventana-comunicaciones fieldSet label {
  text-align: left;
}
.ventana-comunicaciones fieldSet textarea {
  width: 100%;
  min-height: 15ch;
}
.ventana-comunicaciones {
  left: 0;
  transform: translate(0, 0);
  max-height: 100vh;
  height: 100vh;
}
.ventana-comunicaciones .formulario-comunicaciones .comentarios {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  border-top: 1px solid #242424;
  margin-top: 1rem;
  padding-top: 1rem;
}
.ventana-comunicaciones .formulario-comunicaciones .comentarios textarea {
  width: 100%;
  min-height: 12ch;
}
.ventana-comunicaciones .formulario-comunicaciones .destinatario {
  align-items: flex-start;
}
.ventana-comunicaciones .formulario-comunicaciones .destinatario > label {
  flex: 0 1 auto;
  font-size: 1.5rem;
  min-width: inherit;
  font-weight: 200;
}
.ventana-comunicaciones .formulario-comunicaciones .destinatario > div {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 0.5rem;
}
.ventana-comunicaciones .formulario-comunicaciones .destinatario > div .input-radio {
  flex-direction: row-reverse;
  background-color: rgb(29.4695945946, 34.3006756757, 42.0304054054);
  padding: 0.3rem 0.5rem;
  border-radius: 0.3rem;
}
.ventana-comunicaciones .formulario-comunicaciones .destinatario > div .input-radio input[type=radio] {
  margin: 0;
  padding: 0;
}
.ventana-comunicaciones .formulario-comunicaciones .destinatario > div label {
  min-width: initial;
}
.ventana-comunicaciones .formulario-comunicaciones .formulario-estaticos {
  text-align: left;
}

.ventana-documentacion .ventana-documentacion-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.ventana-documentacion .ventana-documentacion-form .contenedor-documentos {
  display: flex;
  align-items: self-start;
  justify-content: space-between;
  flex-direction: column;
  gap: 0.5rem;
}
.ventana-documentacion .ventana-documentacion-form .contenedor-documentos label {
  font-size: 1.1rem;
  padding-right: 2.5rem;
}
.ventana-documentacion .ventana-documentacion-form .botones-formulario {
  display: flex;
  gap: 1rem;
  justify-content: flex-start;
}

.ventana-edicion-contacto {
  text-align: left;
}
.ventana-edicion-contacto form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: min(100%, 520px);
  margin: auto;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  padding: 1rem;
  border-radius: 0.5rem;
}
.ventana-edicion-contacto form fieldset {
  justify-content: flex-start;
}
.ventana-edicion-contacto form fieldset label {
  flex: 1 0 50%;
  font-size: 1.1rem;
}
.ventana-edicion-contacto form fieldset input[types=checkebox] {
  flex: 0 0 auto;
  padding: 0.5rem;
  border-radius: 0.3rem;
  border: 0;
}

.ventana-cotizacion {
  left: 0;
  transform: translate(0, 0);
  max-height: 100vh;
  height: 100vh;
}
.ventana-cotizacion form {
  text-align: left;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  padding: 0.5rem;
  border-radius: 0.3rem;
  margin-top: -10px;
}
.ventana-cotizacion form .botones-formulario {
  display: flex;
  flex-direction: row;
  gap: 0.5rem;
  background-color: rgb(29.4695945946, 34.3006756757, 42.0304054054);
  padding: 0.5rem;
  border-radius: 0.3rem;
}
.ventana-cotizacion form .formador-visible {
  font-size: 1.3rem;
  font-weight: 200;
}
.ventana-cotizacion form label {
  text-align: right;
}

.ventana-buscador {
  left: 0;
  transform: translate(0, 0);
  max-height: 100vh;
  height: 100vh;
}
.ventana-buscador .fieldset-buscador {
  margin-bottom: 1rem;
}
.ventana-buscador .lista-resultados {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-height: calc(100vh - 180px);
  overflow-y: scroll;
  padding: 0.5rem 1rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border-radius: 0.3rem;
}
.ventana-buscador .fila-resultado {
  display: flex;
  flex-direction: row;
  gap: 1rem;
  border-bottom: 1px dashed #fcfcfc;
  padding-bottom: 1rem;
}
.ventana-buscador .fila-resultado .cliente {
  background-color: rgb(29.4695945946, 34.3006756757, 42.0304054054);
  padding: 0.5rem;
  border-radius: 0.3rem;
}
.ventana-buscador .fila-resultado .contactos {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.ventana-buscador .fila-resultado .contacto {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
}
.ventana-buscador .datos-propuesta {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background-color: #3d4757;
  max-width: 24rem;
  padding: 0.5rem;
  border-radius: 0.3rem;
  text-align: left;
}
.ventana-buscador .datos-propuesta .propuesta-estado {
  padding: 0.5rem;
  border-radius: 0.3rem;
  display: flex;
  gap: 0.5rem;
}
.ventana-buscador .datos-propuesta .row-propuesta-titulo {
  margin: 0.1rem 0;
}

.ventana-alta {
  left: 0;
  transform: translate(0, 0);
  max-height: 100vh;
  height: 100vh;
}
.ventana-alta .contenido-alta {
  padding: 0.5rem;
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
  border-radius: 0.3rem;
}
.ventana-alta .contenido-alta .fieldset-alta label {
  width: auto;
  text-align: left;
}
.ventana-alta .contenido-alta .buscar-block {
  display: flex;
  gap: 1rem;
  padding: 0.5rem;
}

.ventana-informacion {
  box-shadow: 0 0px 12px 3px #242424;
  border: 6px solid #2372cc;
}
.ventana-informacion .mensaje-contenido {
  background-color: rgb(39.9797297297, 46.5337837838, 57.0202702703);
}

.ventana-error {
  box-shadow: 0 2px 10px #242424;
  border: 6px solid #c44540;
}

.ventana-advertencia {
  box-shadow: 0 2px 10px #242424;
  border: 6px solid #dd8f21;
}

.ventana-confirmacion {
  box-shadow: 0 2px 10px #4d9402;
}

.mensaje-contenido {
  margin-bottom: 15px;
  padding: 1rem;
}

/*###################################################*/
.ventana-contenido .materias-resultados {
  display: grid;
  grid-template-columns: repeat(3, calc(33% - 0.25rem));
  gap: 0.5rem;
  justify-content: center;
  max-height: 55vh;
  overflow-y: auto;
  padding: 1rem;
  margin-top: 1rem;
  background-color: rgb(29.4695945946, 34.3006756757, 42.0304054054);
}
.ventana-contenido .materias-resultados .materia-checkbox {
  flex: 0 0 min(150px, 20%);
  padding: 0.5rem;
  background-color: #3d4757;
  border-radius: 0.3rem;
  justify-content: space-between;
  transition: all 0.5rem;
}
.ventana-contenido .materias-resultados .materia-checkbox label {
  white-space: auto;
}
.ventana-contenido .materias-resultados .materia-checkbox:hover {
  background-color: #2372cc;
}
.ventana-contenido .materias-resultados .materia-checkbox input {
  min-width: auto;
}
.ventana-contenido .popup-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: min(100%, 520px);
  margin: auto;
}
.ventana-contenido .popup-form .contenedor-documentos {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.ventana-contenido .popup-form .contenedor-documentos label {
  font-size: 1.1rem;
}
.ventana-contenido .popup-form .contenedor-documentos input {
  padding: 0.5rem;
  border-radius: 0.3rem;
  border: 0;
}

.ventana-bloqueador {
  background-color: rgba(0, 0, 0, 0.74);
}

.loader {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 1rem;
  gap: 1rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.loader .loader-title {
  width: 100%;
  font-size: 1.8rem;
  font-weight: 300;
  text-align: center;
  margin-bottom: 2rem;
  padding: 1rem;
}
.loader .loader-item {
  display: block;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  animation: elevateY 1s ease-in-out infinite;
}
.loader .loader-item:nth-of-type(1) {
  animation-delay: 0;
}
.loader .loader-item:nth-of-type(2) {
  animation-delay: 0.5s;
}
.loader .loader-item:nth-of-type(3) {
  animation-delay: 1.25s;
}
.loader .loader-item:nth-of-type(4) {
  animation-delay: 2s;
}
.loader .loader-item:nth-of-type(5) {
  animation-delay: 2.75s;
}
.loader .loader-item:nth-of-type(6) {
  animation-delay: 3.5s;
}

@keyframes elevateY {
  0% {
    transform: translateY(0);
    background-color: white;
  }
  50% {
    transform: translateY(-25px);
    background-color: rgb(0, 153, 255);
  }
  100% {
    transform: translateY(0);
    background-color: white;
  }
}/*# sourceMappingURL=theme.css.map */