/* Executive Precision — SuperAgenda design system (from docs/design/stitch/DESIGN.md) */

:root {
    --ep-background: #f8f9ff;
    --ep-surface: #ffffff;
    --ep-surface-container-lowest: #ffffff;
    --ep-surface-container: #e5eeff;
    --ep-surface-container-low: #eff4ff;
    --ep-surface-container-high: #dce9ff;
    --ep-primary: #002046;
    --ep-primary-container: #1b365d;
    --ep-on-primary: #ffffff;
    --ep-on-primary-container: #aec7f7;
    --ep-primary-fixed: #d6e3ff;
    --ep-secondary: #00658d;
    --ep-secondary-container: #41befd;
    --ep-on-secondary-container: #004b69;
    --ep-accent-cyan: #00a3e0;
    --ep-on-surface: #0b1c30;
    --ep-on-surface-variant: #44474e;
    --ep-outline-variant: #c4c6cf;
    --ep-border: #e2e8f0;
    --ep-tonal: #f1f5f9;
    --ep-error: #ba1a1a;
    --ep-status-confirmed-bg: #d1fae5;
    --ep-status-confirmed-text: #065f46;
    --ep-status-pending-bg: #fef3c7;
    --ep-status-pending-text: #92400e;
    --ep-status-rescheduled-bg: #dbeafe;
    --ep-status-rescheduled-text: #1e40af;
    --ep-radius-sm: 0.5rem;
    --ep-radius-md: 0.75rem;
    --ep-radius-lg: 1rem;
    --ep-shadow: 0 4px 6px -1px rgba(27, 54, 93, 0.1), 0 2px 4px -1px rgba(27, 54, 93, 0.06);
    --ep-sidebar-width: 280px;
    --ep-max-content: 1440px;
    --ep-font: 'Inter', system-ui, -apple-system, sans-serif;
    /* Syncfusion bridge tokens (Bootstrap 5 theme overrides) */
    --sf-primary: var(--ep-primary-container);
    --sf-primary-text: var(--ep-on-primary);
    --sf-accent: var(--ep-accent-cyan);
    --sf-surface: var(--ep-surface);
    --sf-border: var(--ep-border);
}

*, *::before, *::after { box-sizing: border-box; }

body {
    margin: 0;
    font-family: var(--ep-font);
    font-size: 14px;
    line-height: 1.43;
    color: var(--ep-on-surface);
    background: var(--ep-background);
    overflow-x: hidden;
}

.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    vertical-align: middle;
    font-size: 1.25rem;
}

.ep-page {
    max-width: var(--ep-max-content);
    margin: 0 auto;
    width: 100%;
}

/* Sidebar navigation — global rules (NavLink anchors skip component CSS isolation) */
.ep-sidebar a.ep-nav-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    box-sizing: border-box;
    padding: 0.6875rem 0.875rem;
    border-radius: var(--ep-radius-sm);
    border-left: 3px solid transparent;
    color: rgba(255, 255, 255, 0.88);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.25;
    min-height: 44px;
}

.ep-sidebar a.ep-nav-link:hover {
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff;
}

.ep-sidebar a.ep-nav-link.active {
    background: rgba(0, 0, 0, 0.22);
    border-left-color: var(--ep-accent-cyan);
    color: #ffffff;
    font-weight: 600;
}

.ep-sidebar a.ep-nav-link .material-symbols-outlined {
    font-size: 1.3125rem;
    flex-shrink: 0;
}

.ep-sidebar a.ep-nav-link.active .material-symbols-outlined {
    font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

.ep-page-header {
    margin-bottom: 1.5rem;
}

.ep-page-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--ep-primary-container);
    margin: 0 0 0.25rem;
    letter-spacing: -0.01em;
}

.ep-page-subtitle {
    font-size: 14px;
    color: var(--ep-on-surface-variant);
    margin: 0;
}

.ep-card {
    background: var(--ep-surface);
    border: 1px solid var(--ep-border);
    border-radius: var(--ep-radius-lg);
    box-shadow: var(--ep-shadow);
}

.ep-card-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid #f8fafc;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ep-primary-container);
}

.ep-card-body {
    padding: 1.25rem;
}

