@import url("table-row.css");

@import url("../app/css/colores.css");

/* =========================================
   🧱 BASE
========================================= */
body {
    background-color: var(--color-bg-body);
    font-family: 'Montserrat', sans-serif;
}

main {
    margin-top: 102px !important;
}

/* =========================================
   🎯 MEDIA QUERIES
========================================= */
@media (min-width: 1400px) {
    #main-sidenav {
        top: 102px !important;
        left: 24px !important;
        height: calc(100% - 121px) !important;
    }

    .sidenav-link {
        height: 48px !important;
    }

    .sidenav-menu {
        margin-top: -10px !important;
    }

    main {
        margin-left: 348px !important;
    }

    .b-leftmv {
        margin-top: 1px !important;
    }

    #main-navbar {
        padding: 16px 64px!important;
    }
    
}



/* =========================================
   🔧 UTILITARIAS
========================================= */
.cursor-pointer {
    cursor: pointer;
}

.text-white {
    color: var(--color-text-white-caps) !important;
}

.obligatorio {
    color: var(--color-danger-keyword) !important;
}

/* =========================================
   🧭 NAVBAR & SIDENAV
========================================= */
#main-sidenav {
    width: 313px !important;
    height: calc(100% - 32px);
    top: 0px;
    border-radius: 20px;
    padding: 32px 16px;
    gap: 32px;
    position: fixed;
}

#main-navbar {
    height: 80px;
    justify-content: space-between;
    padding: 3px 16px;
}

#logo_owari_menu {
    width: 243px;
    height: 48px;
    gap: 16px;
}

/* En móvil el logo no se oculta: se escala más chico para que entre en la navbar */
@media (max-width: 767.98px) {
    #logo_owari_menu {
        width: auto;
        height: 32px;
    }
}

.sidenav-link {
    width: 275px;
    height: 35px !important;
    border-radius: 16px;
    padding: 10px 16px 12px 16px;
    gap: 16px;
}

.sub-title-menu {
    font-size: 14px;
    margin: 20px 0 7px 15px !important;
}

.ic-menu,
.ic-menu-user {
    font-size: 20px !important;
}

.ic-menu-user {
    color: var(--color-text-secondary) !important;
}

.span-menu-user {
    color: var(--color-text-secondary) !important;
}

.active-ic {
    color: var(--color-accent) !important;
}

.active-sp {
    color: var(--color-special-blue) !important;
}

#menu-nombre-user,
#menu-nombre-finca {
    color: var(--color-text-primary) !important;
}

#menu-nombre-user {
    font-size: 16px !important;
    font-weight: 600;
}

#menu-arrow-user {
    font-size: 12px !important;
    transition: transform 0.3s ease-in-out;
    color: var(--color-text-primary) !important;
}

#menu-nombre-finca {
    font-size: 12px !important;
    font-weight: 400;
}

#contenedor-menu-user {
    display: grid;
    margin-top: -10px !important;
}

#inoco-user {
    height: 30px;
    width: 30px;
    margin-top: -5px;
}

/* =========================================
   🟢 BOTONES
========================================= */
.btn-agro {
    background-color: var(--color-primary);
    color: var(--color-bg-white-keyword);
    border: none;
    padding: 10px 20px;
    cursor: pointer;
    transition: background-color 0.3s;
    text-transform: none;
    font-size: 12px !important;
}

.btn-agro:hover {
    background-color: var(--color-primary-hover);
    color: var(--color-text-white) !important;
}

.btn-agro:active {
    background-color: var(--color-primary-active) !important;
}

.btn-outline-agro {
    border-color: var(--color-primary) !important;
    color: var(--color-primary) !important;
    text-transform: none;
}

.btn-outline-agro-menu {
    background-color: var(--color-bg-white) !important;
    border-color: var(--color-bg-white) !important;
    color: var(--color-text-primary) !important;
    text-transform: none;

    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 14px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;

}

.btn-outline-agro-menu.active {
    border-color: var(--color-primary) !important;
    color: var(--color-primary) !important;
    background-color: var(--color-primary-bg-light) !important;
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 14px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;

}

.btn-outline-agro-menu.listo{
    border-color: var(--color-success-solid) !important;
    background-color: var(--color-success-bg) !important;
    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 14px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-success-text) !important;

}

.titulos-card-compra{
    font-family: Montserrat;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 18px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-primary) !important;

}

.titulos-card-compra-white{
    font-family: Montserrat;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 18px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-white) !important;

}

.precio-card-compra-white{
    font-family: Montserrat;
    font-weight: 700;
    font-style: SemiBold;
    font-size: 32px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-white) !important;
}

.labels-compras{
    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 12px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-black) !important;

}

.btn-outline-agro:hover {
    background-color: var(--color-primary-alpha-10) !important;
    border-color: var(--color-primary) !important;
    color: var(--color-text-primary) !important;
}

.btn-outline-agro:focus {
    box-shadow: 0 0 0 0.2rem var(--color-primary-alpha-50) !important;
}

.btn-outline-agro:active {
    background-color: var(--color-primary-active) !important;
    border-color: var(--color-primary-active) !important;
    color: var(--color-bg-white-keyword) !important;
}

