@charset "UTF-8";
/*
 * Zeke - Identidade Visual
 * Cores: Pantone 1225 (dourado), Preto, Branco
 * Tipografia: Rubik
 */

/* ===== TEMA CLARO ===== */
[data-bs-theme="light"] {
    --bs-primary: #F0AB00;
    --bs-primary-rgb: 240, 171, 0;
    --bs-link-color: #C48900;
    --bs-link-hover-color: #9A6D00;
    --zeke-gold: #F0AB00;
    --zeke-gold-light: #FFD54F;
    --zeke-gold-dark: #C48900;
    --zeke-dark: #2D2926;
    --zeke-sidebar-bg: #F7F5F2;
    --zeke-sidebar-color: #2D2926;
    --zeke-sidebar-active: #C48900;
    --zeke-navbar-bg: #FFFFFF;
    --zeke-navbar-border: #F0AB00;
    --zeke-accent: #C48900;
    --zeke-accent-bg: rgba(240, 171, 0, 0.15);
    --bs-border-color: #b5b5b5;
}

/* ===== TEMA ESCURO ===== */
[data-bs-theme="dark"] {
    --bs-primary: #F0AB00;
    --bs-primary-rgb: 240, 171, 0;
    --bs-link-color: #FFD54F;
    --bs-link-hover-color: #F0AB00;
    --bs-body-bg: #1A1816;
    --bs-body-color: #E8E6E3;
    --zeke-gold: #F0AB00;
    --zeke-gold-light: #FFD54F;
    --zeke-gold-dark: #C48900;
    --zeke-dark: #1A1816;
    --zeke-sidebar-bg: #131110;
    --zeke-sidebar-color: #E8E6E3;
    --zeke-sidebar-active: #F0AB00;
    --zeke-navbar-bg: #211F1D;
    --zeke-navbar-border: #F0AB00;
    --zeke-accent: #F0AB00;
    --zeke-accent-bg: rgba(240, 171, 0, 0.1);
    --zeke-input-bg: #2D2926;
    --zeke-input-border: #3A3633;
}

/* ===== TIPOGRAFIA ===== */
body {
    font-family: 'Rubik', sans-serif !important;
}

/* ===== LOGO SWITCH ===== */
[data-bs-theme="light"] .brand-logo-dark { display: none; }
[data-bs-theme="light"] .brand-logo-light { display: inline; }
[data-bs-theme="dark"] .brand-logo-light { display: none; }
[data-bs-theme="dark"] .brand-logo-dark { display: inline; }

/* ===== SIDEBAR ===== */
.app-sidebar {
    background-color: var(--zeke-sidebar-bg) !important;
}
@media (max-width: 991.98px) {
    .app-sidebar {
        max-height: 100dvh;
    }
    .app-sidebar .sidebar-wrapper {
        overflow-y: auto !important;
        max-height: calc(100dvh - 4rem);
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }
}

.app-sidebar .nav-link {
    color: var(--zeke-sidebar-color) !important;
    opacity: 0.82;
    border-radius: 6px;
    margin: 1px 6px;
    transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1),
                background-color 0.25s cubic-bezier(0.4, 0, 0.2, 1),
                color 0.25s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.18s ease;
}

.app-sidebar .nav-link:hover {
    opacity: 1;
    background-color: rgba(240, 171, 0, 0.12) !important;
}

.app-sidebar .nav-link:active {
    transform: scale(0.985);
}

.app-sidebar .nav-link.active {
    color: var(--zeke-sidebar-active) !important;
    opacity: 1;
    background-color: rgba(240, 171, 0, 0.18) !important;
    box-shadow: inset 3px 0 0 var(--zeke-gold);
}

.app-sidebar .nav-treeview .nav-link.active {
    color: var(--zeke-sidebar-active) !important;
}

/* Sidebar submenu indentation */
.app-sidebar .nav-treeview .nav-link {
    padding-left: 2rem;
}
.app-sidebar .nav-treeview .nav-treeview .nav-link {
    padding-left: 3rem;
}
.app-sidebar .nav-treeview .nav-treeview .nav-treeview .nav-link {
    padding-left: 3.5rem;
}
.app-sidebar .nav-treeview .nav-treeview .nav-treeview .nav-treeview .nav-link {
    padding-left: 4rem;
}

.app-sidebar .nav-link p {
    white-space: normal;
    line-height: 1.3;
}

.sidebar-brand {
    border-bottom: 2px solid var(--zeke-gold);
}

.sidebar-brand .brand-text {
    color: var(--zeke-sidebar-color) !important;
}

.sidebar-brand .brand-text b {
    color: var(--zeke-gold-dark) !important;
}

[data-bs-theme="dark"] .sidebar-brand .brand-text b {
    color: var(--zeke-gold) !important;
}

/* ===== NAVBAR ===== */
.app-header {
    background-color: var(--zeke-navbar-bg) !important;
    border-bottom: 2px solid var(--zeke-navbar-border) !important;
}

/* ===== BOTOES ===== */
.btn-primary {
    --bs-btn-bg: #F0AB00;
    --bs-btn-border-color: #F0AB00;
    --bs-btn-hover-bg: #C48900;
    --bs-btn-hover-border-color: #C48900;
    --bs-btn-active-bg: #9A6D00;
    --bs-btn-active-border-color: #9A6D00;
    --bs-btn-disabled-bg: #F0AB00;
    --bs-btn-disabled-border-color: #F0AB00;
    --bs-btn-disabled-color: #2D2926;
    --bs-btn-color: #2D2926;
    --bs-btn-hover-color: #FFFFFF;
}

.btn-outline-primary {
    --bs-btn-color: #F0AB00;
    --bs-btn-border-color: #F0AB00;
    --bs-btn-hover-bg: #F0AB00;
    --bs-btn-hover-border-color: #F0AB00;
    --bs-btn-hover-color: #2D2926;
    --bs-btn-active-bg: #C48900;
    --bs-btn-active-border-color: #C48900;
}

/* ===== CARDS ===== */
.card {
    border-top: 3px solid var(--zeke-gold);
}

.card-primary:not(.card-outline) {
    border-color: var(--zeke-gold) !important;
}

.card-primary:not(.card-outline) .card-header {
    background-color: transparent !important;
}

.card-primary.card-outline {
    border-top-color: var(--zeke-gold) !important;
}

/* ===== LINKS E ACENTOS ===== */
a {
    color: var(--bs-link-color);
}

a:hover {
    color: var(--bs-link-hover-color);
}

/* ===== NAV TABS / PILLS ===== */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background-color: var(--zeke-gold) !important;
    color: #2D2926 !important;
}

.nav-tabs .nav-link {
    color: var(--bs-body-color) !important;
}

.nav-tabs .nav-link.active {
    color: var(--zeke-gold) !important;
    border-bottom-color: var(--zeke-gold) !important;
}

/* ===== PAGINATION ===== */
.page-item.active .page-link {
    background-color: var(--zeke-gold);
    border-color: var(--zeke-gold);
    color: #2D2926;
}

.page-link {
    color: var(--bs-link-color);
}

p.small.text-muted {
    margin-bottom: 0 !important;
}

.d-sm-flex.align-items-sm-center {
    align-items: center !important;
}

ul.pagination {
    margin-bottom: 0 !important;
    padding: 7px 0;
}

/* ===== FORM FOCUS ===== */
.form-control:focus,
.form-select:focus {
    border-color: var(--zeke-gold);
    box-shadow: 0 0 0 3px rgba(240, 171, 0, 0.22),
                0 1px 2px rgba(0, 0, 0, 0.04);
}

/* ===== ALERTS ===== */
.alert-primary {
    background-color: rgba(240, 171, 0, 0.15);
    border-color: rgba(240, 171, 0, 0.3);
    color: var(--zeke-gold-dark);
}

/* ===== PROGRESS ===== */
.progress-bar {
    background-color: var(--zeke-gold);
}

/* ===== FOOTER ===== */
.app-footer {
    border-top: 2px solid var(--zeke-gold);
}

/* ===== TEMA ESCURO - OVERRIDES ESPECIFICOS ===== */
[data-bs-theme="dark"] .app-sidebar {
    background-color: var(--zeke-sidebar-bg) !important;
}

[data-bs-theme="dark"] .card {
    background-color: #211F1D;
    border-color: #3A3633;
}

[data-bs-theme="dark"] .card-header {
    border-bottom-color: #3A3633;
}

.table td,
.table th {
    vertical-align: middle;
}

.table tbody tr {
    transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.table-hover tbody tr:hover {
    cursor: pointer;
}


[data-bs-theme="dark"] .table {
    --bs-table-bg: transparent;
    --bs-table-striped-bg: rgba(255, 255, 255, 0.055);
    --bs-table-hover-bg: rgba(240, 171, 0, 0.09);
}

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: var(--zeke-input-bg);
    border-color: var(--zeke-input-border);
    color: #E8E6E3;
}

[data-bs-theme="dark"] .app-main {
    background-color: #1A1816;
}

[data-bs-theme="dark"] .content-header {
    color: #E8E6E3;
}

[data-bs-theme="dark"] .dropdown-menu {
    background-color: #2D2926;
    border-color: #3A3633;
}

[data-bs-theme="dark"] .dropdown-item {
    color: #E8E6E3;
}

[data-bs-theme="dark"] .dropdown-item:hover {
    background-color: rgba(240, 171, 0, 0.1);
}

[data-bs-theme="dark"] .alert-primary {
    color: var(--zeke-gold-light);
}

/* ===== USER DROPDOWN ===== */
.zeke-user-dropdown {
    min-width: 240px;
    border: none;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    border-top: 2px solid var(--zeke-gold);
}

[data-bs-theme="dark"] .zeke-user-dropdown {
    background-color: #211F1D;
    border-color: var(--zeke-gold);
}

/* ===== TOGGLE BUTTON ===== */
.theme-toggle {
    cursor: pointer;
    background: none;
    border: none;
    font-size: 1.1rem;
    padding: 0.5rem;
    color: inherit;
    transition: transform 0.3s;
}

.theme-toggle:hover {
    transform: scale(1.15);
}

/* ===== SCROLLBAR (dark) ===== */
[data-bs-theme="dark"] ::-webkit-scrollbar {
    width: 8px;
}

[data-bs-theme="dark"] ::-webkit-scrollbar-track {
    background: #1A1816;
}

[data-bs-theme="dark"] ::-webkit-scrollbar-thumb {
    background: #3A3633;
    border-radius: 4px;
}

[data-bs-theme="dark"] ::-webkit-scrollbar-thumb:hover {
    background: #F0AB00;
}

/* ===== FORM ENHANCEMENTS ===== */
.form-control,
.form-select {
    transition: border-color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                box-shadow 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                background-color 0.2s ease;
}

.form-label {
    font-weight: 500;
    font-size: 0.875rem;
    margin-bottom: 0.35rem;
    letter-spacing: 0.15px;
    line-height: 1.4;
    color: var(--bs-body-color);
}

/* ===== CARD ENHANCEMENTS ===== */
.card {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.2s ease;
}

/* ===== CONTENT HEADER ===== */
.content-header {
    padding: 0.75rem 0;
}
.content-header > .container-fluid,
section.content > .container-fluid {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.breadcrumb {
    background: none;
    padding: 0;
}

/* ===== SECTION TITLE ===== */
.crud-section-title {
    border-left: 3px solid var(--zeke-gold);
    padding-left: 0.75rem;
}

.crud-section-title h5 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--zeke-gold-dark);
}

[data-bs-theme="dark"] .crud-section-title h5 {
    color: var(--zeke-gold-light);
}

/* ===== TOAST NOTIFICATIONS ===== */
.zeke-toast {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1080;
    min-width: 320px;
    max-width: 420px;
    border-radius: 0.5rem;
    overflow: hidden;
    border-left: 4px solid var(--zeke-gold);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    animation: zeke-toast-in 0.4s ease;
    transition: opacity 0.4s ease, transform 0.4s ease;
}

@keyframes zeke-toast-in {
    from { opacity: 0; transform: translateX(100%); }
    to { opacity: 1; transform: translateX(0); }
}

.zeke-toast-header {
    display: flex;
    align-items: center;
    padding: 0.65rem 0.75rem;
    font-size: 0.9rem;
}

.zeke-toast-header strong {
    flex: 1;
}

.zeke-toast-close {
    background: none;
    border: none;
    font-size: 1.25rem;
    line-height: 1;
    cursor: pointer;
    opacity: 0.7;
    color: inherit;
    padding: 0 0.25rem;
}

.zeke-toast-close:hover {
    opacity: 1;
}

.zeke-toast-body {
    padding: 0 0.75rem 0.65rem;
    font-size: 0.85rem;
}

.zeke-toast-progress {
    height: 3px;
    background: rgba(0, 0, 0, 0.1);
}

.zeke-toast-progress-bar {
    height: 100%;
    background: var(--zeke-gold);
    animation: zeke-toast-countdown 4s linear forwards;
}

@keyframes zeke-toast-countdown {
    from { width: 100%; }
    to { width: 0%; }
}

/* Toast types */
.zeke-toast-success {
    background-color: #d4edda;
    color: #155724;
}

.zeke-toast-danger {
    background-color: #f8d7da;
    color: #721c24;
}

.zeke-toast-warning {
    background-color: #fff3cd;
    color: #856404;
}

.zeke-toast-info {
    background-color: #d1ecf1;
    color: #0c5460;
}

/* Toast dark mode */
[data-bs-theme="dark"] .zeke-toast-success {
    background-color: #1a3a2a;
    color: #a3d9b1;
}

[data-bs-theme="dark"] .zeke-toast-danger {
    background-color: #3a1a1e;
    color: #e8a3aa;
}

[data-bs-theme="dark"] .zeke-toast-warning {
    background-color: #3a3018;
    color: #e8d5a3;
}

[data-bs-theme="dark"] .zeke-toast-info {
    background-color: #1a2e3a;
    color: #a3cfe8;
}

[data-bs-theme="dark"] .zeke-toast-progress {
    background: rgba(255, 255, 255, 0.1);
}

/* ===== FILTER CHIPS (estilo app) ===== */
.zeke-filter-chips {
    gap: 0.4rem !important;
}