.ep-metric-card {
    background: var(--ep-surface);
    border: 1px solid var(--ep-outline-variant);
    border-radius: var(--ep-radius-lg);
    padding: 1rem;
    box-shadow: var(--ep-shadow);
}

.ep-metric-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--ep-on-surface-variant);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 0.5rem;
}

.ep-metric-value {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--ep-primary-container);
    line-height: 1.2;
}

.ep-metric-trend {
    font-size: 12px;
    font-weight: 500;
    color: var(--ep-secondary);
}

.ep-status-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
}

.ep-status-chip::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
}

.ep-status-confirmed { background: var(--ep-status-confirmed-bg); color: var(--ep-status-confirmed-text); }
.ep-status-pending { background: var(--ep-status-pending-bg); color: var(--ep-status-pending-text); }
.ep-status-rescheduled { background: var(--ep-status-rescheduled-bg); color: var(--ep-status-rescheduled-text); }
.ep-status-inactive { background: #f1f5f9; color: var(--ep-on-surface-variant); }
.ep-status-active { background: var(--ep-status-confirmed-bg); color: var(--ep-status-confirmed-text); }

.ep-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.ep-toolbar-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.ep-grid-wrap .e-grid {
    border: 1px solid var(--ep-border);
    border-radius: var(--ep-radius-lg);
    overflow: hidden;
}

.ep-grid-wrap .e-grid .e-rowcell {
    height: 48px;
}

.ep-grid-wrap .e-grid .e-altrow {
    background: #f8fafc;
}

.ep-form-card {
    max-width: 720px;
}

.ep-section-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--ep-primary-container);
    margin: 1.5rem 0 1rem;
}

.ep-empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--ep-on-surface-variant);
}

.ep-coming-soon {
    border: 1px dashed var(--ep-outline-variant);
    border-radius: var(--ep-radius-lg);
    padding: 2rem;
    text-align: center;
    background: var(--ep-surface-container-low);
}

/* Syncfusion theme overrides — Executive Precision */
.e-btn.e-primary,
.e-css.e-btn.e-primary {
    background-color: var(--ep-primary-container) !important;
    border-color: var(--ep-primary-container) !important;
    border-radius: var(--ep-radius-sm) !important;
    min-height: 40px;
}

.e-btn.e-primary:hover,
.e-css.e-btn.e-primary:hover {
    background-color: var(--ep-primary) !important;
    border-color: var(--ep-primary) !important;
}

.e-btn.e-outline,
.e-css.e-btn.e-outline {
    border-color: var(--ep-accent-cyan) !important;
    color: var(--ep-primary-container) !important;
    border-radius: var(--ep-radius-sm) !important;
}

.e-btn.e-outline:hover,
.e-css.e-btn.e-outline:hover {
    background-color: var(--ep-surface-container-low) !important;
}

.e-input-group,
.e-input-group.e-control-wrapper,
.e-float-input,
.e-float-input.e-control-wrapper {
    border-radius: var(--ep-radius-sm) !important;
    border-color: var(--ep-outline-variant) !important;
}

.e-input-group:not(.e-disabled):not(.e-float-icon-left).e-input-focus::before,
.e-input-group:not(.e-disabled):not(.e-float-icon-left).e-input-focus::after,
.e-input-group.e-control-wrapper:not(.e-disabled):not(.e-float-icon-left).e-input-focus::before,
.e-input-group.e-control-wrapper:not(.e-disabled):not(.e-float-icon-left).e-input-focus::after {
    background: var(--ep-accent-cyan) !important;
}

.e-ddl.e-input-group.e-control-wrapper,
.e-grid,
.e-schedule,
.e-tab,
.e-dialog,
.e-chat-ui {
    border-radius: var(--ep-radius-sm) !important;
}

/* Grid */
.e-grid .e-headercell,
.e-grid .e-detailheadercell {
    background-color: var(--ep-surface-container-low) !important;
    color: var(--ep-primary-container) !important;
    font-weight: 600;
}

.e-grid .e-rowcell {
    color: var(--ep-on-surface);
}

.e-grid .e-gridheader {
    border-bottom-color: var(--ep-border) !important;
}

.e-grid .e-row.e-active .e-rowcell {
    background-color: var(--ep-surface-container-low) !important;
}

/* Tabs */
.e-tab .e-tab-header {
    background: transparent;
    border-bottom: 1px solid var(--ep-border);
}