.btn-text-agro {
    background-color: var(--color-bg-transparent) !important;
    border: none !important;
    color: var(--color-secondary) !important;
    text-transform: none;
    box-shadow: none !important;
}

.btn-text-agro:hover,
.btn-text-agro:focus,
.btn-text-agro:active {
    background-color: var(--color-bg-transparent) !important;
    border: none !important;
    color: var(--color-secondary) !important;
    box-shadow: none !important;
}

/* =========================================
   🎨 LANDING PAGE
========================================= */
.hero-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 40px;
    line-height: 100%;
    letter-spacing: 0%;
    margin-bottom: 1.5rem;
}

.hero-title-highlight {
    color: var(--color-accent);
}

.hero-description {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 130%;
    letter-spacing: 0%;
    margin-bottom: 1.5rem;
}

.btn-outline-light:hover {
    color: var(--color-primary) !important;
}

.btn-hero-contact {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 12px;
    line-height: 150%;
    letter-spacing: 0%;
    color: var(--color-bg-white) !important;
}

.btn-hero-start {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 12px;
    line-height: 150%;
    letter-spacing: 0%;
    color: var(--color-primary) !important;
}

/* =========================================
   🟨 ALERTAS
========================================= */
.estilo-aler {
    padding: 10px !important;
}

.estilo-aler-close {
    margin-top: -10px !important;
}

.success-alert-icos {
    color: var(--color-success) !important;
}

.danger-alert-icos {
    color: var(--color-danger) !important;
}

.warning-alert-icos {
    color: var(--color-warning) !important;
}

/* =========================================
   🗂️ COMPONENTES VARIOS
========================================= */
h1 {
    font-weight: 700 !important;
    font-size: 28px !important;
}

.text-adro {
    color: var(--color-secondary) !important;
    font-weight: 700;
}

.modal-title {
    color: var(--color-text-tertiary) !important;
    font-weight: 500 !important;
    font-size: 20px !important;
}

.modal {
    z-index: 9999 !important;
}

.datepicker-footer {
    margin-top: 10px;
}

.datepicker-main {
    z-index: 1056;
}

.volver {
    color: var(--color-text-primary) !important;
    font-weight: 600 !important;
    font-size: 16px !important;
}

.card {
    border-radius: 20px !important;
    padding: 32px !important;
}

.subtitle {
    color: var(--color-text-primary) !important;
    font-weight: 600 !important;
    font-size: 18px !important;
}

hr {
    background-color: var(--color-border-light) !important;
    border-radius: 1px !important;
    height: 3px !important;
}

.confirm_clearCache_span{
    font-weight: 400;
    font-size: 14px;
    line-height: 120%;
    letter-spacing: 0%;
    color: var(--color-text-secondary);
}



.back{
    font-weight: 900!important;
    font-size: 25px!important;
    color: var(--color-primary)!important;
    cursor: pointer;
    position: absolute!important;
    margin-top: -6.5px!important;
    margin-left: -20px!important;
}

.nav-link.active {
    background-color: var(--color-bg-transparent) !important;
    border-bottom: 3px solid var(--color-primary)!important; /* solo borde inferior */
    color: var(--color-secondary)!important; /* color del texto */
  }

#hrTag {
    margin-top: -16px !important;
    height: 1px !important; /* grosor de la línea */
    background-color: var(--color-text-primary) !important; /* color de la línea */
    border: none !important; /* elimina bordes por defecto */
}

.tabsubmenu{
    font-weight: 700!important;
    font-size: 13px!important;
    line-height: 100%!important;
    letter-spacing: 0%!important;
    color: var(--color-text-secondary)!important;

}

#form .owari-radial-group{
    position: relative!important;
    margin-top: 32px!important;
}

.select-input {
    max-width: 90%;           /* Asegura que el input no se desborde */
    text-overflow: ellipsis;  /* Agrega los "..." si el texto es muy largo */
    white-space: nowrap;      /* Evita que el texto se divida en varias líneas */
    overflow: hidden;         /* Oculta el texto que se pasa del límite */
    direction: ltr;           /* Asegura comportamiento esperado del texto */
  }
.select-input:focus{
    border: style none!important;
}

  .select-dropdown-container {
    width: fit-content !important;
    max-width: 100%; /* opcional, para limitar el ancho máximo */
  } 

  .day-field-wrapper{
    color: var(--color-secondary) !important;
    font-weight: 500!important;
    font-size: 16px!important;
    line-height: 100%!important;
    letter-spacing: 0%!important;
    text-align: center!important;


  }

  .today > .day-field-wrapper > .day-field{
    background-color: var(--color-accent) !important;
  }

/* Celdas con eventos: cursor pointer en la celda y todo su contenido */
#calendar table tbody td:has(.event),
#calendar table tbody td:has(.event) * {
  cursor: pointer;
}

.card-tarjeta-pago {
    width: 100%;
    height: 100%;
    border-radius: 20px;
    padding: 16px;
    background: linear-gradient(135deg, var(--color-dark-gradient-1) 0%, var(--color-dark-gradient-2) 40%, var(--color-dark-gradient-1) 100%);
    color: var(--color-bg-white);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    box-shadow: 0 6px 24px var(--color-shadow-medium), 0 2px 8px var(--color-shadow-light);
    border: 1px solid var(--color-dark-gradient-2);
    position: relative;
    overflow: hidden;
}

