﻿/* =============================================================================
   pg-reconnect.css
   Overlay de reconexao do Blazor - estilo minimalista "Registro do Arquiteto"
   Substitui o overlay padrao por um badge discreto no canto superior direito.
   ============================================================================= */

/* Reset completo do default - escondido por padrao */
#components-reconnect-modal {
    display: none !important;
    background: transparent !important;
    overflow: hidden !important;
}

/* Esconde todo conteudo gerado pelo Blazor (titulos, botoes, links) */
#components-reconnect-modal > * {
    display: none !important;
}

/* Estados visiveis: show (tentando), failed (esgotou), rejected (state perdido) */
#components-reconnect-modal.components-reconnect-show,
#components-reconnect-modal.components-reconnect-failed,
#components-reconnect-modal.components-reconnect-rejected {
    display: inline-flex !important;
    align-items: center !important;
    position: fixed !important;
    top: 16px !important;
    right: 16px !important;
    bottom: auto !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    max-width: calc(100vw - 32px) !important;

    padding: 10px 14px 10px 12px !important;
    border-radius: 10px !important;

    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    letter-spacing: -0.01em !important;

    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.18),
                0 2px 6px rgba(15, 23, 42, 0.08) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;

    z-index: 99999 !important;
    pointer-events: none !important;

    animation: pgReconnectSlideIn 0.25s ease-out !important;
}

/* Estado: tentando reconectar - indigo */
#components-reconnect-modal.components-reconnect-show {
    background: rgba(67, 56, 202, 0.95) !important;
    color: #FFFFFF !important;
}

#components-reconnect-modal.components-reconnect-show::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 10px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #FFFFFF;
    border-radius: 50%;
    animation: pgReconnectSpin 0.7s linear infinite;
    flex-shrink: 0;
}

#components-reconnect-modal.components-reconnect-show::after {
    content: 'Reconectando ao servidor...';
}

/* Estado: falhou - amber/warning */
#components-reconnect-modal.components-reconnect-failed {
    background: rgba(245, 158, 11, 0.95) !important;
    color: #FFFFFF !important;
}

#components-reconnect-modal.components-reconnect-failed::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 10px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #FFFFFF;
    border-radius: 50%;
    animation: pgReconnectSpin 0.7s linear infinite;
    flex-shrink: 0;
}

#components-reconnect-modal.components-reconnect-failed::after {
    content: 'Conexao perdida - restaurando sessao...';
}

/* Estado: rejected (state perdido) - red/danger */
#components-reconnect-modal.components-reconnect-rejected {
    background: rgba(239, 68, 68, 0.95) !important;
    color: #FFFFFF !important;
}

#components-reconnect-modal.components-reconnect-rejected::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 10px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #FFFFFF;
    border-radius: 50%;
    animation: pgReconnectSpin 0.7s linear infinite;
    flex-shrink: 0;
}

#components-reconnect-modal.components-reconnect-rejected::after {
    content: 'Sessao expirada - recarregando...';
}

/* Animacoes */
@keyframes pgReconnectSpin {
    to { transform: rotate(360deg); }
}

@keyframes pgReconnectSlideIn {
    from {
        transform: translateX(20px);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* Mobile: badge ocupa largura total no topo */
@media (max-width: 480px) {
    #components-reconnect-modal.components-reconnect-show,
    #components-reconnect-modal.components-reconnect-failed,
    #components-reconnect-modal.components-reconnect-rejected {
        top: 8px !important;
        right: 8px !important;
        left: 8px !important;
        max-width: calc(100vw - 16px) !important;
        justify-content: center !important;
    }
}