/* ============================================================
   ADWITIYA SPA THEME
   Muted Rose / Mauve Palette
   ============================================================ */

/* ── 1. CSS Custom Properties ─────────────────────────────── */
:root {
    /* Primary palette */
    --spa-primary: #9B6B7D;
    --spa-primary-hover: #85596B;
    --spa-primary-light: #F5EEF0;
    --spa-primary-rgb: 155, 107, 125;
    /* Accent / secondary */
    --spa-accent: #B8A9AE;
    --spa-accent-light: #EDE8EA;
    /* Text */
    --spa-text-dark: #2D2D2D;
    --spa-text-muted: #7A7A7A;
    --spa-text-light: #A0A0A0;
    /* Surfaces */
    --spa-bg: #FAFAFA;
    --spa-surface: #FFFFFF;
    --spa-border: #E8E0E3;
    /* Font */
    --spa-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    /* Save Button*/
    --spa-btn-save: #28A745;
    --spa-btn-save-hover: #218838;
    --spa-btn-cancel: #6C757D;
    --spa-btn-cancel-hover: #5A6268;
    /* Radius */
    --spa-radius: 6px;
    --spa-radius: 6px;
    --spa-radius-lg: 10px;
}


/* ── 2. Global Shadow Removal ─────────────────────────────── */
*,
*::before,
*::after {
    box-shadow: none !important;
    text-shadow: none !important;
}


/* ── 3. Typography ───────────────── */

/* Force Inter on EVERY element globally */
html,
body,
input,
button,
select,
textarea,
table,
th,
td,
.btn,
.form-control,
.form-select,
.modal,
.modal-content,
.modal-header,
.modal-body,
.modal-footer,
.card,
.card-body,
.card-header,
.nav-link,
.menu-link,
.dropdown-item,
.page-link,
.accordion-button,
.accordion-body,
.navbar,
.pagination,
label,
small,
span,
p,
h1,
h2,
h3,
h4,
h5,
h6,
.swal2-popup,
.toast {
    font-family: var(--spa-font) !important;
}

body {
    font-size: 0.875rem;
    line-height: 1.55;
    color: var(--spa-text-dark);
    background-color: var(--spa-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Heading hierarchy */
h1 {
    font-size: 1.75rem;
    font-weight: 600;
    line-height: 1.3;
    color: var(--spa-text-dark);
    margin-bottom: 0.5em;
}

h2 {
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.3;
    color: var(--spa-text-dark);
    margin-bottom: 0.5em;
}

h3 {
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--spa-text-dark);
    margin-bottom: 0.4em;
}

h4 {
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--spa-text-dark);
    margin-bottom: 0.4em;
}

h5 {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.4;
    color: var(--spa-text-dark);
    margin-bottom: 0.3em;
}

h6 {
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.4;
    color: var(--spa-text-dark);
    margin-bottom: 0.3em;
}

p,
small,
span,
label {
    line-height: 1.55;
}

