/**
 * Presencia Admin — tema «Lumen» (claro, legible).
 * Revertir: quitar renderHook en AdminPanelProvider y borrar este archivo.
 */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root {
    --ps-accent: #4f46e5;
    --ps-accent-soft: #eef2ff;
    --ps-surface: #ffffff;
    --ps-bg: #f0f4f8;
    --ps-border: #e2e8f0;
    --ps-text: #1e293b;
    --ps-text-muted: #64748b;
    --ps-radius: 0.85rem;
    --ps-font: 'Plus Jakarta Sans', system-ui, sans-serif;
}

.fi-body {
    font-family: var(--ps-font) !important;
}

/* —— Fondo continuo (layout + contenido, sin cortes al scroll) —— */
.fi-layout {
    background:
        radial-gradient(ellipse 70% 45% at 0% 0%, rgba(79, 70, 229, 0.06), transparent 55%),
        radial-gradient(ellipse 55% 40% at 100% 0%, rgba(14, 165, 233, 0.05), transparent 50%),
        var(--ps-bg) !important;
}

.fi-main-ctn,
.fi-main {
    background: transparent !important;
}

/* —— Sidebar clara y legible —— */
.fi-sidebar {
    background: var(--ps-surface) !important;
    border-inline-end: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
}

.fi-sidebar::after {
    display: none;
}

.fi-sidebar-header {
    padding-top: 1.25rem !important;
    padding-bottom: 1rem !important;
    border-bottom: 1px solid var(--ps-border) !important;
    background: var(--ps-surface) !important;
}

.fi-sidebar-header .fi-logo {
    height: 3.75rem !important;
    filter: none;
}

.fi-sidebar-header .fi-logo img {
    max-height: 3.75rem !important;
}

.fi-sidebar-group-label {
    font-size: 0.65rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    color: var(--ps-text-muted) !important;
}

.fi-sidebar-item-button {
    color: var(--ps-text) !important;
    font-weight: 600 !important;
    font-size: 0.875rem !important;
    border-radius: 0.65rem !important;
    margin: 0.08rem 0.35rem !important;
}

.fi-sidebar-item-button:hover {
    background: var(--ps-accent-soft) !important;
    color: var(--ps-accent) !important;
    transform: none;
}

.fi-sidebar-item-active .fi-sidebar-item-button {
    background: var(--ps-accent-soft) !important;
    color: var(--ps-accent) !important;
    box-shadow: inset 3px 0 0 var(--ps-accent) !important;
}

.fi-sidebar-item-active .fi-sidebar-item-button::before {
    display: none;
}

.fi-sidebar-item-active .fi-sidebar-item-icon,
.fi-sidebar-item-active .fi-sidebar-item-label {
    color: var(--ps-accent) !important;
    font-weight: 700 !important;
}

/* Usuario en pie del menú */
.ps-sidebar-user {
    margin: 0;
    padding: 1rem 0.85rem 1.1rem;
    border-top: 1px solid var(--ps-border);
    background: #f8fafc;
}