.e-tab .e-tab-header .e-toolbar-item.e-active .e-tab-text,
.e-tab .e-tab-header .e-toolbar-item.e-active .e-tab-icon {
    color: var(--ep-primary-container) !important;
}

.e-tab .e-tab-header .e-indicator {
    background: var(--ep-accent-cyan) !important;
}

.e-tab .e-tab-header .e-toolbar-item .e-tab-text {
    color: var(--ep-on-surface-variant);
}

/* Scheduler */
.e-schedule .e-schedule-toolbar .e-toolbar-item.e-active .e-tbar-btn-text,
.e-schedule .e-schedule-toolbar .e-toolbar-item.e-active .e-icons {
    color: var(--ep-primary-container) !important;
}

.e-schedule .e-appointment {
    border-radius: var(--ep-radius-sm) !important;
}

/* Colores por especialista: EventRendered / ColorField (no forzar primary global) */

.e-schedule .e-work-cells.e-work-hours {
    background-color: var(--ep-surface-container-lowest);
}

/* Dialog */
.e-dialog .e-dlg-header-content {
    background: var(--ep-surface);
    color: var(--ep-primary-container);
    border-bottom: 1px solid var(--ep-border);
}

.e-dialog .e-footer-content {
    border-top: 1px solid var(--ep-border);
}

/* Dropdown / popup lists */
.e-dropdownbase .e-list-item.e-active,
.e-dropdownbase .e-list-item.e-hover {
    background-color: var(--ep-surface-container-low) !important;
    color: var(--ep-primary-container) !important;
}

/* Checkbox / switch primary */
.e-checkbox-wrapper .e-frame.e-check,
.e-css.e-checkbox-wrapper .e-frame.e-check {
    background-color: var(--ep-primary-container) !important;
    border-color: var(--ep-primary-container) !important;
}

/* Toast */
.e-toast-container .e-toast.e-toast-success {
    background-color: var(--ep-status-confirmed-bg) !important;
    color: var(--ep-status-confirmed-text) !important;
}

.e-toast-container .e-toast.e-toast-danger {
    background-color: #ffdad6 !important;
    color: var(--ep-error) !important;
}

/* Chat UI */
.e-chat-ui .e-message-header,
.e-chat-ui .e-message-content {
    font-family: var(--ep-font);
}

.e-chat-ui .e-message-item.e-right .e-message-content {
    background-color: var(--ep-primary-container) !important;
    color: var(--ep-on-primary) !important;
}

.e-chat-ui .e-message-item:not(.e-right) .e-message-content {
    background-color: var(--ep-surface-container) !important;
    color: var(--ep-on-surface) !important;
}

/* Spinner / progress */
.e-spinner-pane .e-spinner-inner .e-spin-material {
    stroke: var(--ep-primary-container) !important;
}

/* FAB (Stitch mobile — calendar + dashboard) */
.ep-fab {
    position: fixed;
    bottom: 80px;
    right: 1rem;
    z-index: 90;
}

.ep-fab .e-btn {
    width: 56px;
    height: 56px;
    border-radius: 999px !important;
    padding: 0;
    box-shadow: 0 4px 14px rgba(0, 32, 70, 0.25);
}

