/* ════════════════════════════════════════════════════════════════
   ACURBUSINESS — Page de connexion V5
   Fichier : wwwroot/css/educated-login.css
   Palette : Option C — violet saturé #6B35BE
   Règle   : zéro couleur hardcodée sauf splash (Blazor non chargé)
   ════════════════════════════════════════════════════════════════ */


/* ══════════════════════════════════════════════════════════════
   1. RESET BODY + LAYOUT SPLIT
   ══════════════════════════════════════════════════════════════ */

body:has(#logon-template-component) {
    margin: 0 !important;
    padding: 0 !important;
    min-height: 100vh !important;
    background: var(--ink-0, #0F1115) !important;
    font-family: var(--font-body, "Geist", system-ui, sans-serif) !important;
}

#logon-template-component.app {
    display: grid !important;
    grid-template-columns: 46% 54% !important;
    grid-template-rows: 100vh !important;
    min-height: 100vh !important;
    width: 100% !important;
}


/* ══════════════════════════════════════════════════════════════
   2. PANNEAU GAUCHE
   Note : les var(--*) sont disponibles ici car le CSS est chargé
   après Blazor — contrairement au splash screen.
   ══════════════════════════════════════════════════════════════ */

.logon-template-header {
    grid-column: 1 !important;
    grid-row: 1 !important;
    /* Fond sombre violet profond — dérivé brand Option C */
    background: radial-gradient(ellipse 80% 60% at 0% 100%, rgba(107, 53, 190, .40) 0%, transparent 60%), radial-gradient(ellipse 60% 50% at 100% 0%, rgba(146, 68, 224, .20) 0%, transparent 55%), linear-gradient(160deg, #1C0B3A 0%, #120828 55%, #0C051E 100%) !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 40px 44px 32px !important;
    position: relative !important;
    overflow: hidden !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

    .logon-template-header > .header-logo {
        display: none !important;
    }

    .logon-template-header::after {
        content: "" !important;
        position: absolute !important;
        inset: 0 !important;
        background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E") !important;
        pointer-events: none !important;
        z-index: 0 !important;
    }

    .logon-template-header > *:not(.header-logo) {
        display: none !important;
    }


/* ══════════════════════════════════════════════════════════════
   3. PANNEAU DROIT — formulaire
   ══════════════════════════════════════════════════════════════ */

.logon-template-body {
    grid-column: 2 !important;
    grid-row: 1 !important;
    background: var(--surface-1, #fff) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 80px !important;
    overflow-y: auto !important;
    min-height: 100vh !important;
}

.logon-main-container {
    width: 100% !important;
    max-width: 420px !important;
    margin-top: -6vh !important;
}

.logon-main.card {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
}


/* ══════════════════════════════════════════════════════════════
   4. TITRE DU FORMULAIRE
   ══════════════════════════════════════════════════════════════ */

.logon-main .card-header,
.logon-main [role="heading"].card-header {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 4px !important;
    text-align: left !important;
    padding: 0 !important;
    margin-bottom: 20px !important;
    font-size: 0 !important;
    color: transparent !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    overflow: visible !important;
}

    .logon-main .card-header::before,
    .logon-main [role="heading"].card-header::before {
        content: "Connexion";
        display: block !important;
        line-height: 1.15 !important;
        color: var(--ink-0, #0F172A) !important;
        font-size: 38px !important;
        font-weight: 800 !important;
        letter-spacing: -0.03em !important;
        margin: 0 !important;
    }

    .logon-main .card-header::after,
    .logon-main [role="heading"].card-header::after {
        content: "Accédez à votre espace de travail AcurBusiness.";
        display: block !important;
        font-size: 14px !important;
        font-weight: 400 !important;
        line-height: 1.5 !important;
        color: var(--ink-2, #475569) !important;
        max-width: 340px !important;
        margin: 0 !important;
    }

.logon-main .card-body {
    padding: 0 !important;
    margin-top: 0 !important;
}


/* ══════════════════════════════════════════════════════════════
   5. CHAMPS DU FORMULAIRE
   ══════════════════════════════════════════════════════════════ */

#logon-template-component .logon-main label.dxbl-fl-cpt {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--ink-3, #94A3B8) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin-bottom: 6px !important;
    display: block !important;
}

.logon-main .dxbl-fl-item {
    margin-bottom: 12px !important;
}

/* Placeholders */
.logon-main input.dxbl-text-edit-input::placeholder {
    color: var(--ink-4, #CBD5E1) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    opacity: 1 !important;
}

/* Input natif */
.logon-main .dxbl-text-edit-input {
    border-radius: var(--radius-sm, 8px) !important;
    background: transparent !important;
    border: none !important;
    padding: 0 14px !important;
    font: 400 14px/1 var(--font-body, "Geist", system-ui, sans-serif) !important;
    color: var(--ink-0, #0F172A) !important;
    transition: var(--ease-fast, 80ms ease) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    height: 100% !important;
    outline: none !important;
}

/* Wrapper input-editor */
.logon-main dxbl-input-editor.dxbl-text-edit {
    border: 1px solid var(--line, #E5E7EB) !important;
    border-radius: var(--radius-lg, 12px) !important;
    background: var(--surface-2, #FAFBFD) !important;
    display: flex !important;
    align-items: stretch !important;
    height: 44px !important;
    overflow: hidden !important;
    box-shadow: none !important;
}

    .logon-main dxbl-input-editor.dxbl-text-edit:focus-within {
        border-color: var(--brand) !important;
        background: var(--surface-1, #fff) !important;
        box-shadow: 0 0 0 3px var(--brand-soft, #EDE8F8) !important;
    }

.logon-main dxbl-input-editor .dxbl-text-edit-input {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    height: 100% !important;
}

/* Classe générique .dxbl-text-edit */
.logon-main .dxbl-text-edit,
.logon-main dxbl-input-editor.dxbl-text-edit,
.logon-main dxbl-combo-box.dxbl-text-edit {
    background: var(--surface-2, #FAFBFD) !important;
    border: 1px solid var(--line, #E5E7EB) !important;
    border-radius: var(--radius-lg, 12px) !important;
    box-shadow: none !important;
}

/* Combobox Société */
.logon-main .dxbl-text-edit-template {
    border: 0 !important;
    background: transparent !important;
}

.logon-main .dxbl-edit-btn-dropdown {
    border: 0 !important;
    background: transparent !important;
    color: var(--ink-3, #94A3B8) !important;
    border-radius: 0 var(--radius-sm, 8px) var(--radius-sm, 8px) 0 !important;
}

.logon-main dxbl-combo-box.dxbl-text-edit {
    display: flex !important;
    align-items: stretch !important;
    border: 1px solid var(--line, #E5E7EB) !important;
    border-radius: var(--radius-lg, 12px) !important;
    background: var(--surface-2, #FAFBFD) !important;
    overflow: hidden !important;
    height: 44px !important;
}

    .logon-main dxbl-combo-box.dxbl-text-edit:focus-within {
        border-color: var(--brand) !important;
        background: var(--surface-1, #fff) !important;
        box-shadow: 0 0 0 3px var(--brand-soft, #EDE8F8) !important;
    }

.logon-main dxbl-combo-box .dxbl-text-edit-input {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    height: 100% !important;
}


/* ══════════════════════════════════════════════════════════════
   6. BOUTON SE CONNECTER
   ══════════════════════════════════════════════════════════════ */

.logon-toolbar {
    margin-top: 16px !important;
}

    .logon-toolbar .dxbl-btn-toolbar {
        width: 100% !important;
    }

    .logon-toolbar .dxbl-btn-group {
        width: 100% !important;
    }

    .logon-toolbar .ActionLogOn,
    .logon-toolbar .dxbl-btn-primary {
        width: 100% !important;
        height: 46px !important;
        border-radius: var(--radius, 10px) !important;
        background: var(--gradient-brand) !important;
        border: 0 !important;
        font: 600 15px/1 var(--font-body, "Geist", system-ui, sans-serif) !important;
        letter-spacing: -0.005em !important;
        color: #fff !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, var(--sh-brand) !important;
        transition: var(--ease-std, 160ms) !important;
        cursor: pointer !important;
    }

        .logon-toolbar .ActionLogOn:hover,
        .logon-toolbar .dxbl-btn-primary:hover {
            background: var(--gradient-brand-h) !important;
            box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, var(--sh-brand-h) !important;
            transform: translateY(-1px) !important;
        }

        .logon-toolbar .ActionLogOn:active,
        .logon-toolbar .dxbl-btn-primary:active {
            transform: translateY(0) !important;
            filter: brightness(.96) !important;
        }

    .logon-toolbar .dxbl-toolbar-btn-ellipsis {
        display: none !important;
    }

/* Reset parasites XAF */
#logon-template-component .main,
#logon-template-component .main-content,
#logon-template-component .detail-view-content {
    background: transparent !important;
}

#logon-template-component .dxbl-fl {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}


/* ══════════════════════════════════════════════════════════════
   7. CONTENU MARKETING (injecté via JS)
   ══════════════════════════════════════════════════════════════ */

#logon-left-content {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 40px 44px 32px !important;
    z-index: 1 !important;
    pointer-events: none !important;
}

    #logon-left-content .ll-logo {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        pointer-events: auto !important;
        text-decoration: none !important;
    }

    #logon-left-content .ll-logo-img {
        width: 152px !important;
        height: 36px !important;
        background-size: contain !important;
        background-repeat: no-repeat !important;
        background-position: left center !important;
        filter: brightness(0) invert(1) !important;
    }

    /* Badge */
    #logon-left-content .ll-badge {
        display: inline-flex !important;
        align-items: center !important;
        gap: 6px !important;
        margin-top: auto !important;
        margin-bottom: 20px !important;
        border: 1px solid rgba(255,255,255,.18) !important;
        border-radius: 999px !important;
        padding: 5px 12px !important;
        font: 600 11px/1 var(--font-body, "Geist", system-ui, sans-serif) !important;
        letter-spacing: 0.07em !important;
        text-transform: uppercase !important;
        color: rgba(255,255,255,.72) !important;
        width: fit-content !important;
    }

    /* Titre hero */
    #logon-left-content .ll-title {
        font: 800 38px/1.12 var(--font-body, "Geist", system-ui, sans-serif) !important;
        letter-spacing: -0.03em !important;
        color: #fff !important;
        margin: 0 0 10px !important;
    }

        /* em → couleur accent Option C */
        #logon-left-content .ll-title em {
            font-style: normal !important;
            color: var(--accent, #9B6FD4) !important;
        }

    /* Sous-titre */
    #logon-left-content .ll-sub {
        font: 400 15px/1.55 var(--font-body, "Geist", system-ui, sans-serif) !important;
        color: rgba(255,255,255,.62) !important;
        margin: 0 0 28px !important;
        max-width: 380px !important;
    }

    /* Features */
    #logon-left-content .ll-features {
        list-style: none !important;
        margin: 0 0 auto !important;
        padding: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 14px !important;
    }

        #logon-left-content .ll-features li {
            display: flex !important;
            align-items: flex-start !important;
            gap: 12px !important;
        }

    #logon-left-content .ll-feat-ico {
        width: 32px !important;
        height: 32px !important;
        border-radius: var(--radius-sm, 8px) !important;
        background: rgba(255,255,255,.10) !important;
        border: 1px solid rgba(255,255,255,.12) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-shrink: 0 !important;
        color: var(--accent, #9B6FD4) !important;
    }

        #logon-left-content .ll-feat-ico svg {
            width: 14px !important;
            height: 14px !important;
        }

    #logon-left-content .ll-feat-body {
        display: flex !important;
        flex-direction: column !important;
        gap: 2px !important;
    }

    #logon-left-content .ll-feat-title {
        font: 600 13.5px/1.2 var(--font-body, "Geist", system-ui, sans-serif) !important;
        color: rgba(255,255,255,.92) !important;
    }

    #logon-left-content .ll-feat-sub {
        font: 400 12px/1.3 var(--font-body, "Geist", system-ui, sans-serif) !important;
        color: rgba(255,255,255,.46) !important;
    }

    /* Footer */
    #logon-left-content .ll-footer {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        margin-top: 32px !important;
        font: 400 11.5px/1 var(--font-body, "Geist", system-ui, sans-serif) !important;
        color: rgba(255,255,255,.34) !important;
    }

        #logon-left-content .ll-footer span + span::before {
            content: "·" !important;
            margin-right: 8px !important;
        }


/* ══════════════════════════════════════════════════════════════
   8. RESPONSIVE — tablette ≤860px
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 860px) {

    #logon-template-component.app {
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto !important;
        min-height: 100vh !important;
    }

    .logon-template-header {
        grid-column: 1 !important;
        grid-row: 1 !important;
        min-height: 220px !important;
        padding: 28px 28px 24px !important;
        position: relative !important;
    }

    #logon-left-content .ll-features,
    #logon-left-content .ll-sub {
        display: none !important;
    }

    #logon-left-content .ll-title {
        font-size: 24px !important;
        margin-bottom: 0 !important;
    }

    #logon-left-content .ll-badge {
        margin-top: 12px !important;
        margin-bottom: 12px !important;
    }

    .logon-template-body {
        grid-column: 1 !important;
        grid-row: 2 !important;
        min-height: unset !important;
        padding: 36px 28px 48px !important;
        justify-content: flex-start !important;
    }

    .logon-main-container {
        max-width: 100% !important;
        margin-top: 0 !important;
    }
}


/* ══════════════════════════════════════════════════════════════
   9. RESPONSIVE — mobile ≤480px
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 480px) {

    .logon-template-header {
        display: none !important;
    }

    #logon-template-component.app {
        grid-template-rows: auto !important;
    }

    .logon-template-body {
        grid-row: 1 !important;
        padding: 48px 24px !important;
        min-height: 100vh !important;
        justify-content: center !important;
    }

    .logon-main-container {
        max-width: 100% !important;
    }

    .logon-main .card-header::before,
    .logon-main [role="heading"].card-header::before {
        font-size: 30px !important;
    }
}