a {
    color: var(--spa-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

    a:hover {
        color: var(--spa-primary-hover);
    }


/* ── 4. Buttons ───────────────────────────────────────────── */

/* Primary */
.btn-primary {
    background-color: var(--spa-primary) !important;
    border-color: var(--spa-primary) !important;
    color: #fff !important;
    padding: 8px 20px;
    border-radius: var(--spa-radius) !important;
    font-weight: 500;
    font-size: 0.875rem;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

    .btn-primary:hover,
    .btn-primary:focus {
        background-color: var(--spa-primary) !important;
        border-color: var(--spa-primary) !important;
        color: #fff !important;
    }

/*Add button*/

.btn-primary {
    background-color: var(--spa-primary) !important;
    border-color: var(--spa-primary) !important;
    color: #fff !important;
    padding: 8px 20px;
    border-radius: var(--spa-radius) !important;
    font-weight: 500;
    font-size: 0.875rem;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

    .btn-primary:hover,
    .btn-primary:focus {
        background-color: var(--spa-primary-hover) !important;
        border-color: var(--spa-primary-hover) !important;
        color: #fff !important;
    }

/*Save button*/

.save-btn {
    background-color: var(--spa-btn-save) !important;
    border-color: var(--spa-btn-save) !important;
    color: #fff !important;
    padding: 8px 20px;
    border-radius: var(--spa-radius) !important;
    font-weight: 500;
    font-size: 0.875rem;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

    .save-btn:hover,
    .save-btn:focus {
        background-color: var(--spa-btn-save-hover) !important;
        border-color: var(--spa-btn-save-hover) !important;
        color: #fff !important;
    }

/* Secondary (used as main CTA in several places) */
.btn-secondary {
    background-color: var(--spa-btn-cancel) !important;
    border-color: var(--spa-btn-cancel) !important;
    color: #fff !important;
    padding: 8px 20px;
    border-radius: var(--spa-radius) !important;
    font-weight: 500;
    font-size: 0.875rem;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

    .btn-secondary:hover,
    .btn-secondary:focus {
        background-color: var(--spa-btn-cancel-hover) !important;
        border-color: var(--spa-btn-cancel-hover) !important;
        color: #fff !important;
    }

/* Outline secondary */
.btn-outline-secondary {
    border-color: var(--spa-border) !important;
    color: var(--spa-text-dark) !important;
    border-radius: var(--spa-radius) !important;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

    .btn-outline-secondary:hover,
    .btn-outline-secondary:focus {
        background-color: var(--spa-primary-light) !important;
        border-color: var(--spa-primary) !important;
        color: var(--spa-primary) !important;
    }

/* Label secondary */
.btn-label-secondary {
    background-color: var(--spa-accent-light) !important;
    color: var(--spa-text-dark) !important;
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius) !important;
    padding: 8px 20px;
    font-weight: 500;
    font-size: 0.875rem;
    transition: background-color 0.2s ease;
}

    .btn-label-secondary:hover {
        background-color: var(--spa-border) !important;
    }

/* Danger (delete) */
.btn-danger {
    background-color: #C65D5D !important;
    border-color: #C65D5D !important;
    color: #fff !important;
    border-radius: var(--spa-radius) !important;
    padding: 8px 20px;
    font-weight: 500;
    font-size: 0.875rem;
    transition: background-color 0.2s ease;
}

    .btn-danger:hover {
        background-color: #A94A4A !important;
        border-color: #A94A4A !important;
    }

/* Submit & Cancel (legacy class names used in some views) */
.btn-submit {
    background-color: var(--spa-primary) !important;
    border-color: var(--spa-primary) !important;
    color: #fff !important;
    padding: 8px 20px;
    border-radius: var(--spa-radius) !important;
    font-weight: 500;
    transition: background-color 0.2s ease;
}

    .btn-submit:hover {
        background-color: var(--spa-primary-hover) !important;
        border-color: var(--spa-primary-hover) !important;
    }

.btn-cancel {
    background-color: var(--spa-accent-light) !important;
    color: var(--spa-text-dark) !important;
    border: 1px solid var(--spa-border) !important;
    padding: 8px 20px;
    border-radius: var(--spa-radius) !important;
    font-weight: 500;
    transition: background-color 0.2s ease;
}

    .btn-cancel:hover {
        background-color: var(--spa-border) !important;
    }

/* Added button (Role page) */
.btn-added {
    background-color: var(--spa-primary) !important;
    border-color: var(--spa-primary) !important;
    color: #fff !important;
    padding: 8px 20px;
    border-radius: var(--spa-radius) !important;
    font-weight: 500;
    font-size: 0.875rem;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: background-color 0.2s ease;
}

    .btn-added:hover {
        background-color: var(--spa-primary-hover) !important;
        border-color: var(--spa-primary-hover) !important;
    }

/* Close button */
.btn-close {
    width: 32px;
    height: 32px;
    padding: 0 !important;
    border-radius: var(--spa-radius) !important;
    background-color: rgba(224, 85, 85, 0.75) !important;
    background-image: none !important;
    border: 1px solid rgba(224, 85, 85, 0.4) !important;
    opacity: 1 !important;
    transition: all 0.2s ease;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative;
    font-size: 0;
    color: #ffffff !important;
    filter: none !important;
}

    .btn-close::before {
        content: '\00d7' !important;
        font-size: 1.25rem !important;
        font-weight: 600;
        line-height: 1;
        color: #ffffff !important;
        background-color: transparent !important;
        mask-image: none !important;
        -webkit-mask-image: none !important;
    }

    .btn-close:hover {
        opacity: 1 !important;
        background-color: rgba(204, 60, 60, 0.9) !important;
        border-color: rgba(204, 60, 60, 0.6) !important;
    }

        .btn-close:hover::before {
            color: #ffffff !important;
        }

/* Modal-specific overrides (beat core.css specificity) */
.modal .btn-close {
    background-color: rgba(224, 85, 85, 0.75) !important;
    background-image: none !important;
    filter: none !important;
    opacity: 1 !important;
    color: #ffffff !important;
}

    .modal .btn-close::before {
        content: '\00d7' !important;
        font-size: 1.25rem !important;
        font-weight: 600;
        line-height: 1;
        color: #ffffff !important;
        background-color: transparent !important;
        mask-image: none !important;
        -webkit-mask-image: none !important;
        block-size: auto !important;
        inline-size: auto !important;
    }

    .modal .btn-close:hover,
    .modal .btn-close:focus,
    .modal .btn-close:active {
        background-color: rgba(204, 60, 60, 0.9) !important;
        border-color: rgba(204, 60, 60, 0.6) !important;
        opacity: 1 !important;
    }

        .modal .btn-close:hover::before,
        .modal .btn-close:focus::before,
        .modal .btn-close:active::before {
            color: #ffffff !important;
        }

/* Override for white variant (toast etc) */
.btn-close-white {
    border-color: rgba(255, 255, 255, 0.3) !important;
}

    .btn-close-white::before {
        color: #fff;
    }

    .btn-close-white:hover {
        background-color: rgba(255, 255, 255, 0.15) !important;
        border-color: rgba(255, 255, 255, 0.5) !important;
    }

/* All buttons — consistent icon+text alignment */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: var(--spa-radius) !important;
    transition: all 0.2s ease;
    white-space: nowrap;
}

    /* Focus states — flat, no glow */
    .btn:focus,
    .btn:active:focus,
    .btn-link.nav-link:focus {
        outline: 2px solid var(--spa-primary-light) !important;
        outline-offset: 2px;
    }


/* ── 5. Forms & Inputs ────────────────────────────────────── */
.form-control,
.form-select {
    height: 38px;
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius) !important;
    font-size: 0.875rem;
    color: var(--spa-text-dark);
    background-color: var(--spa-surface);
    padding: 6px 12px;
    transition: border-color 0.2s ease;
}

    .form-control:focus,
    .form-select:focus {
        border-color: var(--spa-primary) !important;
        outline: none !important;
    }

    .form-control:disabled,
    .form-select:disabled {
        background-color: #F7F5F6 !important;
        cursor: not-allowed;
        opacity: 0.7;
    }

textarea.form-control {
    height: auto;
    min-height: 80px;
}

.form-label,
label {
    width: 100%;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--spa-text-dark);
    margin-bottom: 4px;
}

.form-check-input:focus {
    border-color: var(--spa-primary) !important;
    outline: none !important;
}

.form-check-input:checked {
    background-color: var(--spa-primary) !important;
    border-color: var(--spa-primary) !important;
}

/* Input blocks spacing — content-driven, not rigid */
.input-blocks {
    margin-bottom: 12px;
}

/* ── 5b. Search Bar — Controlled Width ────────────────────── */
.search-input {
    width: 100%;
    max-width: 320px;
    min-width: 180px;
}

    .search-input .form-control,
    .userSearchTextBox {
        width: 100%;
        max-width: 320px;
        min-width: 180px;
        height: 38px;
    }

/* Standalone search bars in permission page etc */
input[type="search"].form-control {
    max-width: 400px;
}

/* Ensure search aligns with adjacent buttons */
.d-flex .search-input,
.d-flex.justify-content-between .search-input {
    flex: 0 1 320px;
}

/* Input group */
.input-group .form-control {
    border-right: 0 !important;
}

.input-group .btn {
    border-left: 0 !important;
    border-color: var(--spa-border) !important;
    height: 38px;
}

    .input-group .btn:hover {
        background-color: var(--spa-primary-light) !important;
    }


/* ── 6. Tables ────────────────────────────────────────────── */

/* Table wrapper — adds rounded border around the table */
.table-responsive {
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    overflow: auto;
}

.table {
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
    min-width: 100%;
    font-size: 0.82rem;
    margin-bottom: 0;
}

    .table > thead > tr > th {
        position: sticky;
        top: 0;
        z-index: 3;
        background: #f8fafc !important;
        border-bottom: 2px solid #e2e8f0 !important;
        border-top: none !important;
        border-left: none !important;
        border-right: none !important;
        padding: 10px 12px !important;
        font-weight: 600;
        color: #475569 !important;
        font-size: 0.76rem;
        text-transform: uppercase;
        letter-spacing: 0.3px;
        white-space: nowrap;
    }

    .table > tbody > tr > td {
        padding: 9px 12px !important;
        border-bottom: 1px solid #f1f5f9 !important;
        border-top: none !important;
        border-left: none !important;
        border-right: none !important;
        vertical-align: middle;
        color: #1e293b;
        white-space: nowrap;
        font-size: 0.82rem;
        background: #fff;
        transition: background-color 0.15s ease;
    }

    .table > tbody > tr:hover > td {
        background-color: #f0f9ff !important;
    }

/* Sticky header */
.sticky-header,
.sticky-header-row {
    position: sticky;
    top: 0;
    z-index: 3;
    background: #f8fafc !important;
    color: #475569 !important;
}

/* Table header override for dark bg themes */
table thead tr {
    background: #f8fafc !important;
    color: #475569 !important;
}

/* Fixed column backgrounds */
.fixed-col,
td.fixed-col,
.fixed-col-left,
td.fixed-col-left {
    background-color: #fff !important;
}

/* Header fixed-col & bg-white should match header bg, not body bg */
.table > thead > tr > th.fixed-col,
.table > thead > tr > th.bg-white,
thead th.fixed-col,
thead th.bg-white {
    background: #f8fafc !important;
}

.table > tbody > tr:hover td.fixed-col,
.table > tbody > tr:hover td.fixed-col-left {
    background-color: #f0f9ff !important;
}

/* Action icons */
.edit-delete-action {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

    .edit-delete-action a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border-radius: var(--spa-radius);
        /*    transition: background-color 0.2s ease;*/
    }

/*.edit-delete-action a:hover {
    background-color: var(--spa-primary-light);
}*/

/* Cursor utility */
.ctmCursor {
    cursor: pointer;
}

/* Employee name/code display in table cells */
.employee-name {
    font-weight: 600;
    color: #1e293b;
    font-size: 0.82rem;
}

.employee-code {
    font-size: 0.7rem;
    color: #94a3b8;
    margin-top: 1px;
}


/* ── 7. Pagination ────────────────────────────────────────── */
.pagination {
    gap: 4px;
    align-items: center;
}

.page-item .page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    min-width: 36px;
    height: 36px;
    padding: 4px 10px;
    border: 1px solid var(--spa-border);
    border-radius: var(--spa-radius) !important;
    color: var(--spa-text-dark);
    font-size: 0.8125rem;
    transition: all 0.2s ease;
    white-space: nowrap;
    line-height: 1;
}

    .page-item .page-link:hover {
        background-color: var(--spa-primary-light);
        border-color: var(--spa-primary);
        color: var(--spa-primary);
    }

    /* Pagination icon sizing */
    .page-item .page-link i {
        font-size: 0.75rem;
        line-height: 1;
        vertical-align: middle;
    }

.page-item.active .page-link {
    background-color: var(--spa-primary) !important;
    border-color: var(--spa-primary) !important;
    color: #fff !important;
}

.page-item.disabled .page-link {
    opacity: 0.5;
    cursor: not-allowed;
    background-color: var(--spa-surface);
}

/* Small pagination variant */
.pagination-sm .page-item .page-link {
    min-width: 30px;
    height: 30px;
    padding: 2px 8px;
    font-size: 0.75rem;
}

/* Page-size dropdown — prevent icon overlap */
.form-select-sm,
select.form-select.form-select-sm {
    height: 32px !important;
    min-height: 32px;
    padding: 4px 30px 4px 10px !important;
    font-size: 0.8125rem !important;
    background-position: right 8px center !important;
    background-size: 14px 10px !important;
    line-height: 1.4;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}


/* ── 8. Modals — Content-Adaptive Design ──────────────────── */

/* Let modals size naturally with content */
.modal-dialog {
    max-width: fit-content;
    min-width: 380px;
    width: auto;
    margin: 1.75rem auto;
}

    /* But respect Bootstrap size classes when explicitly set */
    .modal-dialog.modal-sm {
        max-width: 380px;
        width: 380px;
    }

    .modal-dialog.modal-md {
        max-width: 560px;
        width: auto;
        min-width: 420px;
    }

    .modal-dialog.modal-lg {
        max-width: 720px;
        width: auto;
        min-width: 560px;
    }

    .modal-dialog.modal-xl {
        max-width: 900px;
        width: auto;
        min-width: 720px;
    }

/* Content never exceeds viewport */
.modal-content {
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius-lg) !important;
    /*    overflow: hidden;*/
    max-width: 90vw;
}

/* Header */
.modal-header {
    padding: 14px 20px !important;
    border-bottom: 1px solid var(--spa-border) !important;
    background-color: var(--spa-surface);
}

    .modal-header .modal-title,
    .modal-header h5 {
        font-size: 1rem;
        font-weight: 600;
        color: var(--spa-text-dark);
    }

/* Body — adaptive padding based on content */
.modal-body {
    padding: 20px 24px !important;
    background-color: var(--spa-surface);
}

    /* Modal form field spacing */
    .modal-body .mb-3 {
        margin-bottom: 14px !important;
    }

    .modal-body .col-md-4,
    .modal-body .col-md-6,
    .modal-body .col-md-12 {
        padding-left: 8px;
        padding-right: 8px;
    }

    .modal-body .row {
        /*    margin-left: -8px;
    margin-right: -8px;*/
    }

    .modal-body label {
        display: block;
        margin-bottom: 4px;
        font-size: 0.8125rem;
        font-weight: 500;
    }

/* Footer */
.modal-footer {
    padding: 12px 20px !important;
    border-top: 1px solid var(--spa-border) !important;
    background-color: var(--spa-surface);
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* Button area inside modal body (when no modal-footer) */
.modal-body .text-center {
    padding-top: 8px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* Modal footer alternative (used in some modals) */
.modal-footer-btn {
    padding: 12px 0 0;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* Backdrop */
.modal-backdrop.show {
    opacity: 0.35 !important;
}


/* ── 9. Cards & Panels — Content-Driven Spacing ──────────── */
.card {
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius-lg) !important;
    background-color: var(--spa-surface);
    overflow: hidden;
}

.card-header {
    background-color: var(--spa-surface) !important;
    border-bottom: 1px solid var(--spa-border) !important;
    padding: 14px 20px !important;
}

/* Card body — balanced, not forced rigid */
.card-body {
    padding: 20px !important;
}

.card-title {
    color: var(--spa-text-dark);
    font-weight: 600;
}

.card-subtitle {
    color: var(--spa-text-muted) !important;
}


/* ── 10. Sidebar / Navigation ─────────────────────────────── */
.layout-menu {
    background-color: var(--spa-surface) !important;
    border-right: 1px solid var(--spa-border) !important;
}

.menu-inner-shadow {
    display: none !important;
}

.menu-inner > .menu-item > .menu-link {
    display: flex !important;
    align-items: center !important;
    gap: 8px;
    padding: 10px 16px !important;
    color: var(--spa-text-dark) !important;
    border-radius: var(--spa-radius) !important;
    margin: 0 12px !important;
    transition: background-color 0.2s ease, color 0.2s ease;
    white-space: nowrap;
}

    .menu-inner > .menu-item > .menu-link:hover {
        background-color: var(--spa-primary-light) !important;
        color: var(--spa-primary) !important;
    }

.menu-inner > .menu-item.active > .menu-link {
    background-color: var(--spa-primary) !important;
    color: #fff !important;
}

    /* Active link on hover — keep white styling, don't revert to primary */
    .menu-inner > .menu-item.active > .menu-link:hover {
        background-color: var(--spa-primary-hover) !important;
        color: #fff !important;
    }

    .menu-inner > .menu-item.active > .menu-link i {
        color: #fff !important;
    }

    /* Keep icon white on active hover */
    .menu-inner > .menu-item.active > .menu-link:hover i {
        color: #fff !important;
    }

.menu-inner > .menu-item > .menu-link i {
    color: var(--spa-text-muted);
    transition: color 0.2s ease;
}

.menu-inner > .menu-item > .menu-link:hover i {
    color: var(--spa-primary) !important;
}

/* Submenu */
.menu-sub .menu-item .menu-link {
    display: flex !important;
    align-items: center !important;
    gap: 6px;
    padding: 8px 16px 8px 44px !important;
    color: var(--spa-text-dark) !important;
    font-size: 0.8125rem;
    transition: background-color 0.2s ease, color 0.2s ease;
}

    .menu-sub .menu-item .menu-link:hover {
        background-color: var(--spa-primary-light) !important;
        color: var(--spa-primary) !important;
    }

.menu-sub .menu-item.active .menu-link {
    color: var(--spa-primary) !important;
    font-weight: 600;
    background-color: var(--spa-primary-light) !important;
}

/* Brand */
.app-brand {
    padding: 16px !important;
    border-bottom: 1px solid var(--spa-border);
}


/* ── 11. Navbar / Header ──────────────────────────────────── */

/* Floating navbar — separated from sidebar & edges with rounded borders */
.layout-navbar,
.bg-navbar-theme {
    background-color: var(--spa-surface) !important;
    border: 1px solid var(--spa-border) !important;
    border-bottom: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius-lg) !important;
    margin: 12px 1.5rem 0 1.5rem !important;
    overflow: visible !important;
}

#layout-navbar {
    min-height: 54px;
    padding: 0 !important;
    overflow: visible !important;
}

    #layout-navbar > .container-xxl {
        min-height: 54px;
        padding: 6px 20px !important;
    }

