body{
  font-family: "texto", sans-serif!important;
  font-weight: 300!important;

}
.titulo {
  font-family: "Albert Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
}
.texto-thin {
  font-family: "texto", sans-serif;
  font-weight: 100;
  font-style: normal;
}

.texto-extralight {
  font-family: "texto", sans-serif;
  font-weight: 200;
  font-style: normal;
}

.texto-light {
  font-family: "texto", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.texto-regular {
  font-family: "texto", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.texto-medium {
  font-family: "texto", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.texto-semibold {
  font-family: "texto", sans-serif;
  font-weight: 600;
  font-style: normal;
}

.texto-bold {
  font-family: "texto", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.texto-extrabold {
  font-family: "texto", sans-serif;
  font-weight: 800;
  font-style: normal;
}

.texto-black {
  font-family: "texto", sans-serif;
  font-weight: 900;
  font-style: normal;
}

.texto-thin-italic {
  font-family: "texto", sans-serif;
  font-weight: 100;
  font-style: italic;
}

.texto-extralight-italic {
  font-family: "texto", sans-serif;
  font-weight: 200;
  font-style: italic;
}

.texto-light-italic {
  font-family: "texto", sans-serif;
  font-weight: 300;
  font-style: italic;
}

.texto-regular-italic {
  font-family: "texto", sans-serif;
  font-weight: 400;
  font-style: italic;
}

.texto-medium-italic {
  font-family: "texto", sans-serif;
  font-weight: 500;
  font-style: italic;
}

.texto-semibold-italic {
  font-family: "texto", sans-serif;
  font-weight: 600;
  font-style: italic;
}

.texto-bold-italic {
  font-family: "texto", sans-serif;
  font-weight: 700;
  font-style: italic;
}

.texto-extrabold-italic {
  font-family: "texto", sans-serif;
  font-weight: 800;
  font-style: italic;
}

.texto-black-italic {
  font-family: "texto", sans-serif;
  font-weight: 900;
  font-style: italic;
}
.bg-login {
  background-image: url("../bg.avif");
  background-size: cover;
}
.link:hover {
  background-color: #8e0404!important;
}

/* Sidebar toggle icon rotation */
.nav-link[data-bs-toggle="collapse"] .las.la-arrow-right {
    transition: transform 0.3s ease;
}

.nav-link[data-bs-toggle="collapse"][aria-expanded="true"] .las.la-arrow-right {
    transform: rotate(90deg);
}

.activo {
  background-color: #684141!important;
}

/* Perfect Round Buttons */
.btn-round-perfect {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    min-height: 42px !important;
    max-height: 42px !important;
    border-radius: 1000px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
    overflow: hidden !important;
    line-height: 1 !important;
    border: none !important;
    aspect-ratio: 1 / 1 !important;
}

.btn-round-perfect i {
    font-size: 1.4rem !important;
    margin: 0 !important;
    line-height: 1 !important;
    display: block !important;
}

/* Header Search Responsive */
.search-container-header {
    width: 100% !important;
    max-width: 600px;
    transition: all 0.3s ease;
}

@media (max-width: 991.98px) {
    .search-container-header {
        max-width: 100% !important;
        width: 100% !important;
    }
    
    .header-content-wrapper {
        gap: 10px !important;
        padding-left: 5px !important;
        padding-right: 5px !important;
    }
}

/* Responsive Sidebar Adjustments */
@media (max-width: 991.98px) {
    body {
        flex-direction: column;
    }
    
    aside {
        display: none;
    }

    .offcanvas .nav-link {
        color: #333 !important;
    }
    
    .offcanvas .bg-dark {
        background-color: #f8f9fa !important;
        color: #333 !important;
    }

    .offcanvas .activo {
        background-color: #684141 !important;
        color: white !important;
    }
}

/* Custom Header Normalization */
.header-main-container {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 1rem !important;
}

.header-main-container .btn-header-action {
    width: 100% !important;
}

@media (min-width: 992px) {
    .header-main-container {
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        text-align: left !important;
        gap: 0 !important;
    }
    .header-main-container .btn-header-action {
        width: auto !important;
    }
}

/* Custom Purple Utility */
.bg-purple {
    background-color: #6f42c1 !important;
}

.bg-purple-subtle {
    background-color: #e2d9f3 !important;
}

.text-purple {
    color: #6f42c1 !important;
}

.gridjs-search-input {
    border-radius: 50rem!important;
}