/* ========================================
   UTILWARE SOLUTIONS - BUTTON STYLES
   Estilos mejorados para botones tipo Material Design
   ======================================== */

/* Botones generales - reset de estilos in line */
button, .btn {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    cursor: pointer;
    user-select: none;
}

/* Efecto ripple (Material Design) */
button::before, .btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

button:active::before, .btn:active::before {
    width: 300px;
    height: 300px;
}

/* Botones primarios (azul) */
button[data-clientid*="Button"],
button[data-clientid*="Div"][style*="background-color:var(--vId-color-token-a)"],
button[data-clientid*="Div"][style*="background-color:#1565D8"] {
    box-shadow: 0 2px 4px rgba(21, 101, 216, 0.25) !important;
    transform: translateY(0);
}

button[data-clientid*="Button"]:hover,
button[data-clientid*="Div"][style*="background-color:var(--vId-color-token-a)"]:hover,
button[data-clientid*="Div"][style*="background-color:#1565D8"]:hover {
    box-shadow: 0 4px 12px rgba(21, 101, 216, 0.35) !important;
    transform: translateY(-2px);
}

button[data-clientid*="Button"]:active,
button[data-clientid*="Div"][style*="background-color:var(--vId-color-token-a)"]:active,
button[data-clientid*="Div"][style*="background-color:#1565D8"]:active {
    box-shadow: 0 1px 3px rgba(21, 101, 216, 0.3) !important;
    transform: translateY(0);
}

/* Botones secundarios (outline) */
button[data-clientid*="Button"][style*="background-color:#00000000"],
button[data-clientid*="Div"][style*="border-width:2px"],
button[data-clientid*="Div"][style*="background-color:transparent"] {
    box-shadow: none !important;
    transform: translateY(0);
    background-color: transparent !important;
    border: 2px solid currentColor !important;
}

button[data-clientid*="Button"][style*="background-color:#00000000"]:hover,
button[data-clientid*="Div"][style*="border-width:2px"]:hover,
button[data-clientid*="Div"][style*="background-color:transparent"]:hover {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15) !important;
    transform: translateY(-1px);
}

/* Botones blancos */
button[style*="background-color:#ffffff"],
button[style*="background-color:white"] {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1) !important;
}

button[style*="background-color:#ffffff"]:hover,
button[style*="background-color:white"]:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
    transform: translateY(-2px);
}

/* Animación suave para todos los botones */
button, .btn {
    will-change: transform, box-shadow;
}

/* Focus visible para accesibilidad */
button:focus-visible, .btn:focus-visible {
    outline: 2px solid #1565D8;
    outline-offset: 2px;
}

/* Deshabilitar estado */
button:disabled, .btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
}

/* Botón del header "Asesoría Gratuita" */
button#Button6NLo {
    transition: all 0.25s ease;
}

button#Button6NLo:hover {
    background-color: var(--vId-color-token-a) !important;
    color: white !important;
    border-color: var(--vId-color-token-a) !important;
    box-shadow: 0 4px 12px rgba(21, 101, 216, 0.3) !important;
}

/* Mejoras responsive */
@media (max-width: 768px) {
    button, .btn {
        min-height: 44px; /* Tamaño mínimo táctil recomendado */
    }

    button::before, .btn::before {
        display: none; /* Desactivar ripple en móvil para mejor rendimiento */
    }
}

/* Mejoras de accesibilidad */
@media (prefers-reduced-motion: reduce) {
    button, .btn {
        transition: none;
    }

    button::before, .btn::before {
        transition: none;
    }
}