/* Hamburger toggle */
.layout-menu-toggle .nav-link {
    color: var(--spa-text-dark) !important;
    padding: 4px !important;
    border-radius: var(--spa-radius);
    transition: background-color 0.2s ease;
}

    .layout-menu-toggle .nav-link:hover {
        background-color: var(--spa-primary-light) !important;
        color: var(--spa-primary) !important;
    }

/* Navbar right section */
.navbar-nav-right {
    min-height: 42px;
}

/* User profile trigger in header */
.navbar-dropdown.dropdown-user .nav-link {
    padding: 6px 12px !important;
    border-radius: var(--spa-radius);
    transition: background-color 0.2s ease;
}

    .navbar-dropdown.dropdown-user .nav-link:hover {
        background-color: var(--spa-primary-light) !important;
    }

/* Avatar in header */
.navbar-dropdown .avatar,
.avatar {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--spa-primary) !important;
    background-color: var(--spa-primary-light);
    flex-shrink: 0;
}

    .navbar-dropdown .avatar i,
    .avatar i {
        color: var(--spa-primary) !important;
        font-size: 1.25rem;
    }

/* Username and role text */
.navbar-dropdown.dropdown-user h6 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--spa-text-dark);
    margin-bottom: 0;
}

.navbar-dropdown.dropdown-user small {
    font-size: 0.75rem;
    color: var(--spa-text-muted);
}

