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

/* --- 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;
}

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;
}

/* =================================
   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"],
.dxbl-btn[data-action-name="Google"],
.dxbl-btn[data-action-name="Microsoft"],
.dxbl-btn[data-action-name="Facebook"],
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"],
.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.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"] {
    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,
.dxbl-btn[data-action-name="Google"]:hover,
.dxbl-btn[data-action-name="Microsoft"]:hover,
.dxbl-btn[data-action-name="Facebook"]: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,
.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 {
    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 {
    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,
.dxbl-btn[data-action-name="Google"] img,
.dxbl-btn[data-action-name="Microsoft"] img,
.dxbl-btn[data-action-name="Facebook"] 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="Google"]:focus img,
button[data-action-name="Microsoft"]:focus img,
button[data-action-name="Facebook"]:focus img {
    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="Google"] span,
button[data-action-name="Microsoft"] span,
button[data-action-name="Facebook"] 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="Google"]:hover span,
button[data-action-name="Microsoft"]:hover span,
button[data-action-name="Facebook"]: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="Google"]:focus span,
button[data-action-name="Microsoft"]:focus span,
button[data-action-name="Facebook"]: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 {
    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 * {
    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-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"] {
    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; }
