/* =================================
   CICUMBA LOGIN CARD - PALETA PASTEL VERDE SUAVE
   #6bc29a (verde pastel), #a8d8c0 (acento), #f0f5f2 (fondo)
   ================================= */

/* Fondo animado Open Peeps (multitud) — debajo del formulario */
#cicumba-login-crowd-canvas {
    position: fixed !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 0 !important;
    pointer-events: none !important;
    display: block !important;
    opacity: 0.92;
}

@media (prefers-reduced-motion: reduce) {
    #cicumba-login-crowd-canvas {
        opacity: 0;
        visibility: hidden;
    }
}

html.logon-page #app,
html.logon-page #logon-template-component,
html.logon-page .logon-main-container,
html.logon-page .logon-template-header {
    position: relative;
    z-index: 1;
}

/* --- Contenedores intermedios: transparentes (PROTEGER logon-main-container) --- */
html body #logon-template-component {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    border-color: transparent !important;
    outline: none !important;
    box-shadow: none !important;
}

html body .logon-main:not(.logon-main-container) {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    border-color: transparent !important;
    outline: none !important;
    box-shadow: none !important;
}

/* --- CARD PRINCIPAL (excluir header) --- */
#logon-template-component .logon-main .card:not(.logon-template-header),
#logon-template-component .logon-main-container .card:not(.logon-template-header),
.logon-main-container .card:not(.logon-template-header),
.logon-main .card:not(.logon-template-header),
.card:has(input[type="password"]) {
    background: rgba(255, 255, 255, 0.72) !important;
    background-color: rgba(255, 255, 255, 0.72) !important;
    backdrop-filter: blur(24px) saturate(130%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(130%) !important;
    border: 1px solid rgba(107, 194, 154, 0.18) !important;
    border-radius: 20px !important;
    box-shadow:
        0 8px 32px rgba(107, 194, 154, 0.08),
        0 2px 12px rgba(0, 0, 0, 0.04),
        inset 0 1px 0 rgba(255, 255, 255, 0.5) !important;
    position: relative !important;
    overflow: visible !important;
    color: #2d4a3e !important;
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

#logon-template-component .logon-main .card:not(.logon-template-header):hover,
.logon-main .card:not(.logon-template-header):hover,
.card:has(input[type="password"]):hover {
    border-color: rgba(107, 194, 154, 0.28) !important;
    box-shadow:
        0 16px 48px rgba(107, 194, 154, 0.12),
        0 4px 16px rgba(0, 0, 0, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.6) !important;
}

/* --- CARD BODY --- */
#logon-template-component .logon-main .card .card-body,
.logon-main .card .card-body,
.card:has(input[type="password"]) .card-body {
    background: transparent !important;
    color: #2d4a3e !important;
}


/* --- INPUTS --- */
#logon-template-component .logon-main .card input[type="text"],
#logon-template-component .logon-main .card input[type="password"],
#logon-template-component .logon-main .card .dxbl-text-edit-input,
#logon-template-component .logon-main .card .form-control,
html body.logon-page #logon-template-component input[type="text"],
html body.logon-page #logon-template-component input[type="password"],
.card:has(input[type="password"]) input[type="text"],
.card:has(input[type="password"]) input[type="password"],
.card:has(input[type="password"]) .form-control,
.card:has(input[type="password"]) .dxbl-text-edit-input {
    padding-left: 52px !important;
    background: rgba(240, 248, 243, 0.90) !important;
    background-color: rgba(240, 248, 243, 0.90) !important;
    border: 1.5px solid rgba(107, 194, 154, 0.32) !important;
    border-radius: 12px !important;
    box-shadow: inset 0 2px 4px rgba(107, 194, 154, 0.08) !important;
    transition: all 0.3s ease !important;
    font-size: 15px !important;
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    color: #2d4a3e !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    position: relative !important;
    z-index: 50 !important;
}

#logon-template-component .logon-main .card input::placeholder,
.card:has(input[type="password"]) input::placeholder {
    color: rgba(107, 194, 154, 0.50) !important;
}

/* Estabilidad visual con autofill (Chrome/Edge/Safari) */
#logon-template-component .logon-main .card input:-webkit-autofill,
#logon-template-component .logon-main .card input:-webkit-autofill:hover,
#logon-template-component .logon-main .card input:-webkit-autofill:focus,
.card:has(input[type="password"]) input:-webkit-autofill,
.card:has(input[type="password"]) input:-webkit-autofill:hover,
.card:has(input[type="password"]) input:-webkit-autofill:focus {
    -webkit-text-fill-color: #2d4a3e !important;
    box-shadow: 0 0 0 1000px rgba(240, 248, 243, 0.90) inset !important;
    -webkit-box-shadow: 0 0 0 1000px rgba(240, 248, 243, 0.90) inset !important;
    border: 1.5px solid rgba(107, 194, 154, 0.32) !important;
    transition: background-color 99999s ease-out 0s !important;
    caret-color: #2d4a3e !important;
}

/* Focus */
#logon-template-component .logon-main .card input[type="text"]:focus,
#logon-template-component .logon-main .card input[type="password"]:focus,
#logon-template-component .logon-main .card .dxbl-text-edit-input:focus,
html body.logon-page #logon-template-component input:focus,
.card:has(input[type="password"]) input:focus {
    background: rgba(255, 255, 255, 0.90) !important;
    background-color: rgba(255, 255, 255, 0.90) !important;
    border-color: rgba(107, 194, 154, 0.45) !important;
    box-shadow: 0 0 0 3px rgba(107, 194, 154, 0.12), inset 0 1px 3px rgba(107, 194, 154, 0.04) !important;
    outline: none !important;
    color: #1a3328 !important;
    transform: none !important;
}

/* DevExpress text-edit wrapper */
#logon-template-component .dxbl-text-edit,
html body.logon-page .dxbl-text-edit {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    border-radius: 12px !important;
    box-shadow: none !important;
}

/* --- BOTON PRINCIPAL (Inicia sesion) --- */
#logon-template-component .logon-main .card .logon-toolbar button,
#logon-template-component button[data-action-name="Inicia sesión"],
html body.logon-page .btn-primary,
html body.logon-page .dxbl-btn-primary,
button[data-action-name="Inicia sesión"],
.card:has(input[type="password"]) .btn-primary,
.card:has(input[type="password"]) .btn {
    background: linear-gradient(135deg, #2e8b57 0%, #339966 50%, #2e8b57 100%) !important;
    background-color: #2e8b57 !important;
    border: 1px solid #278a50 !important;
    border-radius: 12px !important;
    padding: 14px 24px !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    color: #ffffff !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.20) !important;
    letter-spacing: 0.5px !important;
    position: relative !important;
    overflow: hidden !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 12px rgba(46, 139, 87, 0.35) !important;
    cursor: pointer !important;
}

/* Hover */
#logon-template-component .logon-main .card .logon-toolbar button:hover,
button[data-action-name="Inicia sesión"]:hover,
html body.logon-page .btn-primary:hover,
.card:has(input[type="password"]) .btn-primary:hover {
    box-shadow: 0 6px 20px rgba(46, 139, 87, 0.40) !important;
    background: linear-gradient(135deg, #339966 0%, #3aad6e 50%, #339966 100%) !important;
    border-color: #2e8b57 !important;
}

/* --- ICONOS DE INPUT --- */
#logon-template-component .cicumba-login-icon,
html body.logon-page .cicumba-login-icon,
.card:has(input[type="password"]) .cicumba-login-icon {
    position: absolute !important;
    top: 50% !important;
    left: 12px !important;
    transform: translateY(-50%) !important;
    z-index: 100 !important;
    background: rgba(107, 194, 154, 0.15) !important;
    background-color: rgba(107, 194, 154, 0.15) !important;
    color: #4a9b76 !important;
    padding: 10px !important;
    border-radius: 10px !important;
    width: 26px !important; height: 26px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    pointer-events: none !important;
    border: 1px solid rgba(107, 194, 154, 0.15) !important;
    backdrop-filter: blur(8px) !important;
    box-shadow: 0 2px 8px rgba(107, 194, 154, 0.08) !important;
    transition: all 0.3s ease !important;
    animation: none !important;
}

/* --- LABELS --- */
#logon-template-component .logon-main .card label,
#logon-template-component .logon-main .card .form-label,
#logon-template-component .logon-main .card .dxbl-fl-cpt,
html body.logon-page .card label,
.card:has(input[type="password"]) label {
    color: #5a7d6d !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    letter-spacing: 0.3px !important;
}

/* Texto descripcion */
#logon-template-component .logon-main .card p,
#logon-template-component .logon-main .card span,
html body.logon-page .card p,
html body.logon-page .card span:not(.cicumba-login-icon):not(.dxbl-btn-caption) {
    color: #7a9b8d !important;
}

/* --- TITULOS --- */
#logon-template-component .logon-main .card h1,
#logon-template-component .logon-main .card h2,
#logon-template-component .logon-main .card h3,
.logon-page h1, .logon-page h2, .logon-page h3,
body.logon-page h1, body.logon-page h2, body.logon-page h3,
.card h1, .card h2, .card h3 {
    color: #2d4a3e !important;
    font-weight: 600 !important;
    text-shadow: none !important;
}

/* --- SELECTOR DE IDIOMA --- */
button[data-action-name="LanguageSwitcher"],
.dxbl-btn[data-action-name="LanguageSwitcher"],
.dxbl-btn.dxbl-btn-text-secondary[data-action-name="LanguageSwitcher"],
button.dxbl-btn.dxbl-btn-text-secondary[data-action-name="LanguageSwitcher"],
button.dxbl-btn.dxbl-btn-secondary[data-action-name="LanguageSwitcher"],
.dxbl-btn.dxbl-btn-secondary[data-action-name="LanguageSwitcher"] {
    background: rgba(107, 194, 154, 0.10) !important;
    background-color: rgba(107, 194, 154, 0.10) !important;
    color: #5a7d6d !important;
    border: 1px solid rgba(107, 194, 154, 0.15) !important;
    border-radius: 10px !important;
    padding: 8px 14px !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    transition: all 0.3s ease !important;
    min-width: min(100%, 320px) !important;
    max-width: 100% !important;
    justify-content: flex-start !important;
    box-sizing: border-box !important;
}

#logon-template-component button[data-action-name="LanguageSwitcher"] span,
.logon-template-header button[data-action-name="LanguageSwitcher"] span {
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    text-align: left !important;
}

button[data-action-name="LanguageSwitcher"]:hover,
.dxbl-btn[data-action-name="LanguageSwitcher"]:hover,
button.dxbl-btn.dxbl-btn-text-secondary[data-action-name="LanguageSwitcher"]:hover {
    background: rgba(107, 194, 154, 0.18) !important;
    color: #3a5a4a !important;
    border-color: rgba(107, 194, 154, 0.25) !important;
}

/* Icono globo del selector de idioma (img inyectada en JS): negro sólido */
#logon-template-component button[data-action-name="LanguageSwitcher"] img,
#logon-template-component button[data-action-name="LanguageSwitcher"] .cicumba-login-lang-globe,
.logon-template-header button[data-action-name="LanguageSwitcher"] img,
.dxbl-btn[data-action-name="LanguageSwitcher"] img {
    opacity: 1 !important;
    filter: brightness(0) !important;
}

/* Aviso inicial: pulso llamativo para indicar que se puede cambiar el idioma */
.cicumba-lang-hint-shell {
    position: relative;
    display: inline-flex;
    max-width: 100%;
    vertical-align: top;
    z-index: 3;
}

.cicumba-lang-hint-shell.cicumba-lang-switcher-hint::before,
.cicumba-lang-hint-shell.cicumba-lang-switcher-hint::after {
    content: "";
    position: absolute;
    inset: -8px;
    border-radius: 14px;
    pointer-events: none;
    border: 2px solid rgba(56, 178, 120, 0.75);
    box-shadow: 0 0 18px rgba(56, 178, 120, 0.35);
    animation: cicumba-login-lang-ring 1.35s ease-out infinite;
}

.cicumba-lang-hint-shell.cicumba-lang-switcher-hint::after {
    animation-delay: 0.68s;
}

@keyframes cicumba-login-lang-ring {
    0% {
        transform: scale(1);
        opacity: 0.95;
    }

    100% {
        transform: scale(1.18);
        opacity: 0;
    }
}

@keyframes cicumba-login-lang-switcher-blink {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(107, 194, 154, 0);
        border-color: rgba(107, 194, 154, 0.15) !important;
        background-color: rgba(107, 194, 154, 0.10) !important;
        transform: scale(1);
    }

    35%, 65% {
        box-shadow:
            0 0 0 5px rgba(56, 178, 120, 0.45),
            0 0 22px rgba(56, 178, 120, 0.55),
            0 0 42px rgba(212, 175, 55, 0.28) !important;
        border-color: rgba(34, 120, 78, 0.85) !important;
        background: linear-gradient(135deg, rgba(107, 194, 154, 0.38), rgba(212, 175, 55, 0.24)) !important;
        transform: scale(1.04);
    }
}

@keyframes cicumba-login-globe-bounce {
    0%, 100% {
        transform: translateY(0) rotate(0deg) scale(1);
    }

    25% {
        transform: translateY(-3px) rotate(-12deg) scale(1.12);
    }

    75% {
        transform: translateY(-3px) rotate(12deg) scale(1.12);
    }
}

button[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint,
.dxbl-btn[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint {
    position: relative;
    z-index: 1;
    animation: cicumba-login-lang-switcher-blink 0.95s ease-in-out 6 !important;
}

button[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint .cicumba-login-lang-globe,
.dxbl-btn[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint .cicumba-login-lang-globe,
button[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint img[src*="globe"],
.dxbl-btn[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint img[src*="globe"] {
    animation: cicumba-login-globe-bounce 0.95s ease-in-out 6 !important;
    transform-origin: center center;
}

@media (prefers-reduced-motion: reduce) {
    .cicumba-lang-hint-shell.cicumba-lang-switcher-hint::before,
    .cicumba-lang-hint-shell.cicumba-lang-switcher-hint::after {
        animation: none !important;
        opacity: 0.75;
        transform: none !important;
    }

    button[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint,
    .dxbl-btn[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint {
        animation: none !important;
        outline: 3px solid rgba(56, 178, 120, 0.75) !important;
        outline-offset: 3px !important;
        box-shadow: 0 0 0 6px rgba(56, 178, 120, 0.18) !important;
    }

    button[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint .cicumba-login-lang-globe,
    .dxbl-btn[data-action-name="LanguageSwitcher"].cicumba-lang-switcher-hint .cicumba-login-lang-globe {
        animation: none !important;
    }
}

/* =================================
   BOTONES OAUTH - PASTEL
   ================================= */

/* Estado normal */
#logon-template-component .logon-bottom-toolbar button,
#logon-template-component .logon-bottom-toolbar .dxbl-btn,
button[data-action-name="Google"],
button[data-action-name="Microsoft"],
button[data-action-name="Facebook"],
button[data-action-name="GitHub"],
.dxbl-btn[data-action-name="Google"],
.dxbl-btn[data-action-name="Microsoft"],
.dxbl-btn[data-action-name="Facebook"],
.dxbl-btn[data-action-name="GitHub"],
button.dxbl-btn.dxbl-btn-secondary[data-action-name="Google"],
button.dxbl-btn.dxbl-btn-secondary[data-action-name="Microsoft"],
button.dxbl-btn.dxbl-btn-secondary[data-action-name="Facebook"],
button.dxbl-btn.dxbl-btn-secondary[data-action-name="GitHub"],
.dxbl-btn.dxbl-btn-secondary[data-action-name="Google"],
.dxbl-btn.dxbl-btn-secondary[data-action-name="Microsoft"],
.dxbl-btn.dxbl-btn-secondary[data-action-name="Facebook"],
.dxbl-btn.dxbl-btn-secondary[data-action-name="GitHub"],
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="Google"],
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="Microsoft"],
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="Facebook"],
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="GitHub"] {
    background: rgba(255, 255, 255, 0.60) !important;
    background-color: rgba(255, 255, 255, 0.60) !important;
    color: #3a5a4a !important;
    border: 1px solid rgba(107, 194, 154, 0.18) !important;
    border-radius: 10px !important;
    transition: all 0.3s ease !important;
}

/* Hover */
#logon-template-component .logon-bottom-toolbar button:hover,
#logon-template-component .logon-bottom-toolbar .dxbl-btn:hover,
button[data-action-name="Google"]:hover,
button[data-action-name="Microsoft"]:hover,
button[data-action-name="Facebook"]:hover,
button[data-action-name="GitHub"]:hover,
.dxbl-btn[data-action-name="Google"]:hover,
.dxbl-btn[data-action-name="Microsoft"]:hover,
.dxbl-btn[data-action-name="Facebook"]:hover,
.dxbl-btn[data-action-name="GitHub"]:hover,
button.dxbl-btn.dxbl-btn-secondary[data-action-name="Google"]:hover,
button.dxbl-btn.dxbl-btn-secondary[data-action-name="Microsoft"]:hover,
button.dxbl-btn.dxbl-btn-secondary[data-action-name="Facebook"]:hover,
button.dxbl-btn.dxbl-btn-secondary[data-action-name="GitHub"]:hover,
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="Google"]:hover,
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="Microsoft"]:hover,
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="Facebook"]:hover,
.dxbl-btn.dxbl-btn-secondary.dxbl-toolbar-layout-block-item.dxbl-toolbar-btn.dxbl-toolbar-item.xaf-action[data-action-name="GitHub"]:hover {
    background: rgba(107, 194, 154, 0.12) !important;
    background-color: rgba(107, 194, 154, 0.12) !important;
    color: #2d4a3e !important;
    border-color: rgba(107, 194, 154, 0.30) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 15px rgba(107, 194, 154, 0.10) !important;
}

/* Focus */
#logon-template-component .logon-bottom-toolbar button:focus,
button[data-action-name="Google"]:focus,
button[data-action-name="Microsoft"]:focus,
button[data-action-name="Facebook"]:focus,
button[data-action-name="GitHub"]:focus {
    background: rgba(107, 194, 154, 0.12) !important;
    background-color: rgba(107, 194, 154, 0.12) !important;
    color: #2d4a3e !important;
    border-color: rgba(107, 194, 154, 0.30) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(107, 194, 154, 0.10) !important;
}

/* ICONOS IMG dentro de botones OAuth */
#logon-template-component .logon-bottom-toolbar button img,
#logon-template-component .logon-bottom-toolbar .dxbl-btn img,
button[data-action-name="Google"] img,
button[data-action-name="Microsoft"] img,
button[data-action-name="Facebook"] img,
button[data-action-name="GitHub"] img,
.dxbl-btn[data-action-name="Google"] img,
.dxbl-btn[data-action-name="Microsoft"] img,
.dxbl-btn[data-action-name="Facebook"] img,
.dxbl-btn[data-action-name="GitHub"] img {
    filter: none !important;
    opacity: 0.80 !important;
    transition: opacity 0.3s ease !important;
}

button[data-action-name="Google"]:hover img,
button[data-action-name="Microsoft"]:hover img,
button[data-action-name="Facebook"]:hover img,
button[data-action-name="GitHub"]:hover img,
button[data-action-name="Google"]:focus img,
button[data-action-name="Microsoft"]:focus img,
button[data-action-name="Facebook"]:focus img,
button[data-action-name="GitHub"]:focus img {
    opacity: 1 !important;
}

/* SVG OAuth (reemplazan <img>): Google / Microsoft conservan color; Facebook azul; GitHub negro marca */
#logon-template-component .logon-bottom-toolbar button[data-action-name="Google"] svg,
#logon-template-component .logon-bottom-toolbar button[data-action-name="Microsoft"] svg,
#logon-template-component .logon-bottom-toolbar button[data-action-name="GitHub"] svg,
button[data-action-name="Google"] svg,
button[data-action-name="Microsoft"] svg,
button[data-action-name="GitHub"] svg {
    flex-shrink: 0 !important;
    display: block !important;
}

button[data-action-name="Facebook"] svg path,
.cicumba-facebook-oauth-icon svg path {
    fill: #1877f2 !important;
}

button[data-action-name="GitHub"] svg path,
.cicumba-github-oauth-icon svg path {
    fill: #181717 !important;
}

button[data-action-name="Google"]:hover svg,
button[data-action-name="Microsoft"]:hover svg,
button[data-action-name="Facebook"]:hover svg,
button[data-action-name="GitHub"]:hover svg,
button[data-action-name="Google"]:focus svg,
button[data-action-name="Microsoft"]:focus svg,
button[data-action-name="Facebook"]:focus svg,
button[data-action-name="GitHub"]:focus svg {
    opacity: 1 !important;
}

/* Texto caption */
#logon-template-component .logon-bottom-toolbar .dxbl-btn-caption,
button[data-action-name="Google"] .dxbl-btn-caption,
button[data-action-name="Microsoft"] .dxbl-btn-caption,
button[data-action-name="Facebook"] .dxbl-btn-caption,
button[data-action-name="GitHub"] .dxbl-btn-caption,
button[data-action-name="Google"] span,
button[data-action-name="Microsoft"] span,
button[data-action-name="Facebook"] span,
button[data-action-name="GitHub"] span {
    color: #3a5a4a !important;
}

button[data-action-name="Google"]:hover .dxbl-btn-caption,
button[data-action-name="Microsoft"]:hover .dxbl-btn-caption,
button[data-action-name="Facebook"]:hover .dxbl-btn-caption,
button[data-action-name="GitHub"]:hover .dxbl-btn-caption,
button[data-action-name="Google"]:hover span,
button[data-action-name="Microsoft"]:hover span,
button[data-action-name="Facebook"]:hover span,
button[data-action-name="GitHub"]:hover span,
button[data-action-name="Google"]:focus .dxbl-btn-caption,
button[data-action-name="Microsoft"]:focus .dxbl-btn-caption,
button[data-action-name="Facebook"]:focus .dxbl-btn-caption,
button[data-action-name="GitHub"]:focus .dxbl-btn-caption,
button[data-action-name="Google"]:focus span,
button[data-action-name="Microsoft"]:focus span,
button[data-action-name="Facebook"]:focus span,
button[data-action-name="GitHub"]:focus span {
    color: #2d4a3e !important;
}

/* =================================
   NUCLEAR OVERRIDE DEVEXPRESS OAUTH - PASTEL
   ================================= */
html body #logon-template-component .logon-bottom-toolbar button.dxbl-btn:hover,
html body #logon-template-component .logon-bottom-toolbar button.dxbl-btn:focus,
html body #logon-template-component .logon-bottom-toolbar button.dxbl-btn:active,
html body #logon-template-component .logon-bottom-toolbar button.dxbl-btn:focus-visible,
html body #logon-template-component .logon-bottom-toolbar button.dxbl-btn.dxbl-active,
html body #logon-template-component .logon-bottom-toolbar button.dxbl-btn.dxbl-focused,
html body .logon-bottom-toolbar button.dxbl-btn:hover,
html body .logon-bottom-toolbar button.dxbl-btn:focus,
html body .logon-bottom-toolbar button.dxbl-btn:active,
html body .logon-bottom-toolbar button.dxbl-btn:focus-visible,
html body button.dxbl-btn[data-action-name="Google"]:hover,
html body button.dxbl-btn[data-action-name="Google"]:focus,
html body button.dxbl-btn[data-action-name="Google"]:active,
html body button.dxbl-btn[data-action-name="Google"]:focus-visible,
html body button.dxbl-btn[data-action-name="Microsoft"]:hover,
html body button.dxbl-btn[data-action-name="Microsoft"]:focus,
html body button.dxbl-btn[data-action-name="Microsoft"]:active,
html body button.dxbl-btn[data-action-name="Microsoft"]:focus-visible,
html body button.dxbl-btn[data-action-name="Facebook"]:hover,
html body button.dxbl-btn[data-action-name="Facebook"]:focus,
html body button.dxbl-btn[data-action-name="Facebook"]:active,
html body button.dxbl-btn[data-action-name="Facebook"]:focus-visible,
html body button.dxbl-btn[data-action-name="GitHub"]:hover,
html body button.dxbl-btn[data-action-name="GitHub"]:focus,
html body button.dxbl-btn[data-action-name="GitHub"]:active,
html body button.dxbl-btn[data-action-name="GitHub"]:focus-visible {
    background: rgba(107, 194, 154, 0.12) !important;
    background-color: rgba(107, 194, 154, 0.12) !important;
    color: #2d4a3e !important;
    border-color: rgba(107, 194, 154, 0.30) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(107, 194, 154, 0.08) !important;
}

html body button.dxbl-btn[data-action-name="Google"]:hover *,
html body button.dxbl-btn[data-action-name="Google"]:focus *,
html body button.dxbl-btn[data-action-name="Google"]:active *,
html body button.dxbl-btn[data-action-name="Microsoft"]:hover *,
html body button.dxbl-btn[data-action-name="Microsoft"]:focus *,
html body button.dxbl-btn[data-action-name="Microsoft"]:active *,
html body button.dxbl-btn[data-action-name="Facebook"]:hover *,
html body button.dxbl-btn[data-action-name="Facebook"]:focus *,
html body button.dxbl-btn[data-action-name="Facebook"]:active *,
html body button.dxbl-btn[data-action-name="GitHub"]:hover *,
html body button.dxbl-btn[data-action-name="GitHub"]:focus *,
html body button.dxbl-btn[data-action-name="GitHub"]:active * {
    color: #2d4a3e !important;
}

/* DX internal state classes */
html body .dxbl-btn.dxbl-btn-secondary.dxbl-active[data-action-name="Google"],
html body .dxbl-btn.dxbl-btn-secondary.dxbl-active[data-action-name="Microsoft"],
html body .dxbl-btn.dxbl-btn-secondary.dxbl-active[data-action-name="Facebook"],
html body .dxbl-btn.dxbl-btn-secondary.dxbl-active[data-action-name="GitHub"],
html body .dxbl-btn.dxbl-btn-secondary.dxbl-focused[data-action-name="Google"],
html body .dxbl-btn.dxbl-btn-secondary.dxbl-focused[data-action-name="Microsoft"],
html body .dxbl-btn.dxbl-btn-secondary.dxbl-focused[data-action-name="Facebook"],
html body .dxbl-btn.dxbl-btn-secondary.dxbl-focused[data-action-name="GitHub"] {
    background: rgba(107, 194, 154, 0.12) !important;
    background-color: rgba(107, 194, 154, 0.12) !important;
    color: #2d4a3e !important;
    border-color: rgba(107, 194, 154, 0.30) !important;
}

/* --- TOOLBAR CONTENEDOR --- */
#logon-template-component .logon-bottom-toolbar,
.logon-bottom-toolbar {
    background: transparent !important;
    border-top: 1px solid rgba(107, 194, 154, 0.10) !important;
}

/* --- SEPARADOR --- */
#logon-template-component .logon-main .card hr,
.card:has(input[type="password"]) hr {
    border-color: rgba(107, 194, 154, 0.12) !important;
    opacity: 0.5 !important;
}

/* --- LINKS --- */
#logon-template-component .logon-main .card a,
.card:has(input[type="password"]) a {
    color: #5bb88a !important;
    text-decoration: none !important;
}

#logon-template-component .logon-main .card a:hover {
    color: #4a9b76 !important;
}

/* --- CHECKBOX --- */
#logon-template-component .logon-main .card input[type="checkbox"] {
    accent-color: #6bc29a !important;
}

#logon-template-component .logon-main .card .form-check-label {
    color: #7a9b8d !important;
    font-size: 13px !important;
}

/* --- FORM GROUPS --- */
#logon-template-component .logon-main .card .form-group,
#logon-template-component .logon-main .card .mb-3,
#logon-template-component .logon-main .card .dxbl-fl-item,
.card:has(input[type="password"]) .form-group,
.card:has(input[type="password"]) .mb-3 {
    opacity: 1 !important;
}

/* --- CARD HEADER INTERNO --- */
#logon-template-component .logon-main .card > .card-header,
.logon-main .card > .card-header {
    background: rgba(107, 194, 154, 0.05) !important;
    border-bottom: 1px solid rgba(107, 194, 154, 0.10) !important;
    color: #2d4a3e !important;
}

/* --- LOADING OVERLAY --- */
.cicumba-loading-overlay {
    position: fixed; inset: 0;
    background: rgba(240, 245, 242, 0.85);
    backdrop-filter: blur(12px);
    display: flex; justify-content: center; align-items: center;
    z-index: 9999;
    opacity: 0; visibility: hidden;
    transition: all 0.4s ease;
    color: #3a5a4a;
    font-size: 14px;
}

.cicumba-loading-overlay.show { opacity: 1; visibility: visible; }

.cicumba-spinner {
    width: 32px; height: 32px;
    border: 2px solid rgba(107, 194, 154, 0.20);
    border-top: 2px solid rgba(107, 194, 154, 0.65);
    border-radius: 50%;
    animation: spinSmooth 1s linear infinite;
    margin-bottom: 14px;
}

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

/* --- DEVEXPRESS FORM LAYOUT --- */
#logon-template-component .dxbl-fl-ctrl,
#logon-template-component .dxbl-fl-item {
    position: relative !important;
}

/* --- SCROLLBAR --- */
body.logon-page {
    overflow: hidden !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
    height: 100vh !important;
}

body.logon-page::-webkit-scrollbar { display: none !important; }
html.logon-page { overflow: hidden !important; scrollbar-width: none !important; }
html.logon-page::-webkit-scrollbar { display: none !important; }
.logon-page * { scrollbar-width: none !important; -ms-overflow-style: none !important; }
.logon-page *::-webkit-scrollbar { display: none !important; }