/* Hide the default Bootstrap dropdown caret */
.navbar-dropdown.dropdown-user .dropdown-toggle::after {
    display: none;
}

/* User dropdown menu */
.navbar-dropdown .dropdown-menu {
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius-lg) !important;
    padding: 6px !important;
    min-width: 180px !important;
    margin-top: 1px !important;
    z-index: 1050 !important;
}

    /* Dropdown items — proper styling */
    .navbar-dropdown .dropdown-menu .dropdown-item {
        border-radius: var(--spa-radius) !important;
        font-size: 0.8125rem;
        font-weight: 500;
        padding: 8px 14px !important;
        color: var(--spa-text-dark);
        transition: background-color 0.2s ease, color 0.2s ease;
    }

        .navbar-dropdown .dropdown-menu .dropdown-item:hover {
            background-color: var(--spa-primary-light) !important;
            color: var(--spa-primary) !important;
        }

        .navbar-dropdown .dropdown-menu .dropdown-item.text-danger {
            color: #C65D5D !important;
        }

            .navbar-dropdown .dropdown-menu .dropdown-item.text-danger:hover {
                background-color: #fdf0f0 !important;
                color: #A94A4A !important;
            }

    .navbar-dropdown .dropdown-menu .dropdown-divider {
        margin: 4px 0;
        border-color: var(--spa-border);
    }