.zeke-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
    border-radius: 18px;
    background-color: #242424;
    color: #999;
    border: none;
    white-space: nowrap;
    transition: background-color 0.2s, color 0.2s;
}

.zeke-chip:hover {
    background-color: #333;
    color: #bbb;
}

[data-bs-theme="light"] .zeke-chip {
    background-color: #e8e8e8;
    color: #555;
}

[data-bs-theme="light"] .zeke-chip:hover {
    background-color: #ddd;
    color: #333;
}

.zeke-chip-remove {
    background: none;
    border: none;
    padding: 0;
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
    color: inherit;
    opacity: 0.5;
}

.zeke-chip-remove:hover {
    opacity: 1;
}

.zeke-filter-btn {
    min-width: 38px;
}


/* ===== ZEKE MODAL ===== */
.zeke-modal .modal-content {
    border: none;
    border-top: 3px solid var(--zeke-gold);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.zeke-modal .modal-header {
    border-bottom-color: rgba(240, 171, 0, 0.35);
}

.zeke-modal .modal-header .modal-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--zeke-gold-dark);
}

[data-bs-theme="dark"] .zeke-modal .modal-header .modal-title {
    color: var(--zeke-gold-light);
}

.zeke-modal .modal-footer {
    border-top-color: rgba(240, 171, 0, 0.35);
}

[data-bs-theme="dark"] .zeke-modal .modal-content {
    background-color: #211F1D;
    border-color: #3A3633;
}

[data-bs-theme="dark"] .zeke-modal .modal-header {
    border-bottom-color: #3A3633;
}

[data-bs-theme="dark"] .zeke-modal .modal-footer {
    border-top-color: #3A3633;
}

[data-bs-theme="dark"] .zeke-modal .btn-close {
    filter: invert(1);
}

/* ===== ZEKE CONFIRM DIALOG ===== */
.zeke-confirm-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1090;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: zeke-confirm-fade-in 0.2s ease;
}

@keyframes zeke-confirm-fade-in {
    from { opacity: 0; }
    to { opacity: 1; }
}

.zeke-confirm-dialog {
    background: #fff;
    border-radius: 0.75rem;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
    max-width: 380px;
    width: 90%;
    overflow: hidden;
    animation: zeke-confirm-slide-in 0.25s ease;
    border-top: 3px solid var(--zeke-gold);
}