.ps-sidebar-user__card {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.ps-sidebar-user__avatar {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.65rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(135deg, #6366f1, #4f46e5);
}

.ps-sidebar-user__hello {
    margin: 0;
    font-size: 0.8rem;
    line-height: 1.3;
    color: var(--ps-text-muted);
}

.ps-sidebar-user__hello strong {
    color: var(--ps-text);
    font-weight: 700;
}

.ps-sidebar-user__role {
    margin: 0.15rem 0 0;
    font-size: 0.72rem;
    color: var(--ps-text-muted);
}

.ps-sidebar-user__logout-panel {
    margin-top: 0.65rem;
    padding: 0.45rem;
    border-radius: 0.55rem;
    background: #ffffff;
    border: 1px solid var(--ps-border);
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.ps-sidebar-user__logout {
    margin-top: 0;
}

.ps-sidebar-user__logout-btn {
    display: inline-flex !important;
    width: 100%;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0.55rem 0.65rem;
    border-radius: 0.5rem;
    border: none !important;
    background: linear-gradient(180deg, #ef4444 0%, #dc2626 100%) !important;
    color: #fff !important;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(220, 38, 38, 0.35);
    transition: transform 0.12s ease, box-shadow 0.15s ease, filter 0.15s ease;
    -webkit-appearance: none;
    appearance: none;
}

.ps-sidebar-user__logout-btn:hover {
    filter: brightness(1.06);
    box-shadow: 0 4px 14px rgba(220, 38, 38, 0.45);
    transform: translateY(-1px);
}

.ps-sidebar-user__logout-btn:active {
    transform: translateY(0);
    filter: brightness(0.96);
}

.ps-sidebar-user__logout-btn svg {
    width: 1rem !important;
    height: 1rem !important;
    max-width: 1rem;
    max-height: 1rem;
    flex-shrink: 0;
    color: #fff !important;
    stroke: currentColor !important;
}

.dark .ps-sidebar-user__logout-panel {
    background: rgba(30, 41, 59, 0.85);
    border-color: #334155;
}

/* —— Topbar —— */
.fi-topbar {
    background: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(12px) !important;
    border-bottom: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
}

.fi-topbar .fi-user-menu {
    display: none !important;
}

/* —— Encabezados —— */
.fi-header-heading {
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    color: var(--ps-text) !important;
    background: none !important;
    -webkit-text-fill-color: unset !important;
}

.fi-header-subheading {
    color: var(--ps-text-muted) !important;
}

/* —— Tarjetas —— */
.fi-section,
.fi-wi-widget {
    border-radius: var(--ps-radius) !important;
    border: 1px solid var(--ps-border) !important;
    background: var(--ps-surface) !important;
    box-shadow: none !important;
}

.fi-section::before,
.fi-wi-widget::before {
    display: none !important;
}

.fi-btn-color-primary {
    background: linear-gradient(135deg, #6366f1, #4f46e5) !important;
    border: none !important;
    box-shadow: none !important;
}

.fi-input-wrp {
    border-radius: 0.55rem !important;
    border-color: var(--ps-border) !important;
    background: #fff !important;
}

.fi-input-wrp:focus-within {
    border-color: var(--ps-accent) !important;
    box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.15) !important;
}

.fi-ta-ctn {
    border-radius: var(--ps-radius) !important;
    border: 1px solid var(--ps-border) !important;
    background: var(--ps-surface) !important;
}

.fi-ta-header-cell {
    background: #f8fafc !important;
    color: var(--ps-text-muted) !important;
}

/* Login */
.fi-simple-layout {
    min-height: 100vh !important;
    background:
        radial-gradient(circle at 50% 0%, rgba(79, 70, 229, 0.13), transparent 34rem),
        radial-gradient(circle at 15% 85%, rgba(14, 165, 233, 0.1), transparent 30rem),
        linear-gradient(180deg, #f8fafc 0%, #e9eef5 100%) !important;
}

.fi-simple-layout::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.45) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.45) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: radial-gradient(circle at center, black 0%, transparent 72%);
    opacity: 0.45;
}

.fi-simple-page {
    width: min(100%, 30rem) !important;
    padding: 2.15rem 2rem !important;
    border: 1px solid rgba(226, 232, 240, 0.95) !important;
    border-radius: 1.35rem !important;
    background: rgba(255, 255, 255, 0.96) !important;
    box-shadow:
        0 24px 70px rgba(15, 23, 42, 0.13),
        0 1px 0 rgba(255, 255, 255, 0.9) inset !important;
    backdrop-filter: blur(14px);
}

.fi-simple-page .fi-logo,
.fi-simple-page .fi-logo img {
    width: auto !important;
    max-width: min(15rem, 78vw) !important;
    height: auto !important;
    max-height: 5.25rem !important;
    object-fit: contain !important;
}

.fi-simple-page .fi-logo {
    margin-inline: auto !important;
    padding: 0.4rem 0.65rem !important;
    border-radius: 1rem !important;
    background: #fff !important;
    box-shadow: 0 1px 8px rgba(15, 23, 42, 0.05) !important;
}

.fi-simple-page .fi-header-heading {
    margin-top: 0.65rem !important;
    text-align: center !important;
    font-size: 1.35rem !important;
    font-weight: 800 !important;
    letter-spacing: -0.035em !important;
    color: #0f172a !important;
}

.fi-simple-page .fi-fo-field-wrp-label span,
.fi-simple-page .fi-fo-field-wrp-label label {
    color: #334155 !important;
    font-size: 0.88rem !important;
    font-weight: 700 !important;
}

.fi-simple-page .fi-input-wrp {
    min-height: 2.85rem !important;
    border: 1px solid #dbe4ee !important;
    border-radius: 0.85rem !important;
    background: #fff !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03) !important;
}

.fi-simple-page .fi-input-wrp:focus-within {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.14) !important;
}

.fi-simple-page .fi-input {
    min-height: 2.75rem !important;
    font-size: 0.96rem !important;
}

.fi-simple-page .fi-link {
    color: #4f46e5 !important;
    font-weight: 700 !important;
}

.fi-simple-page .fi-link:hover {
    color: #3730a3 !important;
}

.fi-simple-page .fi-btn-color-primary {
    min-height: 2.85rem !important;
    border-radius: 0.85rem !important;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 55%, #2563eb 100%) !important;
    color: #fff !important;
    font-weight: 800 !important;
    box-shadow: 0 14px 28px rgba(79, 70, 229, 0.24) !important;
}

.fi-simple-page .fi-btn-color-primary:hover {
    filter: brightness(1.05);
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(79, 70, 229, 0.31) !important;
}

.fi-simple-page .fi-checkbox-input {
    border-radius: 0.35rem !important;
    border-color: #cbd5e1 !important;
}

@media (max-width: 640px) {
    .fi-simple-page {
        width: calc(100vw - 1.5rem) !important;
        padding: 1.45rem 1.15rem !important;
        border-radius: 1rem !important;
    }

    .fi-simple-page .fi-logo,
    .fi-simple-page .fi-logo img {
        max-width: min(13rem, 74vw) !important;
    }
}

/* —— Escritorio (superficie continua, sin cortes) —— */
.fi-dashboard-page .fi-header {
    display: none !important;
}

.fi-dashboard-page .fi-account-widget {
    display: none !important;
}

.fi-dashboard-page .fi-page > section {
    gap: 0.5rem !important;
}

.fi-dashboard-page .fi-wi {
    gap: 0.5rem !important;
    align-items: stretch !important;
}

.fi-dashboard-page .fi-wi-widget.fi-wi-estado-dia,
.fi-dashboard-page .fi-wi-widget.fi-wi-licencia-cupo,
.fi-dashboard-page .fi-wi-widget.fi-wi-ausencias-pendientes {
    background: transparent !important;
    border: none !important;
}

.fi-dashboard-page .fi-wi-licencia-cupo .lcy-shell,
.fi-dashboard-page .fi-wi-estado-dia .edd-panel {
    padding: 0 !important;
    background: var(--ps-surface) !important;
    border: 1px solid var(--ps-border) !important;
    border-radius: var(--ps-radius) !important;
    box-shadow: none !important;
}

.fi-dashboard-page .fi-wi-licencia-cupo .lcy-inner,
.fi-dashboard-page .fi-wi-estado-dia .edd-panel-inner {
    background: var(--ps-surface) !important;
    border-radius: inherit;
}

.fi-dashboard-page .fi-wi-estado-dia .edd-table-wrap {
    border-color: var(--ps-border) !important;
    background: #f8fafc !important;
}

@media (min-width: 1024px) {
    .fi-dashboard-page .fi-wi-estado-dia .edd-table {
        font-size: 0.95rem;
    }

    .fi-dashboard-page .fi-wi-estado-dia .edd-title {
        font-size: 1.35rem;
    }
}

.ps-dashboard-welcome {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
}

.ps-dashboard-welcome__hello {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--ps-text);
}