/* ── 12. Accordion (Permissions page) ─────────────────────── */
.accordion-item {
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius) !important;
    margin-bottom: 8px;
    overflow: hidden;
}

.accordion-button {
    font-weight: 500;
    font-size: 0.9375rem;
    color: var(--spa-text-dark) !important;
    background-color: var(--spa-surface) !important;
    padding: 12px 16px;
    transition: background-color 0.2s ease;
}

    .accordion-button:not(.collapsed) {
        background-color: var(--spa-primary-light) !important;
        color: var(--spa-primary) !important;
    }

    .accordion-button::after {
        filter: none;
    }

.accordion-body {
    padding: 16px !important;
    background-color: var(--spa-surface);
}

    /* Permission checkboxes */
    .accordion-body label {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        margin-right: 16px;
        margin-bottom: 8px;
        cursor: pointer;
        font-size: 0.875rem;
    }

    .accordion-body input[type="checkbox"] {
        accent-color: var(--spa-primary);
        width: 16px;
        height: 16px;
        cursor: pointer;
    }


/* ── 13. Dropdowns ────────────────────────────────────────── */
.dropdown-menu {
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius) !important;
    padding: 6px !important;
}

.dropdown-item {
    border-radius: var(--spa-radius) !important;
    padding: 8px 12px !important;
    font-size: 0.875rem;
    color: var(--spa-text-dark);
    transition: background-color 0.15s ease;
}

    .dropdown-item:hover {
        background-color: var(--spa-primary-light) !important;
        color: var(--spa-primary) !important;
    }


/* ── 14. Badges & Labels ──────────────────────────────────── */
.badge.bg-label-primary,
.badge.bg-label-success,
.badge.bg-label-info,
.badge.bg-label-danger,
.badge.bg-label-warning {
    font-weight: 500;
    font-size: 0.75rem;
    border-radius: var(--spa-radius);
}


/* ── 15. Progress Bars ────────────────────────────────────── */
.progress {
    border-radius: 20px;
    background-color: var(--spa-accent-light);
    overflow: hidden;
}

.progress-bar {
    border-radius: 20px;
}


/* ── 16. Scrollbar ────────────────────────────────────────── */

/* Chrome / Edge / Safari */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: var(--spa-accent-light);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb {
    background: var(--spa-accent);
    border-radius: 10px;
    transition: background 0.2s ease;
}

    ::-webkit-scrollbar-thumb:hover {
        background: var(--spa-primary);
    }

/* Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: var(--spa-accent) var(--spa-accent-light);
}


/* ── 17. Loading Overlay ──────────────────────────────────── */
.loading-overlay {
    background: rgba(0, 0, 0, 0.3) !important;
}

.loader {
    background: var(--spa-primary) !important;
}


/* ── 18. Dynamic Content Safety ───────────────────────────── */
.menu-link div,
.menu-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.table td {
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Icon + text in nav links and buttons */
.menu-link,
.page-link,
.nav-link,
.dropdown-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px;
}

    /* Prevent icons from shrinking */
    .menu-link i,
    .btn i,
    .page-link i,
    .nav-link i {
        flex-shrink: 0;
    }


/* ── 19. Page Headers ─────────────────────────────────────── */
.page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spa-space-md);
    margin-bottom: var(--spa-space-lg);
}

.page-title h4 {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 600;
}


/* ── 20. Login Page ───────────────────────────────────────── */
.authentication-wrapper {
    background-color: var(--spa-bg);
}

.authentication-bg {
    background-color: var(--spa-bg) !important;
}

#formAuthentication .form-control {
    height: 42px;
}

#formAuthentication .btn {
    height: 42px;
    font-size: 0.9375rem;
    font-weight: 600;
    justify-content: center;
}


/* ── 21. Toast / Toastr ───────────────────────────────────── */
.toast {
    border-radius: var(--spa-radius-lg) !important;
}


/* ── 22. SweetAlert2 Overrides ────────────────────────────── */
.swal2-popup {
    border-radius: var(--spa-radius-lg) !important;
}

.swal2-confirm {
    background-color: var(--spa-primary) !important;
    border-radius: var(--spa-radius) !important;
}

.swal2-cancel {
    border-radius: var(--spa-radius) !important;
}


/* ── 23. Responsive Adjustments ───────────────────────────── */
@media (max-width: 768px) {

    .search-input,
    .search-input .form-control,
    .userSearchTextBox {
        max-width: 100%;
        width: 100%;
        min-width: unset;
        flex: 1 1 100% !important;
    }

    .page-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .d-flex.justify-content-between.align-items-center.flex-wrap {
        flex-direction: column;
        align-items: flex-start !important;
        gap: 12px;
    }

    .card-body {
        padding: 16px !important;
    }

    .table > thead > tr > th,
    .table > tbody > tr > td {
        padding: 8px 10px !important;
        font-size: 0.8125rem;
    }

    /* Modals go full width on small screens */
    .modal-dialog {
        min-width: unset !important;
        max-width: 95vw !important;
        width: auto !important;
        margin: 0.5rem auto;
    }
}

@media (max-width: 576px) {
    .pagination {
        flex-wrap: wrap;
    }

    .btn {
        font-size: 0.8125rem;
        padding: 6px 14px;
    }
}


/* ── 24. Misc & Utilities ─────────────────────────────────── */

/* Nav pills */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background-color: var(--spa-primary) !important;
    color: #fff !important;
    border-color: var(--spa-primary) !important;
}

/* Divider */
.divider .divider-text {
    color: var(--spa-text-muted);
}

/* Text colors */
.text-body-secondary {
    color: var(--spa-text-muted) !important;
}

/* Border overrides */
.border-top {
    border-color: var(--spa-border) !important;
}

.border-bottom {
    border-color: var(--spa-border) !important;
}

/* Content wrapper */
.content-wrapper {
    background-color: var(--spa-bg);
}

/* Table top (search area above table on some pages) */
.table-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spa-space-md);
    margin-bottom: var(--spa-space-md);
}

.search-set {
    display: flex;
    align-items: center;
    gap: var(--spa-space-sm);
}

/* Mobile menu toggler */
.menu-mobile-toggler {
    border-radius: var(--spa-radius) !important;
}

    .menu-mobile-toggler .text-bg-secondary {
        background-color: var(--spa-primary) !important;
    }


/* ── 25. Attendance Page ─────────────────────────────────── */

