:root {
    --custom-green: #32CD32;
    --bulma-link-color: #3273dc; /* Color link de Bulma */
    --rz-primary: var(--bulma-link) !important;
    --rz-dialog-title-background-color: var(--bulma-link) !important;
    --rz-dialog-title-color: white !important;
    --rz-dialog-close-color: white !important;
    --bulma-subtitle-color: #444 !important;
}

body {
    background-color: #f8f9fe;
    color: #333;
}

.title {
    color: #333;
}

.letra-blanca span{
    color:white !important;
}

.full-height {
    min-height: 100vh;
    background-color: #f8f9fe;
}
   
.navbar-divider {
    background-color: white;
}

.card-container {
    min-width: 120px;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px; /* Aumenta el espacio interno de la tarjeta */
}

.card-image {
    margin-top: 10px; /* Aumenta el espacio entre el borde superior y la imagen */
    margin-bottom: 15px; /* Espacio debajo de la imagen */
}

.card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.card-title {
    margin-bottom: 10px;
}

.card-text {
    font-size: 16px;
}

@media (max-width: 576px) {
    .card-text {
        font-size: 14px; /* Ajusta el tama�o de fuente en pantallas peque�as */
    }

    .card-container {
        padding: 15px; /* Reduce el padding en pantallas peque�as */
    }
}

.rotating-icon i {
    animation: rotate 4s linear infinite;
}