.card-tarjeta-pago::before,
.card-tarjeta-pago::after {
    content: "";
    position: absolute;
    z-index: 0;
    pointer-events: none;
}

.card-tarjeta-pago::before {
    top: -40px;
    left: -60px;
    width: 70%;
    height: 80%;
    background: linear-gradient(120deg, var(--color-dark-overlay-1) 60%, var(--color-dark-overlay-2) 100%);
    clip-path: polygon(0 0, 100% 0, 60% 100%, 0 80%);
    opacity: 0.7;
}

.card-tarjeta-pago::after {
    bottom: -30px;
    right: -40px;
    width: 60%;
    height: 60%;
    background: linear-gradient(100deg, var(--color-dark-overlay-3) 0%, var(--color-dark-overlay-4) 100%);
    clip-path: polygon(40% 0, 100% 20%, 100% 100%, 0 100%);
    opacity: 0.5;
}

/* Chip dorado estilo tarjeta con patrón de líneas internas */
.card-chip {
    position: absolute;
    top: 24px;
    left: 24px;
    width: 48px;
    height: 36px;
    border-radius: 8px;
    box-shadow: 0 2px 6px var(--color-shadow-card);
    border: 1.5px solid var(--color-gold);
    z-index: 2;
    overflow: hidden;
    background-color: var(--color-gold-lighter);
}
.card-chip::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(135deg, var(--color-gold-lighter) 60%, var(--color-gold) 100%);
    border-radius: 8px;
    opacity: 0.85;
}
.card-chip::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    /* SVG con patrón de líneas asimétricas, líneas dorado más claro */
    background-image: url("data:image/svg+xml;utf8,<svg width='48' height='36' xmlns='http://www.w3.org/2000/svg'><rect x='2' y='2' width='44' height='32' rx='6' fill='none' stroke='%23bfa040' stroke-width='2'/><line x1='2' y1='14' x2='32' y2='14' stroke='%23d6b85a' stroke-width='1.3'/><line x1='32' y1='2' x2='32' y2='34' stroke='%23d6b85a' stroke-width='1.3'/><line x1='2' y1='26' x2='18' y2='26' stroke='%23d6b85a' stroke-width='1.3'/><line x1='18' y1='26' x2='18' y2='34' stroke='%23d6b85a' stroke-width='1.3'/><line x1='18' y1='26' x2='32' y2='26' stroke='%23d6b85a' stroke-width='1.3'/><line x1='2' y1='22' x2='18' y2='22' stroke='%23d6b85a' stroke-width='1.3'/><line x1='2' y1='10' x2='32' y2='10' stroke='%23d6b85a' stroke-width='1.3'/><line x1='38' y1='2' x2='38' y2='34' stroke='%23d6b85a' stroke-width='1.3'/></svg>");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    background-position: center;
    border-radius: 8px;
    opacity: 1;
}

.btn{
    /* Estilo base que conserve el texto original que no pase todo en mayuscula */
    text-transform: none !important;


}


.decimal-card {
    font-weight: 500;
    font-style: Medium;
    font-size: 1.1rem;
    line-height: 100%;
    letter-spacing: 0%;

}

.text-sub{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 18px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-text-primary);

}

.btn-detalle-input {
    font-family: Montserrat;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 14px;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-secondary);
    display: flex;
    justify-content: flex-end;
    align-items: center;         /* Centra verticalmente el contenido */
    margin-right: 10px;
    text-align: right;
    position: absolute;
    top: 50%;                    /* Posiciona desde el centro vertical */
    right: 0;
    transform: translateY(-50%); /* Ajusta para centrar exactamente */
    cursor: pointer;
}

/*
* aca miraremos si tiene la clase Moneda y la clase readonly para ponerlo gricesito el fondo del input
*/
input.Moneda[readonly] {
    
    background-color: var(--color-bg-input-disabled) !important;
    cursor: not-allowed;
}

.botones-acciones{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 12px;
    leading-trim: NONE;
    line-height: 150%;
    letter-spacing: 0%;
    color: var(--color-primary);
    cursor: pointer;

}

.botones-acciones-agregar{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 12px;
    leading-trim: NONE;
    line-height: 150%;
    letter-spacing: 0%;
    color: var(--color-primary);
    cursor: pointer;

}

.botones-acciones-agregar.disabled,
.botones-acciones-agregar:disabled {
    color: var(--color-text-disabled) !important;
    cursor: not-allowed !important;
}

.mensaje-degrupo{
    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 16px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-primary);

}

.card-degrupo{
    opacity: 1!important;
    border-width: 1px!important;
    border-style: solid!important;
    box-shadow: none!important;
    border-color: var(--color-border-medium)!important;
    padding-top: 12px!important;

}

.card-grandie{
    background: linear-gradient(96.34deg, var(--color-primary) 1.45%, var(--color-primary-gradient) 45.56%, var(--color-primary) 94.72%);
    box-shadow: 0px 4px 24px var(--color-shadow-grandie);
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
}

.content-text-hero{
    margin-top: -27px!important;
}

.text-align-left{
    text-align: left!important;
}

.sub_titulo_inicio{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 32px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-secondary);
}