/* --- Filter bar card --- */
.card.mb-4 .card-body .d-flex.align-items-center {
    gap: 20px;
}

.card.mb-4 .card-body .col-auto {
    gap: 8px !important;
}

.card.mb-4 .card-body .form-label {
    margin-bottom: 0;
    font-weight: 600;
    font-size: 0.8125rem;
    color: var(--spa-text-dark);
    white-space: nowrap;
    width: auto;
}

/* --- Fix dropdown text/arrow overlap --- */
.form-select {
    padding-right: 36px !important;
    background-position: right 10px center !important;
    /* background-size: 14px 10px !important; */
}

/* --- Page title --- */
.attendance-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--spa-text-dark);
    margin-bottom: 0;
}

.attendance-date,
.attendance-day {
    color: #7A4E5D;
}

.dayOffButton {
    background-color: rgba(155, 107, 125, 0.15) !important;
    color: var(--spa-primary) !important;
    border: 1px solid rgba(155, 107, 125, 0.25) !important;
    border-radius: 50px !important;
    font-family: var(--spa-font);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease;
    height: auto;
}

    .dayOffButton:hover {
        background-color: rgba(155, 107, 125, 0.25) !important;
        border-color: var(--spa-primary) !important;
        color: var(--spa-primary-hover) !important;
    }

/* --- Save Attendance button (dark primary) --- */
input[type="button"][value="Save Attendance"],
.btn-save-attendance {
    background-color: var(--spa-primary);
    color: #fff;
    border: 1px solid var(--spa-primary);
    padding: 8px 24px;
    border-radius: var(--spa-radius);
    font-family: var(--spa-font);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.1s ease;
    letter-spacing: 0.2px;
}

    input[type="button"][value="Save Attendance"]:hover,
    .btn-save-attendance:hover {
        background-color: var(--spa-primary-hover);
        border-color: var(--spa-primary-hover);
    }

/* --- Status radio button spacing --- */
.table td .d-flex.justify-content-between.align-items-center {
    gap: 16px;
}

/* --- Status header labels — rounded pill backgrounds --- */
.table > thead > tr > th .d-flex.justify-content-between.align-items-center {
    gap: 16px;
}

.table > thead > tr > th .d-flex span {
    background-color: rgba(155, 107, 125, 0.15);
    color: var(--spa-primary-hover);
    font-weight: 700;
    font-size: 0.75rem;
    padding: 3px 12px;
    border-radius: 20px;
    letter-spacing: 0.4px;
}

/* --- Status radio buttons --- */
input[type="radio"].cursor-pointer {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border: 2px solid var(--spa-border);
    border-radius: 50%;
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease;
    position: relative;
    vertical-align: middle;
}

    input[type="radio"].cursor-pointer:hover {
        border-color: var(--spa-primary);
    }

    input[type="radio"].cursor-pointer:checked {
        border-color: var(--spa-primary);
        background-color: var(--spa-primary);
    }

        input[type="radio"].cursor-pointer:checked::after {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            width: 6px;
            height: 6px;
            background: #fff;
            border-radius: 50%;
            transform: translate(-50%, -50%);
        }

/* --- Employee name & code in table row --- */
.employee-name {
    font-weight: 600;
    color: var(--spa-text-dark);
    font-size: 0.875rem;
    line-height: 1.3;
}

.employee-code {
    font-size: 0.75rem;
    color: var(--spa-text-muted);
    letter-spacing: 0.2px;
}

/* --- Table time inputs — compact --- */
input[type="time"].form-control {
    width: 100%;
    height: 32px;
    padding: 4px 8px;
    font-size: 0.8125rem;
    font-variant-numeric: tabular-nums;
}

/* --- Empty state row --- */
.table > tbody > tr > td.text-center.text-muted {
    font-size: 0.875rem;
    padding: 16px 16px !important;
    color: var(--spa-text-light);
    letter-spacing: 0.2px;
}

/* ── 26. Summary Cards (Global / Reusable) ───────────────── */
/* Base card — shared across Attendance, Leads, and future modules */

.summary-card {
    background-color: var(--spa-surface);
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    border: 1px solid var(--spa-border) !important;
    border-radius: var(--spa-radius-lg) !important;
    transition: all 0.2s ease;
    min-width: 160px;
}

    .summary-card:hover {
        border-color: rgba(var(--spa-primary-rgb), 0.3) !important;
    }

/* Icon container */
.summary-icon {
    width: 42px;
    height: 42px;
    border-radius: 25%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .summary-icon i {
        font-size: 18px;
    }

/* Count value */
.summary-count {
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1;
    color: var(--spa-text-dark);
}

/* Label text */
.summary-label {
    font-size: 0.75rem;
    color: var(--spa-text-muted);
    letter-spacing: 0.2px;
    margin-top: 2px;
}

/* Summary row wrapper */
.summary-row {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}



/* ── 26a. Attendance Summary Cards (attn-*) ──────────────── */

.summary-card.attn-total .summary-icon {
    background: rgba(13, 110, 253, 0.12);
}

    .summary-card.attn-total .summary-icon i {
        color: #0d6efd;
    }

.summary-card.attn-present .summary-icon {
    background: rgba(25, 135, 84, 0.12);
}

    .summary-card.attn-present .summary-icon i {
        color: #198754;
    }

.summary-card.attn-absent .summary-icon {
    background: rgba(220, 53, 69, 0.12);
}

    .summary-card.attn-absent .summary-icon i {
        color: #dc3545;
    }

.summary-card.attn-dayoff .summary-icon {
    background: rgba(255, 193, 7, 0.12);
}

    .summary-card.attn-dayoff .summary-icon i {
        color: #ffc107;
    }


/* ── 26b. Lead Summary Cards (lead-*) ────────────────────── */

.summary-card.lead-summary {
    flex-direction: row;
    align-items: center;
    gap: 14px;
    padding: 14px 20px;
}

    .summary-card.lead-summary .summary-icon {
        background: rgba(var(--spa-primary-rgb), 0.12);
    }

        .summary-card.lead-summary .summary-icon i {
            color: var(--spa-primary);
        }

.lead-emp-name {
    font-weight: 600;
    font-size: 0.82rem;
    color: #1e293b;
}

.lead-stat {
    font-size: 0.78rem;
    color: #64748b;
}

    .lead-stat strong {
        color: var(--spa-text-dark);
        font-weight: 700;
    }


/* ── 26c. Salary Summary Cards (salary-*) ────────────────── */

.summary-card.salary-summary {
    flex-direction: row;
    align-items: center;
    gap: 14px;
    padding: 14px 20px;
}

.summary-icon-emp {
    background: #ede9fe;
    color: #7c3aed;
}

.summary-icon-incentive {
    background: #dcfce7;
    color: #16a34a;
}

.summary-icon-advance {
    background: #fee2e2;
    color: #dc2626;
}

.summary-icon-net {
    background: #fef3c7;
    color: #d97706;
}


/* ── 26d. Search Filter Button ───────────────────────────── */

.btn-search {
    background-color: rgba(155, 107, 125, 0.15) !important;
    color: var(--spa-primary) !important;
    border: 1px solid rgba(155, 107, 125, 0.25) !important;
    border-radius: 50px !important;
    font-family: var(--spa-font);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease;
    height: auto;
    padding: 6px 16px;
}

    .btn-search:hover {
        background-color: rgba(155, 107, 125, 0.25) !important;
        border-color: var(--spa-primary) !important;
        color: var(--spa-primary-hover) !important;
    }

/* ── 28. Shared Components (emp-info, badges, bars) ──────── */
/* Used by: AttendanceList, Salary, Attendance */

.emp-info {
    display: flex;
    flex-direction: column;
}

    .emp-info .emp-name {
        font-weight: 600;
        color: #1e293b;
        font-size: 0.82rem;
    }

    .emp-info .emp-designation {
        font-size: 0.7rem;
        color: #94a3b8;
        margin-top: 1px;
    }

    .emp-info .emp-sub {
        font-size: 0.7rem;
        color: #94a3b8;
        margin-top: 1px;
    }

.att-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 26px;
    height: 22px;
    border-radius: 5px;
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0 5px;
}