@media (max-width: 768px) {
    .ep-page-title { font-size: 1.25rem; }
    .ep-hide-mobile { display: none !important; }
    .ep-hide-desktop { display: block !important; }

    /* Shared page toolbar — collapsible filters (Stitch mobile) */
    .ep-page-toolbar-mobile {
        display: flex;
        justify-content: flex-end;
        margin-bottom: 0.5rem;
    }

    .ep-page-toolbar .ep-toolbar {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }

    .ep-page-toolbar .ep-toolbar-filters {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
    }

    .ep-page-toolbar .ep-toolbar-filters.ep-page-filters--collapsed {
        display: none;
    }

    .ep-page-toolbar .ep-toolbar-filters > *,
    .ep-page-toolbar .ep-toolbar-filters .e-ddl,
    .ep-page-toolbar .ep-toolbar-filters .e-input-group,
    .ep-page-toolbar .ep-toolbar-filters .e-multiselect {
        width: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
    }

    .ep-page-toolbar .ep-toolbar-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 0.5rem;
        width: 100%;
    }

    .ep-page-toolbar .ep-toolbar-actions .e-btn {
        flex: 1 1 auto;
        min-width: 0;
        justify-content: center;
    }

    .ep-page-header {
        margin-bottom: 1rem;
    }

    .ep-page-header .ep-page-title {
        word-break: normal;
        overflow-wrap: anywhere;
    }

    .ep-page-header .ep-page-subtitle {
        font-size: 0.875rem;
        line-height: 1.45;
    }

    .ep-grid-wrap {
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .ep-grid-wrap .e-grid {
        width: 100% !important;
        min-width: 0;
    }

    .ep-admin-tenants-grid .e-grid {
        min-width: 0;
    }

    .ep-admin-tenants-grid .e-grid .e-rowcell {
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .ep-admin-cards,
    .ep-admin-detail-grid {
        grid-template-columns: 1fr;
    }

    .ep-superadmin-banner {
        flex-direction: column;
        align-items: flex-start;
    }

    .ep-content > .ep-tenant-warning,
    .ep-content > .ep-superadmin-banner.ep-tenant-warning {
        margin: 0 0 1rem;
    }

    /* Calendar — mobile layout (Stitch: calendar_syncfusion_optimized MOBILE) */
    .ep-calendar-toolbar-mobile {
        display: flex;
        justify-content: flex-end;
        margin-bottom: 0.5rem;
    }

    .ep-calendar-filter-toggle {
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
        min-height: 44px;
        padding: 0.35rem 0.85rem;
        font-size: 0.875rem;
    }

    .ep-calendar-toolbar .ep-toolbar {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }

    .ep-calendar-toolbar .ep-toolbar-filters {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
    }

    .ep-calendar-toolbar .ep-toolbar-filters.ep-calendar-filters--collapsed {
        display: none;
    }

    .ep-calendar-toolbar .ep-toolbar-filters .e-ddl,
    .ep-calendar-toolbar .ep-toolbar-filters .calendar-specialist-filter {
        width: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
    }

    .ep-calendar-toolbar .ep-toolbar > .d-flex {
        width: 100%;
        justify-content: stretch;
    }

    .ep-calendar-toolbar .ep-toolbar > .d-flex .e-btn.e-outline {
        flex: 1;
    }

    .calendar-specialist-legend {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 0.25rem;
    }

    .ep-card ::deep .calendar-shift-schedule.e-schedule {
        height: min(620px, calc(100dvh - 17rem)) !important;
        min-height: 360px;
    }

    .calendar-filter-hint {
        display: none;
    }

    /* Dashboard — mobile layout (Stitch: dashboard_general_mobile) */
    .ep-dashboard-metrics {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.75rem;
        --bs-gutter-x: 0;
        --bs-gutter-y: 0;
    }

    .ep-dashboard-metrics > [class*="col-"] {
        width: 100%;
        max-width: 100%;
        flex: none;
        padding: 0;
        margin-bottom: 0 !important;
    }

    .ep-dashboard-metric-hero {
        grid-column: 1 / -1;
    }

    .ep-dashboard-upcoming .ep-upcoming-row {
        border-bottom: 1px solid var(--ep-border);
    }

    .ep-dashboard-upcoming .ep-upcoming-row:last-child {
        border-bottom: none;
        margin-bottom: 0 !important;
        padding-bottom: 0 !important;
    }

    .ep-dashboard-shortcuts {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 0.75rem;
        margin-left: 0;
        margin-right: 0;
        padding-bottom: 0.25rem;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .ep-dashboard-shortcuts::-webkit-scrollbar {
        display: none;
    }

    .ep-dashboard-shortcuts > [class*="col-"] {
        flex: 0 0 min(280px, 85vw);
        max-width: min(280px, 85vw);
        padding: 0;
        margin-bottom: 0 !important;
    }
}

@media (min-width: 769px) {
    .ep-hide-desktop { display: none !important; }

    .ep-page-toolbar-mobile {
        display: none;
    }

    .ep-page-toolbar .ep-toolbar-filters.ep-page-filters--collapsed {
        display: flex;
    }

    .ep-calendar-toolbar .ep-toolbar-filters.ep-calendar-filters--collapsed {
        display: flex;
    }
}
