/* ═══════════════════════════════════════════════════════════
   FOMPLUS STATUS DOWNDETECTOR V10.1
   Microsoft Graph (optimizado) + Brand Kit + Modo oscuro real
   Sin header, boton flotante arriba a la derecha
   ═══════════════════════════════════════════════════════════ */

html {
    font-size: 16px;
}

/* ──────────────────────────────────────────────────────────
   VARIABLES MODO CLARO
   ────────────────────────────────────────────────────────── */

:root,
[data-bs-theme="light"] {
    --fp-blue: #2D2D74;
    --fp-blue-soft: #ECECFF;
    --fp-bg: #F4F6FB;
    --fp-border: #DDE2F1;
    --fp-text: #151827;
    --fp-muted: #64708A;
    --fp-card: #FFFFFF;
    --fp-card-alt: #F9FAFF;
    --fp-detail-bg: #FBFCFF;
    --fp-gradient-start: rgba(45, 45, 116, 0.10);

    --status-ok: #17A34A;
    --status-ok-bg: #E7F7ED;
    --status-warning: #F59E0B;
    --status-warning-bg: #FFF4D6;
    --status-warning-text: #8A5A00;
    --status-down: #DC2626;
    --status-down-bg: #FDECEC;

    --shadow-soft: 0 16px 40px rgba(45, 45, 116, 0.10);
    --shadow-card: 0 10px 26px rgba(45, 45, 116, 0.08);
    --shadow-card-hover: 0 18px 34px rgba(45, 45, 116, 0.12);
}

/* ──────────────────────────────────────────────────────────
   VARIABLES MODO OSCURO — Grises neutros, SIN morado
   ────────────────────────────────────────────────────────── */

[data-bs-theme="dark"] {
    --fp-blue: #8B9FFF;
    --fp-blue-soft: #1E2130;
    --fp-bg: #0F1117;
    --fp-border: #272B38;
    --fp-text: #E8EAF0;
    --fp-muted: #8B92A5;
    --fp-card: #181B25;
    --fp-card-alt: #1C1F2A;
    --fp-detail-bg: #14161E;
    --fp-gradient-start: rgba(139, 159, 255, 0.04);

    --status-ok: #4ADE80;
    --status-ok-bg: rgba(74, 222, 128, 0.10);
    --status-warning: #FBBF24;
    --status-warning-bg: rgba(251, 191, 36, 0.10);
    --status-warning-text: #FBBF24;
    --status-down: #F87171;
    --status-down-bg: rgba(248, 113, 113, 0.10);

    --shadow-soft: 0 16px 40px rgba(0, 0, 0, 0.40);
    --shadow-card: 0 10px 26px rgba(0, 0, 0, 0.30);
    --shadow-card-hover: 0 18px 34px rgba(0, 0, 0, 0.40);
}

/* ──────────────────────────────────────────────────────────
   BASE
   ────────────────────────────────────────────────────────── */

body {
    margin: 0;
    background:
        radial-gradient(circle at top left, var(--fp-gradient-start), transparent 34rem),
        var(--fp-bg);
    color: var(--fp-text);
    font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Arial, sans-serif;
}

/* ──────────────────────────────────────────────────────────
   BOTON FLOTANTE DE TEMA
   ────────────────────────────────────────────────────────── */

.btn-theme-toggle {
    position: fixed;
    top: 18px;
    right: 24px;
    z-index: 1050;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: 1px solid var(--fp-border);
    border-radius: 12px;
    background: var(--fp-card);
    cursor: pointer;
    font-size: 1.2rem;
    transition: background 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
    box-shadow: var(--shadow-card);
}

.btn-theme-toggle:hover {
    border-color: var(--fp-blue);
    background: var(--fp-blue-soft);
    box-shadow: var(--shadow-card-hover);
}

[data-bs-theme="light"] .theme-icon-dark {
    display: none;
}

[data-bs-theme="dark"] .theme-icon-light {
    display: none;
}

/* ──────────────────────────────────────────────────────────
   SUMMARY CARD
   ────────────────────────────────────────────────────────── */

.summary-card {
    border-radius: 18px;
    overflow: hidden;
    background: linear-gradient(135deg, var(--fp-card) 0%, var(--fp-card-alt) 100%);
    border: 1px solid var(--fp-border) !important;
    box-shadow: var(--shadow-soft) !important;
}

.summary-card::before {
    content: "";
    display: block;
    height: 6px;
    background: linear-gradient(90deg, #2D2D74, #4A4AA5, #2D2D74);
}

.summary-logo {
    width: 46px;
    height: 46px;
    object-fit: contain;
}

.summary-card h1,
.section-title-brand {
    color: var(--fp-blue);
    letter-spacing: -0.03em;
}

.border-lg-start {
    border-left: 1px solid var(--fp-border);
}

/* ──────────────────────────────────────────────────────────
   STATUS BADGES
   ────────────────────────────────────────────────────────── */

.status-badge,
.service-group-status,
.service-item-status {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    font-weight: 800;
    border: 1px solid transparent;
}

.status-badge {
    gap: 0.45rem;
    padding: 0.55rem 0.95rem;
    font-size: 0.88rem;
}

.status-badge::before,
.service-group-status::before,
.service-item-status::before {
    content: "";
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 999px;
    display: inline-block;
    margin-right: 0.4rem;
}

/* Operativo (verde) */

.status-operativo,
.service-group-status.operativo,
.service-item-status.operativo {
    background: var(--status-ok-bg);
    color: var(--status-ok);
}

.status-operativo::before,
.service-group-status.operativo::before,
.service-item-status.operativo::before {
    background: var(--status-ok);
}

/* Degradado (amarillo) */

.status-degradado,
.service-group-status.degradado {
    background: var(--status-warning-bg);
    color: var(--status-warning-text);
}

.status-degradado::before,
.service-group-status.degradado::before {
    background: var(--status-warning);
}

/* No operativo (rojo) */

.status-no-operativo,
.service-group-status.no-operativo,
.service-item-status.no-operativo {
    background: var(--status-down-bg);
    color: var(--status-down);
}

.status-no-operativo::before,
.service-group-status.no-operativo::before,
.service-item-status.no-operativo::before {
    background: var(--status-down);
}

/* Cargando */

.status-loading {
    background: var(--fp-blue-soft);
    color: var(--fp-muted);
    border-color: var(--fp-border);
}

/* ──────────────────────────────────────────────────────────
   KPI CARDS
   ────────────────────────────────────────────────────────── */

.kpi-card {
    border-radius: 16px;
    border: 1px solid var(--fp-border) !important;
    background: var(--fp-card) !important;
    box-shadow: var(--shadow-card) !important;
    transition: transform 160ms ease, box-shadow 160ms ease;
}

.kpi-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-card-hover) !important;
}