.att-P {
    background: #dcfce7;
    color: #16a34a;
}

.att-A {
    background: #fee2e2;
    color: #dc2626;
}

.att-H {
    background: #e0e7ff;
    color: #4f46e5;
}

.att-L {
    background: #fff7ed;
    color: #ea580c;
}

.att-O {
    background: #f1f5f9;
    color: #64748b;
}

.search-summary-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}

.rules-box {
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 0.78rem;
    color: #92400e;
    line-height: 1.7;
}

    .rules-box strong {
        color: #78350f;
    }


/* ── 29. Attendance List Table (AttendanceList.cshtml) ────── */

.attendance-table-wrap {
    max-height: 75vh;
    overflow: auto;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
}

.attendance-table {
    border-collapse: separate;
    border-spacing: 0;
    min-width: 100%;
    font-size: 0.82rem;
}

    .attendance-table thead th {
        position: sticky;
        top: 0;
        z-index: 3;
        background: #f8fafc;
        border-bottom: 2px solid #e2e8f0;
        padding: 8px 6px;
        font-weight: 600;
        color: #475569;
        font-size: 0.78rem;
        text-transform: uppercase;
        letter-spacing: 0.3px;
        text-align: center;
    }

        .attendance-table thead th:nth-child(1),
        .attendance-table tbody td:nth-child(1) {
            position: sticky;
            left: 0;
            z-index: 4;
            min-width: 40px;
            width: 40px;
            text-align: center;
            border-right: 1px solid rgba(0, 0, 0, 0.05);
        }

        .attendance-table thead th:nth-child(2),
        .attendance-table tbody td:nth-child(2) {
            position: sticky;
            left: 40px;
            z-index: 4;
            min-width: 160px;
            white-space: nowrap;
            border-right: 1px solid rgba(0, 0, 0, 0.05);
        }

        .attendance-table thead th:nth-child(1),
        .attendance-table thead th:nth-child(2) {
            z-index: 5;
        }

    .attendance-table tbody td {
        padding: 7px 6px;
        border-bottom: 1px solid #f1f5f9;
        vertical-align: middle;
        text-align: center;
        white-space: nowrap;
    }

        .attendance-table tbody td:nth-child(1),
        .attendance-table tbody td:nth-child(2) {
            background: #fff;
        }

    .attendance-table tbody tr:hover td {
        background: #f0f9ff !important;
    }

    .attendance-table tbody td:nth-child(2) {
        text-align: left;
        font-weight: 500;
        color: #1e293b;
    }

/* Day column headers */
.day-header {
    line-height: 1.2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

    .day-header .day-num {
        font-size: 0.85rem;
        font-weight: 700;
        color: #334155;
    }

    .day-header .day-name {
        font-size: 0.68rem;
        color: #94a3b8;
        font-weight: 500;
    }

/* Holiday dot and tooltip */
.holiday-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #f59e0b;
    margin: 0 auto;
    cursor: default;
}

.day-header-wrap {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

    .day-header-wrap .holiday-tooltip {
        display: none;
        position: absolute;
        top: calc(100% + 6px);
        left: 50%;
        transform: translateX(-50%);
        background: #1e293b;
        color: #fff;
        font-size: 0.68rem;
        font-weight: 500;
        padding: 4px 8px;
        border-radius: 5px;
        white-space: nowrap;
        z-index: 99;
        pointer-events: none;
        letter-spacing: 0;
        text-transform: none;
    }

        .day-header-wrap .holiday-tooltip::before {
            content: '';
            position: absolute;
            bottom: 100%;
            left: 50%;
            transform: translateX(-50%);
            border: 4px solid transparent;
            border-bottom-color: #1e293b;
        }

    .day-header-wrap:hover .holiday-tooltip {
        display: block;
    }

/* Status badges */
.status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 6px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.5px;
}

.status-P {
    background: #dcfce7;
    color: #16a34a;
}

.status-A {
    background: #fee2e2;
    color: #dc2626;
}

.status-L {
    background: #fff7ed;
    color: #ea580c;
}

.status-H {
    background: #e0e7ff;
    color: #4f46e5;
}

.status-O {
    background: #f1f5f9;
    color: #64748b;
}

.status-none {
    color: #e2e8f0;
    font-size: 0.7rem;
}

/* Sticky summary columns (right side) */
.summary-col-header,
.summary-col {
    position: sticky;
    z-index: 4;
    background: #f8fafc;
}

.summary-col-header {
    font-size: 0.72rem !important;
    min-width: 40px;
    border-bottom: 2px solid #e2e8f0;
}