@keyframes rotate {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

.gradient-text {
    background: linear-gradient(90deg, #ff0057, #7303c0, #00f260, #0575e6);
    background-size: 400% 400%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: gradientAnimation 10s ease infinite;
}

@keyframes gradientAnimation {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 100% 50%;
    }
}

.subtitle {
    color: #333 !important;
}

.file-cta {
    color: #333;
}

/* Estilos para el fondo de billetes volando */
.flying-bills {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
   /* z-index: -1; *//* Para que est� detr�s del contenido */
    pointer-events: none; /* Evita interferencias con la interacci�n */
}

.bill {
    position: absolute;
    bottom: -100px;
    width: 60px;
    height: 40px;
    background-image: url('assets/images/bill.png'); /* Ruta a la imagen del billete */
    background-size: contain;
    background-repeat: no-repeat;
/*    opacity: 0;*/
    animation: moveBills 10s linear infinite;
}

.creditcard {
    position: absolute;
    bottom: -100px;
    width: 60px;
    height: 40px;
    background-image: url('assets/images/creditcard.png'); /* Ruta a la imagen del billete */
    background-size: contain;
    background-repeat: no-repeat;
    /*    opacity: 0;*/
    animation: moveBills 10s linear infinite;
}

@keyframes moveBills {
    0% {
        transform: translateY(0) rotate(0deg);
    }

    100% {
        transform: translateY(-120vh) rotate(720deg);
    }
}

/* Asegura que el contenido principal est� por encima del fondo */
.container {
    position: relative;
    z-index: 1;
}
    
.custom-title {
    font-size: 1.5rem;
    font-weight: bold;
    color: #444;
    /* Otros estilos que desees */
    text-align: center;
    margin-bottom: 1rem;
}

.section {
    --bulma-section-padding: 2rem 1.5rem !important;
    margin-top:45px;
}

strong {
    color:#111 !important;
}

.label {
    color: #333;
}

.bulmaPrimary {
    background-color: var(--rz-primary) !important;
    color: white !important;
}

    .bulmaPrimary * {
        background-color: var(--rz-primary) !important; /* var(--rz-primary) !important;*/
        color: white !important;
    }

.blackPrimary {
    background-color: black !important;
    color: white !important;
}

    .blackPrimary * {
        background-color: black !important; /* var(--rz-primary) !important;*/
        color: white !important;
    }

.f-green {
    color: var(--custom-green);
}

.navbar.is-link .navbar-dropdown {
    background-color: #384fff !important;
    color: white;
}

    .navbar.is-link .navbar-dropdown .navbar-item {
        background-color: #384fff !important;
        color: white;
    }


        .navbar.is-link .navbar-dropdown .navbar-item:hover {
            background-color: #4d62ff !important;
        }

.equal-height {
    display: flex;
    flex-direction: column;
    height: 100%;
}

    .equal-height .card-content {
        flex-grow: 1;
    }

.custom-datepicker::-webkit-calendar-picker-indicator {
    opacity: 0;
    cursor: pointer;
}
.custom-datepicker {
    cursor: pointer;
}

input[type="date"] {
    position: relative;
}

    input[type="date"]::-webkit-calendar-picker-indicator {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        opacity: 0;
        cursor: pointer;
    }

input[type="date"] {
    -moz-appearance: textfield;
}

.button-container {
    display: flex;
    gap: 0.5rem; /* Espacio entre los botones */
}

    .button-container .button {
        flex-shrink: 0; /* Evita que los botones se encojan */
    }
/* Estilos personalizados para el desbordamiento horizontal de la tabla */
.table-container {
    overflow-x: auto; /* Habilita el desbordamiento horizontal */
    -webkit-overflow-scrolling: touch; /* Habilita el desplazamiento suave en dispositivos m�viles */
    white-space: nowrap; /* Evita que el contenido se ajuste en varias l�neas */
}

    /* Estilos personalizados para la barra de desplazamiento */
    .table-container::-webkit-scrollbar {
        height: 8px; /* Altura de la barra de desplazamiento */
    }

    .table-container::-webkit-scrollbar-thumb {
        background-color: #888; /* Color del pulgar de la barra de desplazamiento */
        border-radius: 4px; /* Radio del borde del pulgar de la barra de desplazamiento */
    }

        .table-container::-webkit-scrollbar-thumb:hover {
            background-color: #555; /* Color del pulgar de la barra de desplazamiento al pasar el mouse */
        }

/* Personalizar la barra de desplazamiento en navegadores Firefox */
.table-container {
    scrollbar-width: thin; /* Grosor de la barra de desplazamiento */
    scrollbar-color: #888 transparent !important; /* Color de la barra de desplazamiento y fondo transparente */
}

/* Personalizar la barra de desplazamiento en Internet Explorer 10+ */
.table-container {
    -ms-overflow-style: none; /* Ocultar las flechas en IE */
}

    /* Asegurar que la tabla tenga un ancho m�nimo fijo */
    .table-container table {
        min-width: 928px; /* Ajusta el valor seg�n sea necesario */
    }

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

    /* Personalizar la barra de desplazamiento en navegadores Webkit (Chrome, Safari) */
    .table-responsive::-webkit-scrollbar {
        height: 8px; /* Altura de la barra de desplazamiento */
    }

    .table-responsive::-webkit-scrollbar-track {
        background: transparent; /* Fondo transparente */
    }

    .table-responsive::-webkit-scrollbar-thumb {
        background: #888; /* Color de la barra de desplazamiento */
        border-radius: 4px; /* Bordes redondeados */
    }

        .table-responsive::-webkit-scrollbar-thumb:hover {
            background: #555; /* Color de la barra de desplazamiento al pasar el rat�n */
        }

/* Personalizar la barra de desplazamiento en navegadores Firefox */
.table-responsive {
    scrollbar-width: thin; /* Grosor de la barra de desplazamiento */
    /*scrollbar-color: #888 transparent;*/ /* Color de la barra de desplazamiento y fondo transparente */
}

/* Personalizar la barra de desplazamiento en Internet Explorer 10+ */
.table-responsive {
    -ms-overflow-style: none; /* Ocultar las flechas en IE */
}

.espacio-superior {
    margin-top: 20px;
}

.bulma-link-button {
    background-color: var(--bulma-link-color);
    color: white;
}

.radzen-secondary-button {
    background-color: #ff4081; /* Color secundario de Radzen */
    color: white;
}

/* Estilos personalizados para la barra de desplazamiento */
.modal-card-body::-webkit-scrollbar {
    width: 8px; /* Ancho de la barra de desplazamiento */
}

.modal-card-body::-webkit-scrollbar-thumb {
    background-color: #888; /* Color del pulgar de la barra de desplazamiento */
    border-radius: 4px; /* Radio del borde del pulgar de la barra de desplazamiento */
}

    .modal-card-body::-webkit-scrollbar-thumb:hover {
        background-color: #555; /* Color del pulgar de la barra de desplazamiento al pasar el mouse */
    }

/* Estilos generales para todos los scrollbars en navegadores Webkit (Chrome, Safari) */
::-webkit-scrollbar {
    width: 8px; /* Ancho de la barra de desplazamiento */
}

::-webkit-scrollbar-thumb {
    background-color: #888; /* Color del pulgar de la barra de desplazamiento */
    border-radius: 4px; /* Radio del borde del pulgar de la barra de desplazamiento */
}

    ::-webkit-scrollbar-thumb:hover {
        background-color: #555; /* Color del pulgar de la barra de desplazamiento al pasar el mouse */
    }

/* Estilos generales para todos los scrollbars en navegadores Firefox */
* {
    scrollbar-width: thin !important; /* Grosor de la barra de desplazamiento */
    /*scrollbar-color: #888 transparent;*/ /* Color de la barra de desplazamiento y fondo transparente */
}

/* Estilos generales para todos los scrollbars en Internet Explorer 10+ */
* {
    -ms-overflow-style: none; /* Ocultar las flechas en IE */
}

/* Centrar numeros de calendario de radzen */
.rz-calendar-view td a.rz-state-default, .rz-calendar-view td span.rz-state-default, .rz-calendar-view th a.rz-state-default, .rz-calendar-view th span.rz-state-default {
    text-align: center;
}

.file.has-name .file-cta {
    background-color: var(--rz-input-background-color);
}

.center-content {
    display: flex;
    justify-content: center;
    align-items: center;
}

.navbar-divider{
    display:block !important;
}

.rz-dialog-titlebar, .rz-dialog-side-titlebar {
    padding-bottom: 1rem !important;
}

.logout-button {
    margin-top: 1.5rem;
    display: flex;
    justify-content: center;
}


/*#components-reconnect-modal {
    display: none;
}

    #components-reconnect-modal.components-reconnect-show,
    #components-reconnect-modal.components-reconnect-failed,
    #components-reconnect-modal.components-reconnect-rejected {
        display: block;
        background-color: white;
        padding: 2rem;
        border-radius: 0.5rem;
        text-align: center;
        box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.3);
        margin: 50px 50px;
        position: fixed;
        top: 0;
        z-index: 10001;
    }*/

#components-reconnect-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1000;
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    justify-content: center;
    align-items: center;
    text-align: center;
    color: white;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

    #components-reconnect-modal.components-reconnect-show,
    #components-reconnect-modal.components-reconnect-failed,
    #components-reconnect-modal.components-reconnect-rejected {
        display: flex;
    }

    #components-reconnect-modal .reconnect-content {
        background-color: rgba(220, 53, 69, 0.85);
        padding: 2rem;
        border-radius: 8px;
        max-width: 600px;
        width: 90%;
        box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
    }

    #components-reconnect-modal .reconnect-icon {
        font-size: 4rem;
        margin-bottom: 1rem;
    }

    #components-reconnect-modal .reconnect-title {
        font-size: 1.8rem;
        font-weight: bold;
        margin-bottom: 1rem;
    }

    #components-reconnect-modal .reconnect-message {
        font-size: 1.2rem;
        margin-bottom: 1.5rem;
    }

    #components-reconnect-modal .reconnect-spinner {
        display: inline-block;
        width: 50px;
        height: 50px;
        border: 5px solid rgba(255, 255, 255, 0.3);
        border-radius: 50%;
        border-top-color: white;
        animation: spin 1s ease-in-out infinite;
    }

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