.kpi-card .card-body {
    padding: 1.3rem;
}

.kpi-value {
    display: block;
    color: var(--fp-blue);
    font-size: 2.1rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.04em;
}

.kpi-ok {
    color: var(--status-ok) !important;
}

.kpi-down {
    color: var(--status-down) !important;
}

/* ──────────────────────────────────────────────────────────
   GRID DE SERVICIOS (align-items: start = independiente)
   ────────────────────────────────────────────────────────── */

.service-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
    gap: 1.25rem 1.5rem;
}

/* ──────────────────────────────────────────────────────────
   TARJETA DE GRUPO
   ────────────────────────────────────────────────────────── */

.service-group-card {
    background: var(--fp-card);
    border: 1px solid var(--fp-border);
    border-radius: 16px;
    color: var(--fp-text);
    overflow: hidden;
    box-shadow: var(--shadow-card);
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.service-group-card:hover {
    transform: translateY(-2px);
    border-color: var(--fp-blue);
    box-shadow: var(--shadow-card-hover);
}

.service-group-button {
    width: 100%;
    min-height: 78px;
    border: 0;
    background: linear-gradient(135deg, var(--fp-card) 0%, var(--fp-card-alt) 100%);
    color: inherit;
    padding: 1.05rem 1.25rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: left;
    gap: 1rem;
}

.service-group-button:hover {
    background: linear-gradient(135deg, var(--fp-card) 0%, var(--fp-blue-soft) 100%);
}

.service-group-left {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    min-width: 0;
}

/* Icono expandir / colapsar */

.toggle-icon {
    width: 1.35rem;
    height: 1.35rem;
    border: 1px solid var(--fp-border);
    border-radius: 6px;
    color: var(--fp-blue);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--fp-card);
    font-size: 0.95rem;
    line-height: 1;
    flex: 0 0 auto;
}

.service-group-button[aria-expanded="true"] .toggle-icon {
    background: var(--fp-blue);
    color: #FFFFFF;
}

[data-bs-theme="dark"] .service-group-button[aria-expanded="true"] .toggle-icon {
    color: #0F1117;
}

.service-group-title {
    margin: 0;
    color: var(--fp-blue);
    font-size: 1.05rem;
    font-weight: 850;
}

.service-group-subtitle {
    margin: 0.25rem 0 0;
    color: var(--fp-muted);
    font-size: 0.84rem;
}

.service-group-status {
    padding: 0.42rem 0.75rem;
    font-size: 0.78rem;
    white-space: nowrap;
}

/* Contenido expandido */

.service-group-detail {
    padding: 0 1rem 1rem;
    display: grid;
    gap: 0.75rem;
    background: var(--fp-detail-bg);
}

/* ──────────────────────────────────────────────────────────
   FILA DE SERVICIO INDIVIDUAL
   ────────────────────────────────────────────────────────── */

.service-item-row {
    background: var(--fp-card);
    border: 1px solid var(--fp-border);
    border-left: 5px solid var(--status-ok);
    border-radius: 12px;
    padding: 0.95rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.service-item-row.no-operativo {
    border-left-color: var(--status-down);
}

.service-item-left {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    min-width: 0;
}

.status-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    margin-top: 0.42rem;
    background: var(--status-ok);
    flex: 0 0 auto;
}

.service-item-row.no-operativo .status-dot {
    background: var(--status-down);
}

.service-item-name {
    display: block;
    color: var(--fp-blue);
    font-size: 0.98rem;
    font-weight: 800;
}

.service-item-description {
    margin-top: 0.25rem;
    color: var(--fp-muted);
    font-size: 0.86rem;
}

.service-item-status {
    padding: 0.35rem 0.68rem;
    font-size: 0.82rem;
    white-space: nowrap;
}

/* ──────────────────────────────────────────────────────────
   BOTON SECUNDARIO
   ────────────────────────────────────────────────────────── */

.btn-outline-secondary {
    border-color: var(--fp-border);
    color: var(--fp-blue);
    font-weight: 700;
}

.btn-outline-secondary:hover {
    background: var(--fp-blue);
    border-color: var(--fp-blue);
    color: #FFFFFF;
}

/* ──────────────────────────────────────────────────────────
   RESPONSIVE
   ────────────────────────────────────────────────────────── */

@media (max-width: 991.98px) {
    .border-lg-start {
        border-left: 0;
        border-top: 1px solid var(--fp-border);
        padding-top: 1.5rem;
    }

    .service-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .service-group-button,
    .service-item-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .service-group-status,
    .service-item-status {
        align-self: flex-start;
    }

    .btn-theme-toggle {
        top: 12px;
        right: 14px;
        width: 38px;
        height: 38px;
    }
}