@keyframes zeke-confirm-slide-in {
    from { opacity: 0; transform: scale(0.9) translateY(-10px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}

.zeke-confirm-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1.5rem auto 1rem;
    font-size: 1.5rem;
}

.zeke-confirm-icon-danger {
    background: rgba(220, 53, 69, 0.12);
    color: #dc3545;
}

.zeke-confirm-icon-warning {
    background: rgba(240, 171, 0, 0.15);
    color: #F0AB00;
}

.zeke-confirm-icon-primary {
    background: rgba(240, 171, 0, 0.15);
    color: #F0AB00;
}

.zeke-confirm-icon-info {
    background: rgba(13, 202, 240, 0.12);
    color: #0dcaf0;
}

.zeke-confirm-body {
    text-align: center;
    padding: 0 1.5rem 1.25rem;
}

.zeke-confirm-title {
    font-size: 1.05rem;
    font-weight: 600;
    margin-bottom: 0.35rem;
}

.zeke-confirm-message {
    font-size: 0.875rem;
    color: #6c757d;
    margin: 0;
}

.zeke-confirm-actions {
    display: flex;
    border-top: 1px solid #e9ecef;
}

.zeke-confirm-actions button {
    flex: 1;
    padding: 0.75rem;
    border: none;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s;
}

.zeke-confirm-cancel {
    background: #f8f9fa;
    color: #6c757d;
}

.zeke-confirm-cancel:hover {
    background: #e9ecef;
}

.zeke-confirm-ok,
.zeke-confirm-alt {
    color: #fff;
}

.zeke-confirm-ok-danger {
    background: #dc3545;
}

.zeke-confirm-ok-danger:hover {
    background: #bb2d3b;
}

.zeke-confirm-ok-warning {
    background: #F0AB00;
    color: #2D2926;
}

.zeke-confirm-ok-warning:hover {
    background: #C48900;
}

.zeke-confirm-ok-primary {
    background: #F0AB00;
    color: #2D2926;
}

.zeke-confirm-ok-primary:hover {
    background: #C48900;
}

.zeke-confirm-ok-info {
    background: #0dcaf0;
    color: #000;
}

.zeke-confirm-ok-info:hover {
    background: #31d2f2;
}

/* Confirm dark mode */
[data-bs-theme="dark"] .zeke-confirm-dialog {
    background: #211F1D;
    border-color: #3A3633;
}

[data-bs-theme="dark"] .zeke-confirm-title {
    color: #E8E6E3;
}

[data-bs-theme="dark"] .zeke-confirm-message {
    color: #9E9A95;
}

[data-bs-theme="dark"] .zeke-confirm-actions {
    border-top-color: #3A3633;
}

[data-bs-theme="dark"] .zeke-confirm-cancel {
    background: #2D2926;
    color: #9E9A95;
}

[data-bs-theme="dark"] .zeke-confirm-cancel:hover {
    background: #3A3633;
}

[data-bs-theme="dark"] .zeke-confirm-ok-warning,
[data-bs-theme="dark"] .zeke-confirm-ok-warning:hover {
    background: #F0AB00;
    color: #2D2926;
}

[data-bs-theme="dark"] .zeke-confirm-ok-primary,
[data-bs-theme="dark"] .zeke-confirm-ok-primary:hover {
    background: #F0AB00;
    color: #2D2926;
}

/* ===== ZEKE SMALL BOX (Dashboard Cards) ===== */
.zeke-small-box {
    border-radius: 0.5rem;
    padding: 1.25rem;
    position: relative;
    overflow: hidden;
    margin-bottom: 1rem;
    color: #fff;
    min-height: 130px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.zeke-small-box .inner h3 {
    font-size: 2.2rem;
    font-weight: 700;
    margin: 0;
    line-height: 1;
}

.zeke-small-box .inner p {
    font-size: 0.9rem;
    margin: 0.25rem 0 0;
    opacity: 0.9;
}

.zeke-small-box .icon {
    position: absolute;
    top: 0.75rem;
    right: 1rem;
    font-size: 4rem;
    opacity: 0.15;
    line-height: 1;
}

.zeke-small-box .footer {
    font-size: 0.8rem;
    padding-top: 0.5rem;
    margin-top: 0.5rem;
    border-top: 1px solid rgba(255,255,255,0.2);
    opacity: 0.85;
}

.zeke-small-box.bg-gold { background: linear-gradient(135deg, #F0AB00 0%, #C48900 100%); color: #fff; }
.zeke-small-box.bg-gold .icon { opacity: 0.15; color: #fff; }
.zeke-small-box.bg-purple { background: linear-gradient(135deg, #7B1FA2 0%, #4A148C 100%); }
.zeke-small-box.bg-teal { background: linear-gradient(135deg, #00897B 0%, #004D40 100%); }
.zeke-small-box.bg-green { background: linear-gradient(135deg, #43A047 0%, #2E7D32 100%); }
.zeke-small-box.bg-red { background: linear-gradient(135deg, #E53935 0%, #B71C1C 100%); }

[data-bs-theme="dark"] .zeke-small-box.bg-gold { background: linear-gradient(135deg, #C48900 0%, #9A6D00 100%); }
[data-bs-theme="dark"] .zeke-small-box.bg-purple { background: linear-gradient(135deg, #6A1B9A 0%, #38006B 100%); }
[data-bs-theme="dark"] .zeke-small-box.bg-teal { background: linear-gradient(135deg, #00796B 0%, #003D33 100%); }
[data-bs-theme="dark"] .zeke-small-box.bg-green { background: linear-gradient(135deg, #388E3C 0%, #1B5E20 100%); }
[data-bs-theme="dark"] .zeke-small-box.bg-red { background: linear-gradient(135deg, #C62828 0%, #8E0000 100%); }

/* ===== ZEKE RANGE SLIDER ===== */
.zeke-range {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 8px;
    background: #e0e0e0;
    border-radius: 4px;
    outline: none;
    cursor: pointer;
}

.zeke-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 24px;
    height: 24px;
    background: var(--zeke-gold);
    border: 3px solid #fff;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 5px rgba(0,0,0,0.25);
    transition: transform 0.15s;
}

.zeke-range::-moz-range-thumb {
    width: 24px;
    height: 24px;
    background: var(--zeke-gold);
    border: 3px solid #fff;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 5px rgba(0,0,0,0.25);
    transition: transform 0.15s;
}

.zeke-range:hover::-webkit-slider-thumb { transform: scale(1.15); }
.zeke-range:hover::-moz-range-thumb { transform: scale(1.15); }

[data-bs-theme="dark"] .zeke-range { background: #3A3633; }
[data-bs-theme="dark"] .zeke-range::-webkit-slider-thumb { border-color: #2D2926; }
[data-bs-theme="dark"] .zeke-range::-moz-range-thumb { border-color: #2D2926; }

/* ===== ZEKE SEDE VIEW TABS ===== */
.zeke-sede-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem;
    border-radius: 0.5rem;
    background: linear-gradient(135deg, var(--zeke-gold) 0%, var(--zeke-gold-dark) 100%);
    color: #2D2926;
    margin-bottom: 1.5rem;
}

.zeke-sede-header .avatar {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: rgba(255,255,255,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 700;
    flex-shrink: 0;
}

.zeke-sede-header h2 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
}

.zeke-sede-header .subtitle {
    margin: 0;
    opacity: 0.7;
    font-size: 0.9rem;
}

/* ===== ESCALAS - HEADER SECTION ===== */
.zeke-header-section {
    background: var(--zeke-accent-bg);
    border-radius: 12px;
    padding: 1.5rem 2rem;
    margin-bottom: 1.5rem;
    color: var(--zeke-accent);
}

.zeke-header-section h1 {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 0 0.25rem;
    color: var(--zeke-accent);
}

.zeke-header-section h1 i {
    margin-right: 0.5rem;
}

.zeke-header-section .header-subtitle {
    margin: 0;
    opacity: 0.75;
    font-size: 0.9rem;
}

/* ===== ESCALAS - EVENT COUNTER ===== */
.zeke-event-counter {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: rgba(240, 171, 0, 0.1);
    border: 1px solid rgba(240, 171, 0, 0.2);
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--zeke-gold-dark);
    margin-bottom: 1rem;
}

[data-bs-theme="dark"] .zeke-event-counter {
    background: rgba(240, 171, 0, 0.15);
    border-color: rgba(240, 171, 0, 0.3);
    color: var(--zeke-gold-light);
}

/* ===== ESCALAS - EVENT CARDS ===== */
.zeke-event-card {
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.2s, box-shadow 0.2s;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.zeke-event-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    border-color: rgba(240, 171, 0, 0.35);
}

[data-bs-theme="dark"] .zeke-event-card {
    border-color: rgba(255, 255, 255, 0.1);
    background: var(--bs-card-bg);
}

[data-bs-theme="dark"] .zeke-event-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

.zeke-event-card .card-header {
    background: var(--zeke-accent-bg);
    color: var(--zeke-accent);
    padding: 0.75rem 1rem;
    border: none;
    border-bottom: 1px solid var(--zeke-accent-bg);
}

.zeke-event-card .card-header h5 {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
}

.zeke-event-card .card-body {
    padding: 1rem;
    flex: 1;
}

.zeke-event-card .card-datetime {
    font-size: 0.85rem;
    color: #666;
    margin-bottom: 0.75rem;
}

[data-bs-theme="dark"] .zeke-event-card .card-datetime {
    color: #aaa;
}

.zeke-event-card .funcao-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.3rem 0.6rem;
    font-size: 0.78rem;
    font-weight: 600;
    border-radius: 16px;
    background: #242424;
    color: #ccc;
    margin: 0.15rem;
}

[data-bs-theme="light"] .zeke-event-card .funcao-badge {
    background: #e8e8e8;
    color: #444;
}

.zeke-event-card .card-footer {
    padding: 0.5rem 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    background: transparent;
}

[data-bs-theme="dark"] .zeke-event-card .card-footer {
    border-top-color: rgba(255, 255, 255, 0.08);
}

/* Gestao de escalas - bulk mode selection */
.evento-card-wrapper.bulk-mode .zeke-event-card {
    cursor: pointer;
    user-select: none;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.15s, background 0.15s;
}
.evento-card-wrapper.bulk-mode .zeke-event-card:hover {
    border-color: rgba(240, 171, 0, 0.4);
    box-shadow: 0 0 0 1px rgba(240, 171, 0, 0.2);
}
.evento-card-wrapper.selected .zeke-event-card {
    border: 2px solid var(--zeke-accent) !important;
    background: var(--zeke-accent-bg) !important;
    box-shadow: 0 0 8px rgba(240, 171, 0, 0.08) !important;
}
.evento-card-wrapper.selected .zeke-event-card .card-header {
    background: var(--zeke-accent-bg) !important;
    color: var(--zeke-accent) !important;
}
[data-bs-theme="dark"] .evento-card-wrapper.selected .zeke-event-card {
    background: var(--zeke-accent-bg) !important;
    box-shadow: 0 0 8px rgba(240, 171, 0, 0.1) !important;
}

/* ===== ESCALAS - MONTH NAV ===== */
.zeke-month-nav {
    display: flex;
    align-items: center;
    gap: 0;
}

.zeke-month-nav .btn-month-prev,
.zeke-month-nav .btn-month-next {
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 0.2s;
}

.zeke-month-nav .btn-month-prev {
    border-radius: 6px 0 0 6px;
    border-right: none;
}

.zeke-month-nav .btn-month-next {
    border-radius: 0 6px 6px 0;
    border-left: none;
}

.zeke-month-nav .btn-month-prev:hover,
.zeke-month-nav .btn-month-next:hover {
    background: var(--zeke-gold);
    color: #fff;
    border-color: var(--zeke-gold);
}

.zeke-month-nav .month-display {
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    padding: 0.375rem 1.25rem;
    font-size: 0.875rem;
    font-weight: 600;
    text-align: center;
    min-width: 160px;
    cursor: pointer;
    position: relative;
}

.zeke-month-nav .month-display input[type="month"] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

/* ===== ESCALAS - MATRIX TABLE ===== */
.zeke-matrix-table {
    width: auto;
    border-collapse: collapse;
}

.zeke-matrix-table .area-header td {
    background: rgba(240, 171, 0, 0.1);
    font-weight: 700;
    font-size: 0.85rem;
    color: var(--zeke-gold-dark);
    padding: 0.5rem 0.75rem;
    border-bottom: 2px solid rgba(240, 171, 0, 0.3);
}

[data-bs-theme="dark"] .zeke-matrix-table .area-header td {
    background: rgba(240, 171, 0, 0.15);
    color: var(--zeke-gold-light);
    border-bottom-color: rgba(240, 171, 0, 0.35);
}

.zeke-matrix-table td,
.zeke-matrix-table th {
    padding: 0.5rem 0.75rem;
    vertical-align: middle;
    border-bottom: 1px solid var(--bs-border-color);
    white-space: nowrap;
}

.zeke-matrix-table .funcao-name {
    font-weight: 600;
    font-size: 0.875rem;
}

.zeke-matrix-table .funcao-area-sub {
    font-size: 0.75rem;
    color: #999;
}

.manage-cell-membro {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
    position: relative;
}
.manage-cell-membro .membro-assigned {
    font-size: 0.78rem;
    font-weight: 500;
    white-space: nowrap;
}
.manage-cell-membro .btn-remover {
    position: absolute;
    top: -4px;
    right: -8px;
    padding: 0 0.2rem;
    font-size: 0.6rem;
    line-height: 1;
    opacity: 0;
    transition: opacity 0.15s;
}
.manage-cell-membro:hover .btn-remover {
    opacity: 1;
}
.manage-cell-blocked {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.15rem;
    color: #999;
    font-size: 0.75rem;
}
.manage-cell-blocked i {
    font-size: 1.2rem;
    opacity: 0.4;
}

/* Manage page - sticky function column */
.zeke-matrix-table .sticky-col {
    position: sticky;
    left: 0;
    z-index: 1;
    background: var(--bs-body-bg, #fff);
}
[data-bs-theme="dark"] .zeke-matrix-table .sticky-col {
    background: var(--bs-body-bg, #1a1d20);
}
.zeke-matrix-table .evento-col-header {
    font-size: 0.8rem;
    padding: 0.5rem;
    line-height: 1.3;
}

/* Manage page - avatars */
.manage-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(0, 0, 0, 0.08);
    flex-shrink: 0;
}
[data-bs-theme="dark"] .manage-avatar {
    border-color: rgba(255, 255, 255, 0.12);
}

/* Card header accent (gold) */
.card-header.zeke-accent {
    background: var(--zeke-accent-bg) !important;
}
.card-header.zeke-accent .card-title,
.card-header.zeke-accent h5 {
    color: var(--zeke-accent) !important;
}

/* Manage readonly (escala mensal) */
.manage-readonly td,
.manage-readonly tr {
    cursor: default !important;
}
.manage-readonly tr:hover td {
    background-color: inherit !important;
}

/* Manage page - editable function names */
.funcao-editable {
    cursor: pointer;
    transition: color 0.15s;
    border-bottom: 1px dashed transparent;
}
.funcao-editable:hover {
    color: var(--zeke-gold-dark);
    border-bottom-color: var(--zeke-gold-dark);
}
[data-bs-theme="dark"] .funcao-editable:hover {
    color: var(--zeke-gold-light);
    border-bottom-color: var(--zeke-gold-light);
}
.funcao-editable.customized {
    font-style: italic;
}
.funcao-editable.flash-gold {
    color: var(--zeke-gold-dark);
    transition: color 0.8s ease;
}
[data-bs-theme="dark"] .funcao-editable.flash-gold {
    color: var(--zeke-gold-light);
}

/* Quantity hint message */
.qty-hint {
    background: linear-gradient(135deg, var(--zeke-gold), var(--zeke-gold-dark));
    color: #fff;
    font-size: 0.8rem;
    padding: 0.4rem 0.75rem;
    border-radius: 0.375rem;
    margin-bottom: 0.5rem;
    opacity: 1;
    transition: opacity 0.4s ease;
}
.qty-hint-fade {
    opacity: 0;
}

/* Manage page - member list in modal */
.manage-member-list {
    max-height: 350px;
    overflow-y: auto;
}
.manage-member-list .membro-item {
    cursor: pointer;
    transition: background 0.1s;
}
.manage-member-list .membro-item:hover {
    background: rgba(240, 171, 0, 0.06);
}
[data-bs-theme="dark"] .manage-member-list .membro-item:hover {
    background: rgba(240, 171, 0, 0.1);
}

/* ===== ESCALAS - LOAD MORE BUTTON ===== */
.zeke-load-more {
    display: flex;
    justify-content: center;
    padding: 1.5rem 0;
}

.zeke-load-more .btn {
    border-radius: 20px;
    padding: 0.5rem 2rem;
    font-weight: 600;
    border: 2px solid var(--zeke-gold);
    color: var(--zeke-gold-dark);
    background: transparent;
    transition: all 0.2s;
}

.zeke-load-more .btn:hover {
    background: var(--zeke-gold);
    color: #fff;
}

[data-bs-theme="dark"] .zeke-load-more .btn {
    color: var(--zeke-gold-light);
}

/* ===== ESCALAS - MANAGE INFO BAR ===== */
.zeke-manage-info {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.25rem;
    background: rgba(240, 171, 0, 0.08);
    border-radius: 10px;
    border: 1px solid rgba(240, 171, 0, 0.15);
    margin-bottom: 1rem;
}

[data-bs-theme="dark"] .zeke-manage-info {
    background: rgba(240, 171, 0, 0.1);
    border-color: rgba(240, 171, 0, 0.2);
}

.zeke-manage-info .info-item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.875rem;
}

.zeke-manage-info .info-item strong {
    font-weight: 600;
}

.zeke-manage-info .info-separator {
    width: 1px;
    height: 20px;
    background: rgba(240, 171, 0, 0.3);
}

/* ===== Badge Accent ===== */
.badge-zeke-accent {
    background-color: rgba(196, 137, 0, 0.2);
    color: #9A6D00;
}
[data-bs-theme="dark"] .badge-zeke-accent {
    background-color: var(--zeke-accent-bg);
    color: var(--zeke-accent);
}
.badge-zeke-info {
    background-color: rgba(55, 90, 140, 0.2);
    color: #375a8c;
}
[data-bs-theme="dark"] .badge-zeke-info {
    background-color: rgba(108, 142, 191, 0.15);
    color: #8baad4;
}

/* ===== Checkboxes ===== */
.form-check-input:checked {
    background-color: var(--zeke-gold-dark);
    border-color: var(--zeke-gold-dark);
}
.form-check-input:focus {
    border-color: var(--zeke-gold);
    box-shadow: 0 0 0 .25rem rgba(196, 137, 0, .25);
}

/* ===== Widget User (profile card) ===== */
.card-widget.widget-user .widget-user-image {
    text-align: center;
    padding: 1rem 0;
}
.card-widget.widget-user .widget-user-image > img {
    border-radius: 50% !important;
    width: 110px !important;
    height: 110px !important;
    object-fit: cover;
    margin: 0 auto;
}
.card-widget.widget-user .card-footer {
    padding-top: 4rem;
}

/* ===== MOBILE: espaçamento entre cards ===== */
@media (max-width: 767.98px) {
    .card + .card,
    .card + .alert,
    .alert + .card {
        margin-top: 0.75rem;
    }
}

/* ===== PRINT ===== */
@media print {
    .app-sidebar,
    .app-header,
    .app-footer,
    .content-header,
    .btn,
    .no-print {
        display: none !important;
        border: none !important;
        height: 0 !important;
        overflow: hidden !important;
    }
    .app-main {
        margin-left: 0 !important;
        padding: 0 !important;
    }
    .app-wrapper {
        margin-left: 0 !important;
    }
    .card {
        border: 1px solid #ddd !important;
        box-shadow: none !important;
        break-inside: avoid;
    }
    body {
        background: #fff !important;
        color: #000 !important;
    }
}


/* .select2-wrapper: hook legado de markup p/ posicionar invalid-feedback
   abaixo do select (a lib Select2 foi removida; a classe segue em alguns forms) */
.select2-wrapper {
    display: flex;
    flex-direction: column;
}
.select2-wrapper .invalid-feedback {
    order: 2;
}

/* ===== BOOTSTRAP DATEPICKER — Integração com tema Zeke ===== */
.datepicker {
    background-color: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    padding: 8px;
}
.datepicker table {
    width: 100%;
}
.datepicker table tr td,
.datepicker table tr th {
    color: var(--bs-body-color);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 0.95rem;
}
.datepicker table tr td span:hover,
.datepicker table tr td.day:hover {
    background-color: rgba(240, 171, 0, 0.3) !important;
    color: var(--bs-body-color) !important;
}
.datepicker table tr td.active,
.datepicker table tr td.active:hover,
.datepicker table tr td span.active,
.datepicker table tr td span.active:hover,
.datepicker table tr td span.active.active,
.datepicker table tr td span.focused {
    background: var(--zeke-gold) !important;
    background-color: var(--zeke-gold) !important;
    background-image: none !important;
    color: #2D2926 !important;
    font-weight: 600;
}
.datepicker table tr td span.focused:hover {
    background: var(--zeke-gold-dark) !important;
    background-color: var(--zeke-gold-dark) !important;
    background-image: none !important;
    color: #fff !important;
    font-weight: 600;
}
.datepicker table tr td.today,
.datepicker table tr td.today:hover {
    background-color: var(--zeke-accent-bg) !important;
    color: var(--zeke-gold) !important;
    font-weight: 600;
}
.datepicker table tr td.disabled,
.datepicker table tr td.disabled:hover {
    color: var(--bs-secondary-color) !important;
    opacity: 0.4;
    cursor: not-allowed !important;
    background: transparent !important;
}
.datepicker .datepicker-switch,
.datepicker .prev,
.datepicker .next {
    color: var(--bs-body-color);
    font-weight: 600;
    font-size: 1rem;
}
.datepicker .datepicker-switch:hover,
.datepicker .prev:hover,
.datepicker .next:hover {
    background-color: var(--zeke-accent-bg) !important;
    color: var(--zeke-gold) !important;
}
.datepicker .dow {
    color: var(--bs-secondary-color);
    font-weight: 500;
}

/* Campos readonly usados com datepicker/flatpickr — manter aparência editável */
.form-control.datepicker-input[readonly],
.form-control.flatpickr-input[readonly],
.form-control.readonly-visual-normal[readonly] {
    border-style: solid !important;
    cursor: pointer !important;
}
[data-bs-theme="dark"] .form-control.datepicker-input[readonly],
[data-bs-theme="dark"] .form-control.flatpickr-input[readonly],
[data-bs-theme="dark"] .form-control.readonly-visual-normal[readonly] {
    background-color: var(--zeke-input-bg) !important;
    border-color: var(--zeke-input-border) !important;
    color: #E8E6E3 !important;
}
[data-bs-theme="light"] .form-control.datepicker-input[readonly],
[data-bs-theme="light"] .form-control.flatpickr-input[readonly],
[data-bs-theme="light"] .form-control.readonly-visual-normal[readonly] {
    background-color: #fff !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}

/* Campos readonly/disabled — visual claro de "não editável" */
.form-control[readonly]:not(.flatpickr-input):not(.readonly-visual-normal),
.form-control:disabled {
    background-color: #e8e0d4 !important;
    border-style: dashed !important;
    border-color: #b5a48a !important;
    opacity: 1;
    cursor: not-allowed;
    color: #6b5e4d !important;
}
.btn-group:has(.btn-check:disabled) .btn {
    opacity: .5;
    cursor: not-allowed;
    border-style: dashed !important;
    background-color: transparent !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-secondary-color) !important;
}
/* Mantem o botao selecionado com a cor da variante pra continuar legivel */
.btn-group:has(.btn-check:disabled) .btn-check:checked + .btn {
    background-color: var(--bs-btn-active-bg) !important;
    border-color: var(--bs-btn-active-border-color) !important;
    color: var(--bs-btn-active-color) !important;
    border-style: solid !important;
    opacity: .75;
}
[data-bs-theme="dark"] .form-control[readonly]:not(.flatpickr-input):not(.readonly-visual-normal),
[data-bs-theme="dark"] .form-control:disabled {
    background-color: #302a24 !important;
    border-color: #5a4f3e !important;
    color: #9a8e7a !important;
}
[data-bs-theme="dark"] .btn-group:has(.btn-check:disabled) .btn-check:checked + .btn {
    border-color: var(--bs-btn-active-border-color) !important;
    opacity: .75;
}

/* Badge flutuante estilo app (canto superior direito) */
.mat-badge-wrap { position: relative; display: inline-block; }
.mat-badge {
    position: absolute; top: -6px; right: -6px;
    font-size: 10px; line-height: 1; padding: 3px 5px;
    border-radius: 10px; min-width: 18px; text-align: center;
    pointer-events: none;
}

/* Dia da semana — círculos toggle */
.dia-circle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    user-select: none;
    transition: background-color 0.15s, color 0.15s, border-color 0.15s;
    border: 1.5px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    color: var(--bs-secondary-color);
}
.dia-circle:hover {
    border-color: var(--zeke-gold);
    color: var(--zeke-gold);
}
.dia-circle.active {
    background: var(--zeke-gold);
    border-color: var(--zeke-gold);
    color: #fff;
}

/* Reunião — chips de preview de datas geradas */
.reuniao-date-chip {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 14px;
    font-size: 0.8rem;
    margin: 2px 4px 2px 0;
}
.reuniao-date-chip.primary {
    background: var(--zeke-gold);
    color: #fff;
}
.reuniao-date-chip.secondary {
    background: var(--zeke-navbar-bg);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color);
}

/* Flatpickr — force 7 days per row (Bootstrap border-box breaks the grid) */
.flatpickr-day {
    max-width: 14.2857% !important;
    min-width: 14.2857% !important;
}

/* Flatpickr dark mode */
[data-bs-theme="dark"] .flatpickr-calendar {
    background: #2b2b2b;
    border-color: #444;
    box-shadow: 0 4px 16px rgba(0,0,0,.4);
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-months,
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-month {
    background: #333;
    color: #e0e0e0;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months,
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-current-month input.cur-year {
    background: #333;
    color: #e0e0e0;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-weekdays,
[data-bs-theme="dark"] .flatpickr-calendar span.flatpickr-weekday {
    background: #333;
    color: #999;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-day {
    color: #ddd;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-day:hover {
    background: #444;
    border-color: #555;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-day.selected {
    background: var(--zeke-gold);
    border-color: var(--zeke-gold);
    color: #fff;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-day.today {
    border-color: var(--zeke-gold);
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-day.flatpickr-disabled,
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-day.prevMonthDay,
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-day.nextMonthDay {
    color: #555;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-months .flatpickr-prev-month,
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-months .flatpickr-next-month {
    fill: #ccc;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-months .flatpickr-prev-month:hover,
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-months .flatpickr-next-month:hover {
    fill: var(--zeke-gold);
}

/* Erro de validação client-side não empurra layout */
.invalid-feedback-client {
    position: absolute;
    top: 100%;
    left: 0;
    margin-top: 0 !important;
}
.mb-3, .form-group {
    position: relative;
}

/* Bootstrap 5 removeu o estilo de .form-group (BS4) — restaura o espaçamento
   vertical para as views que ainda usam a classe crua */
.form-group {
    margin-bottom: 1rem;
}

/* ===== FORM DASHBOARD LAYOUT ===== */
/* Layout reutilizável para formulários com sidebar de preview */

.form-dashboard {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1.25rem;
    align-items: stretch;
}
.form-dashboard-main {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}
.form-dashboard-sidebar {
    display: flex;
    flex-direction: column;
}

/* Seções do formulário */
.form-dashboard-section {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: .5rem;
    padding: 1.25rem;
}
.form-dashboard-section-title {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .95rem;
    font-weight: 600;
    color: var(--bs-heading-color, var(--bs-body-color));
    margin-bottom: 1rem;
    padding-bottom: .75rem;
    border-bottom: 2px solid var(--zeke-gold);
}
.form-dashboard-section-title i {
    color: var(--zeke-gold-dark);
    font-size: 1rem;
}

/* Footer com botões */
.form-dashboard-footer {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}

/* Sidebar - Preview */
.form-dashboard-preview {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: .5rem;
    padding: 1.25rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.form-dashboard-preview-title {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--bs-heading-color, var(--bs-body-color));
    margin-bottom: 1rem;
}
.form-dashboard-preview-title i {
    color: var(--zeke-gold-dark);
}
.form-dashboard-preview-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .45rem 0;
    border-bottom: 1px solid var(--bs-border-color);
    font-size: .85rem;
}
.form-dashboard-preview-item:has(+ .form-dashboard-shortcuts) {
    border-bottom: none;
}
.form-dashboard-preview-label {
    color: var(--bs-secondary-color, #6c757d);
    font-weight: 500;
}
.form-dashboard-preview-value {
    font-weight: 600;
    color: var(--bs-heading-color, var(--bs-body-color));
    text-align: right;
    max-width: 60%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Sidebar - Atalhos */
.form-dashboard-shortcuts {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--bs-border-color);
}
.form-dashboard-shortcuts-title {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .85rem;
    font-weight: 600;
    color: var(--bs-heading-color, var(--bs-body-color));
    margin-bottom: .75rem;
}
.form-dashboard-shortcut-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .35rem;
    font-size: .8rem;
}
.form-dashboard-shortcut-key {
    background: var(--zeke-gold);
    color: #333;
    padding: 2px 7px;
    border-radius: 4px;
    font-weight: 600;
    font-size: .75rem;
    min-width: 32px;
    text-align: center;
    white-space: nowrap;
}
.form-dashboard-shortcut-desc {
    color: var(--bs-secondary-color, #6c757d);
}

/* Sidebar - Dica */
.form-dashboard-tip {
    margin-top: auto;
    padding: .75rem;
    background: var(--zeke-accent-bg);
    border-radius: .5rem;
    border: 1px solid rgba(240, 171, 0, 0.2);
}
.form-dashboard-tip-title {
    font-size: .8rem;
    font-weight: 600;
    color: var(--zeke-gold-dark);
    margin-bottom: .25rem;
}
.form-dashboard-tip-text {
    font-size: .78rem;
    color: var(--bs-secondary-color, #6c757d);
    line-height: 1.4;
}

/* Animação de foco no botão salvar (form-dashboard) */
.form-dashboard .btn-primary:focus {
    box-shadow: 0 0 0 4px rgba(240, 171, 0, 0.35),
                0 0 15px rgba(240, 171, 0, 0.4) !important;
    animation: fd-pulse-focus 1.5s infinite;
}
@keyframes fd-pulse-focus {
    0%, 100% { box-shadow: 0 0 0 4px rgba(240, 171, 0, 0.35), 0 0 15px rgba(240, 171, 0, 0.4); }
    50% { box-shadow: 0 0 0 6px rgba(240, 171, 0, 0.5), 0 0 25px rgba(240, 171, 0, 0.6); }
}

/* Responsivo */
@media (max-width: 991.98px) {
    .form-dashboard {
        grid-template-columns: 1fr;
    }
    .form-dashboard-sidebar {
        position: static;
        order: -1;
    }
}

/* Notification Bell */
.notification-item-unread {
    border-left: 3px solid var(--zeke-gold, #F0AB00);
    background-color: rgba(240, 171, 0, 0.05);
}

[data-bs-theme="dark"] .notification-item-unread {
    background-color: rgba(240, 171, 0, 0.1);
}

#notification-dropdown .dropdown-item:hover {
    background-color: rgba(240, 171, 0, 0.1);
}

#notification-count {
    font-size: 0.6rem;
    padding: 2px 5px;
    position: relative;
    top: -8px;
    left: -5px;
}

/* Custom SVG menu icons */
.nav-icon svg {
    width: 1em;
    height: 1em;
    fill: currentColor;
}
.sidebar .nav-link .nav-icon svg {
    font-size: 1.2rem;
    margin-right: 0.3rem;
}

/* Social login buttons */
.btn-social {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 500;
    transition: opacity 0.2s;
}
.btn-social:hover { opacity: 0.85; }

.btn-social-google {
    background: #fff;
    color: #3c4043;
    border: 1px solid #dadce0;
}
[data-bs-theme="dark"] .btn-social-google {
    background: #2d2d2d;
    color: #e8eaed;
    border-color: #5f6368;
}

.btn-social-facebook {
    background: #1877F2;
    color: #fff;
    border: none;
}

.btn-social-apple {
    background: #000;
    color: #fff;
    border: none;
}
[data-bs-theme="dark"] .btn-social-apple {
    background: #fff;
    color: #000;
}

/* ── Card tools fix ── */
.card-header > .card-tools { margin-right: 0; display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }

/* ── Presença Grid: 3-button control ── */
.presenca-btn-group { display: inline-flex; gap: 0; }
.presenca-btn {
    width: 36px; height: 34px; border: 2px solid #dee2e6;
    background: #fff; display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: all 0.15s; font-size: 14px; color: #adb5bd;
}
.presenca-btn:first-child { border-radius: 6px 0 0 6px; }
.presenca-btn:last-child { border-radius: 0 6px 6px 0; }
.presenca-btn:not(:first-child) { border-left: none; }
.presenca-btn:hover { background: #f0f0f0; }
.presenca-btn.active-presente { background: #198754; border-color: #198754; color: #fff; border-left: 2px solid #198754 !important; }
.presenca-btn.active-pendente { background: #ffc107; border-color: #ffc107; color: #000; border-left: 2px solid #ffc107 !important; }
.presenca-btn.active-ausente { background: #dc3545; border-color: #dc3545; color: #fff; border-left: 2px solid #dc3545 !important; }
.presenca-btn.active-presente:hover { background: #157347; }
.presenca-btn.active-pendente:hover { background: #e0a800; }
.presenca-btn.active-ausente:hover { background: #bb2d3b; }
.presenca-btn.disabled { pointer-events: none; opacity: 0.5; }

tr[data-presenca="presente"] { background: rgba(25,135,84,0.06) !important; }
tr[data-presenca="ausente"] { background: rgba(220,53,69,0.06) !important; }

.presenca-motivo { transition: opacity 0.2s; }
.presenca-motivo.is-hidden { opacity: 0.3; pointer-events: none; }

.badge-pendente { background: #ffc107; color: #000; }
.badge-lancado { background: #198754; color: #fff; }

[data-bs-theme="dark"] .presenca-btn { background: #2b3035; border-color: #495057; color: #6c757d; }
[data-bs-theme="dark"] .presenca-btn:not(:first-child) { border-left-color: #495057; }
[data-bs-theme="dark"] .presenca-btn:hover { background: #343a40; }
[data-bs-theme="dark"] .presenca-btn.active-presente { background: #198754; border-color: #198754; color: #fff; border-left-color: #198754 !important; }
[data-bs-theme="dark"] .presenca-btn.active-pendente { background: #ffc107; border-color: #ffc107; color: #000; border-left-color: #ffc107 !important; }
[data-bs-theme="dark"] .presenca-btn.active-ausente { background: #dc3545; border-color: #dc3545; color: #fff; border-left-color: #dc3545 !important; }
[data-bs-theme="dark"] .presenca-btn.active-presente:hover { background: #157347; }
[data-bs-theme="dark"] .presenca-btn.active-pendente:hover { background: #e0a800; }
[data-bs-theme="dark"] .presenca-btn.active-ausente:hover { background: #bb2d3b; }

/* =====================================================================
 * POLISH PASS 1 — micro-interações, sombras, focus rings, mobile
 * Áreas: layout base (sidebar/navbar), tabelas, formulários/modais.
 * Mantém parity light/dark. Nada aqui remove regras anteriores.
 * ===================================================================== */

/* --- Variáveis de sombra/ring consistentes --- */
[data-bs-theme="light"] {
    --zeke-shadow-sm: 0 1px 2px rgba(28, 24, 18, 0.04), 0 1px 3px rgba(28, 24, 18, 0.06);
    --zeke-shadow-md: 0 4px 10px rgba(28, 24, 18, 0.06), 0 2px 4px rgba(28, 24, 18, 0.05);
    --zeke-shadow-lg: 0 12px 28px rgba(28, 24, 18, 0.12), 0 4px 10px rgba(28, 24, 18, 0.06);
    --zeke-ring: 0 0 0 3px rgba(240, 171, 0, 0.28);
    --zeke-divider: rgba(28, 24, 18, 0.06);
}
[data-bs-theme="dark"] {
    --zeke-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.35);
    --zeke-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.45), 0 2px 4px rgba(0, 0, 0, 0.35);
    --zeke-shadow-lg: 0 14px 32px rgba(0, 0, 0, 0.55), 0 4px 10px rgba(0, 0, 0, 0.35);
    --zeke-ring: 0 0 0 3px rgba(240, 171, 0, 0.35);
    --zeke-divider: rgba(255, 255, 255, 0.06);
}

/* --- App header: sombra sutil + border fino no light, grosso no dark --- */
[data-bs-theme="light"] .app-header {
    box-shadow: 0 1px 3px rgba(28, 24, 18, 0.05);
    border-bottom-width: 1px !important;
}
[data-bs-theme="dark"] .app-header {
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.25);
}

/* --- Avatar/ícones no navbar: micro-interação no hover --- */
.app-header .navbar-nav .nav-link > img,
.app-header .navbar-nav .nav-link > i {
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                filter 0.2s ease;
}
.app-header .navbar-nav .nav-link:hover > img,
.app-header .navbar-nav .nav-link:hover > i {
    transform: scale(1.08);
}

/* --- Sidebar brand: transição suave --- */
.sidebar-brand,
.sidebar-brand .brand-text,
.sidebar-brand .brand-image {
    transition: color 0.25s ease, opacity 0.25s ease;
}

/* --- Focus-visible global (teclado, não mouse) --- */
.btn:focus-visible,
.nav-link:focus-visible,
.page-link:focus-visible,
.dropdown-item:focus-visible {
    outline: none;
    box-shadow: var(--zeke-ring);
    border-radius: 0.25rem;
}

/* --- Botões: micro-elevação no hover (primary/outline) --- */
.btn-primary,
.btn-outline-primary,
.btn-success,
.btn-danger,
.btn-warning,
.btn-info {
    transition: transform 0.12s ease,
                box-shadow 0.18s ease,
                background-color 0.18s ease,
                border-color 0.18s ease,
                color 0.18s ease;
}
.btn-primary:hover,
.btn-success:hover,
.btn-danger:hover,
.btn-warning:hover,
.btn-info:hover {
    box-shadow: 0 2px 6px rgba(240, 171, 0, 0.25);
    transform: translateY(-1px);
}
.btn-primary:active,
.btn-outline-primary:active,
.btn-success:active,
.btn-danger:active,
.btn-warning:active,
.btn-info:active {
    transform: translateY(0);
    box-shadow: none;
}

/* --- Card: elevação refinada --- */
.card {
    box-shadow: var(--zeke-shadow-sm) !important;
}
.card:hover {
    box-shadow: var(--zeke-shadow-md) !important;
}

/* --- Tabela: header pegajoso em scroll + divisores sutis --- */
.table > thead > tr > th {
    font-weight: 600;
    font-size: 0.82rem;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    color: rgba(45, 41, 38, 0.72);
    background-color: rgba(240, 171, 0, 0.04);
    border-bottom: 1px solid rgba(240, 171, 0, 0.25) !important;
}
[data-bs-theme="dark"] .table > thead > tr > th {
    color: rgba(232, 230, 227, 0.78);
    background-color: rgba(240, 171, 0, 0.06);
    border-bottom-color: rgba(240, 171, 0, 0.3) !important;
}

.table-responsive > .table > thead > tr > th,
.card > .card-body > .table > thead > tr > th {
    position: sticky;
    top: 0;
    z-index: 4;
}

.table td {
    border-color: var(--zeke-divider) !important;
}

.table tbody tr:hover {
    box-shadow: inset 2px 0 0 var(--zeke-gold);
}

/* --- Ações inline na tabela: opacidade suave até hover do row --- */
.table tbody tr .row-actions,
.table tbody tr td .btn-group-row-actions {
    opacity: 0.55;
    transition: opacity 0.15s ease;
}
.table tbody tr:hover .row-actions,
.table tbody tr:hover td .btn-group-row-actions,
.table tbody tr:focus-within .row-actions,
.table tbody tr:focus-within td .btn-group-row-actions {
    opacity: 1;
}

/* --- Badges: leve elevação --- */
.badge {
    letter-spacing: 0.2px;
    font-weight: 600;
}

/* --- Modal: backdrop blur + conteúdo com animação refinada --- */
.modal-backdrop.show {
    opacity: 0.55;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
}
.zeke-modal .modal-content {
    box-shadow: var(--zeke-shadow-lg) !important;
    border-radius: 0.75rem;
}
.zeke-modal .modal-header {
    padding: 1rem 1.25rem;
}
.zeke-modal .modal-footer {
    padding: 0.85rem 1.25rem;
    gap: 0.5rem;
}
.modal.fade .modal-dialog {
    transition: transform 0.28s cubic-bezier(0.34, 1.15, 0.64, 1), opacity 0.2s;
}

/* --- Form controls: hover state sutil antes do focus --- */
.form-control:hover:not(:focus):not([readonly]):not(:disabled),
.form-select:hover:not(:focus):not(:disabled) {
    border-color: rgba(240, 171, 0, 0.55);
}

/* --- Dark mode: placeholders legíveis --- */
[data-bs-theme="dark"] .form-control::placeholder,
[data-bs-theme="dark"] .form-select::placeholder {
    color: rgba(232, 230, 227, 0.5);
    opacity: 1;
}

/* --- Invalid feedback: animação sutil de entrada --- */
.invalid-feedback.d-block,
.is-invalid ~ .invalid-feedback {
    animation: zeke-field-error-in 0.2s cubic-bezier(0.34, 1.35, 0.64, 1);
}
@keyframes zeke-field-error-in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- Alert: entrada suave --- */
.alert {
    animation: zeke-alert-in 0.28s cubic-bezier(0.34, 1.2, 0.64, 1);
}
@keyframes zeke-alert-in {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- Readonly: gradient sutil em vez de só cor chapada --- */
[data-bs-theme="light"] .form-control[readonly]:not(.flatpickr-input):not(.readonly-visual-normal),
[data-bs-theme="light"] .form-control:disabled {
    background-image: linear-gradient(135deg,
        rgba(240, 171, 0, 0.035) 0%,
        rgba(240, 171, 0, 0.08) 100%);
}
[data-bs-theme="dark"] .form-control[readonly]:not(.flatpickr-input):not(.readonly-visual-normal),
[data-bs-theme="dark"] .form-control:disabled {
    background-image: linear-gradient(135deg,
        rgba(240, 171, 0, 0.04) 0%,
        rgba(240, 171, 0, 0.09) 100%);
}

/* --- Nav tabs: transição suave de borda --- */
.nav-tabs .nav-link {
    transition: color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                border-color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                background-color 0.2s ease;
}

/* --- Confirm dialog: animação de saída --- */
.zeke-confirm-overlay.is-leaving {
    animation: zeke-confirm-fade-out 0.18s ease forwards;
}
.zeke-confirm-overlay.is-leaving .zeke-confirm-dialog {
    animation: zeke-confirm-scale-out 0.18s ease forwards;
}
@keyframes zeke-confirm-fade-out {
    from { opacity: 1; }
    to   { opacity: 0; }
}
@keyframes zeke-confirm-scale-out {
    from { opacity: 1; transform: scale(1) translateY(0); }
    to   { opacity: 0; transform: scale(0.96) translateY(-4px); }
}

/* --- Breadcrumb: separador mais elegante --- */
.breadcrumb-item + .breadcrumb-item::before {
    content: "\203A";
    font-weight: 400;
    color: rgba(0, 0, 0, 0.35);
}
[data-bs-theme="dark"] .breadcrumb-item + .breadcrumb-item::before {
    color: rgba(255, 255, 255, 0.4);
}

/* --- Content header: tipografia --- */
.content-header h1 {
    letter-spacing: -0.2px;
    font-weight: 600;
}

/* --- Pagination: pills arredondadas e transições --- */
.page-link {
    transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.page-item:not(.active) .page-link:hover {
    background-color: rgba(240, 171, 0, 0.1);
    color: var(--zeke-gold-dark);
}

/* --- Dropdown: sombra e entrada suave --- */
.dropdown-menu.show {
    box-shadow: var(--zeke-shadow-md);
    animation: zeke-dropdown-in 0.16s cubic-bezier(0.34, 1.2, 0.64, 1);
}
@keyframes zeke-dropdown-in {
    from { opacity: 0; transform: translateY(-4px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
.dropdown-item {
    transition: background-color 0.12s ease, color 0.12s ease;
}

/* ===== MOBILE (<992px) ===== */
@media (max-width: 991.98px) {
    /* Touch targets: mínimo 44px em botões de ação */
    .btn {
        min-height: 42px;
    }
    .btn-sm {
        min-height: 34px;
    }

    /* Ações de linha sempre visíveis no mobile (sem hover) */
    .table tbody tr .row-actions,
    .table tbody tr td .btn-group-row-actions {
        opacity: 1;
    }

    /* Modal full-height mobile mais confortável */
    .modal-dialog:not(.modal-dialog-centered):not(.modal-fullscreen) {
        margin: 0.5rem;
    }
    .zeke-modal .modal-content {
        border-radius: 0.5rem;
    }

    /* Tabelas: permitir wrap de texto em colunas grandes */
    .table td {
        padding-top: 0.7rem;
        padding-bottom: 0.7rem;
    }

    /* Sidebar offcanvas: sombra ao abrir */
    .app-sidebar.offcanvas-start.show {
        box-shadow: var(--zeke-shadow-lg);
    }

    /* Form labels: um pouco mais de respiro */
    .form-label {
        margin-bottom: 0.4rem;
    }
}

/* ===== DESKTOP (>=1200px) ===== */
@media (min-width: 1200px) {
    /* Hover richer no desktop */
    .table-hover tbody tr:hover {
        background-color: var(--bs-table-hover-bg, rgba(240, 171, 0, 0.06));
    }

    /* Sidebar com pequeno respiro horizontal */
    .app-sidebar .nav-link {
        padding-right: 0.75rem;
    }
}

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* =====================================================================
 * POLISH PASS 2 — empty states, loading, toast, entrada de views
 * ===================================================================== */

/* --- Empty state (ZGrid e qualquer listagem) --- */
.zeke-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    padding: 2.5rem 1rem;
    text-align: center;
    animation: zeke-empty-in 0.35s cubic-bezier(0.34, 1.2, 0.64, 1);
}
.zeke-empty-state-icon {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle at 30% 30%,
        rgba(240, 171, 0, 0.18) 0%,
        rgba(240, 171, 0, 0.05) 70%);
    color: var(--zeke-gold-dark);
    font-size: 1.8rem;
    box-shadow: inset 0 0 0 1px rgba(240, 171, 0, 0.25);
}
[data-bs-theme="dark"] .zeke-empty-state-icon {
    color: var(--zeke-gold);
    background: radial-gradient(circle at 30% 30%,
        rgba(240, 171, 0, 0.22) 0%,
        rgba(240, 171, 0, 0.05) 70%);
    box-shadow: inset 0 0 0 1px rgba(240, 171, 0, 0.35);
}
.zeke-empty-state-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--bs-body-color);
    letter-spacing: -0.1px;
}
.zeke-empty-state-subtitle {
    font-size: 0.875rem;
    color: rgba(45, 41, 38, 0.65);
    max-width: 320px;
}
[data-bs-theme="dark"] .zeke-empty-state-subtitle {
    color: rgba(232, 230, 227, 0.55);
}
.zeke-empty-state-actions {
    margin-top: 0.5rem;
}
@keyframes zeke-empty-in {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- ZGrid loading overlay --- */
.zeke-zgrid {
    position: relative;
}
.zeke-zgrid-loading {
    position: absolute;
    inset: 0;
    display: none;
    align-items: flex-start;
    justify-content: center;
    z-index: 5;
    pointer-events: none;
    backdrop-filter: blur(1.5px);
    -webkit-backdrop-filter: blur(1.5px);
    background: rgba(255, 255, 255, 0.55);
}
.zeke-zgrid-loading.is-active {
    display: flex;
    animation: zeke-fade-in 0.18s ease;
}
[data-bs-theme="dark"] .zeke-zgrid-loading {
    background: rgba(26, 24, 22, 0.55);
}
.zeke-zgrid-loading-inner {
    margin-top: 4.5rem;
    padding: 0.85rem 1rem;
    background: var(--bs-body-bg);
    border-radius: 0.6rem;
    box-shadow: var(--zeke-shadow-md);
    border: 1px solid var(--bs-border-color);
    display: flex;
    align-items: center;
    gap: 0.6rem;
    animation: zeke-slide-down 0.22s cubic-bezier(0.34, 1.2, 0.64, 1);
}
@keyframes zeke-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes zeke-slide-down {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- Input group com ícone de busca: visual unificado (1 controle) --- */
.input-group > .input-group-text {
    transition: border-color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
                background-color 0.2s ease;
}
[data-bs-theme="light"] .input-group > .input-group-text {
    background-color: #fff !important;
    border-color: var(--bs-border-color) !important;
    color: rgba(45, 41, 38, 0.55);
}
[data-bs-theme="dark"] .input-group > .input-group-text {
    background-color: var(--zeke-input-bg) !important;
    border-color: var(--zeke-input-border) !important;
    color: rgba(232, 230, 227, 0.55);
}
.input-group > .input-group-text:not(:last-child) {
    border-right: 0 !important;
    margin-right: -1px;
    position: relative;
    z-index: 1;
}
.input-group > .input-group-text + .form-control {
    border-left: 0 !important;
    padding-left: 0.25rem;
}
/* Hover: borda dourada sutil em ambos (ícone + input) juntos */
.input-group:hover:not(:focus-within) > .input-group-text,
.input-group:hover:not(:focus-within) > .form-control:not([readonly]):not(:disabled) {
    border-color: rgba(240, 171, 0, 0.55) !important;
}
.input-group:hover:not(:focus-within) > .input-group-text {
    color: rgba(240, 171, 0, 0.85);
}

/* No focus: ring só no wrapper, borda gold em todas as partes, input nativo perde seu ring */
.input-group:focus-within > .input-group-text,
.input-group:focus-within > .form-control {
    border-color: var(--zeke-gold) !important;
}
.input-group:focus-within > .input-group-text {
    color: var(--zeke-gold);
}
.input-group:focus-within > .form-control:focus {
    box-shadow: none !important;
}
.input-group:focus-within {
    border-radius: 0.375rem;
    box-shadow: 0 0 0 3px rgba(240, 171, 0, 0.22);
}

/* --- Content: entrada suave quando a view carrega --- */
.app-main > .content,
.app-main > section.content {
    animation: zeke-page-in 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes zeke-page-in {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- Breadcrumb / content header: cor gold sutil --- */
.breadcrumb-item.active {
    color: var(--zeke-gold-dark);
    font-weight: 500;
}
[data-bs-theme="dark"] .breadcrumb-item.active {
    color: var(--zeke-gold-light);
}

/* --- Toast polish (flash messages) --- */
.toast,
.toast-container .toast {
    border: none;
    box-shadow: var(--zeke-shadow-lg);
    border-radius: 0.6rem;
    overflow: hidden;
    animation: zeke-toast-in 0.32s cubic-bezier(0.34, 1.25, 0.64, 1);
}
.toast .toast-header {
    border-bottom: 1px solid var(--zeke-divider);
    padding: 0.55rem 0.85rem;
}
.toast .toast-body {
    padding: 0.85rem;
    font-size: 0.9rem;
}
.toast.text-bg-success { border-left: 4px solid #198754; }
.toast.text-bg-danger  { border-left: 4px solid #dc3545; }
.toast.text-bg-warning { border-left: 4px solid #ffc107; }
.toast.text-bg-info    { border-left: 4px solid #0dcaf0; }
.toast.text-bg-primary { border-left: 4px solid var(--zeke-gold); }
@keyframes zeke-toast-in {
    from { opacity: 0; transform: translateX(24px) scale(0.96); }
    to   { opacity: 1; transform: translateX(0) scale(1); }
}

/* --- Spinner: dourado por padrão quando dentro do loading --- */
.zeke-zgrid-loading-inner .spinner-border.text-primary {
    color: var(--zeke-gold) !important;
    width: 1.25rem;
    height: 1.25rem;
    border-width: 0.18em;
}

/* --- Skeleton shimmer (use em placeholders futuros) --- */
.zeke-skeleton {
    background: linear-gradient(90deg,
        rgba(0, 0, 0, 0.04) 0%,
        rgba(240, 171, 0, 0.10) 50%,
        rgba(0, 0, 0, 0.04) 100%);
    background-size: 200% 100%;
    border-radius: 0.35rem;
    animation: zeke-shimmer 1.4s ease-in-out infinite;
    min-height: 1rem;
}
[data-bs-theme="dark"] .zeke-skeleton {
    background: linear-gradient(90deg,
        rgba(255, 255, 255, 0.04) 0%,
        rgba(240, 171, 0, 0.12) 50%,
        rgba(255, 255, 255, 0.04) 100%);
    background-size: 200% 100%;
}
@keyframes zeke-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* --- ZGrid toolbar (search + filters): espaçamento refinado --- */
.zeke-zgrid .card-body > .d-flex.align-items-center.gap-2.p-3,
.zeke-zgrid > .d-flex.align-items-center.gap-2.p-3 {
    padding-bottom: 0.5rem !important;
}

/* --- Empty-row padrão: remove hover (não é clicável) --- */
.zeke-empty-row,
.zeke-empty-row:hover {
    background-color: transparent !important;
    box-shadow: none !important;
    cursor: default !important;
}

/* --- Card-header: tipografia e peso --- */
.card-header {
    font-weight: 600;
    letter-spacing: 0.1px;
    background-color: transparent;
    border-bottom: 1px solid var(--zeke-divider);
}
.card-header h3,
.card-header .card-title,
.card-header h5 {
    margin-bottom: 0;
    font-size: 1rem;
    letter-spacing: -0.1px;
}

/* --- Form-card / crud-form: respiro e entrada --- */
.crud-section-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}
.crud-section-title h5 {
    margin-bottom: 0;
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.1px;
}

/* --- Mural empty state já tinha estilo próprio, só garantir fallback --- */
.mural-empty {
    animation: zeke-empty-in 0.35s cubic-bezier(0.34, 1.2, 0.64, 1);
}

/* --- Pagination: border-radius total nas bordas --- */
.pagination .page-item:first-child .page-link { border-top-left-radius: 0.375rem; border-bottom-left-radius: 0.375rem; }
.pagination .page-item:last-child .page-link  { border-top-right-radius: 0.375rem; border-bottom-right-radius: 0.375rem; }

/* =====================================================================
 * POLISH PASS 3 — cards (form/detail/actions), toast custom, alertas
 * ===================================================================== */

/* --- form-card: footer sticky opcional no mobile + botão primary maior --- */
.zeke-form-footer {
    background-color: transparent;
    border-top: 1px solid var(--zeke-divider);
    padding: 0.85rem 1rem;
}
.zeke-form-footer .btn-primary {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    font-weight: 600;
}
.zeke-form-footer .btn + .btn {
    margin-left: 0;
}

/* --- form-card: alerta de erros consolidado --- */
.zeke-form-errors {
    border: none;
    border-left: 4px solid #dc3545;
    background-color: rgba(220, 53, 69, 0.08);
    color: inherit;
    border-radius: 0.4rem;
    padding: 0.85rem 1rem;
    margin-bottom: 1rem;
    box-shadow: 0 1px 2px rgba(220, 53, 69, 0.08);
}
.zeke-form-errors > i {
    color: #dc3545;
    font-size: 1.15rem;
}
.zeke-form-errors strong {
    color: #a72232;
    font-weight: 600;
    letter-spacing: 0.1px;
}
[data-bs-theme="dark"] .zeke-form-errors {
    background-color: rgba(220, 53, 69, 0.12);
}
[data-bs-theme="dark"] .zeke-form-errors strong {
    color: #f3a5ad;
}

/* --- detail-card: tipografia das linhas, entrada suave --- */
.card > .card-body > .table.table-striped {
    margin-bottom: 0;
}
.card > .card-body > .table.table-striped tr {
    transition: background-color 0.15s ease;
}
.card > .card-body > .table.table-striped tr td:first-child {
    font-weight: 600;
    color: var(--bs-body-color);
    width: 35%;
    max-width: 260px;
    letter-spacing: 0.1px;
}
.card > .card-body > .table.table-striped tr td {
    padding: 0.7rem 1rem;
    border-color: var(--zeke-divider) !important;
    vertical-align: top;
}
[data-bs-theme="light"] .card > .card-body > .table.table-striped {
    --bs-table-striped-bg: rgba(240, 171, 0, 0.035);
}
[data-bs-theme="dark"] .card > .card-body > .table.table-striped {
    --bs-table-striped-bg: rgba(240, 171, 0, 0.06);
}
@media (max-width: 575.98px) {
    .card > .card-body > .table.table-striped tr {
        display: flex;
        flex-direction: column;
        border-bottom: 1px solid var(--zeke-divider);
    }
    .card > .card-body > .table.table-striped tr td:first-child {
        width: 100%;
        max-width: none;
        padding-bottom: 0.15rem;
        font-size: 0.78rem;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        color: rgba(45, 41, 38, 0.6);
        border-bottom: 0;
    }
    [data-bs-theme="dark"] .card > .card-body > .table.table-striped tr td:first-child {
        color: rgba(232, 230, 227, 0.55);
    }
    .card > .card-body > .table.table-striped tr td:last-child {
        padding-top: 0;
        border-top: 0;
    }
}

/* --- actions-bar: sticky no fundo do mobile, shadow elevada --- */
.zeke-actions-bar {
    border-top: 3px solid var(--zeke-gold);
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    box-shadow: var(--zeke-shadow-sm) !important;
}
.zeke-actions-bar .card-body {
    padding: 0.85rem 1rem;
}
@media (max-width: 767.98px) {
    .zeke-actions-bar {
        position: sticky;
        bottom: 0;
        z-index: 10;
        background-color: var(--bs-body-bg);
        backdrop-filter: blur(4px);
        box-shadow: 0 -6px 16px rgba(0, 0, 0, 0.08) !important;
    }
}

/* --- Zeke Toast custom: sombra, animação refinada, responsivo --- */
.zeke-toast {
    box-shadow: var(--zeke-shadow-lg) !important;
    border-radius: 0.6rem !important;
    border-left-width: 4px !important;
    animation: zeke-toast-pop 0.42s cubic-bezier(0.34, 1.3, 0.64, 1) !important;
}
@keyframes zeke-toast-pop {
    0%   { opacity: 0; transform: translateX(40px) scale(0.92); }
    60%  { opacity: 1; transform: translateX(-4px) scale(1.01); }
    100% { opacity: 1; transform: translateX(0) scale(1); }
}
.zeke-toast-header {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    padding: 0.7rem 0.85rem !important;
    font-size: 0.92rem !important;
    letter-spacing: 0.1px;
}
[data-bs-theme="dark"] .zeke-toast-header {
    border-bottom-color: rgba(255, 255, 255, 0.08);
}
.zeke-toast-header > i:first-child {
    font-size: 1.05rem;
}
.zeke-toast-body {
    padding: 0.65rem 0.85rem 0.85rem !important;
    line-height: 1.5;
}
.zeke-toast-close {
    transition: opacity 0.15s ease, transform 0.15s ease;
    border-radius: 0.25rem;
}
.zeke-toast-close:hover {
    opacity: 1;
    transform: scale(1.15);
}
.zeke-toast-progress-bar {
    background: linear-gradient(90deg, var(--zeke-gold), var(--zeke-gold-dark)) !important;
}
/* Ícone de cada tipo com cor mais saturada */
.zeke-toast-success > .zeke-toast-header > i:first-child { color: #198754; }
.zeke-toast-danger  > .zeke-toast-header > i:first-child { color: #dc3545; }
.zeke-toast-warning > .zeke-toast-header > i:first-child { color: #b5851b; }
.zeke-toast-info    > .zeke-toast-header > i:first-child { color: #0a6585; }
[data-bs-theme="dark"] .zeke-toast-success > .zeke-toast-header > i:first-child { color: #6fd199; }
[data-bs-theme="dark"] .zeke-toast-danger  > .zeke-toast-header > i:first-child { color: #f2939d; }
[data-bs-theme="dark"] .zeke-toast-warning > .zeke-toast-header > i:first-child { color: #f2cf7a; }
[data-bs-theme="dark"] .zeke-toast-info    > .zeke-toast-header > i:first-child { color: #7cc4dc; }

@media (max-width: 575.98px) {
    .zeke-toast {
        top: 0.75rem !important;
        right: 0.75rem !important;
        left: 0.75rem !important;
        min-width: 0 !important;
        max-width: none !important;
    }
}

/* --- Card hover: só para cards não-footer (evita elevar form-card inteiro) --- */
.card {
    transition: box-shadow 0.22s cubic-bezier(0.4, 0, 0.2, 1),
                border-color 0.22s ease;
}

/* --- Crud section title: linha divisória gold sutil embaixo --- */
.crud-section-title {
    padding-bottom: 0.45rem;
    border-bottom: 1px dashed rgba(240, 171, 0, 0.35);
    margin-bottom: 1rem;
}

/* --- Labels com required: asterisco dourado em vez de vermelho puro --- */
.form-label .text-danger {
    color: var(--zeke-gold-dark) !important;
    font-weight: 700;
}
[data-bs-theme="dark"] .form-label .text-danger {
    color: var(--zeke-gold) !important;
}

/* --- Checkbox/radio: cor primária dourada + anel sutil --- */
.form-check-input:checked {
    background-color: var(--zeke-gold);
    border-color: var(--zeke-gold-dark);
}
.form-check-input:focus {
    border-color: var(--zeke-gold);
    box-shadow: 0 0 0 3px rgba(240, 171, 0, 0.22);
}
.form-check-input {
    transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

/* --- Btn-close em modais: hover dourado --- */
.btn-close {
    transition: opacity 0.15s ease, transform 0.15s ease;
}
.btn-close:hover {
    transform: scale(1.1);
}

/* =====================================================================
 * POLISH PASS 4 — modais AJAX (loading, saving, stacked, responsivo)
 * ===================================================================== */

/* --- Entrada/saída refinadas do modal --- */
.modal.fade .modal-dialog {
    transform: translateY(-20px) scale(0.97);
    opacity: 0;
    transition: transform 0.32s cubic-bezier(0.34, 1.2, 0.64, 1),
                opacity 0.24s ease;
}
.modal.fade.show .modal-dialog {
    transform: translateY(0) scale(1);
    opacity: 1;
}

/* --- Modal body loading (conteúdo via AJAX) --- */
.zeke-modal-body-loading,
.modal-body.is-loading {
    position: relative;
    min-height: 140px;
}
.zeke-modal-body-loading::before,
.modal-body.is-loading::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--bs-body-bg);
    opacity: 0.7;
    z-index: 1;
    border-radius: inherit;
}
.zeke-modal-body-loading::after,
.modal-body.is-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 2.5rem;
    height: 2.5rem;
    margin: -1.25rem 0 0 -1.25rem;
    border: 3px solid rgba(240, 171, 0, 0.25);
    border-top-color: var(--zeke-gold);
    border-radius: 50%;
    animation: zeke-spin 0.8s linear infinite;
    z-index: 2;
}
@keyframes zeke-spin {
    to { transform: rotate(360deg); }
}

/* --- Modal submitting (overlay inteiro durante save AJAX) --- */
.modal.is-submitting .modal-content {
    pointer-events: none;
}
.modal.is-submitting .modal-content::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: rgba(255, 255, 255, 0.55);
    backdrop-filter: blur(1.5px);
    -webkit-backdrop-filter: blur(1.5px);
    z-index: 10;
    animation: zeke-fade-in 0.12s ease;
}
[data-bs-theme="dark"] .modal.is-submitting .modal-content::after {
    background: rgba(26, 24, 22, 0.6);
}
.modal.is-submitting .modal-footer::before {
    content: '';
    position: absolute;
    width: 1.5rem;
    height: 1.5rem;
    right: 1rem;
    top: 50%;
    margin-top: -0.75rem;
    border: 2.5px solid rgba(240, 171, 0, 0.25);
    border-top-color: var(--zeke-gold);
    border-radius: 50%;
    animation: zeke-spin 0.8s linear infinite;
    z-index: 11;
}
.modal.is-submitting .modal-footer {
    position: relative;
}

/* --- Stacked modals: z-index crescente + backdrops escurecendo mais --- */
.modal.show + .modal.show {
    z-index: 1065;
}
.modal-backdrop.show + .modal-backdrop.show {
    z-index: 1060;
    opacity: 0.7;
}

/* --- Modal em telas pequenas: full-height confortável --- */
@media (max-width: 575.98px) {
    .modal-dialog:not(.modal-dialog-centered):not(.modal-fullscreen):not(.modal-sm) {
        margin: 0;
        min-height: 100vh;
        display: flex;
        align-items: flex-end;
    }
    .modal-dialog:not(.modal-dialog-centered):not(.modal-fullscreen):not(.modal-sm) .modal-content {
        border-radius: 1rem 1rem 0 0;
        width: 100%;
    }
    /* Entrada slide-up em mobile (bottom sheet style) */
    .modal.fade .modal-dialog:not(.modal-dialog-centered):not(.modal-fullscreen):not(.modal-sm) {
        transform: translateY(100%);
    }
    .modal.fade.show .modal-dialog:not(.modal-dialog-centered):not(.modal-fullscreen):not(.modal-sm) {
        transform: translateY(0);
    }
}

/* --- Modal close button: espaçamento e ring de foco --- */
.modal-header .btn-close {
    margin-left: auto;
    opacity: 0.65;
}
.modal-header .btn-close:focus-visible {
    outline: none;
    box-shadow: var(--zeke-ring);
}

/* --- Modal body com scroll: gradiente sutil indicando mais conteúdo --- */
.modal-body {
    scroll-behavior: smooth;
}
.modal-dialog-scrollable .modal-body {
    background:
        linear-gradient(var(--bs-body-bg) 30%, rgba(255, 255, 255, 0)),
        linear-gradient(rgba(255, 255, 255, 0), var(--bs-body-bg) 70%) 0 100%,
        radial-gradient(farthest-side at 50% 0, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0)),
        radial-gradient(farthest-side at 50% 100%, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0)) 0 100%;
    background-repeat: no-repeat;
    background-color: var(--bs-body-bg);
    background-size: 100% 32px, 100% 32px, 100% 12px, 100% 12px;
    background-attachment: local, local, scroll, scroll;
}
[data-bs-theme="dark"] .modal-dialog-scrollable .modal-body {
    background:
        linear-gradient(#211F1D 30%, rgba(33, 31, 29, 0)),
        linear-gradient(rgba(33, 31, 29, 0), #211F1D 70%) 0 100%,
        radial-gradient(farthest-side at 50% 0, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0)),
        radial-gradient(farthest-side at 50% 100%, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0)) 0 100%;
    background-color: #211F1D;
    background-repeat: no-repeat;
    background-size: 100% 32px, 100% 32px, 100% 12px, 100% 12px;
    background-attachment: local, local, scroll, scroll;
}

/* --- Helpers programáticos: .zeke-modal-skeleton para placeholder AJAX --- */
.zeke-modal-skeleton {
    display: grid;
    gap: 0.7rem;
    padding: 0.5rem 0;
}
.zeke-modal-skeleton > div {
    height: 0.9rem;
    border-radius: 0.35rem;
}
.zeke-modal-skeleton > div:nth-child(1) { width: 40%; }
.zeke-modal-skeleton > div:nth-child(2) { width: 85%; }
.zeke-modal-skeleton > div:nth-child(3) { width: 70%; }
.zeke-modal-skeleton > div:nth-child(4) { width: 90%; }
.zeke-modal-skeleton > div:nth-child(5) { width: 55%; }
.zeke-modal-skeleton > div {
    background: linear-gradient(90deg,
        rgba(0, 0, 0, 0.04) 0%,
        rgba(240, 171, 0, 0.12) 50%,
        rgba(0, 0, 0, 0.04) 100%);
    background-size: 200% 100%;
    animation: zeke-shimmer 1.4s ease-in-out infinite;
}
[data-bs-theme="dark"] .zeke-modal-skeleton > div {
    background: linear-gradient(90deg,
        rgba(255, 255, 255, 0.05) 0%,
        rgba(240, 171, 0, 0.14) 50%,
        rgba(255, 255, 255, 0.05) 100%);
    background-size: 200% 100%;
}

/* =====================================================================
 * POLISH PASS 5 — flatpickr, input-group completo, badges, scrollbars
 * ===================================================================== */

/* ------------------------------------------------------------------
 * SCROLLBARS — light mode (dark já existe)
 * ------------------------------------------------------------------ */
[data-bs-theme="light"] ::-webkit-scrollbar,
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}
[data-bs-theme="light"] ::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.02);
}
[data-bs-theme="light"] ::-webkit-scrollbar-thumb {
    background: rgba(45, 41, 38, 0.18);
    border-radius: 6px;
    border: 2px solid transparent;
    background-clip: padding-box;
    transition: background-color 0.2s ease;
}
[data-bs-theme="light"] ::-webkit-scrollbar-thumb:hover {
    background: var(--zeke-gold-dark);
    background-clip: padding-box;
    border: 2px solid transparent;
}
[data-bs-theme="light"] ::-webkit-scrollbar-corner {
    background: transparent;
}
/* Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: rgba(45, 41, 38, 0.25) transparent;
}
[data-bs-theme="dark"] * {
    scrollbar-color: #3A3633 #1A1816;
}

/* ------------------------------------------------------------------
 * INPUT-GROUP — polish completo (tamanhos, validação, addons, clear)
 * ------------------------------------------------------------------ */

/* input-group-sm/lg: border-radius coerente */
.input-group-sm > .input-group-text,
.input-group-sm > .form-control,
.input-group-sm > .form-select {
    border-radius: 0.3rem;
}
.input-group-lg > .input-group-text,
.input-group-lg > .form-control,
.input-group-lg > .form-select {
    border-radius: 0.5rem;
}

/* Addon à direita (sufixo): remover borda esquerda dele também */
.input-group > .form-control + .input-group-text,
.input-group > .form-select + .input-group-text {
    border-left: 0 !important;
    margin-left: -1px;
    position: relative;
    z-index: 1;
}

/* Botão dentro do input-group: alinha com input, remove ring duplicado */
.input-group > .btn {
    z-index: 2;
    transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.input-group:focus-within > .btn-outline-secondary {
    border-color: var(--zeke-gold) !important;
}

/* Validação: o ícone bootstrap de feedback dentro de input-group */
.input-group.has-validation {
    flex-wrap: nowrap;
}
.input-group > .form-control.is-invalid,
.input-group > .form-select.is-invalid {
    z-index: 3;
}
.input-group > .form-control.is-valid ~ .input-group-text,
.input-group > .form-control.is-invalid ~ .input-group-text {
    border-color: inherit !important;
}
/* Invalid state: borda vermelha se propaga ao addon */
.input-group:has(.is-invalid) > .input-group-text {
    border-color: #dc3545 !important;
    color: #dc3545;
}
.input-group:has(.is-valid) > .input-group-text {
    border-color: #198754 !important;
    color: #198754;
}

/* Focus ring vermelho quando inválido */
.form-control.is-invalid:focus,
.form-select.is-invalid:focus {
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.22) !important;
}
.input-group:focus-within:has(.is-invalid) {
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.22);
}

/* Clear button (×) dentro de input-group */
.input-group > .btn-clear,
.input-group > button[type="button"].btn-outline-secondary[title*="limpar" i],
.input-group > button[type="button"].btn-outline-secondary[title*="clear" i] {
    border-left: 0 !important;
    color: rgba(45, 41, 38, 0.45);
}
.input-group > .btn-clear:hover {
    color: #dc3545;
    background-color: rgba(220, 53, 69, 0.08);
}

/* ------------------------------------------------------------------
 * FLATPICKR — light mode (dark já tinha) + polish geral
 * ------------------------------------------------------------------ */

.flatpickr-calendar {
    border-radius: 0.6rem !important;
    box-shadow: var(--zeke-shadow-lg) !important;
    border: 1px solid var(--bs-border-color) !important;
    overflow: hidden;
    animation: zeke-fp-in 0.22s cubic-bezier(0.34, 1.2, 0.64, 1);
    font-family: 'Rubik', sans-serif !important;
}
@keyframes zeke-fp-in {
    from { opacity: 0; transform: translateY(-4px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Seta do calendário apontando pro input */
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowBottom:before {
    border-bottom-color: var(--zeke-gold);
    border-top-color: var(--zeke-gold);
}

/* Header (meses) */
[data-bs-theme="light"] .flatpickr-calendar .flatpickr-months,
[data-bs-theme="light"] .flatpickr-calendar .flatpickr-month {
    background: linear-gradient(135deg, rgba(240, 171, 0, 0.08), rgba(240, 171, 0, 0.02));
    color: #2D2926;
    border-top-left-radius: 0.6rem;
    border-top-right-radius: 0.6rem;
}
.flatpickr-calendar .flatpickr-current-month {
    font-weight: 600;
    padding-top: 6px;
}
.flatpickr-calendar .flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-calendar .flatpickr-current-month input.cur-year {
    font-weight: 600;
}

/* Setas prev/next */
.flatpickr-calendar .flatpickr-prev-month,
.flatpickr-calendar .flatpickr-next-month {
    transition: background-color 0.15s ease, fill 0.15s ease;
    border-radius: 0.35rem;
    padding: 6px !important;
    margin: 2px;
}
.flatpickr-calendar .flatpickr-prev-month:hover,
.flatpickr-calendar .flatpickr-next-month:hover {
    background-color: rgba(240, 171, 0, 0.15);
    fill: var(--zeke-gold-dark) !important;
}
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-prev-month:hover,
[data-bs-theme="dark"] .flatpickr-calendar .flatpickr-next-month:hover {
    background-color: rgba(240, 171, 0, 0.2);
}

/* Dias */
.flatpickr-calendar .flatpickr-day {
    border-radius: 0.35rem;
    transition: background-color 0.15s ease, color 0.15s ease, transform 0.1s ease;
    font-weight: 500;
    border: none;
    max-width: 38px;
    height: 36px;
    line-height: 36px;
}
.flatpickr-calendar .flatpickr-day:hover:not(.selected):not(.flatpickr-disabled) {
    background: rgba(240, 171, 0, 0.14);
    color: var(--zeke-gold-dark);
    transform: scale(1.05);
}
.flatpickr-calendar .flatpickr-day.today:not(.selected) {
    border: 1px solid var(--zeke-gold) !important;
    color: var(--zeke-gold-dark);
    font-weight: 700;
}
.flatpickr-calendar .flatpickr-day.selected,
.flatpickr-calendar .flatpickr-day.startRange,
.flatpickr-calendar .flatpickr-day.endRange {
    background: var(--zeke-gold) !important;
    border-color: var(--zeke-gold) !important;
    color: #2D2926 !important;
    font-weight: 600;
    box-shadow: 0 2px 6px rgba(240, 171, 0, 0.35);
}
.flatpickr-calendar .flatpickr-day.inRange {
    background: rgba(240, 171, 0, 0.18) !important;
    color: var(--zeke-gold-dark) !important;
    border-color: transparent !important;
    box-shadow: none;
}
.flatpickr-calendar .flatpickr-day.flatpickr-disabled {
    opacity: 0.3;
}

/* Time picker */
.flatpickr-time input,
.flatpickr-time .flatpickr-am-pm {
    transition: background-color 0.15s ease;
    font-weight: 500;
}
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover {
    background: rgba(240, 171, 0, 0.1) !important;
}

/* Weekdays header */
[data-bs-theme="light"] .flatpickr-calendar .flatpickr-weekdays,
[data-bs-theme="light"] .flatpickr-calendar span.flatpickr-weekday {
    background: transparent;
    color: rgba(45, 41, 38, 0.55);
    font-weight: 600;
    font-size: 0.75rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

/* ------------------------------------------------------------------
 * BADGES — padronização + variantes soft + micro-interação
 * ------------------------------------------------------------------ */

/* Base: padding/radius/peso consistente em todas as badges */
.badge {
    --bs-badge-padding-x: 0.55rem;
    --bs-badge-padding-y: 0.35em;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.25px;
    border-radius: 0.375rem;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    line-height: 1.2;
    transition: background-color 0.15s ease, color 0.15s ease;
}
.badge > i {
    font-size: 0.85em;
    opacity: 0.9;
}

/* Pill variant */
.badge.rounded-pill {
    border-radius: 999px;
    padding-left: 0.7rem;
    padding-right: 0.7rem;
}

/* Soft variants (fundo translúcido + texto forte) — padrão world-class */
.badge-soft-primary   { background-color: rgba(240, 171, 0, 0.15); color: var(--zeke-gold-dark); }
.badge-soft-success   { background-color: rgba(25, 135, 84, 0.14); color: #146c43; }
.badge-soft-danger    { background-color: rgba(220, 53, 69, 0.14); color: #b02a37; }
.badge-soft-warning   { background-color: rgba(255, 193, 7, 0.2);  color: #997404; }
.badge-soft-info      { background-color: rgba(13, 202, 240, 0.15); color: #087990; }
.badge-soft-secondary { background-color: rgba(108, 117, 125, 0.15); color: #495057; }
[data-bs-theme="dark"] .badge-soft-primary   { background-color: rgba(240, 171, 0, 0.18); color: var(--zeke-gold-light); }
[data-bs-theme="dark"] .badge-soft-success   { background-color: rgba(25, 135, 84, 0.22); color: #75c09a; }
[data-bs-theme="dark"] .badge-soft-danger    { background-color: rgba(220, 53, 69, 0.2);  color: #f3a5ad; }
[data-bs-theme="dark"] .badge-soft-warning   { background-color: rgba(255, 193, 7, 0.2);  color: #f2cf7a; }
[data-bs-theme="dark"] .badge-soft-info      { background-color: rgba(13, 202, 240, 0.2); color: #7cc4dc; }
[data-bs-theme="dark"] .badge-soft-secondary { background-color: rgba(108, 117, 125, 0.25); color: #adb5bd; }

/* Dot variant (com bolinha antes) — status online/offline/etc */
.badge-dot::before {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
    margin-right: 0.1rem;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.2);
}
.badge-dot.pulsing::before {
    animation: zeke-badge-pulse 1.6s ease-in-out infinite;
}
@keyframes zeke-badge-pulse {
    0%, 100% { box-shadow: 0 0 0 0 currentColor; opacity: 1; }
    50%      { box-shadow: 0 0 0 5px rgba(0, 0, 0, 0); opacity: 0.8; }
}

/* Badges existentes ganham tratamento soft por padrão */
.badge-pendente { background: rgba(255, 193, 7, 0.2) !important; color: #997404 !important; }
.badge-lancado  { background: rgba(25, 135, 84, 0.14) !important; color: #146c43 !important; }
[data-bs-theme="dark"] .badge-pendente { background: rgba(255, 193, 7, 0.2) !important; color: #f2cf7a !important; }
[data-bs-theme="dark"] .badge-lancado  { background: rgba(25, 135, 84, 0.22) !important; color: #75c09a !important; }

/* Badges clicáveis: hover sutil */
a.badge,
button.badge {
    cursor: pointer;
    text-decoration: none;
}
a.badge:hover,
button.badge:hover {
    filter: brightness(1.05);
    transform: translateY(-1px);
}

/* =============================================
   BANNER PLANO GRATUITO (Funcionalidade Indisponível)
   ============================================= */
.info-planos {
    background: #fff3cd;
    border-left: 4px solid #ffc107;
    padding: 15px 20px;
    border-radius: 8px;
    margin-bottom: 25px;
}
.info-planos-title {
    font-weight: 600;
    color: #856404;
    margin: 0 0 8px 0;
    font-size: 1.15rem;
}
.info-planos-content {
    color: #856404;
    margin: 0 0 15px 0;
    padding: 0;
    font-size: 1rem;
    line-height: 1.6;
}
.info-planos .btn {
    margin-top: 10px;
}
[data-bs-theme="dark"] .info-planos {
    background: #3a2f12;
    border-left-color: #c9a227;
}
[data-bs-theme="dark"] .info-planos-title,
[data-bs-theme="dark"] .info-planos-content {
    color: #ffe9a0;
}

/* ── Pessoa Photo Badge (birthday/wedding) ── */
.ppb-wrapper {
    position: relative;
    display: inline-block;
}
.ppb-list {
    border-radius: 50%;
}
.ppb-list .ppb-photo {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
}
.ppb-list.ppb-birthday {
    background: linear-gradient(135deg, #e74c3c, #f39c12, #e91e63, #9b59b6);
    padding: 2px;
}
.ppb-list.ppb-wedding {
    background: linear-gradient(135deg, #f0c27f, #e8a23a, #d4a843, #c79832);
    padding: 2px;
}
.ppb-form {
    display: inline-block;
}
.ppb-form.ppb-birthday .ppb-photo-form img {
    border: 3px solid transparent;
    background-image: linear-gradient(var(--bs-body-bg), var(--bs-body-bg)), linear-gradient(135deg, #e74c3c, #f39c12, #e91e63, #9b59b6);
    background-origin: border-box;
    background-clip: padding-box, border-box;
    box-shadow: 0 0 12px rgba(231, 76, 60, 0.4);
}
.ppb-form.ppb-wedding .ppb-photo-form img {
    border: 3px solid transparent;
    background-image: linear-gradient(var(--bs-body-bg), var(--bs-body-bg)), linear-gradient(135deg, #f0c27f, #e8a23a, #d4a843, #c79832);
    background-origin: border-box;
    background-clip: padding-box, border-box;
    box-shadow: 0 0 12px rgba(212, 168, 67, 0.4);
}
.ppb-badge {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    line-height: 1;
    border: 2px solid var(--bs-body-bg);
    z-index: 2;
}
.ppb-badge-form {
    width: 24px;
    height: 24px;
    font-size: 13px;
    bottom: 0;
    right: 0;
}
.ppb-badge-birthday {
    background: #e74c3c;
}
.ppb-badge-wedding {
    background: #d4a843;
}
.ppb-label-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 4px;
}
.ppb-arrow {
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
}
.ppb-arrow-birthday {
    border-bottom: 6px solid #e74c3c;
}
.ppb-arrow-wedding {
    border-bottom: 6px solid #d4a843;
}
.ppb-label {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}
.ppb-label-birthday {
    background: linear-gradient(135deg, #e74c3c, #e91e63);
    color: #fff;
}
.ppb-label-wedding {
    background: linear-gradient(135deg, #d4a843, #e8a23a);
    color: #fff;
}
[data-bs-theme="dark"] .ppb-form.ppb-birthday .ppb-photo-form img {
    box-shadow: 0 0 16px rgba(231, 76, 60, 0.5);
}
[data-bs-theme="dark"] .ppb-form.ppb-wedding .ppb-photo-form img {
    box-shadow: 0 0 16px rgba(212, 168, 67, 0.5);
}


/* ===== SVG Icons (sidebar) ===== */
.zeke-icon.nav-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
}
.zeke-icon svg {
    width: 1.2rem;
    height: 1.2rem;
    fill: currentColor;
}

/* ===== ZGrid: bloco de áreas/funções do participante (paridade apps) ===== */
.zgrid-funcoes-bloco {
    margin-top: 6px;
    padding: 8px;
    border-radius: 8px;
    background: #F0F0F0; /* iOS SurfaceSecondary light */
}
[data-bs-theme="dark"] .zgrid-funcoes-bloco {
    background: #2A2520; /* iOS SurfaceSecondary dark */
}
.zgrid-funcoes-header {
    font-size: 10px;
    font-weight: 700;
    color: var(--bs-secondary-color);
}
.zgrid-funcoes-vazio {
    font-size: 12px;
    color: var(--bs-secondary-color);
}
.zgrid-funcoes-area {
    font-size: 11px;
    font-weight: 700;
    margin-top: 2px;
    color: var(--bs-secondary-color);
}
.zgrid-funcoes-nomes {
    font-size: 12px;
    color: var(--zeke-gold-dark);
}
[data-bs-theme="dark"] .zgrid-funcoes-nomes {
    color: var(--zeke-gold);
}

/* Em linhas zebradas (table-striped) o fundo do bloco alterna para a cor base da
   tabela — senão ele se confunde com o fundo listrado da própria linha. */
.table-striped > tbody > tr:nth-of-type(odd) .zgrid-funcoes-bloco {
    background: var(--bs-body-bg);
}

/* ===== Participantes do grupo: modo expandido (full width, cards em grade) ===== */
.participantes-expanded table thead {
    display: none;
}
.participantes-expanded table tbody {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    padding: 12px;
}
@media (max-width: 1399px) {
    .participantes-expanded table tbody { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1099px) {
    .participantes-expanded table tbody { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
    .participantes-expanded table tbody { grid-template-columns: 1fr; }
}
.participantes-expanded table tbody tr {
    border: 1px solid var(--bs-border-color) !important;
    border-radius: 10px;
    padding: 10px;
    background: var(--bs-body-bg) !important;
}
/* No card o fundo é sempre o base — bloco de funções volta à cor cheia em todas as linhas */
.participantes-expanded .zgrid-funcoes-bloco,
.participantes-expanded .table-striped > tbody > tr:nth-of-type(odd) .zgrid-funcoes-bloco {
    background: #F0F0F0;
}
[data-bs-theme="dark"] .participantes-expanded .zgrid-funcoes-bloco,
[data-bs-theme="dark"] .participantes-expanded .table-striped > tbody > tr:nth-of-type(odd) .zgrid-funcoes-bloco {
    background: #2A2520;
}

/* Altura mínima = bloco com 1 área + 1 função (header 10px + área 11px + função 12px,
   line-height 1.5, padding 8+8) — blocos "Nenhuma função atribuída" alinham com os demais. */
.zgrid-funcoes-bloco {
    min-height: 66px;
}

/* Centraliza o "Nenhuma função atribuída" no espaço restante do bloco (min-height). */
.zgrid-funcoes-bloco {
    display: flex;
    flex-direction: column;
}
.zgrid-funcoes-vazio {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
}

/* ===== Participantes do grupo: layout da célula (ambos os modos) =====
   td da pessoa vira display:contents → linha do nome, botão de ação e bloco de
   funções são itens flex da própria tr: o bloco quebra pra baixo em largura total
   e o botão centraliza verticalmente só com a faixa foto/nome/cargo. */
#participantes-col table tbody tr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding: 8px 12px;
    border-bottom: 1px solid var(--bs-border-color);
}
#participantes-col table tbody tr > td {
    display: block;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important; /* zebra sai dos td e vai pra tr (abaixo) */
    padding: 0;
}
#participantes-col table tbody tr > td:first-child {
    display: contents;
}
#participantes-col table tbody tr > td:first-child > .d-flex {
    flex: 1 1 0;
    order: 1;
    min-width: 0;
}
#participantes-col table tbody tr > td:last-child {
    order: 2;
    margin-left: 8px;
}
#participantes-col table tbody tr > td:first-child > .zgrid-funcoes-bloco {
    flex: 0 0 100%;
    order: 3;
}
#participantes-col .table-striped > tbody > tr:nth-of-type(odd) {
    background-color: var(--bs-tertiary-bg);
}
/* No modo card a zebra não se aplica (fundo base em todas) */
.participantes-expanded.participantes-expanded .table-striped > tbody > tr:nth-of-type(odd) {
    background-color: var(--bs-body-bg);
}

/* O botão de ação agora é inline na célula — esconde o th "Ações" órfão do cabeçalho. */
#participantes-col table thead th:last-child {
    display: none;
}

/* ===== ZSelect ===== */
.zs-root { position: relative; }
/* min-height = altura padrão do .form-control (1.5em + .75rem + 2px de borda),
   pra alinhar com os outros campos quando o conteúdo é de 1 linha; cresce se precisar */
.zs-field { display: flex; align-items: center; gap: 6px; min-height: calc(1.5em + .75rem + 2px); padding: 2px 6px;
    background: var(--bs-body-bg); border: 1px solid var(--bs-border-color); border-radius: 8px; cursor: text; }
[data-bs-theme="dark"] .zs-field { background: var(--zeke-input-bg); border-color: var(--zeke-input-border); }
.zs-root:not(.zs-disabled) .zs-field:hover:not(:focus-within):not(.zs-open) { border-color: rgba(240, 171, 0, 0.55); }
.zs-root .zs-field:focus-within,
.zs-root .zs-field.zs-open,
/* fallback sem JS: dropdown visível (x-show já inicializado e sem display:none) */
.zs-root:has(> .zs-dropdown:not([x-cloak]):not([style*="display: none"])) .zs-field { border-color: var(--zeke-gold); box-shadow: 0 0 0 3px rgba(240, 171, 0, 0.22),
    0 1px 2px rgba(0, 0, 0, 0.04); }
/* Dark: igual ao input com foco — borda mantém a cor base, só o glow aparece */
[data-bs-theme="dark"] .zs-root .zs-field:focus-within,
[data-bs-theme="dark"] .zs-root .zs-field.zs-open,
[data-bs-theme="dark"] .zs-root:has(> .zs-dropdown:not([x-cloak]):not([style*="display: none"])) .zs-field { border-color: var(--zeke-input-border); }
.zs-field.is-invalid { border-color: var(--bs-danger); }
.zs-field-content { flex: 1; display: flex; flex-wrap: wrap; gap: 4px; align-items: center; padding-left: 4px; }
.zs-placeholder { color: var(--bs-secondary-color); }
.zs-chip { display: inline-flex; align-items: center; gap: 6px; padding: 2px 8px 2px 10px; font-size: 13px;
    background: var(--bs-tertiary-bg); border: 1px solid var(--bs-border-color); border-radius: 16px; }
.zs-chip-rich { padding-left: 3px; }
.zs-chip-x { border: 0; background: none; color: var(--bs-secondary-color); font-weight: 600; padding: 0 2px; line-height: 1; }
.zs-clear { border: 0; background: none; color: var(--bs-secondary-color); font-weight: 600; padding: 0 6px; }
/* align-self: stretch — o botão acompanha a altura do campo em vez de impô-la
   (padding vertical aqui somava 42px e desalinhava com os .form-control de 38px) */
.zs-expand { border: 0; border-left: 1px solid var(--bs-border-color); background: none; color: var(--bs-body-color);
    padding: 0 8px 0 10px; align-self: stretch; }
/* Estados travados: esconde limpar (×) e busca avançada (⛶) nos três jeitos
   usados hoje — fieldset disabled (recibos, plano gratuito), prop disabled
   (.zs-disabled) e wrappers readonly por JS (.zs-readonly). */
fieldset:disabled .zs-clear, fieldset:disabled .zs-chip-x, fieldset:disabled .zs-expand,
.zs-disabled .zs-clear, .zs-disabled .zs-chip-x, .zs-disabled .zs-expand,
.zs-readonly .zs-clear, .zs-readonly .zs-chip-x, .zs-readonly .zs-expand { display: none; }
.zs-disabled .zs-field { cursor: default; background: var(--bs-secondary-bg); opacity: .8; }
.zs-readonly .zs-field { cursor: default; }
.zs-avatar { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; flex: none; }
/* Single: nome longo quebra dentro do próprio span, ao lado do avatar (que fica
   centralizado verticalmente), em vez de o span inteiro pular pra linha de baixo */
.zs-field-content > .zs-avatar + span { flex: 1 1 0; min-width: 0; }
.zs-field-content > .zs-avatar { margin-right: 4px; }
.zs-avatar-sm { width: 20px; height: 20px; }
.zs-avatar-initials { display: inline-flex; align-items: center; justify-content: center;
    background: #5b76a8; color: #fff; font-size: 10px; font-weight: 600; }
.zs-dropdown { position: absolute; top: 100%; left: 0; right: 0; z-index: 1050; margin-top: 6px;
    background: var(--bs-body-bg); border: 1px solid var(--bs-border-color); border-radius: 8px;
    box-shadow: 0 6px 18px rgba(0,0,0,.10); overflow: hidden; }
.zs-search { display: flex; align-items: center; gap: 8px; padding: 9px 12px;
    background: var(--bs-tertiary-bg); border-bottom: 1px solid var(--bs-border-color); color: var(--bs-secondary-color); }
.zs-search input { border: 0; background: transparent; outline: none; flex: 1; min-width: 0; width: 100%; color: var(--bs-body-color); }
.zs-results { max-height: 260px; overflow-y: auto; }
.zs-loading { opacity: .5; }
.zs-item { display: flex; align-items: center; gap: 10px; padding: 8px 12px; cursor: pointer;
    border-bottom: 1px solid var(--bs-border-color-translucent); }
.zs-item:last-child { border-bottom: 0; }
.zs-item:hover { background: var(--bs-tertiary-bg); }
.zs-item-selected { background: rgba(13,110,253,.08); }
.zs-item-text { line-height: 1.25; }
.zs-sublabel { color: var(--bs-secondary-color); font-size: 12px; }
/* Variante rica sem avatar (ex.: conta contábil): número menor/discreto em cima, nome em destaque embaixo */
.zs-item-text.zs-no-avatar { font-size: 11px; color: var(--bs-secondary-color); }
.zs-field:has(.zs-no-avatar) { padding-top: 0; padding-bottom: 0; }
.zs-item-text.zs-no-avatar .zs-sublabel { font-size: 1rem; color: var(--bs-body-color); }
.zs-check { width: 16px; height: 16px; border: 1.5px solid var(--bs-secondary-color); border-radius: 4px; flex: none; position: relative; }
.zs-check-on { background: #0d6efd; border-color: #0d6efd; }
.zs-check-on::after { content: "✓"; color: #fff; font-size: 11px; position: absolute; top: -2px; left: 2px; }
.zs-empty { padding: 14px 12px; color: var(--bs-secondary-color); text-align: center; }
.zs-footer { display: flex; justify-content: space-between; align-items: center; padding: 7px 12px;
    font-size: 12px; color: var(--bs-secondary-color); background: var(--bs-tertiary-bg);
    border-top: 1px solid var(--bs-border-color); }
.zs-modal-list .zs-item { border: 1px solid var(--bs-border-color-translucent); border-radius: 6px; margin-bottom: 4px; }
.zs-filter-overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.5); z-index: 1065; }
.zs-filter-dialog { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 1070;
    width: 90%; max-width: 500px; }
.zs-filter-dialog .modal-content { background: var(--bs-body-bg); }
.zs-filter-dialog .modal-body { max-height: 65vh; overflow-y: auto; }
.zs-skeleton { background: linear-gradient(90deg, var(--bs-tertiary-bg) 25%, var(--bs-body-bg) 50%, var(--bs-tertiary-bg) 75%); background-size: 200% 100%; animation: zs-shimmer 1.2s infinite; }
[data-bs-theme="dark"] .zs-dropdown { box-shadow: 0 6px 18px rgba(0,0,0,.45); }
[data-bs-theme="dark"] .zs-item-selected { background: rgba(13,110,253,.18); }
@keyframes zs-shimmer { to { background-position: -200% 0; } }
[x-cloak] { display: none !important; }
