html {
  font-size: 90%;
}

/* Estilos para el ribbon de ambiente */
.corner-ribbon {
    width: 200px;
    background: #e43;
    position: fixed;
    top: 25px;
    left: -50px;
    /* Cambiar a right para la derecha */
    text-align: center;
    line-height: 50px;
    letter-spacing: 1px;
    color: #f0f0f0;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    box-shadow: 0 0 3px rgba(0, 0, 0, .3);
    z-index: 9999;
    pointer-events: none;
    /* Para que puedas hacer clic a través de ella */
    font-weight: bold;
    opacity: 0.8;
}

/* Colores dinámicos según entorno */

.env-local { /* Verde para Local */
    background: #28a745;
}
.env-qa { /* Amarillo para QA */
    background: #ffc107;
    color: #333;
}
.env-stag {
    background: #fd7e14;
}

/* Utilidades personalizadas para Dashboard */
.rounded-xl {
    border-radius: 12px !important;
}

.cursor-pointer {
    cursor: pointer;
}

@keyframes pulse {
    0% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(0.8); }
    100% { opacity: 1; transform: scale(1); }
}

.animate-pulse {
    animation: pulse 2s infinite ease-in-out;
}

.letter-spacing-sm {
    letter-spacing: 0.5px;
}

.letter-spacing-md {
    letter-spacing: 1px;
}

/* Card especial para Dashboard con mejor sombreado y definición */
.card-dashboard {
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.06) !important;
    border-radius: 12px !important;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.05), 0 1px 2px 0 rgba(0, 0, 0, 0.03) !important;
    transition: all 0.2s ease-in-out;
}

.card-dashboard:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.07), 0 4px 6px -2px rgba(0, 0, 0, 0.05) !important;
    border-color: rgba(99, 102, 241, 0.15) !important; /* Toque muy sutil del color primario */
}