.sub_titulo_p_inicio{
    font-family: Montserrat;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 18px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-text-primary)!important;
}

.sub_titulo_span_inicio{
    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 18px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-text-primary)!important;
}
.titulo_inicio{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 32px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: var(--color-secondary);

}

.sub_titulo_span{
    font-family: Montserrat;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 16px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-text-primary)!important;

}

#cars-info .card{
    padding: 24px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
}

#planes .card{
    padding: 6px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
}

#planes .card .card {
    border-color: var(--color-border-cyan)!important;
    box-shadow: none!important;
    border-style: solid!important;
    border-width: 1px!important;
    width: 100% !important;
}

.fa-check-inicio{
    margin-left: 5px!important;
    color: var(--color-primary)!important;
    padding-right: 8px!important;
}

#plan_recomendado {
    margin-left: 6px !important;
    opacity: 1;
    border-radius: 32px;
    padding: 4px 10px !important;
    background: var(--color-accent) !important;

    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 14px;
    line-height: 1 !important;
    letter-spacing: 0%;

    vertical-align: middle;
    position: relative;
    top: -2px; /* Ajusta este valor según lo que necesites */
}

#cars-info .card i {
    margin-bottom: auto !important;
}

#cars-info .card span {
    margin-top: auto !important;
}

#cars-info .row {
    align-items: stretch !important;
}

#cars-info [class*='col'] {
    display: flex !important;
}

#cars-info .card {
    width: 100% !important;
    height: 100% !important;
}

.text-badge-comentario{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 14px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;

}

.text-nombre-comentario{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 20px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-primary)!important;
}

.text-cargo-comentario{
    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 16px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-text-secondary)!important;
}

.text-descripcion-comentario{
    font-family: Montserrat;
    font-size: 16px;
    leading-trim: NONE;
    line-height: 1.5 !important;
    color: var(--color-text-primary)!important;
    text-align: left!important;
}

#contenedor-mensaje-unico{
    background-color: var(--color-accent) !important;
}

.tabsubmenu {
    text-transform: lowercase !important;
}

.tabsubmenu::first-letter {
    text-transform: uppercase !important;
}

.card-estadisticas {
    width: 100%;
    height: 100%;
    border-radius: 20px;
    padding: 16px;
    background: linear-gradient(135deg, var(--color-bg-white-keyword) 0%, var(--color-bg-white-keyword) 40%, var(--color-bg-white-keyword) 100%);
    color: var(--color-text-primary);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
}

.card-est{
    padding: 16px !important;
    padding-top: 30px !important;
}

.card-est-1{
    padding: 16px !important;
}

.card-est > .row > .col-4 span {
    margin-left: 10px !important;
}

.hr-total{
    border: none !important;
    position: relative !important;
}

.hr-total::after {
    content: "" !important;
    position: absolute !important;
    right: 0 !important;
    top: 10% !important;
    bottom: 10% !important;
    width: 1px !important;
    background-color: var(--color-border-lighter) !important;
}

@media (max-width: 768px) {
    .card-estadisticas {
        padding: 10;
    }
}

.titulos-tag-estadisticas{
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 11px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-text-primary) !important;
}

.titulos-tag-estadisticas-1 {
    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 12px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-secondary) !important;

}

.titulos-tag-estadisticas-2 {
    font-family: Montserrat;
    font-weight: 400;
    font-style: Regular;
    font-size: 10px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-secondary) !important;
}

.subtitulo-tag-estadisticas-1 {
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 24px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-primary) !important;

}

.subtitulo-tag-estadisticas-2 {
    font-family: Montserrat;
    font-weight: 700;
    font-style: Bold;
    font-size: 16px;
    leading-trim: NONE;
    line-height: 160%;
    letter-spacing: 0%;
    color: var(--color-text-primary) !important;
}

.subtitulo-tag-estadisticas{
    font-family: Montserrat;
    font-weight: 600;
    font-size: 10px;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--color-text-primary) !important;
}

.badge-agro{
    background-color: var(--color-accent) !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    border-top-left-radius: 20px !important;
    border-bottom-left-radius: 0px !important;
    border-top-right-radius: 0px !important;
    padding: 10px !important;
}

#inventario_de_arboles {
    display: block !important;
    max-height: 280px !important;
    width: 100% !important;
    overflow-y: auto !important;
    overflow-x: auto !important;
    table-layout: fixed !important;
}

#inventario_de_arboles thead {
    position: sticky !important;
    top: 0 !important;
    background-color: var(--color-bg-white-keyword) !important;
    z-index: 10 !important;
    display: table !important;
    width: 100% !important;
    table-layout: fixed !important;
}

#inventario_de_arboles tbody {
    display: table !important;
    width: 100% !important;
    table-layout: fixed !important;
}

#ultima_recoleccion {
    display: block !important;
    max-height: 300px !important;
    width: 100% !important;
    overflow-y: auto !important;
    overflow-x: auto !important;
    table-layout: fixed !important;
}

#ultima_recoleccion thead {
    position: sticky !important;
    top: 0 !important;
    background-color: var(--color-bg-white-keyword) !important;
    z-index: 10 !important;
    display: table !important;
    width: 100% !important;
    table-layout: fixed !important;
}