@media (max-width: 768px) {
    .profile-row {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .profile-column-img {
        width: 100% !important;
        margin-bottom: 1rem;
    }

    .profile-info p {
        text-align: center;
    }
}

@media screen and (max-width: 1023px) {
    /* Oculta los dropdowns en m�vil por defecto */
    .navbar-item.has-dropdown .navbar-dropdown {
        display: none;
    }
    /* Muestra el dropdown cuando su contenedor tiene is-active */
    .navbar-item.has-dropdown.is-active .navbar-dropdown {
        display: block;
    }
}

@media (max-width: 576px) {
    .auth-buttons-container {
        flex-direction: column;
        align-items: center;
        gap: 1.5rem;
    }

    .auth-button {
        width: 80%;
        max-width: 280px;
        justify-content: center;
    }
}

@media (max-width: 768px) {
    .totales-container {
        flex-direction: column;
        align-items: center;
        gap: 15px;
    }

    .total-item {
        width: 100%;
        justify-content: center;
    }
}

/* Responsive para botones y contenedor principal */
@media (max-width: 768px) {
    .field > div:first-child > div {
        flex-direction: column;
        gap: 15px;
    }

        .field > div:first-child > div > .rz-dropdown {
            margin-right: 0 !important;
            width: 100% !important;
        }

    .botones-agregar-container {
        width: 100%;
        justify-content: center;
        margin-top: 0;
    }

    .boton-agregar {
        flex: 1;
        min-width: 140px;
        font-size: 0.85rem;
        padding: 0.5rem 1rem;
    }
}

@media (max-width: 480px) {
    .botones-agregar-container {
        flex-direction: column;
        gap: 8px;
    }

    .boton-agregar {
        width: 100%;
        min-width: unset;
    }
}

/* Responsive para botones de agregar gasto e ingreso */
@media (max-width: 768px) {
    .botones-agregar-container {
        width: 100%;
        justify-content: center;
        flex-wrap: nowrap;
    }

    .boton-agregar {
        min-width: 120px;
        width: 120px;
        font-size: 0.85rem;
        padding: 0.6rem 1.2rem;
        flex: 0 0 auto;
    }
}

@media (max-width: 480px) {
    .botones-agregar-container {
        flex-direction: row;
        gap: 10px;
        justify-content: center;
    }

    .boton-agregar {
        min-width: 110px;
        width: 110px;
        font-size: 0.8rem;
        padding: 0.6rem 1rem;
    }
}

/* Responsive para resumen unificado */
@media (max-width: 768px) {
    .resumen-unificado-container {
        flex-direction: column;
        gap: 1.5rem;
        align-items: flex-start;
    }

    .resumen-divider {
        display: none;
    }

    .resumen-item {
        width: 100%;
        justify-content: flex-start !important;
        padding: 0.5rem 0;
    }

    .resumen-item:not(:last-child) {
        border-bottom: 1px solid #e0e0e0;
        padding-bottom: 1rem;
    }
}