.ps-dashboard-welcome__hello strong {
    font-weight: 800;
    color: var(--ps-accent);
}

.ps-dashboard-welcome__sub {
    margin: 0.15rem 0 0;
    font-size: 0.8rem;
    color: var(--ps-text-muted);
}

/* Widgets escritorio (modo claro por defecto) */
.fi-wi-estado-dia .edd-title {
    color: #0f172a;
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
}

.fi-wi-estado-dia .edd-date-line {
    color: #334155;
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
}

.fi-wi-estado-dia .edd-kpi--out {
    background: rgba(244, 63, 94, 0.1) !important;
    border-color: rgba(244, 63, 94, 0.38) !important;
}

.fi-wi-estado-dia .edd-kpi--out .edd-kpi-num {
    color: #be123c !important;
}

.fi-wi-estado-dia .edd-kpi--out .edd-kpi-lbl {
    color: #9f1239 !important;
}

.fi-wi-estado-dia .edd-panel-inner {
    background: #fff;
}

.fi-wi-licencia-cupo .lcy-inner {
    background: #fff;
}

.fi-sidebar-nav::-webkit-scrollbar {
    width: 5px;
}

.fi-sidebar-nav::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 9999px;
}

/* —— Modo oscuro opcional —— */
.dark .fi-layout {
    background: linear-gradient(165deg, #0f172a 0%, #1e293b 100%) !important;
}

.dark .fi-sidebar {
    background: #1e293b !important;
    border-inline-end-color: #334155 !important;
}

.dark .fi-sidebar-header {
    background: #1e293b !important;
    border-bottom-color: #334155 !important;
}

.dark .fi-sidebar-group-label {
    color: #94a3b8 !important;
}

.dark .fi-sidebar-item-button {
    color: #e2e8f0 !important;
}

.dark .fi-sidebar-item-button:hover,
.dark .fi-sidebar-item-active .fi-sidebar-item-button {
    background: rgba(99, 102, 241, 0.2) !important;
    color: #e0e7ff !important;
}

.dark .ps-sidebar-user {
    background: #0f172a;
    border-color: #334155;
}

.dark .ps-sidebar-user__hello strong {
    color: #f1f5f9;
}

.dark .ps-sidebar-user__role,
.dark .ps-sidebar-user__hello {
    color: #94a3b8;
}

.dark .ps-sidebar-user__logout-btn {
    background: linear-gradient(180deg, #f87171 0%, #dc2626 100%) !important;
    color: #fff !important;
    box-shadow: 0 2px 10px rgba(248, 113, 113, 0.3);
}

.dark .fi-topbar {
    background: rgba(15, 23, 42, 0.95) !important;
    border-bottom-color: #334155 !important;
}

.dark .fi-header-heading {
    color: #f1f5f9 !important;
}

.dark .fi-section,
.dark .fi-wi-widget {
    background: #1e293b !important;
    border-color: #334155 !important;
}

.dark .ps-dashboard-welcome {
    background: #1e293b;
    border-color: #334155;
}

.dark .ps-dashboard-welcome__hello {
    color: #f1f5f9;
}

.dark .fi-wi-estado-dia .edd-panel-inner,
.dark .fi-wi-licencia-cupo .lcy-inner {
    background: rgba(15, 23, 42, 0.95);
}