#ultima_recoleccion tbody {
    display: table !important;
    width: 100% !important;
    table-layout: fixed !important;
}


#control_de_empleados {
    display: block !important;
    max-height: 250px !important;
    width: 100% !important;
    overflow-y: auto !important;
    overflow-x: auto !important;
    table-layout: fixed !important;
}

#control_de_empleados thead {
    position: sticky !important;
    top: 0 !important;
    background-color: var(--color-bg-white-keyword) !important;
    z-index: 10 !important;
    display: table !important;
    width: 100% !important;
    table-layout: fixed !important;
}

#control_de_empleados tbody {
    display: table !important;
    width: 100% !important;
    table-layout: fixed !important;
}

.pagination-btn.btn-agro.disabled{
    background-color: var(--color-primary) !important;
    color: var(--color-bg-white) !important;
    opacity: 1 !important;
}

.pagination-btn.btn-agro{
    background-color: var(--color-bg-white) !important;
    color: var(--color-text-primary) !important;
    opacity: 1 !important;
}

.title-card-agro{
    font-family: Montserrat;
    font-weight: 700;
    font-style: bold;
    font-size: 14px;
    color: var(--color-text-primary) !important;
}

/* =========================================
   🎨 SELECTOR DE COLORES PERSONALIZADO
   ========================================= */
.color-picker-wrapper {
    position: relative;
}

.color-picker-btn:hover {
    opacity: 0.85;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.color-picker-btn:active {
    transform: translateY(-50%) scale(0.98);
}

.color-picker-input {
    text-align: center !important;
}

.color-picker-input:focus {
    color: transparent !important;
}

.color-picker-dropdown {
    position: fixed !important;
    background: white;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    z-index: 99999 !important;
    min-width: 240px;
    max-width: 280px;
}

.color-picker-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 8px;
    margin-bottom: 12px;
}

.color-picker-option {
    width: 32px;
    height: 32px;
    border-radius: 4px;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s;
    position: relative;
}

.color-picker-option:hover {
    transform: scale(1.1);
    border-color: var(--color-primary);
}

.color-picker-option.selected {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px white, 0 0 0 4px var(--color-primary);
}

.color-picker-option.selected::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-weight: bold;
    font-size: 16px;
    text-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
}




/* Ajustes puntuales para elementos que no usan variables */
[data-mdb-theme="dark"] body {
    background-color: var(--color-bg-body);
}

[data-mdb-theme="dark"] .card {
    background-color: var(--color-bg-card) !important;
    border-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] hr {
    background-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] .hr-table {
    background-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] #main-navbar {
    background-color: var(--color-bg-white) !important;
    border-bottom: 1px solid var(--color-border-light);
}

[data-mdb-theme="dark"] #main-sidenav {
    background-color: var(--color-bg-white) !important;
}

[data-mdb-theme="dark"] .dropdown-menu {
    background-color: var(--color-bg-white) !important;
    border-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] .dropdown-item:hover {
    background-color: var(--color-bg-lighter) !important;
}

[data-mdb-theme="dark"] .dropdown-divider {
    border-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] .text-adro {
    color: var(--color-primary) !important;
}

/* Loading screen — inline style hardcodeado en loadingWeb.js */
[data-mdb-theme="dark"] #loading-screen {
    background-color: var(--color-bg-body) !important;
}

/* Spinner overlay de table-rowAsinc — inline style rgba(255,255,255,0.8) */
[data-mdb-theme="dark"] #table-loading-spinner {
    background: rgba(18, 18, 18, 0.85) !important;
}

/* Las filas de tabla usan bg-white de MDB que es !important hardcodeado */
[data-mdb-theme="dark"] .bg-white {
    background-color: var(--color-bg-card) !important;
}

/* Texto dentro de las filas */
[data-mdb-theme="dark"] .bg-white span,
[data-mdb-theme="dark"] .bg-white p {
    color: var(--color-text-primary) !important;
}

/* Cabecera de tabla (thead.table-light) — en dark aparece gris claro de MDB */
[data-mdb-theme="dark"] .table-light,
[data-mdb-theme="dark"] .table-light > * {
    --mdb-table-bg: var(--color-bg-lighter);
    --mdb-table-color: var(--color-text-primary);
    background-color: var(--color-bg-lighter) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border-medium) !important;
}

/* Filas de tabla body en dark */
[data-mdb-theme="dark"] .table > tbody > tr > td,
[data-mdb-theme="dark"] .table > tbody > tr > th {
    background-color: var(--color-bg-card) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] .table > tbody > tr:hover > td,
[data-mdb-theme="dark"] .table > tbody > tr:hover > th {
    background-color: var(--color-bg-lighter) !important;
}

/* Modal (new_item_tabla_simple) — sin override MDB pone gris */
[data-mdb-theme="dark"] .modal-content {
    background-color: var(--color-bg-white) !important;
    border-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] .modal-header,
[data-mdb-theme="dark"] .modal-footer {
    background-color: var(--color-bg-white) !important;
    border-color: var(--color-border-light) !important;
}

[data-mdb-theme="dark"] .modal-title,
[data-mdb-theme="dark"] .modal-body {
    color: var(--color-text-primary) !important;
}