.sticky-r-5,
.sticky-r-5h {
    right: 160px;
    border-left: 1px solid rgba(0, 0, 0, 0.05);
}

.sticky-r-4,
.sticky-r-4h {
    right: 120px;
}

.sticky-r-3,
.sticky-r-3h {
    right: 80px;
}

.sticky-r-2,
.sticky-r-2h {
    right: 40px;
}

.sticky-r-1,
.sticky-r-1h {
    right: 0;
}

.summary-col-header.sticky-r-5h,
.summary-col-header.sticky-r-4h,
.summary-col-header.sticky-r-3h,
.summary-col-header.sticky-r-2h,
.summary-col-header.sticky-r-1h {
    z-index: 6;
}

.summary-col {
    font-weight: 600;
    font-size: 0.78rem;
    background: #fff;
}

    .summary-col.s-P {
        color: #16a34a;
    }

    .summary-col.s-A {
        color: #dc2626;
    }

    .summary-col.s-L {
        color: #ea580c;
    }

    .summary-col.s-H {
        color: #4f46e5;
    }

    .summary-col.s-O {
        color: #64748b;
    }

/* Legend */
.attendance-legend {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    padding: 0;
    margin: 0;
    list-style: none;
}

    .attendance-legend li {
        display: flex;
        align-items: center;
        gap: 6px;
        font-size: 0.8rem;
        color: #64748b;
    }

.legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 3px;
}

.legend-holiday-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #f59e0b;
}


/* ── 30. Salary Table (Salary.cshtml) ────────────────────── */

.salary-table-wrap {
    max-height: 75vh;
    overflow: auto;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
}

.salary-table {
    border-collapse: separate;
    border-spacing: 0;
    min-width: 100%;
    font-size: 0.82rem;
}

    .salary-table thead th {
        position: sticky;
        top: 0;
        z-index: 3;
        background: #f8fafc;
        border-bottom: 2px solid #e2e8f0;
        padding: 10px 10px;
        font-weight: 600;
        color: #475569;
        font-size: 0.76rem;
        text-transform: uppercase;
        letter-spacing: 0.3px;
        text-align: center;
        white-space: nowrap;
    }

        .salary-table thead th:nth-child(1),
        .salary-table tbody td:nth-child(1) {
            position: sticky;
            left: 0;
            z-index: 4;
            min-width: 40px;
            width: 40px;
            text-align: center;
            border-right: 1px solid rgba(0, 0, 0, 0.05);
        }

        .salary-table thead th:nth-child(2),
        .salary-table tbody td:nth-child(2) {
            position: sticky;
            left: 40px;
            z-index: 4;
            min-width: 170px;
            white-space: nowrap;
            border-right: 1px solid rgba(0, 0, 0, 0.05);
        }

        .salary-table thead th:nth-child(1),
        .salary-table thead th:nth-child(2) {
            z-index: 5;
        }

    .salary-table tbody td {
        padding: 9px 10px;
        border-bottom: 1px solid #f1f5f9;
        vertical-align: middle;
        text-align: center;
        white-space: nowrap;
    }

        .salary-table tbody td:nth-child(1),
        .salary-table tbody td:nth-child(2) {
            background: #fff;
        }

    .salary-table tbody tr:hover td {
        background: #f0f9ff !important;
    }

    .salary-table tbody td:nth-child(2) {
        text-align: left;
        font-weight: 500;
        color: #1e293b;
    }

.col-gross {
    border-left: 1px solid rgba(0, 0, 0, 0.06);
}

/* Sticky right columns: Net Pay and Adjustments */
.sticky-right-col {
    position: sticky;
    z-index: 2;
    background: #fff;
}

.salary-table thead th.sticky-right-col {
    background: #f8fafc;
    z-index: 6;
}

.sticky-right-col.col-net {
    right: 50px;
    border-left: 1px solid rgba(0, 0, 0, 0.06);
}

.sticky-right-col.col-adj {
    right: 0;
    width: 50px;
    min-width: 50px;
    max-width: 50px;
}

.salary-table tbody tr:hover td.sticky-right-col {
    background: #f0f9ff !important;
}


/* ── 31. Branch Selection (BranchSelection/Index.cshtml) ─── */

.branch-container {
    max-width: 900px;
    margin: 40px auto;
    text-align: center;
    padding: 0 16px;
}

.branch-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--spa-text-dark);
    margin-bottom: 6px;
}

.branch-subtitle {
    font-size: 0.875rem;
    color: var(--spa-text-muted);
    margin-bottom: 32px;
}

.branch-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    border: 1px solid var(--spa-border);
    border-radius: var(--spa-radius-lg);
    padding: 28px 20px;
    cursor: pointer;
    transition: border-color 0.2s ease, transform 0.2s ease, background-color 0.2s ease;
    background: var(--spa-surface);
    text-align: center;
}

    .branch-card:hover {
        border-color: var(--spa-primary);
        background: var(--spa-primary-light);
        transform: translateY(-2px);
    }

.branch-icon {
    width: 52px;
    height: 52px;
    margin: 0 auto 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--spa-primary-light);
    color: var(--spa-primary);
    font-size: 1.5rem;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.branch-card:hover .branch-icon {
    background: var(--spa-primary);
    color: #fff;
}

.branch-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--spa-text-dark);
    margin-bottom: 2px;
}

.branch-sub {
    font-size: 0.8125rem;
    color: var(--spa-text-muted);
}


/* ── 27. Soft Badges (Inventory) ──────────────────────────── */
.badge-soft-success {
    background-color: rgba(25, 135, 84, 0.12);
    color: #198754;
    font-weight: 600;
    font-size: 0.75rem;
    padding: 5px 12px;
    border-radius: 50px;
    letter-spacing: 0.3px;
}

.badge-soft-danger {
    background-color: rgba(220, 53, 69, 0.12);
    color: #dc3545;
    font-weight: 600;
    font-size: 0.75rem;
    padding: 5px 12px;
    border-radius: 50px;
    letter-spacing: 0.3px;
}

.badge-soft-info {
    background-color: rgba(13, 110, 253, 0.12);
    color: #0d6efd;
    font-weight: 600;
    font-size: 0.75rem;
    padding: 5px 12px;
    border-radius: 50px;
    letter-spacing: 0.3px;
}

.text-success {
    color: green;
}

.text-danger {
    color: red;
}

.text-warning {
    color: orange;
}

.text-muted {
    color: gray;
}