/* =========================================
   💳 PLAN CARDS — compartido entre index y modal suscripción
========================================= */
.plan-toggle-wrap {
    display: flex;
    justify-content: center;
    margin: 0 0 40px;
}
.plan-toggle {
    background: white;
    padding: 6px;
    border-radius: 999px;
    display: inline-flex;
    box-shadow: 0 2px 10px rgba(20,40,38,.06);
    position: relative;
}
.plan-toggle button {
    appearance: none;
    border: 0;
    background: transparent;
    font-family: inherit;
    font-weight: 700;
    font-size: 15px;
    color: #6B6B6B;
    padding: 12px 28px;
    border-radius: 999px;
    cursor: pointer;
    position: relative;
    z-index: 2;
    transition: color .25s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.plan-toggle button.active { color: white; }
.plan-pill {
    position: absolute;
    top: 6px; bottom: 6px;
    left: 6px;
    width: calc(50% - 6px);
    background: #00897A;
    border-radius: 999px;
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    z-index: 1;
    box-shadow: 0 4px 12px rgba(0,137,122,.3);
}
.plan-toggle[data-mode="anual"] .plan-pill { transform: translateX(100%); }
.plan-save-tag {
    background: #8BC53F;
    color: white;
    font-size: 10px;
    padding: 3px 7px;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .04em;
}
.plan-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    align-items: stretch;
    padding: 0 4px;
}
.plan-card {
    background: #FFFFFF;
    border-radius: 14px !important;
    padding: 28px 26px 26px;
    box-shadow: 0 2px 14px rgba(20,40,38,.06) !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 320px;
    position: relative;
    transition: transform .2s ease, box-shadow .2s ease;
    border: none !important;
}
.plan-card.recom {
    box-shadow: 0 8px 28px rgba(0,137,122,.14) !important;
}
.plan-badge-recom {
    position: absolute;
    top: -14px;
    right: 22px;
    background: #8BC53F;
    color: white;
    font-weight: 800;
    font-size: 12px;
    padding: 5px 12px;
    border-radius: 999px;
    letter-spacing: .04em;
}
.plan-name {
    font-weight: 800;
    font-size: 24px;
    color: #3C3C3C;
    line-height: 1.1;
    margin: 0 0 4px;
    letter-spacing: -0.2px;
    text-transform: capitalize;
}
.plan-period-label {
    font-weight: 600;
    font-size: 12px;
    color: #6B6B6B;
    margin-bottom: 14px;
    letter-spacing: .04em;
    text-transform: capitalize;
}
.plan-pricing {
    display: flex;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 4px;
}
.plan-amount {
    font-weight: 800;
    font-size: 27px;
    color: #3C3C3C;
    letter-spacing: -0.4px;
}
.plan-per {
    font-weight: 500;
    font-size: 15px;
    color: #3C3C3C;
}
.plan-strike {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #6B6B6B;
    margin-bottom: 16px;
    min-height: 18px;
}
.plan-strike s { text-decoration-thickness: 1.5px; }
.plan-save-num { color: #00897A; font-weight: 800; margin-left: 4px; }
.plan-features {
    border: 1.5px solid #BFE4DE;
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 18px;
    flex: 1;
    list-style: none;
}
.plan-features.highlight { background: #DFF3EF; }
.plan-feature {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    color: #3C3C3C;
    font-weight: 500;
    padding: 5px 0;
    line-height: 1.35;
}
.plan-feature svg {
    flex: 0 0 16px;
    margin-top: 2px;
    color: #00897A;
}
.plan-feature b { font-weight: 800; }
.plan-cta {
    appearance: none;
    border: 1.5px solid #00897A;
    background: transparent;
    color: #00897A;
    font-family: inherit;
    font-weight: 700;
    font-size: 14px;
    padding: 12px 18px;
    border-radius: 999px;
    cursor: pointer;
    transition: background .15s ease, color .15s ease, transform .12s ease;
    width: 100%;
    letter-spacing: .2px;
}
.plan-cta:hover { background: #00897A; color: white; }
.plan-cta.filled { background: #00897A; color: white; }
.plan-cta.filled:hover { background: #007A6F; transform: translateY(-1px); }
/* Comparison table */
.plan-compare {
    margin-top: 48px;
    background: white;
    border-radius: 14px;
    box-shadow: 0 2px 14px rgba(20,40,38,.06);
    padding: 28px 32px 32px;
}
.plan-compare h2 {
    margin: 0 0 20px;
    color: #007A6F;
    font-weight: 800;
    font-size: 20px;
}
table.plan-cmp { width: 100%; border-collapse: collapse; font-size: 14px; }
table.plan-cmp th, table.plan-cmp td {
    padding: 12px 10px;
    text-align: center;
    border-bottom: 1px solid #EEF1F1;
}
table.plan-cmp thead th {
    color: #007A6F;
    font-weight: 800;
    font-size: 14px;
    border-bottom: 2px solid #BFE4DE;
    padding-bottom: 10px;
}
table.plan-cmp tbody tr td:first-child {
    text-align: left;
    color: #3C3C3C;
    font-weight: 600;
}
table.plan-cmp tbody tr:hover { background: #FAFCFC; }
table.plan-cmp .ok { color: #00897A; font-weight: 800; }
table.plan-cmp .no { color: #C8CDCE; font-weight: 700; }
table.plan-cmp .num { font-weight: 800; color: #3C3C3C; }
table.plan-cmp .col-recom { background: linear-gradient(180deg, #F4FBF9 0%, #FFFFFF 100%); }
table.plan-cmp thead th.col-recom::after {
    content: "Recomendado";
    display: inline-block;
    margin-left: 6px;
    background: #8BC53F;
    color: white;
    font-size: 10px;
    font-weight: 800;
    padding: 3px 7px;
    border-radius: 999px;
    vertical-align: middle;
    letter-spacing: .04em;
}
.plan-footnote {
    text-align: center;
    margin-top: 24px;
    color: #6B6B6B;
    font-size: 13px;
    font-weight: 500;
}
.plan-footnote b { color: #3C3C3C; font-weight: 700; }
@media (max-width: 1100px) {
    .plan-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .plan-grid { grid-template-columns: 1fr; }
    table.plan-cmp { font-size: 12px; }
    table.plan-cmp th, table.plan-cmp td { padding: 8px 6px; }
}

/* =========================================
   🔐 LOGIN — hero al fondo + card solo para form
========================================= */
body.login-page {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-gradient) 50%, var(--color-secondary) 100%);
    background-attachment: fixed;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    min-height: 100vh;
    color: var(--color-text-white);
}

body.login-page main {
    margin-top: 0 !important;
    margin-left: 0 !important;
}

.login-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr auto;
    min-height: 100vh;
    width: 100%;
    padding: 48px 56px;
    gap: 32px;
    align-items: stretch;
}

/* --- Panel hero (sobre fondo, sin card) --- */
.login-hero {
    position: relative;
    grid-column: 1;
    grid-row: 1;
    background: transparent;
    color: var(--color-text-white);
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 32px;
}

.login-hero-logo {
    width: 168px;
    background: var(--color-bg-body);
    border-radius: 16px;
    padding: 14px 18px;
    box-shadow: 0 4px 16px var(--color-shadow-card);
}

.login-hero-logo img {
    width: 100%;
    height: auto;
    display: block;
}

.login-hero-content {
    margin: auto 0;
}

.login-hero-kicker {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: clamp(13px, 1.1vw, 18px);
    letter-spacing: 0.18em;
    color: var(--color-text-white);
    opacity: 0.85;
    display: block;
    margin-bottom: 22px;
}

.login-hero-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 900 !important;
    font-size: clamp(40px, 4.4vw, 76px) !important;
    line-height: 0.95;
    letter-spacing: -0.01em;
    margin: 0;
    text-transform: uppercase;
    color: var(--color-text-white);
}

.login-hero-title-accent {
    color: var(--color-accent);
    display: inline-block;
    margin-top: 6px;
}

.login-hero-footer {
    grid-column: 1;
    grid-row: 2;
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(10.5px, 0.7vw, 13px);
    color: var(--color-text-white);
    opacity: 0.75;
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: nowrap;
    white-space: nowrap;
    margin-top: 24px;
}

.login-hero-footer > * {
    white-space: nowrap;
}

.login-hero-footer a {
    color: var(--color-text-white);
    text-decoration: underline;
    opacity: 0.9;
}

.login-hero-footer a:hover {
    opacity: 1;
}

/* --- Panel formulario (derecha): solo centra el card --- */
.login-form-area {
    grid-column: 2;
    grid-row: 1 / span 2;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    background: transparent;
}

/* --- Card que envuelve SOLO el formulario --- */
.login-form-inner {
    width: 100%;
    max-width: 480px;
    background-color: var(--color-bg-body);
    border-radius: 28px;
    padding: 44px 40px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.35);
}

.login-form-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 22px;
    color: var(--color-primary);
    margin: 0 0 22px;
}

/* Botón Google */
.login-google-btn {
    width: 100%;
    background: var(--color-bg-white);
    border: 1px solid var(--color-border-light);
    border-radius: 12px;
    padding: 12px 16px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    font-size: 14px;
    color: var(--color-text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    cursor: pointer;
    transition: box-shadow 0.2s, transform 0.1s;
}

.login-google-btn:hover {
    box-shadow: 0 4px 12px var(--color-shadow-light);
}

.login-google-btn:active {
    transform: translateY(1px);
}

.login-google-btn svg,
.login-google-btn img {
    width: 18px;
    height: 18px;
}

/* Divisor "O CON TU CORREO" */
.login-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px 0 18px;
    color: var(--color-text-secondary);
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.15em;
}

.login-divider::before,
.login-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background-color: var(--color-border-medium);
    opacity: 0.5;
}

/* Inputs dentro del card: fondo blanco para que destaquen */
.login-form-area .form-outline .form-control {
    background-color: var(--color-bg-white);
}

.login-form-area .form-outline {
    margin-bottom: 14px;
}

/* Opciones: mostrar contraseña + recordarme */
.login-options {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin: 6px 0 14px;
    flex-wrap: wrap;
}

.login-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    color: var(--color-text-primary);
    cursor: pointer;
    user-select: none;
    margin: 0;
}

.login-check input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary);
    cursor: pointer;
}

.login-check-accent input[type="checkbox"] {
    accent-color: var(--color-accent);
}

/* Link olvidé contraseña */
.login-forgot {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    color: var(--color-text-primary);
    text-decoration: underline;
    margin-bottom: 22px;
    cursor: pointer;
}

.login-forgot:hover {
    color: var(--color-primary);
}

/* Botón principal pill verde lima */
.btn-login-pill {
    width: auto;
    min-width: 180px;
    background-color: var(--color-accent);
    color: var(--color-bg-white);
    border: none;
    border-radius: 999px;
    padding: 13px 36px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.2s, box-shadow 0.2s, transform 0.1s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-login-pill:hover {
    background-color: #a6d04e;
    box-shadow: 0 4px 14px rgba(144, 194, 61, 0.35);
    color: var(--color-bg-white);
}

.btn-login-pill:active {
    transform: translateY(1px);
}

.btn-login-pill:disabled {
    background-color: var(--color-text-disabled);
    cursor: not-allowed;
    box-shadow: none;
}

/* Texto Regístrate */
.login-signup {
    margin: 20px 0 0;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    color: var(--color-text-primary);
}

.login-signup-link {
    color: var(--color-primary);
    font-weight: 700;
    text-decoration: none;
}

.login-signup-link:hover {
    text-decoration: underline;
    color: var(--color-primary-hover);
}

/* Countdown (page 3) */
.login-countdown {
    color: var(--color-text-primary);
}

/* Bloques page: por defecto sin estructura visual extra (form.js los oculta/muestra) */
.login-page-block {
    width: 100%;
}

/* --- MÓVIL: stack hero arriba + card crema flotando debajo + footer al final --- */
@media (max-width: 991.98px) {
    .login-wrapper {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
        min-height: auto;
        padding: 28px 20px 32px;
        gap: 0;
    }

    .login-hero {
        grid-column: 1;
        grid-row: 1;
        min-height: auto;
        padding-bottom: 24px;
    }

    .login-form-area {
        grid-column: 1;
        grid-row: 2;
    }

    .login-hero-footer {
        grid-column: 1;
        grid-row: 3;
        margin-top: 28px;
        flex-wrap: wrap;
        white-space: normal;
        justify-content: center;
        text-align: center;
        font-size: 11px;
    }

    .login-hero-logo {
        width: 132px;
    }

    .login-hero-content {
        margin: 24px 0 0;
    }

    .login-hero-title {
        font-size: clamp(32px, 9vw, 48px) !important;
    }

    .login-form-inner {
        max-width: 100%;
        padding: 32px 24px;
        border-radius: 24px;
    }
}

@media (max-width: 480px) {
    .login-wrapper {
        padding: 20px 14px 24px;
    }
    .login-form-inner {
        padding: 26px 20px;
        border-radius: 20px;
    }
    .login-options {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
}

/* --- Cookie banner (aviso de cookies del login) --- */
.cookie-banner {
    border: none !important;
    border-radius: 24px !important;
    padding: 32px 36px 28px !important;
    background-color: var(--color-bg-white) !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18) !important;
}

.cookie-banner-body {
    display: flex;
    gap: 20px;
    align-items: flex-start;
}

.cookie-banner-icon {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background-color: var(--color-primary-bg-light);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    font-size: 26px;
}

.cookie-banner-content {
    flex: 1;
    min-width: 0;
}

.cookie-banner-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 800 !important;
    font-size: 22px !important;
    color: var(--color-primary);
    margin: 0 0 10px;
    line-height: 1.25;
}

.cookie-banner-desc {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    font-size: 14px;
    color: var(--color-text-primary);
    line-height: 1.55;
    margin: 0;
}

.cookie-banner-link {
    color: var(--color-primary);
    text-decoration: underline;
    font-weight: 600;
}

.cookie-banner-link:hover {
    color: var(--color-primary-hover);
}

.cookie-banner-footer {
    display: flex;
    justify-content: flex-end;
    margin-top: 22px;
}

.cookie-banner-btn {
    background-color: var(--color-primary);
    color: var(--color-bg-white);
    border: none;
    border-radius: 999px;
    padding: 12px 36px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.2s, box-shadow 0.2s, transform 0.1s;
}

.cookie-banner-btn:hover {
    background-color: var(--color-primary-hover);
    box-shadow: 0 6px 16px rgba(var(--color-primary-rgb), 0.35);
}

.cookie-banner-btn:active {
    transform: translateY(1px);
}

@media (max-width: 575.98px) {
    .cookie-banner {
        padding: 24px 22px 22px !important;
    }
    .cookie-banner-body {
        flex-direction: column;
        gap: 14px;
    }
    .cookie-banner-icon {
        width: 48px;
        height: 48px;
        font-size: 22px;
    }
    .cookie-banner-title {
        font-size: 19px !important;
    }
    .cookie-banner-footer {
        justify-content: center;
        margin-top: 18px;
    }
    .cookie-banner-btn {
        width: 100%;
    }
}

/* --- Dark mode ajustes login --- */
[data-mdb-theme="dark"] body.login-page {
    background-color: var(--color-bg-cream);
}

[data-mdb-theme="dark"] .login-hero-logo {
    background: var(--color-bg-body);
}

[data-mdb-theme="dark"] .login-google-btn {
    background: var(--color-bg-white);
    color: var(--color-text-primary);
    border-color: var(--color-border-medium);
}
