/* ============================================================
   RMS Global Theme  —  Bootstrap Color Palette
   Applies to all pages site-wide via BundleConfig.
   Loaded LAST so all overrides take effect.
   ============================================================ */

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
    /* Bootstrap 5 palette */
    --bs-primary:       #0d6efd;
    --bs-primary-dark:  #0a58ca;
    --bs-primary-lt:    #cfe2ff;
    --bs-success:       #198754;
    --bs-success-lt:    #d1e7dd;
    --bs-danger:        #dc3545;
    --bs-danger-lt:     #f8d7da;
    --bs-warning:       #ffc107;
    --bs-warning-lt:    #fff3cd;
    --bs-info:          #0dcaf0;
    --bs-info-lt:       #cff4fc;
    --bs-secondary:     #6c757d;
    --bs-dark:          #212529;
    --bs-dark-mid:      #343a40;
    --bs-light:         #f8f9fa;
    --bs-border:        #dee2e6;
    --bs-body-bg:       #f4f6f9;

    /* Shadows */
    --rms-shadow-sm:    0 1px 4px rgba(0,0,0,0.06);
    --rms-shadow:       0 2px 10px rgba(0,0,0,0.08);
    --rms-shadow-lg:    0 4px 20px rgba(0,0,0,0.12);
    --rms-radius:       6px;
    --rms-radius-lg:    8px;
}

/* ── Page Base ─────────────────────────────────────────────── */
body {
    background: var(--bs-body-bg);
    background-attachment: fixed;
    color: var(--bs-dark);
    font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 1rem;
    min-height: 100vh;
}
.container-fluid { padding-top: 8px; }

/* ── Scrollbar ─────────────────────────────────────────────── */
::-webkit-scrollbar              { width: 6px; height: 6px; }
::-webkit-scrollbar-track        { background: #f1f1f1; }
::-webkit-scrollbar-thumb        { background: #adb5bd; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover  { background: #6c757d; }


/* ============================================================
   BOOTSTRAP OVERRIDES
   ============================================================ */

/* ── Cards ─────────────────────────────────────────────────── */
.card {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius-lg) !important;
    box-shadow: var(--rms-shadow-sm) !important;
    background: #fff !important;
}
.card-header {
    background: #eef2ff !important;
    border-bottom: 2px solid var(--bs-primary) !important;
    font-weight: 700 !important;
    color: #084298 !important;
    font-size: 0.95rem !important;
    padding: 11px 16px !important;
    border-radius: var(--rms-radius-lg) var(--rms-radius-lg) 0 0 !important;
}
.card-body   { padding: 16px 18px !important; }
.card-footer {
    background: var(--bs-light) !important;
    border-top: 1px solid var(--bs-border) !important;
    padding: 10px 16px !important;
    border-radius: 0 0 var(--rms-radius-lg) var(--rms-radius-lg) !important;
}

/* Card header color variants */
.card-header.bg-primary,
.card-header.bg-primary-subtle   { background: #cfe2ff !important; color: #084298 !important; border-bottom-color: var(--bs-primary) !important; }
.card-header.bg-success,
.card-header.bg-success-subtle   { background: #d1e7dd !important; color: #0f5132 !important; border-bottom-color: var(--bs-success) !important; }
.card-header.bg-info,
.card-header.bg-info-subtle      { background: #cff4fc !important; color: #055160 !important; border-bottom-color: var(--bs-info) !important; }
.card-header.bg-danger,
.card-header.bg-danger-subtle    { background: #f8d7da !important; color: #842029 !important; border-bottom-color: var(--bs-danger) !important; }
.card-header.bg-warning,
.card-header.bg-warning-subtle   { background: #fff3cd !important; color: #664d03 !important; border-bottom-color: var(--bs-warning) !important; }
.card-header.bg-dark             { background: #343a40 !important; color: #fff !important;    border-bottom-color: var(--bs-dark) !important; }
.card-header.bg-light            { background: #f8f9fa !important; color: #495057 !important; border-bottom-color: var(--bs-border) !important; }
.card-header.bg-secondary-subtle { background: #e2e3e5 !important; color: #41464b !important; border-bottom-color: var(--bs-secondary) !important; }

/* Colored left-border variants */
.card.border-primary   { border-left: 4px solid var(--bs-primary)   !important; }
.card.border-success   { border-left: 4px solid var(--bs-success)   !important; }
.card.border-info      { border-left: 4px solid var(--bs-info)      !important; }
.card.border-danger    { border-left: 4px solid var(--bs-danger)    !important; }
.card.border-warning   { border-left: 4px solid var(--bs-warning)   !important; }
.card.border-secondary { border-left: 4px solid var(--bs-secondary) !important; }
.card.border-dark      { border-left: 4px solid var(--bs-dark)      !important; }


/* ── Tables ─────────────────────────────────────────────────── */
.table {
    border-collapse: collapse;
    width: 100%;
    font-size: 0.9rem;
    color: var(--bs-dark);
    margin-bottom: 0.75rem;
}
.table thead th,
.table > thead > tr > th {
    background: #f8f9fa !important;
    color: #495057 !important;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    padding: 10px 12px;
    border: none !important;
    border-bottom: 2px solid var(--bs-border) !important;
    white-space: nowrap;
}
.table > tbody > tr > td,
.table td {
    padding: 8px 12px;
    border-bottom: 1px solid #f0f0f0;
    vertical-align: middle;
    color: var(--bs-dark);
}
.table > tbody > tr:last-child > td { border-bottom: none; }
.table > tbody > tr:hover > td,
.table-hover > tbody > tr:hover > td { background: #e8f0fe !important; }
.table-striped > tbody > tr:nth-of-type(odd)  > td { background: #f8f9fa; }
.table-striped > tbody > tr:nth-of-type(even) > td { background: #ffffff; }
.table-bordered,
.table-bordered th,
.table-bordered td { border: 1px solid var(--bs-border) !important; }
.table-bordered thead th { border: 1px solid var(--bs-border) !important; }

/* Colored thead variants */
.table.border-success thead th { background: var(--bs-success)   !important; }
.table.border-info    thead th { background: #0a9dbf             !important; }
.table.border-danger  thead th { background: var(--bs-danger)    !important; }
.table.border-warning thead th { background: #cc9800             !important; color: #fff !important; }
.table.border-primary thead th { background: var(--bs-primary)   !important; }

/* Row highlights */
.table .bg-danger-subtle  td,  .bg-danger-subtle  td { background: #f8d7da !important; }
.table .bg-warning-subtle td,  .bg-warning-subtle td { background: #fff3cd !important; }
.table .bg-success-subtle td,  .bg-success-subtle td { background: #d1e7dd !important; }


/* ── Buttons ─────────────────────────────────────────────────── */
.btn {
    border-radius: var(--rms-radius) !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    padding: 6px 14px !important;
    transition: all 0.15s !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    margin-bottom: 3px !important;
}
.btn:hover  { opacity: 0.88; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn[disabled], .btn.disabled { opacity: 0.5 !important; pointer-events: none; }

.btn-primary   { background: var(--bs-primary)    !important; border-color: var(--bs-primary)    !important; color: #fff !important; }
.btn-success   { background: var(--bs-success)    !important; border-color: var(--bs-success)    !important; color: #fff !important; }
.btn-info      { background: var(--bs-info)       !important; border-color: var(--bs-info)       !important; color: #fff !important; }
.btn-danger    { background: var(--bs-danger)     !important; border-color: var(--bs-danger)     !important; color: #fff !important; }
.btn-warning   { background: var(--bs-warning)    !important; border-color: var(--bs-warning)    !important; color: #212529 !important; }
.btn-secondary { background: var(--bs-secondary)  !important; border-color: var(--bs-secondary)  !important; color: #fff !important; }
.btn-dark      { background: var(--bs-dark)       !important; border-color: var(--bs-dark)       !important; color: #fff !important; }
.btn-light     { background: var(--bs-light)      !important; border-color: var(--bs-border)     !important; color: var(--bs-dark) !important; }

.btn-outline-primary   { background: transparent !important; border: 1.5px solid var(--bs-primary)   !important; color: var(--bs-primary)   !important; }
.btn-outline-success   { background: transparent !important; border: 1.5px solid var(--bs-success)   !important; color: var(--bs-success)   !important; }
.btn-outline-info      { background: transparent !important; border: 1.5px solid var(--bs-info)      !important; color: #055160            !important; }
.btn-outline-danger    { background: transparent !important; border: 1.5px solid var(--bs-danger)    !important; color: var(--bs-danger)    !important; }
.btn-outline-warning   { background: transparent !important; border: 1.5px solid var(--bs-warning)   !important; color: #664d03            !important; }
.btn-outline-secondary { background: transparent !important; border: 1.5px solid var(--bs-secondary) !important; color: var(--bs-secondary) !important; }
.btn-outline-dark      { background: transparent !important; border: 1.5px solid var(--bs-dark)      !important; color: var(--bs-dark)      !important; }

.btn-outline-primary:hover   { background: var(--bs-primary)   !important; color: #fff !important; }
.btn-outline-success:hover   { background: var(--bs-success)   !important; color: #fff !important; }
.btn-outline-info:hover      { background: var(--bs-info)      !important; color: #fff !important; }
.btn-outline-danger:hover    { background: var(--bs-danger)    !important; color: #fff !important; }
.btn-outline-warning:hover   { background: var(--bs-warning)   !important; color: #212529 !important; }
.btn-outline-secondary:hover { background: var(--bs-secondary) !important; color: #fff !important; }
.btn-outline-dark:hover      { background: var(--bs-dark)      !important; color: #fff !important; }


/* ── Forms ───────────────────────────────────────────────────── */
.form-control, .form-select {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius) !important;
    font-size: 0.9rem !important;
    padding: 6px 10px !important;
    color: var(--bs-dark) !important;
    background: #fff !important;
    transition: border-color 0.15s, box-shadow 0.15s !important;
}
.form-control:focus, .form-select:focus {
    border-color: #86b7fe !important;
    box-shadow: 0 0 0 0.25rem rgba(13,110,253,0.25) !important;
    outline: none !important;
}
.form-control:disabled, .form-control[readonly],
.form-select:disabled {
    background: var(--bs-light) !important;
    color: var(--bs-secondary) !important;
    cursor: not-allowed !important;
}
.form-label {
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    color: #495057 !important;
    margin-bottom: 4px !important;
}
.form-check-input:checked {
    background-color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
}
.form-check-input:focus { box-shadow: 0 0 0 0.25rem rgba(13,110,253,0.25) !important; }
.input-group-text {
    background: var(--bs-light) !important;
    border-color: var(--bs-border) !important;
    color: var(--bs-secondary) !important;
    font-size: 0.9rem !important;
}
.invalid-feedback { color: var(--bs-danger) !important; font-size: 0.8rem !important; }
.is-invalid { border-color: var(--bs-danger) !important; }
.is-invalid:focus { box-shadow: 0 0 0 0.25rem rgba(220,53,69,0.25) !important; }


/* ── Nav Tabs ────────────────────────────────────────────────── */
.nav-tabs {
    border-bottom: 2px solid var(--bs-border) !important;
    gap: 2px;
}
.nav-tabs .nav-link {
    border: none !important;
    border-bottom: 3px solid transparent !important;
    border-radius: var(--rms-radius) var(--rms-radius) 0 0 !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    color: var(--bs-secondary) !important;
    padding: 8px 18px !important;
    margin-bottom: -2px !important;
    transition: all 0.2s !important;
    background: transparent !important;
}
.nav-tabs .nav-link:hover {
    color: var(--bs-primary) !important;
    background: var(--bs-primary-lt) !important;
    border-bottom-color: #86b7fe !important;
}
.nav-tabs .nav-link.active {
    color: var(--bs-primary) !important;
    border-bottom-color: var(--bs-primary) !important;
    background: #e8f0fe !important;
    font-weight: 700 !important;
}

/* Nav Pills */
.nav-pills .nav-link {
    border-radius: var(--rms-radius) !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    color: var(--bs-secondary) !important;
    padding: 6px 16px !important;
}
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background: var(--bs-primary) !important;
    color: #fff !important;
}


/* ── Badges ──────────────────────────────────────────────────── */
.badge { font-size: 0.78rem !important; font-weight: 700 !important; padding: 3px 8px !important; border-radius: 4px !important; }
.badge.bg-primary   { background: var(--bs-primary)   !important; }
.badge.bg-success   { background: var(--bs-success)   !important; }
.badge.bg-info      { background: var(--bs-info)      !important; color: #fff !important; }
.badge.bg-danger    { background: var(--bs-danger)    !important; }
.badge.bg-warning   { background: var(--bs-warning)   !important; color: #212529 !important; }
.badge.bg-secondary { background: var(--bs-secondary) !important; }
.badge.bg-dark      { background: var(--bs-dark)      !important; }
.badge.bg-light     { background: var(--bs-light)     !important; color: var(--bs-dark) !important; }


/* ── Alerts ──────────────────────────────────────────────────── */
.alert { border-radius: var(--rms-radius) !important; font-size: 0.9rem !important; border-left-width: 4px !important; padding: 10px 14px !important; }
.alert-primary   { background: #cfe2ff !important; border-color: var(--bs-primary)   !important; color: #084298 !important; }
.alert-success   { background: #d1e7dd !important; border-color: var(--bs-success)   !important; color: #0f5132 !important; }
.alert-info      { background: #cff4fc !important; border-color: var(--bs-info)      !important; color: #055160 !important; }
.alert-danger    { background: #f8d7da !important; border-color: var(--bs-danger)    !important; color: #842029 !important; }
.alert-warning   { background: #fff3cd !important; border-color: var(--bs-warning)   !important; color: #664d03 !important; }
.alert-secondary { background: #e2e3e5 !important; border-color: var(--bs-secondary) !important; color: #41464b !important; }


/* ── Modals ──────────────────────────────────────────────────── */
.modal-content {
    border: none !important;
    border-radius: var(--rms-radius-lg) !important;
    box-shadow: 0 10px 40px rgba(0,0,0,0.18) !important;
    overflow: hidden;
}
.modal-header {
    background: #fff !important;
    color: var(--bs-dark) !important;
    border-bottom: 2px solid var(--bs-primary) !important;
    padding: 14px 20px !important;
}
.modal-header .modal-title { color: var(--bs-dark) !important; font-size: 0.95rem !important; font-weight: 700 !important; }
.modal-header .btn-close   { filter: none !important; opacity: 0.6 !important; }
.modal-header .btn-close:hover { opacity: 1 !important; }
.modal-body   { padding: 20px 22px !important; background: #fff !important; }
.modal-footer { background: var(--bs-light) !important; border-top: 1px solid var(--bs-border) !important; padding: 10px 20px !important; }


/* ── Dropdowns ───────────────────────────────────────────────── */
.dropdown-menu {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius) !important;
    box-shadow: var(--rms-shadow) !important;
    font-size: 0.9rem !important;
    padding: 4px !important;
}
.dropdown-item { border-radius: 4px !important; padding: 6px 12px !important; font-weight: 500 !important; transition: all 0.15s !important; }
.dropdown-item:hover, .dropdown-item:focus { background: var(--bs-primary-lt) !important; color: var(--bs-primary-dark) !important; }
.dropdown-item.active { background: var(--bs-primary) !important; color: #fff !important; }


/* ── Progress Bars ───────────────────────────────────────────── */
.progress { border-radius: 6px !important; background: #e9ecef !important; height: 8px !important; }
.progress-bar { background: var(--bs-primary) !important; border-radius: 6px !important; }
.progress-bar.bg-success { background: var(--bs-success) !important; }
.progress-bar.bg-danger  { background: var(--bs-danger)  !important; }
.progress-bar.bg-warning { background: var(--bs-warning) !important; }


/* ── Pagination ──────────────────────────────────────────────── */
.pagination .page-link {
    border: 1px solid var(--bs-border) !important;
    color: var(--bs-primary) !important;
    border-radius: var(--rms-radius) !important;
    margin: 0 2px !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    background: #fff !important;
    transition: all 0.15s !important;
}
.pagination .page-link:hover { background: var(--bs-primary-lt) !important; border-color: #86b7fe !important; color: var(--bs-primary-dark) !important; }
.pagination .page-item.active .page-link { background: var(--bs-primary) !important; border-color: var(--bs-primary) !important; color: #fff !important; }
.pagination .page-item.disabled .page-link { color: #adb5bd !important; }


/* ============================================================
   KENDO UI OVERRIDES
   ============================================================ */

/* ── Kendo Grid ──────────────────────────────────────────────── */
.k-grid {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius-lg) !important;
    overflow: hidden !important;
    box-shadow: var(--rms-shadow-sm) !important;
    font-size: 0.9rem !important;
    font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif !important;
}

.k-grid-header,
.k-grid-header-wrap { background: transparent !important; border-bottom: none !important; }

.k-grid-header th.k-header,
.k-grid-header .k-header {
    background: #f8f9fa !important;
    color: #495057 !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.4px !important;
    border-color: var(--bs-border) !important;
    border-bottom: 2px solid var(--bs-border) !important;
    padding: 10px 12px !important;
    white-space: nowrap !important;
}
.k-grid-header th.k-header a,
.k-grid-header .k-link          { color: #495057 !important; font-weight: 700 !important; }
.k-grid-header .k-i-sort-asc-sm,
.k-grid-header .k-i-sort-desc-sm { color: var(--bs-secondary) !important; }
.k-grid-header th.k-header.k-state-focused { background: #e9ecef !important; }

.k-grid tbody tr > td { border-color: #f0f0f0 !important; padding: 8px 12px !important; color: var(--bs-dark) !important; vertical-align: middle !important; }
.k-grid tbody tr.k-alt > td { background: #f8f9fa !important; }
.k-grid tbody tr:hover > td,
.k-grid tbody tr.k-state-hover > td { background: #e8f0fe !important; cursor: pointer; }
.k-grid tbody tr.k-state-selected > td,
.k-state-selected > td { background: #cfe2ff !important; color: #084298 !important; font-weight: 600 !important; }

/* Pager */
.k-pager-wrap,
.k-grid-pager {
    background: #fff !important;
    border-top: 1px solid var(--bs-border) !important;
    color: var(--bs-secondary) !important;
    padding: 6px 12px !important;
    font-size: 0.85rem !important;
}
.k-pager-wrap .k-link,
.k-pager-nav {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius) !important;
    color: var(--bs-primary) !important;
    background: #fff !important;
    margin: 0 2px !important;
    min-width: 28px !important; height: 28px !important;
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
}
.k-pager-wrap .k-link:hover,
.k-pager-nav:hover { background: var(--bs-primary-lt) !important; border-color: #86b7fe !important; }
.k-pager-wrap .k-state-selected,
.k-pager-numbers .k-state-selected { background: var(--bs-primary) !important; color: #fff !important; border-color: var(--bs-primary) !important; }
.k-pager-info { color: var(--bs-secondary) !important; font-size: 0.82rem !important; }

/* Filter row */
.k-grid-filter-row td, .k-filtercell { background: var(--bs-light) !important; }
.k-grid-filter-row input.k-textbox, .k-filtercell input {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius) !important;
    font-size: 0.85rem !important;
    padding: 4px 8px !important;
}
.k-grid-filter-row input:focus { border-color: #86b7fe !important; }

/* Toolbar */
.k-grid-toolbar {
    background: #fff !important;
    border-bottom: 1px solid var(--bs-border) !important;
    padding: 8px 12px !important;
}
.k-column-menu, .k-popup { border-radius: var(--rms-radius) !important; box-shadow: var(--rms-shadow) !important; }


/* ── Kendo Tab Strip ─────────────────────────────────────────── */
.k-tabstrip { border: 1px solid var(--bs-border) !important; border-radius: var(--rms-radius) !important; overflow: hidden !important; }
.k-tabstrip-items,
.k-tabstrip > .k-tabstrip-items-wrapper > .k-tabstrip-items {
    background: #fff !important;
    border-bottom: 2px solid var(--bs-border) !important;
    padding: 4px 6px 0 !important;
}
.k-tabstrip-items .k-item,
.k-tabstrip .k-item { border: none !important; border-bottom: 3px solid transparent !important; border-radius: 6px 6px 0 0 !important; margin-bottom: -2px !important; transition: all 0.2s !important; }
.k-tabstrip-items .k-item .k-link,
.k-tabstrip .k-item .k-link { font-size: 0.9rem !important; font-weight: 600 !important; color: var(--bs-secondary) !important; padding: 8px 18px !important; }
.k-tabstrip-items .k-item:hover .k-link,
.k-tabstrip .k-item:hover .k-link { color: var(--bs-primary) !important; background: var(--bs-primary-lt) !important; }
.k-tabstrip-items .k-item.k-state-active .k-link,
.k-tabstrip .k-item.k-state-active .k-link,
.k-tabstrip-items .k-state-active > .k-link { color: var(--bs-primary) !important; font-weight: 700 !important; background: #e8f0fe !important; }
.k-tabstrip-items .k-item.k-state-active,
.k-tabstrip .k-item.k-state-active { border-bottom-color: var(--bs-primary) !important; }
.k-tabstrip > .k-content,
.k-tabstrip-content { padding: 16px !important; background: #fff !important; border: none !important; }


/* ── Kendo Inputs / Dropdowns ────────────────────────────────── */
.k-textbox, .k-input, .k-combobox .k-input,
.k-autocomplete .k-input, .k-numerictextbox .k-input,
.k-datepicker .k-input, .k-datetimepicker .k-input {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius) !important;
    font-size: 0.9rem !important;
    color: var(--bs-dark) !important;
    height: auto !important;
    padding: 6px 10px !important;
}
.k-textbox:focus, .k-state-focused .k-input,
.k-state-focused.k-textbox { border-color: #86b7fe !important; box-shadow: 0 0 0 0.25rem rgba(13,110,253,0.25) !important; }
.k-dropdown-wrap, .k-picker-wrap, .k-numeric-wrap {
    border: 1px solid var(--bs-border) !important;
    border-radius: var(--rms-radius) !important;
    background: #fff !important;
}
.k-state-focused .k-dropdown-wrap,
.k-state-focused .k-picker-wrap { border-color: #86b7fe !important; box-shadow: 0 0 0 0.25rem rgba(13,110,253,0.25) !important; }
.k-select { background: var(--bs-light) !important; border-left: 1px solid var(--bs-border) !important; border-radius: 0 var(--rms-radius) var(--rms-radius) 0 !important; }
.k-select .k-icon { color: var(--bs-secondary) !important; }

.k-popup.k-list-container { border: 1px solid var(--bs-border) !important; border-radius: var(--rms-radius) !important; box-shadow: var(--rms-shadow) !important; overflow: hidden !important; }
.k-list .k-item, .k-list-optionlabel { font-size: 0.9rem !important; padding: 6px 10px !important; border-radius: 4px !important; margin: 1px 4px !important; }
.k-list .k-item:hover, .k-list .k-state-hover { background: var(--bs-primary-lt) !important; color: var(--bs-primary-dark) !important; }
.k-list .k-state-selected, .k-list .k-item.k-state-selected { background: var(--bs-primary) !important; color: #fff !important; font-weight: 600 !important; }


/* ── Kendo Buttons ───────────────────────────────────────────── */
.k-button { border-radius: var(--rms-radius) !important; font-size: 0.875rem !important; font-weight: 600 !important; padding: 6px 14px !important; transition: opacity 0.15s !important; }
.k-button.k-primary, .k-button[class*="k-primary"] { background: var(--bs-primary) !important; color: #fff !important; border-color: var(--bs-primary) !important; }
.k-button:not(.k-primary):not([class*="k-primary"]) { background: #fff !important; color: var(--bs-dark) !important; border: 1px solid var(--bs-border) !important; }
.k-button:hover { opacity: 0.88 !important; }
.k-button[disabled], .k-state-disabled .k-button { opacity: 0.5 !important; }
.k-link { color: var(--bs-primary) !important; text-decoration: none !important; }
.k-link:hover { color: var(--bs-primary-dark) !important; text-decoration: underline !important; }


/* ── Kendo Window / Dialog ───────────────────────────────────── */
.k-window { border: 1px solid var(--bs-border) !important; border-radius: var(--rms-radius-lg) !important; box-shadow: 0 10px 40px rgba(0,0,0,0.18) !important; overflow: hidden !important; }
.k-window-titlebar { background: #fff !important; color: var(--bs-dark) !important; border-bottom: 2px solid var(--bs-primary) !important; padding: 12px 18px !important; font-size: 0.9rem !important; font-weight: 700 !important; }
.k-window-title { color: var(--bs-dark) !important; }
.k-window-titlebar .k-button { background: var(--bs-light) !important; border-radius: 50% !important; color: var(--bs-secondary) !important; border: 1px solid var(--bs-border) !important; width: 28px !important; height: 28px !important; padding: 0 !important; min-width: 0 !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; }
.k-window-titlebar .k-button:hover { background: var(--bs-danger-lt) !important; color: var(--bs-danger) !important; border-color: var(--bs-danger) !important; }
.k-window-content { padding: 18px 20px !important; background: #fff !important; }


/* ── Kendo Calendar ──────────────────────────────────────────── */
.k-calendar { border: 1px solid var(--bs-border) !important; border-radius: var(--rms-radius) !important; box-shadow: var(--rms-shadow) !important; overflow: hidden !important; }
.k-calendar .k-header { background: var(--bs-primary-lt) !important; color: #084298 !important; }
.k-calendar .k-header .k-link { color: #084298 !important; }
.k-calendar .k-today .k-link { color: var(--bs-primary) !important; font-weight: 700 !important; }
.k-calendar td.k-state-selected .k-link { background: var(--bs-primary) !important; color: #fff !important; border-radius: 50% !important; }
.k-calendar td:hover .k-link { background: var(--bs-primary-lt) !important; border-radius: 50% !important; }


/* ── Kendo Tooltip / Notifications ──────────────────────────── */
.k-tooltip { background: var(--bs-dark) !important; color: #fff !important; border-radius: var(--rms-radius) !important; font-size: 0.82rem !important; padding: 5px 10px !important; }
.k-notification-success { background: #d1e7dd !important; color: #0f5132 !important; border-color: var(--bs-success) !important; }
.k-notification-error   { background: #f8d7da !important; color: #842029 !important; border-color: var(--bs-danger)  !important; }
.k-notification-warning { background: #fff3cd !important; color: #664d03 !important; border-color: var(--bs-warning) !important; }
.k-notification-info    { background: #cff4fc !important; color: #055160 !important; border-color: var(--bs-info)    !important; }


/* ============================================================
   COMMON PAGE PATTERNS
   ============================================================ */

[ng-controller] { padding: 6px 0; }

/* Section titles */
.section-title, .page-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--bs-dark);
    padding-bottom: 8px;
    border-bottom: 2px solid transparent;
    position: relative;
    margin-bottom: 16px;
    display: inline-block;
}
.section-title::after, .page-title::after {
    content: '';
    position: absolute;
    bottom: -2px; left: 0;
    width: 100%; height: 2px;
    background: var(--bs-primary);
    border-radius: 2px;
}

/* Panels (Bootstrap 3) */
.panel { border-radius: var(--rms-radius-lg) !important; overflow: hidden !important; box-shadow: var(--rms-shadow-sm) !important; }
.panel-heading { padding: 10px 16px !important; font-weight: 700 !important; font-size: 0.95rem !important; }
.panel-default > .panel-heading { background: #fff !important; color: var(--bs-dark) !important; border-color: var(--bs-border) !important; border-bottom: 2px solid var(--bs-primary) !important; }
.panel-primary > .panel-heading { background: var(--bs-primary)   !important; color: #fff !important; }
.panel-success > .panel-heading { background: var(--bs-success)   !important; color: #fff !important; }
.panel-info    > .panel-heading { background: var(--bs-info)      !important; color: #fff !important; }
.panel-danger  > .panel-heading { background: var(--bs-danger)    !important; color: #fff !important; }
.panel-warning > .panel-heading { background: var(--bs-warning)   !important; color: #212529 !important; }
.panel-body { padding: 14px 16px !important; }

/* Well */
.well { background: var(--bs-light) !important; border: 1px solid var(--bs-border) !important; border-radius: var(--rms-radius) !important; box-shadow: none !important; }

/* Labels (Bootstrap 3) */
.label-default  { background: var(--bs-secondary) !important; }
.label-primary  { background: var(--bs-primary)   !important; }
.label-success  { background: var(--bs-success)   !important; }
.label-info     { background: var(--bs-info)       !important; }
.label-danger   { background: var(--bs-danger)    !important; }
.label-warning  { background: var(--bs-warning)   !important; }

/* List Groups */
.list-group { border-radius: var(--rms-radius) !important; overflow: hidden !important; }
.list-group-item { border-color: var(--bs-border) !important; font-size: 0.9rem !important; padding: 8px 14px !important; transition: all 0.15s !important; }
.list-group-item:hover { background: var(--bs-primary-lt) !important; }
.list-group-item.active { background: var(--bs-primary) !important; border-color: var(--bs-primary) !important; color: #fff !important; }

/* Breadcrumb */
.breadcrumb { background: transparent !important; font-size: 0.85rem !important; padding: 6px 0 !important; }
.breadcrumb-item a { color: var(--bs-primary) !important; }
.breadcrumb-item.active { color: var(--bs-secondary) !important; }

/* Text / BG utilities */
.text-primary { color: var(--bs-primary)   !important; }
.text-success { color: var(--bs-success)   !important; }
.text-info    { color: var(--bs-info)       !important; }
.text-danger  { color: var(--bs-danger)    !important; }
.text-warning { color: var(--bs-warning)   !important; }
.text-muted   { color: var(--bs-secondary) !important; }
.bg-primary   { background: var(--bs-primary)   !important; color: #fff !important; }
.bg-success   { background: var(--bs-success)   !important; color: #fff !important; }
.bg-info      { background: var(--bs-info)       !important; color: #fff !important; }
.bg-danger    { background: var(--bs-danger)    !important; color: #fff !important; }
.bg-warning   { background: var(--bs-warning)   !important; color: #212529 !important; }

hr { border-color: var(--bs-border) !important; opacity: 1 !important; margin: 12px 0 !important; }
small, .small { font-size: 0.82rem !important; color: var(--bs-secondary) !important; }

/* Navbar */
.navbar {
    background: #fff !important;
    box-shadow: 0 1px 0 var(--bs-border), 0 2px 8px rgba(0,0,0,0.06) !important;
    border-bottom: 3px solid var(--bs-primary) !important;
    padding: 6px 16px !important;
}
.navbar .navbar-brand { color: var(--bs-dark) !important; }
.navbar .nav-link { color: #495057 !important; font-weight: 500; font-size: 0.92rem !important; }
.navbar .nav-link:hover,
.navbar .nav-link:focus { color: var(--bs-primary) !important; background: var(--bs-primary-lt) !important; border-radius: var(--rms-radius); }
.navbar .nav-item.active .nav-link,
.navbar .nav-link.active { color: var(--bs-primary) !important; font-weight: 700 !important; }
.navbar .navbar-toggler { border-color: var(--bs-border) !important; }
.navbar .navbar-toggler-icon { filter: invert(0); }
body { padding-top: 60px !important; }

/* Breadcrumb */
.rms-breadcrumb-nav {
    background: #fff;
    border-bottom: 1px solid var(--bs-border);
    padding: 6px 16px;
    margin-bottom: 8px;
}
.rms-breadcrumb-nav .breadcrumb {
    margin: 0;
    padding: 0;
    background: transparent;
    font-size: 0.85rem;
}
.rms-breadcrumb-nav .breadcrumb-item a {
    color: var(--bs-primary);
    text-decoration: none;
    font-weight: 500;
}
.rms-breadcrumb-nav .breadcrumb-item a:hover { text-decoration: underline; }
.rms-breadcrumb-nav .breadcrumb-item.active { color: var(--bs-secondary); font-weight: 600; }
.rms-breadcrumb-nav .breadcrumb-item + .breadcrumb-item::before {
    color: var(--bs-secondary);
    content: "/";
}

/* Navbar dropdowns */
.navbar-nav li:hover > ul.dropdown-menu { display: block; }
.dropdown-submenu { position: relative; }
.dropdown-submenu > .dropdown-menu { top: 0; left: 100%; margin-top: -6px; }
.dropdown-menu > li > a:hover:after { text-decoration: underline; transform: rotate(-90deg); }
.dropdown-menu-left { right: 0; left: auto; }


/* ============================================================
   UI-GRID & ag-Grid OVERRIDES
   ============================================================ */
.ui-grid-header-cell {
    background: #f8f9fa !important;
    color: #495057 !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    border-right-color: rgba(255,255,255,0.1) !important;
}
.ui-grid-header-cell .ui-grid-cell-contents { color: #fff !important; }
.ui-grid-row:nth-child(odd)  .ui-grid-cell { background: #f8f9fa !important; }
.ui-grid-row:nth-child(even) .ui-grid-cell { background: #ffffff !important; }
.ui-grid-row:hover .ui-grid-cell { background: #e8f0fe !important; }
.ui-grid-row.ui-grid-row-selected .ui-grid-cell { background: var(--bs-primary-lt) !important; color: #084298 !important; }
.ui-grid-cell { font-size: 0.9rem !important; color: var(--bs-dark) !important; border-color: #f0f0f0 !important; }
.ui-grid-pager { background: #fff !important; border-top: 1px solid var(--bs-border) !important; }
.ui-grid-pager button { background: #fff !important; border: 1px solid var(--bs-border) !important; border-radius: var(--rms-radius) !important; color: var(--bs-primary) !important; }
.ui-grid-pager button:hover { background: var(--bs-primary-lt) !important; }

/* ag-Grid */
.ag-header-row { background: #f8f9fa !important; }
.ag-header-cell-label { color: #495057 !important; font-size: 0.8rem !important; font-weight: 700 !important; text-transform: uppercase !important; }
.ag-row-odd      { background: #f8f9fa !important; }
.ag-row-even     { background: #ffffff !important; }
.ag-row-hover    { background: #e8f0fe !important; }
.ag-row-selected { background: var(--bs-primary-lt) !important; }


/* ============================================================
   MEMBERS DIRECTIVE COMPONENT STYLES
   ============================================================ */

.members-section-title {
    font-size: 1.1rem; font-weight: 700; color: var(--bs-dark);
    margin-bottom: 16px; display: inline-block;
    padding-bottom: 6px; position: relative;
}
.members-section-title::after {
    content: ''; position: absolute; bottom: 0; left: 0;
    width: 100%; height: 3px;
    background: var(--bs-primary); border-radius: 2px;
}

/* Action bar */
.members-action-bar {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 8px; margin-bottom: 16px;
}
.members-action-bar .btn-add-member {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 16px; border-radius: var(--rms-radius);
    font-size: 0.875rem; font-weight: 600; border: none; cursor: pointer;
    background: var(--bs-primary); color: #fff; transition: opacity 0.15s;
}
.members-action-bar .btn-add-member:hover { opacity: 0.88; }
.members-action-bar .btn-verify {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 16px; border-radius: var(--rms-radius);
    font-size: 0.875rem; font-weight: 600; cursor: pointer;
    background: transparent; border: 1.5px solid var(--bs-primary);
    color: var(--bs-primary); transition: all 0.15s;
}
.members-action-bar .btn-verify:hover { background: var(--bs-primary); color: #fff; }

.members-verify-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px; border-radius: 20px;
    font-size: 0.85rem; font-weight: 600;
}
.members-verify-badge.verified   { background: #d1e7dd; color: #0f5132; }
.members-verify-badge.unverified { background: #f8d7da; color: #842029; }

/* Custom tabs */
.members-tabs {
    display: flex; border-bottom: 2px solid var(--bs-border);
    margin-bottom: 18px; gap: 2px;
}
.members-tab-btn {
    padding: 8px 20px; font-size: 0.9rem; font-weight: 600;
    border: none; border-radius: var(--rms-radius) var(--rms-radius) 0 0;
    cursor: pointer; background: transparent; color: var(--bs-secondary);
    transition: all 0.2s; border-bottom: 3px solid transparent; margin-bottom: -2px;
}
.members-tab-btn.active { color: var(--bs-primary); border-bottom-color: var(--bs-primary); background: #e8f0fe; }
.members-tab-btn:not(.active):hover { color: var(--bs-primary); background: var(--bs-primary-lt); border-bottom-color: #86b7fe; }
.members-tab-content { display: none; }
.members-tab-content.active { display: block; }

/* Member card */
.member-card {
    background: #fff; border: 1px solid var(--bs-border);
    border-left: 4px solid var(--bs-primary); border-radius: var(--rms-radius-lg);
    overflow: hidden; margin-bottom: 14px;
    box-shadow: var(--rms-shadow-sm); transition: box-shadow 0.2s;
}
.member-card:hover { box-shadow: var(--rms-shadow); }
.member-card-body   { padding: 16px 18px 12px; }
.member-card-footer {
    background: var(--bs-light); border-top: 1px solid var(--bs-border);
    padding: 8px 16px; display: flex; justify-content: flex-end; gap: 8px;
}
.btn-edit-member {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 14px; border-radius: var(--rms-radius); font-size: 0.85rem; font-weight: 600;
    border: 1.5px solid var(--bs-primary); background: transparent;
    color: var(--bs-primary); cursor: pointer; transition: all 0.15s;
}
.btn-edit-member:hover { background: var(--bs-primary); color: #fff; }
.btn-delete-member {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 14px; border-radius: var(--rms-radius); font-size: 0.85rem; font-weight: 600;
    border: 1.5px solid var(--bs-danger); background: transparent;
    color: var(--bs-danger); cursor: pointer; transition: all 0.15s;
}
.btn-delete-member:hover { background: var(--bs-danger); color: #fff; }

/* Address card */
.address-card { background: #fff; border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-info); border-radius: var(--rms-radius-lg); overflow: hidden; box-shadow: var(--rms-shadow-sm); }
.address-card-header { background: #fff; padding: 12px 16px; border-bottom: 2px solid var(--bs-primary); display: flex; align-items: center; gap: 8px; }
.address-card-header h6 { margin: 0; font-size: 0.95rem; font-weight: 700; color: var(--bs-dark); }
.address-card-body { padding: 18px 20px; }
.address-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.address-form-grid .full-width { grid-column: 1 / -1; }
.form-field label { display: block; font-size: 0.8rem; font-weight: 600; color: #495057; margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.3px; }
.form-field input, .form-field select {
    width: 100%; padding: 6px 10px; border: 1px solid var(--bs-border);
    border-radius: var(--rms-radius); font-size: 0.9rem; color: var(--bs-dark);
    background: #fff; outline: none; box-sizing: border-box; transition: border-color 0.15s, box-shadow 0.15s;
}
.form-field input:focus, .form-field select:focus { border-color: #86b7fe; box-shadow: 0 0 0 0.25rem rgba(13,110,253,0.25); }
.form-field input[disabled], .form-field select[disabled],
.form-field input[ng-disabled], .form-field select[ng-disabled] { background: var(--bs-light); color: var(--bs-secondary); cursor: not-allowed; }
.field-error { font-size: 0.8rem; color: var(--bs-danger); margin-top: 3px; }
.required-star { color: var(--bs-danger); }
.btn-save-address {
    display: inline-flex; align-items: center; gap: 6px; padding: 7px 20px;
    border-radius: var(--rms-radius); font-size: 0.9rem; font-weight: 600;
    border: none; cursor: pointer; background: var(--bs-success); color: #fff; transition: opacity 0.15s; margin-top: 8px;
}
.btn-save-address:hover { opacity: 0.88; }
.btn-save-address[disabled] { opacity: 0.5; cursor: not-allowed; }
.btn-edit-address {
    display: inline-flex; align-items: center; gap: 6px; padding: 7px 20px;
    border-radius: var(--rms-radius); font-size: 0.9rem; font-weight: 600;
    cursor: pointer; background: transparent; border: 1.5px solid var(--bs-primary);
    color: var(--bs-primary); transition: all 0.15s; margin-top: 8px;
}
.btn-edit-address:hover { background: var(--bs-primary); color: #fff; }

@media (max-width: 600px) {
    .address-form-grid { grid-template-columns: 1fr; }
    .address-form-grid .full-width { grid-column: 1; }
}


/* ============================================================
   MEMBER VIEW COMPONENT STYLES
   ============================================================ */

.mv-photo-wrap { width: 80px; height: 80px; border-radius: 50%; border: 3px solid var(--bs-primary); overflow: hidden; flex-shrink: 0; background: var(--bs-light); box-shadow: 0 0 0 3px var(--bs-primary-lt); }
.mv-photo-wrap img { width: 100%; height: 100%; object-fit: cover; }
.mv-name { font-size: 0.95rem; font-weight: 700; color: var(--bs-dark); margin-bottom: 8px; }
.mv-meta-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 8px 14px; margin: 8px 0; }
.mv-meta-item { display: flex; flex-direction: column; }
.mv-meta-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--bs-secondary); margin-bottom: 2px; }
.mv-meta-value { font-size: 0.9rem; font-weight: 500; color: var(--bs-dark); }
.mv-bohra-badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 9px; border-radius: 10px; font-size: 0.78rem; font-weight: 700; }
.mv-bohra-badge.yes { background: #d1e7dd; color: #0f5132; }
.mv-bohra-badge.no  { background: #e9ecef; color: var(--bs-secondary); }
.mv-contact-chip { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 10px; background: var(--bs-primary-lt); border: 1px solid #86b7fe; color: #084298; font-size: 0.82rem; font-weight: 500; margin: 2px 3px 2px 0; }
.mv-email-chip  { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 10px; background: var(--bs-info-lt); border: 1px solid #86d3e0; color: #055160; font-size: 0.82rem; font-weight: 500; margin: 2px 3px 2px 0; }
.mv-remark-row { background: var(--bs-light); border-left: 3px solid var(--bs-primary); padding: 6px 12px; font-size: 0.85rem; color: var(--bs-dark); border-radius: 0 var(--rms-radius) var(--rms-radius) 0; margin-top: 8px; }


/* ============================================================
   MEMBER ADD/EDIT MODAL STYLES
   ============================================================ */

.mae-modal-header { background: #fff; border-bottom: 2px solid var(--bs-primary); padding: 16px 22px; display: flex; align-items: center; justify-content: space-between; }
.mae-modal-title { font-size: 0.95rem; font-weight: 700; color: var(--bs-dark); margin: 0; display: flex; align-items: center; gap: 8px; }
.mae-close-btn { background: var(--bs-light); border: 1px solid var(--bs-border); color: var(--bs-secondary); width: 30px; height: 30px; border-radius: 50%; cursor: pointer; font-size: 1rem; display: flex; align-items: center; justify-content: center; transition: all 0.2s; }
.mae-close-btn:hover { background: var(--bs-danger-lt); color: var(--bs-danger); border-color: var(--bs-danger); }
.mae-modal-body { padding: 20px 22px; background: #fff; }
.mae-alert { background: #f8d7da; border: 1px solid #f5c2c7; color: #842029; padding: 10px 14px; border-radius: var(--rms-radius); font-size: 0.875rem; margin-bottom: 14px; }

.mae-section-head { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: var(--bs-primary); border-bottom: 2px solid var(--bs-primary-lt); padding-bottom: 4px; margin: 16px 0 10px; }
.mae-section-head:first-of-type { margin-top: 0; }

.mae-grid-4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 10px 12px; }
.mae-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr;     gap: 10px 12px; }
.mae-grid-2 { display: grid; grid-template-columns: 1fr 1fr;         gap: 10px 12px; }
.mae-grid-2-photo { display: grid; grid-template-columns: 1fr auto;  gap: 10px 16px; align-items: start; }

.mae-field label { display: block; font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; color: #495057; margin-bottom: 3px; }
.mae-field input[type="text"],
.mae-field input[type="number"],
.mae-field select,
.mae-field textarea { width: 100%; padding: 6px 10px; border: 1px solid var(--bs-border); border-radius: var(--rms-radius); font-size: 0.88rem; color: var(--bs-dark); background: #fff; box-sizing: border-box; outline: none; transition: border-color 0.15s, box-shadow 0.15s; }
.mae-field input:focus,
.mae-field select:focus,
.mae-field textarea:focus { border-color: #86b7fe; box-shadow: 0 0 0 0.25rem rgba(13,110,253,0.25); }
.mae-field input[disabled], .mae-field select[disabled] { background: var(--bs-light); color: var(--bs-secondary); }

.mae-radio-group { display: flex; gap: 16px; align-items: center; padding: 7px 0; }
.mae-radio-label { display: flex; align-items: center; gap: 6px; font-size: 0.88rem; color: var(--bs-dark); cursor: pointer; }
.mae-radio-label input[type="radio"] { accent-color: var(--bs-primary); width: 15px; height: 15px; cursor: pointer; }

.mae-photo-preview { width: 90px; height: 90px; border-radius: 50%; border: 3px solid var(--bs-border); object-fit: cover; display: block; }
.mae-photo-upload { margin-top: 6px; }
.mae-photo-upload input[type="file"] { font-size: 0.8rem; color: var(--bs-secondary); }

.mae-dynamic-list { margin-top: 4px; }
.mae-dynamic-item { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.mae-dynamic-item input { flex: 1; padding: 6px 10px; border: 1px solid var(--bs-border); border-radius: var(--rms-radius); font-size: 0.88rem; outline: none; transition: border-color 0.15s; }
.mae-dynamic-item input:focus { border-color: #86b7fe; }
.mae-btn-remove { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; border: none; background: #f8d7da; color: var(--bs-danger); cursor: pointer; font-size: 0.85rem; display: flex; align-items: center; justify-content: center; transition: background 0.15s; }
.mae-btn-remove:hover { background: var(--bs-danger); color: #fff; }
.mae-btn-add-item { display: inline-flex; align-items: center; gap: 5px; padding: 4px 12px; border-radius: var(--rms-radius); border: 1.5px dashed #86b7fe; background: transparent; color: var(--bs-primary); font-size: 0.82rem; font-weight: 600; cursor: pointer; transition: all 0.15s; margin-top: 2px; }
.mae-btn-add-item:hover { background: var(--bs-primary-lt); border-style: solid; }

.mae-modal-footer { padding: 12px 22px; background: var(--bs-light); border-top: 1px solid var(--bs-border); display: flex; justify-content: flex-end; gap: 10px; }
.mae-btn-save { display: inline-flex; align-items: center; gap: 6px; padding: 7px 22px; border-radius: var(--rms-radius); border: none; background: var(--bs-success); color: #fff; font-size: 0.9rem; font-weight: 600; cursor: pointer; transition: opacity 0.15s; }
.mae-btn-save:hover { opacity: 0.88; }
.mae-btn-save[disabled] { opacity: 0.5; cursor: not-allowed; }
.mae-btn-cancel { display: inline-flex; align-items: center; gap: 6px; padding: 7px 18px; border-radius: var(--rms-radius); border: 1px solid var(--bs-border); background: #fff; color: var(--bs-dark); font-size: 0.9rem; font-weight: 600; cursor: pointer; transition: all 0.15s; }
.mae-btn-cancel:hover { border-color: var(--bs-danger); color: var(--bs-danger); }
.mae-required { color: var(--bs-danger); }

@media (max-width: 600px) {
    .mae-grid-4 { grid-template-columns: 1fr 1fr; }
    .mae-grid-3 { grid-template-columns: 1fr 1fr; }
    .mae-grid-2-photo { grid-template-columns: 1fr; }
}


/* ============================================================
   AGREEMENTS PAGE STYLES
   ============================================================ */

.agr-page-wrapper { padding: 4px 0; }

.agr-action-bar {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 8px; margin-bottom: 14px; padding: 10px 14px;
    background: #fff; border: 1px solid var(--bs-border);
    border-bottom: 2px solid var(--bs-primary);
    border-radius: var(--rms-radius-lg); box-shadow: var(--rms-shadow-sm);
}
.agr-action-buttons { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

.agr-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 6px 14px; border-radius: var(--rms-radius);
    font-size: 0.85rem; font-weight: 600; cursor: pointer; border: none;
    text-decoration: none; transition: opacity 0.15s, transform 0.1s; white-space: nowrap;
}
.agr-btn:hover   { opacity: 0.85; transform: translateY(-1px); text-decoration: none; }
.agr-btn:active  { transform: translateY(0); }
.agr-btn[disabled], .agr-btn.disabled { opacity: 0.45; cursor: not-allowed; pointer-events: none; }

.agr-btn-indigo        { background: var(--bs-primary)   ; color: #fff; }
.agr-btn-green         { background: var(--bs-success)   ; color: #fff; }
.agr-btn-blue          { background: #0a9dbf             ; color: #fff; }
.agr-btn-dark          { background: var(--bs-dark-mid)  ; color: #fff; }
.agr-btn-outline-indigo { background: transparent; border: 1.5px solid var(--bs-primary); color: var(--bs-primary); }
.agr-btn-outline-indigo:hover { background: var(--bs-primary); color: #fff; }

.agr-selector-wrap { min-width: 200px; }
.agr-selector-wrap select { width: 100%; padding: 6px 10px; border: 1px solid var(--bs-border); border-radius: var(--rms-radius); font-size: 0.9rem; color: var(--bs-dark); background: #fff; outline: none; cursor: pointer; }
.agr-selector-wrap select:focus { border-color: #86b7fe; box-shadow: 0 0 0 0.25rem rgba(13,110,253,0.25); }

.agr-reason-alert { display: flex; align-items: center; gap: 8px; background: #f8d7da; border: 1px solid #f5c2c7; border-left: 4px solid var(--bs-danger); border-radius: var(--rms-radius); padding: 10px 14px; font-size: 0.9rem; color: #842029; font-weight: 500; margin-bottom: 14px; }

.agr-info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 10px 16px; margin-bottom: 14px; }
.agr-info-item { display: flex; flex-direction: column; }
.agr-info-label { font-size: 0.73rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--bs-secondary); margin-bottom: 2px; }
.agr-info-value { font-size: 0.9rem; font-weight: 500; color: var(--bs-dark); }

.agr-status-badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 9px; border-radius: 10px; font-size: 0.8rem; font-weight: 600; background: var(--bs-primary-lt); color: #084298; border: 1px solid #86b7fe; }

.agr-sub-title { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--bs-primary); border-bottom: 1.5px solid var(--bs-primary-lt); padding-bottom: 4px; margin: 14px 0 8px; }


/* ============================================================
   COMMERCIAL AGREEMENT STYLES
   ============================================================ */

.agr-com-card { background: #fff; border: 1px solid var(--bs-border); border-left: 5px solid var(--bs-success); border-radius: var(--rms-radius-lg); overflow: hidden; box-shadow: var(--rms-shadow-sm); margin-bottom: 14px; }
.agr-com-header { background: #fff; padding: 12px 18px; border-bottom: 2px solid var(--bs-success); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.agr-com-header-title { font-size: 0.9rem; font-weight: 700; color: var(--bs-dark); display: flex; align-items: center; gap: 7px; }
.agr-com-body { padding: 18px 20px; }

.agr-detail-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px 16px; margin-bottom: 14px; }
.agr-detail-item { display: flex; flex-direction: column; }
.agr-detail-item.full { grid-column: 1 / -1; }
.agr-detail-label { font-size: 0.73rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--bs-secondary); margin-bottom: 2px; }
.agr-detail-value { font-size: 0.9rem; font-weight: 500; color: var(--bs-dark); }

.agr-unit-chip { display: inline-flex; align-items: center; gap: 4px; padding: 2px 9px; border-radius: 10px; background: #d1e7dd; color: #0f5132; border: 1px solid #a3cfbb; font-size: 0.82rem; font-weight: 600; margin: 2px 3px 2px 0; }

.agr-toggle-btn { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 5px; font-size: 0.8rem; font-weight: 600; border: 1px solid var(--bs-success); background: transparent; color: var(--bs-success); cursor: pointer; margin-left: 8px; transition: all 0.15s; }
.agr-toggle-btn:hover { background: #d1e7dd; }
.agr-toggle-btn.blue  { border-color: var(--bs-primary); color: var(--bs-primary); }
.agr-toggle-btn.blue:hover { background: var(--bs-primary-lt); }

.agr-section-divider { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--bs-primary); border-bottom: 1.5px solid var(--bs-primary-lt); padding-bottom: 4px; margin: 16px 0 10px; display: flex; align-items: center; gap: 6px; }

.agr-status-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px 14px; margin-bottom: 14px; }
.agr-status-row { background: var(--bs-light); border: 1px solid var(--bs-border); border-radius: var(--rms-radius); padding: 10px 12px; }
.agr-status-row-label { font-size: 0.73rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--bs-secondary); margin-bottom: 4px; }
.agr-status-row-val { font-size: 0.9rem; font-weight: 600; color: var(--bs-dark); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

.agr-enc-card { background: var(--bs-warning-lt); border: 1px solid #ffd699; border-left: 4px solid var(--bs-warning); border-radius: var(--rms-radius); padding: 12px 14px; margin: 10px 0; }
.agr-enc-title { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: #664d03; margin-bottom: 10px; }
.agr-enc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

.agr-addl-card { background: var(--bs-light); border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-info); border-radius: var(--rms-radius); padding: 12px 14px; margin: 10px 0; }
.agr-addl-title { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: #055160; margin-bottom: 10px; }
.agr-addl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px 14px; }
.agr-addl-grid .full { grid-column: 1 / -1; }

.agr-addendum-row { background: var(--bs-light); border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-secondary); border-radius: var(--rms-radius); padding: 10px 14px; margin: 10px 0; display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.agr-addendum-label { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; color: var(--bs-secondary); margin-right: 4px; }
.agr-addendum-link { display: inline-flex; align-items: center; gap: 5px; font-size: 0.85rem; color: var(--bs-primary); text-decoration: none; font-weight: 500; padding: 3px 10px; border-radius: 5px; border: 1px solid #86b7fe; background: #fff; transition: all 0.15s; }
.agr-addendum-link:hover { background: var(--bs-primary-lt); text-decoration: none; }

.agr-rent-addr-card { background: var(--bs-light); border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-primary); border-radius: var(--rms-radius); padding: 12px 14px; margin: 10px 0; }
.agr-rent-addr-title { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--bs-primary); margin-bottom: 10px; display: flex; align-items: center; justify-content: space-between; }

.agr-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.agr-table th { padding: 8px 10px; text-align: left; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px; color: #495057; border-bottom: 2px solid var(--bs-border); background: #f8f9fa; }
.agr-table td { padding: 7px 10px; color: var(--bs-dark); border-bottom: 1px solid #f0f0f0; vertical-align: middle; }
.agr-table tbody tr:hover { background: #e8f0fe; }
.agr-row-danger td { background: #f8d7da !important; }

.agr-btn-danger { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: var(--rms-radius); font-size: 0.85rem; font-weight: 600; border: none; cursor: pointer; background: var(--bs-danger); color: #fff; transition: opacity 0.15s; text-decoration: none; }
.agr-btn-danger:hover { opacity: 0.85; color: #fff; text-decoration: none; }

.agr-history-btn { display: inline-flex; align-items: center; gap: 3px; padding: 2px 8px; border-radius: 4px; font-size: 0.78rem; font-weight: 600; border: 1px solid var(--bs-border); background: var(--bs-light); color: var(--bs-secondary); cursor: pointer; text-decoration: none; transition: all 0.15s; }
.agr-history-btn:hover { background: var(--bs-primary); color: #fff; border-color: var(--bs-primary); text-decoration: none; }

.agr-badge-yes { display:inline-block; padding:2px 8px; border-radius:8px; font-size:0.7rem; font-weight:700; background:#d1e7dd; color:#0f5132; }
.agr-badge-no  { display:inline-block; padding:2px 8px; border-radius:8px; font-size:0.7rem; font-weight:700; background:#e9ecef; color:#6c757d; }


/* ============================================================
   RESIDENTIAL AGREEMENT STYLES
   ============================================================ */

.agr-res-card { background: #fff; border: 1px solid var(--bs-border); border-left: 5px solid var(--bs-primary); border-radius: var(--rms-radius-lg); overflow: hidden; box-shadow: var(--rms-shadow-sm); margin-bottom: 14px; }
.agr-res-header { background: #fff; padding: 12px 18px; border-bottom: 2px solid var(--bs-primary); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.agr-res-header-title { font-size: 0.9rem; font-weight: 700; color: var(--bs-dark); display: flex; align-items: center; gap: 7px; }
.agr-res-body { padding: 18px 20px; }

.agr-res-detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px 16px; margin-bottom: 14px; }
.agr-res-detail-item { display: flex; flex-direction: column; }
.agr-res-detail-item.full { grid-column: 1 / -1; }
.agr-res-detail-label { font-size: 0.73rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--bs-secondary); margin-bottom: 2px; }
.agr-res-detail-value { font-size: 0.9rem; font-weight: 500; color: var(--bs-dark); }

.agr-res-unit-chip { display: inline-flex; align-items: center; gap: 4px; padding: 2px 9px; border-radius: 10px; background: var(--bs-primary-lt); color: #084298; border: 1px solid #86b7fe; font-size: 0.82rem; font-weight: 600; margin: 2px 3px 2px 0; }

.agr-res-divider { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--bs-primary); border-bottom: 1.5px solid var(--bs-primary-lt); padding-bottom: 4px; margin: 16px 0 10px; display: flex; align-items: center; gap: 6px; }

.agr-res-toggle-btn { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 5px; font-size: 0.8rem; font-weight: 600; border: 1px solid var(--bs-primary); background: transparent; color: var(--bs-primary); cursor: pointer; margin-left: 8px; transition: all 0.15s; }
.agr-res-toggle-btn:hover { background: var(--bs-primary-lt); }

.agr-res-status-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px 14px; margin-bottom: 14px; }
.agr-res-status-row { background: var(--bs-light); border: 1px solid var(--bs-border); border-radius: var(--rms-radius); padding: 10px 12px; }
.agr-res-status-label { font-size: 0.73rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--bs-secondary); margin-bottom: 4px; }
.agr-res-status-val { font-size: 0.9rem; font-weight: 600; color: var(--bs-dark); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

.agr-res-addendum-row { background: var(--bs-light); border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-secondary); border-radius: var(--rms-radius); padding: 10px 14px; margin: 10px 0; display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.agr-res-addendum-label { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; color: var(--bs-secondary); }
.agr-res-addendum-link { display: inline-flex; align-items: center; gap: 5px; font-size: 0.85rem; color: var(--bs-primary); text-decoration: none; font-weight: 500; padding: 3px 9px; border-radius: 5px; border: 1px solid #86b7fe; background: #fff; transition: all 0.15s; }
.agr-res-addendum-link:hover { background: var(--bs-primary-lt); text-decoration: none; }
.agr-litigation-notice { font-size: 0.88rem; color: #842029; font-weight: 500; background: #f8d7da; border: 1px solid #f5c2c7; border-radius: var(--rms-radius); padding: 6px 12px; }

.agr-res-addl-card { background: var(--bs-light); border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-info); border-radius: var(--rms-radius); padding: 12px 14px; margin: 10px 0; }
.agr-res-addl-title { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; color: #055160; margin-bottom: 10px; }
.agr-res-addl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px 14px; }
.agr-res-addl-grid .full { grid-column: 1 / -1; }

.agr-res-rent-card { background: var(--bs-light); border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-primary); border-radius: var(--rms-radius); padding: 12px 14px; margin: 10px 0; }
.agr-res-rent-title { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; color: var(--bs-primary); margin-bottom: 10px; display: flex; align-items: center; justify-content: space-between; }
.agr-res-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.agr-res-table th { padding: 8px 10px; text-align: left; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px; color: #495057; background: #f8f9fa; border-bottom: 2px solid var(--bs-border); }
.agr-res-table td { padding: 7px 10px; color: var(--bs-dark); border-bottom: 1px solid #f0f0f0; }
.agr-res-table tbody tr:hover { background: #e8f0fe; }

.agr-res-btn-danger { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: var(--rms-radius); font-size: 0.85rem; font-weight: 600; border: none; cursor: pointer; background: var(--bs-danger); color: #fff; transition: opacity 0.15s; text-decoration: none; }
.agr-res-btn-danger:hover { opacity: 0.85; color: #fff; text-decoration: none; }
.agr-res-edit-link { display: inline-flex; align-items: center; gap: 5px; font-size: 0.85rem; color: var(--bs-primary); text-decoration: none; font-weight: 500; padding: 3px 9px; border-radius: 5px; border: 1px solid #86b7fe; background: #fff; transition: all 0.15s; }
.agr-res-edit-link:hover { background: var(--bs-primary-lt); text-decoration: none; }


/* ============================================================
   AGREEMENT OPTION (TRANSIT) STYLES
   ============================================================ */

.agr-opt-card { background: #fff; border: 1px solid var(--bs-border); border-left: 5px solid var(--bs-info); border-radius: var(--rms-radius-lg); overflow: hidden; box-shadow: var(--rms-shadow-sm); margin-bottom: 14px; }
.agr-opt-header { background: #eef2ff; padding: 10px 16px; border-bottom: 2px solid var(--bs-primary, #0d6efd); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.agr-opt-header-title { font-size: 0.95rem; font-weight: 700; color: #084298; flex: 1; }
.agr-opt-header-title i { color: var(--bs-primary, #0d6efd) !important; }
.agr-opt-header-date { font-size: 0.82rem; color: #4a6fa5; font-weight: 500; }
.agr-opt-body { padding: 14px 16px; }

.agr-opt-info-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; margin-bottom: 10px; }
.agr-opt-field { display: flex; flex-direction: column; }
.agr-opt-field-label { font-size: 0.73rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--bs-secondary); margin-bottom: 2px; }
.agr-opt-field-value { font-size: 0.9rem; font-weight: 500; color: var(--bs-dark); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

.agr-opt-sub-section { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--bs-primary); border-bottom: 1.5px solid var(--bs-primary-lt); padding-bottom: 4px; margin: 12px 0 8px; display: flex; align-items: center; justify-content: space-between; }

.agr-opt-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 10px; }
.agr-opt-stat-tile { background: var(--bs-light); border: 1px solid var(--bs-border); border-radius: var(--rms-radius); padding: 8px 10px; text-align: center; }
.agr-opt-stat-tile .lbl { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; color: var(--bs-secondary); display: block; margin-bottom: 3px; }
.agr-opt-stat-tile .val { font-size: 0.95rem; font-weight: 700; color: var(--bs-primary); }

.agr-opt-toggle-btn { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 5px; font-size: 0.8rem; font-weight: 600; border: 1px solid var(--bs-primary); background: transparent; color: var(--bs-primary); cursor: pointer; transition: all 0.15s; }
.agr-opt-toggle-btn:hover { background: var(--bs-primary-lt); }

.agr-opt-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; margin-top: 6px; }
.agr-opt-table th { padding: 8px 10px; text-align: left; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px; color: #495057; background: #f8f9fa; border-bottom: 2px solid var(--bs-border); }
.agr-opt-table td { padding: 7px 10px; color: var(--bs-dark); border-bottom: 1px solid #f0f0f0; vertical-align: middle; }
.agr-opt-table tbody tr:hover { background: #e8f0fe; }
.agr-opt-table .row-ended td { background: #f8d7da !important; }

.agr-rent-slab { background: #fff; border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-success); border-radius: var(--rms-radius); padding: 12px 14px; margin-bottom: 10px; box-shadow: var(--rms-shadow-sm); }
.agr-rent-slab-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px 10px; margin-bottom: 10px; }
.agr-rent-slab-grid .full { grid-column: 1 / -1; }

.agr-rent-highlight { background: #d1e7dd; border-radius: var(--rms-radius); padding: 8px 10px; text-align: center; }
.agr-rent-highlight .lbl { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; color: #0f5132; display: block; }
.agr-rent-highlight .val { font-size: 0.92rem; font-weight: 800; color: var(--bs-success); }
.agr-rent-deduction { background: #f8d7da; border-radius: var(--rms-radius); padding: 8px 10px; text-align: center; }
.agr-rent-deduction .lbl { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; color: #842029; display: block; }
.agr-rent-deduction .val { font-size: 0.92rem; font-weight: 800; color: var(--bs-danger); }
.agr-rent-net { background: var(--bs-primary-lt); border-radius: var(--rms-radius); padding: 8px 10px; text-align: center; }
.agr-rent-net .lbl { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; color: #084298; display: block; }
.agr-rent-net .val { font-size: 0.92rem; font-weight: 800; color: var(--bs-primary); }

.agr-refund-card { background: var(--bs-warning-lt); border: 1px solid #ffd699; border-left: 4px solid var(--bs-warning); border-radius: var(--rms-radius); padding: 10px 12px; margin-top: 8px; }
.agr-refund-title { font-size: 0.78rem; font-weight: 700; text-transform: uppercase; color: #664d03; margin-bottom: 8px; }
.agr-refund-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px 10px; }
.agr-refund-grid .full { grid-column: 1 / -1; }

.agr-no-cheque { display: flex; align-items: center; gap: 7px; background: var(--bs-light); border: 1px solid var(--bs-border); border-radius: var(--rms-radius); padding: 7px 12px; font-size: 0.85rem; color: var(--bs-secondary); margin-top: 8px; }

.agr-calc-btn { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: var(--rms-radius); font-size: 0.82rem; font-weight: 600; border: 1px solid var(--bs-primary); background: transparent; color: var(--bs-primary); cursor: pointer; transition: all 0.15s; }
.agr-calc-btn:hover { background: var(--bs-primary-lt); }

.agr-change-link { display: inline-flex; align-items: center; gap: 4px; font-size: 0.82rem; color: var(--bs-primary); font-weight: 500; padding: 2px 8px; border-radius: 4px; border: 1px solid #86b7fe; background: var(--bs-primary-lt); text-decoration: none; transition: all 0.15s; }
.agr-change-link:hover { background: var(--bs-primary); color: #fff; text-decoration: none; }

.agr-opt-remark { background: var(--bs-light); border-left: 3px solid var(--bs-secondary); padding: 6px 12px; font-size: 0.85rem; color: var(--bs-dark); border-radius: 0 var(--rms-radius) var(--rms-radius) 0; margin-top: 4px; }


/* ============================================================
   AGREEMENT PAYMENT STYLES
   ============================================================ */

.agr-pay-card { background: #fff; border: 1px solid var(--bs-border); border-left: 4px solid var(--bs-warning); border-radius: var(--rms-radius); overflow: hidden; margin-top: 6px; box-shadow: var(--rms-shadow-sm); }
.agr-pay-header { background: var(--bs-warning-lt); padding: 8px 14px; border-bottom: 1px solid #ffd699; display: flex; align-items: center; gap: 7px; }
.agr-pay-header-title { font-size: 0.85rem; font-weight: 700; color: #664d03; text-transform: uppercase; letter-spacing: 0.4px; }
.agr-pay-body { padding: 0; }
.agr-pay-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.agr-pay-table th { padding: 8px 10px; text-align: left; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px; color: #495057; background: #f8f9fa; border-bottom: 2px solid var(--bs-border); white-space: nowrap; }
.agr-pay-table td { padding: 8px 10px; color: var(--bs-dark); border-bottom: 1px solid #f0f0f0; vertical-align: middle; }
.agr-pay-table tbody tr:hover { background: var(--bs-light); }
.agr-pay-table .row-cancelled td { background: #f8d7da !important; }

.agr-cheque-status { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 8px; font-size: 0.78rem; font-weight: 700; }
.agr-cheque-status.normal    { background: #d1e7dd; color: #0f5132; border: 1px solid #a3cfbb; }
.agr-cheque-status.returned  { background: #f8d7da; color: #842029; border: 1px solid #f5c2c7; }
.agr-cheque-status.cancelled { background: #e9ecef; color: #6c757d; border: 1px solid var(--bs-border); }

.agr-cheque-cancel-btn { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: var(--rms-radius); font-size: 0.78rem; font-weight: 600; border: 1px solid var(--bs-danger); background: transparent; color: var(--bs-danger); cursor: pointer; transition: all 0.15s; text-decoration: none; white-space: nowrap; }
.agr-cheque-cancel-btn:hover { background: var(--bs-danger); color: #fff; text-decoration: none; }


/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    .k-grid { font-size: 0.82rem !important; }
    .k-grid-header th.k-header { font-size: 0.72rem !important; padding: 7px 8px !important; }
    .k-grid tbody tr > td { padding: 6px 8px !important; }
    .btn { padding: 5px 10px !important; font-size: 0.82rem !important; }
    .agr-detail-grid  { grid-template-columns: 1fr 1fr; }
    .agr-status-grid  { grid-template-columns: 1fr; }
    .agr-addl-grid    { grid-template-columns: 1fr 1fr; }
    .agr-res-detail-grid { grid-template-columns: 1fr; }
    .agr-opt-stats    { grid-template-columns: 1fr 1fr; }
    .agr-rent-slab-grid { grid-template-columns: 1fr 1fr; }
}


/* ============================================================
   HOME PAGE (TASK DASHBOARD) STYLES
   ============================================================ */

.dashboard-container { padding: 30px 20px; background: var(--bs-body-bg); min-height: 100vh; }
.dashboard-header { margin-bottom: 36px; text-align: center; }
.dashboard-header h1 { font-size: 2rem; color: var(--bs-dark); font-weight: 700; margin-bottom: 8px; }
.dashboard-header p { font-size: 1rem; color: var(--bs-secondary); margin: 0; }

.section-title { font-size: 1.15rem; font-weight: 700; color: var(--bs-dark); margin-bottom: 18px; padding-bottom: 10px; border-bottom: 3px solid var(--bs-border); position: relative; }
.section-title::before { content: ''; position: absolute; bottom: -3px; left: 0; width: 0; height: 3px; background: linear-gradient(90deg, var(--bs-primary), var(--bs-success)); animation: rms-slide-in 0.6s ease forwards; }

@keyframes rms-slide-in { to { width: 100%; } }
@keyframes rms-spin { to { transform: rotate(360deg); } }

.category-section { margin-bottom: 36px; }
.category-card { background: #fff; border-radius: var(--rms-radius-lg); padding: 22px; box-shadow: var(--rms-shadow); border: 1px solid var(--bs-border); transition: box-shadow 0.2s; }
.category-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.10); }

.tile-container { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-top: 14px; }

.task-tile { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; background: #fff; border: 1.5px solid var(--bs-border); border-radius: var(--rms-radius); transition: all 0.2s; text-decoration: none; cursor: pointer; color: var(--bs-dark); }
.task-tile:hover { border-color: var(--bs-primary); background: #e8f0fe; box-shadow: 0 4px 12px rgba(13,110,253,0.12); transform: translateX(4px); text-decoration: none; color: var(--bs-dark); }
.task-tile.high-priority   { border-left: 4px solid var(--bs-danger); }
.task-tile.medium-priority { border-left: 4px solid var(--bs-warning); }
.task-tile.low-priority    { border-left: 4px solid var(--bs-success); }

.task-content { display: flex; align-items: center; gap: 12px; flex: 1; }
.task-icon { font-size: 1.4rem; color: var(--bs-primary); min-width: 28px; text-align: center; }
.task-info { display: flex; flex-direction: column; }
.task-label { font-weight: 500; font-size: 0.92rem; color: var(--bs-dark); margin: 0; }
.task-count { font-size: 1.6rem; font-weight: 700; color: var(--bs-primary); margin: 0; line-height: 1; }

.task-count-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 46px; padding: 6px 12px; background: var(--bs-primary); color: #fff; border-radius: 20px; font-weight: 700; font-size: 1rem; }
.task-count-badge.high   { background: var(--bs-danger); }
.task-count-badge.medium { background: var(--bs-warning); color: var(--bs-dark); }
.task-count-badge.zero   { background: var(--bs-secondary); }

.admin-section { margin-top: 34px; text-align: center; }

.btn-refresh { background: var(--bs-success); color: #fff; border: none; padding: 10px 26px; border-radius: var(--rms-radius); font-size: 0.95rem; font-weight: 600; cursor: pointer; transition: all 0.2s; box-shadow: 0 3px 12px rgba(25,135,84,0.25); }
.btn-refresh:hover { opacity: 0.88; transform: translateY(-1px); }
.btn-refresh:active { transform: translateY(0); }

.empty-state { text-align: center; padding: 34px 20px; color: var(--bs-secondary); }
.empty-state i { font-size: 2.6rem; margin-bottom: 12px; opacity: 0.4; display: block; }

.spinner { display: inline-block; width: 18px; height: 18px; border: 3px solid rgba(255,255,255,0.4); border-radius: 50%; border-top-color: #fff; animation: rms-spin 0.8s linear infinite; }

@media (max-width: 768px) {
    .dashboard-header h1 { font-size: 1.5rem; }
    .tile-container { grid-template-columns: 1fr; }
    .section-title { font-size: 1rem; }
}


/* ============================================================
   LOGIN PAGE STYLES
   ============================================================ */

.login-wrapper { height: 100vh; display: flex; }

.login-panel-left { width: 58%; height: 100%; position: sticky; top: 0; align-self: flex-start; background: url('/images/background.png') center center / cover no-repeat; overflow: hidden; flex-shrink: 0; }

.login-left-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(33,37,41,0.78) 0%, rgba(13,110,253,0.45) 100%); display: flex; align-items: center; padding: 50px 52px; }
.login-left-content { width: 100%; }

.login-panel-left::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; width: 0; background: linear-gradient(90deg, var(--bs-primary), var(--bs-success)); animation: rms-slide-in 1s ease forwards; z-index: 2; }

.login-left-title { font-size: 1.8rem; font-weight: 700; color: #fff; margin: 0 0 8px; letter-spacing: -0.3px; text-shadow: 0 2px 8px rgba(0,0,0,0.25); }
.login-left-sub { font-size: 0.92rem; color: rgba(255,255,255,0.80); margin: 0 0 28px; }

.login-left-tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; max-width: 480px; }
.login-tile { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: rgba(255,255,255,0.12); border: 1.5px solid rgba(255,255,255,0.25); border-radius: var(--rms-radius); font-size: 0.80rem; font-weight: 500; color: rgba(255,255,255,0.90); backdrop-filter: blur(4px); transition: all 0.2s; cursor: default; }
.login-tile:hover { background: rgba(255,255,255,0.22); border-color: rgba(255,255,255,0.50); transform: translateY(-2px); }
.login-tile i { color: #9ec8ff; font-size: 0.92rem; min-width: 14px; }

.login-panel-right { flex: 1; background: var(--bs-body-bg); display: flex; justify-content: center; align-items: center; padding: 40px 36px; overflow-y: auto; min-height: 0; }

.login-card { width: 100%; max-width: 360px; display: flex; flex-direction: column; align-items: center; }

.login-logo-block { margin-bottom: -22px; z-index: 1; background: #fff; width: 172px; height: 72px; border-radius: 18px; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 18px rgba(13,110,253,0.15), 0 1px 4px rgba(0,0,0,0.08); border: 2px solid var(--bs-border); }
.login-logo { width: 148px; height: auto; object-fit: contain; }

.login-box { width: 100%; background: #fff; border-radius: var(--rms-radius-lg); padding: 44px 32px 28px; box-shadow: var(--rms-shadow); border: 1px solid var(--bs-border); }
.login-card-top { margin-bottom: 24px; text-align: center; }
.login-heading { font-size: 1.6rem; font-weight: 700; color: var(--bs-dark); margin: 0 0 6px; }
.login-subheading { font-size: 0.95rem; color: var(--bs-secondary); margin: 0 0 16px; }

.login-divider { height: 3px; background: var(--bs-border); border-radius: 2px; position: relative; overflow: hidden; }
.login-divider::after { content: ''; position: absolute; top: 0; left: 0; height: 3px; width: 0; background: linear-gradient(90deg, var(--bs-primary), var(--bs-success)); border-radius: 2px; animation: rms-slide-in 0.9s 0.3s ease forwards; }

.login-ms-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 12px 20px; border: none; border-radius: var(--rms-radius); background: var(--bs-primary); color: #fff; font-size: 0.95rem; font-weight: 600; cursor: pointer; transition: all 0.2s; box-shadow: 0 4px 14px rgba(13,110,253,0.25); letter-spacing: 0.01em; }
.login-ms-btn:hover { opacity: 0.88; transform: translateY(-1px); }
.login-ms-btn:active { transform: translateY(0); }

.ms-logo { width: 20px; height: 20px; background-image: url('https://upload.wikimedia.org/wikipedia/commons/4/44/Microsoft_logo.svg'); background-size: cover; background-color: #fff; border-radius: 3px; padding: 2px; flex-shrink: 0; }
.login-btn-arrow { margin-left: auto; font-size: 0.85rem; opacity: 0.75; }

.login-error { display: flex; align-items: center; gap: 8px; margin-top: 16px; padding: 10px 14px; border-radius: var(--rms-radius); background: var(--bs-danger-lt); border: 1px solid #f5c2c7; color: #842029; font-size: 0.9rem; font-weight: 500; }
.login-error i { color: var(--bs-danger); flex-shrink: 0; }

.login-footer { margin-top: 26px; font-size: 0.8rem; color: var(--bs-secondary); text-align: center; }

@media (max-width: 860px) {
    .login-panel-left { display: none; }
    .login-panel-right { padding: 30px 20px; }
}
@media (max-width: 480px) {
    .login-box { padding: 44px 20px 24px; }
    .login-heading { font-size: 1.3rem; }
}


/* ============================================================
   ANNEXURE PAGE STYLES
   ============================================================ */

.anx-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.anx-card { background: #fff; border-radius: var(--rms-radius-lg); box-shadow: var(--rms-shadow); border: 1px solid var(--bs-border); border-left: 5px solid var(--bs-primary); margin-bottom: 20px; overflow: hidden; }

.anx-card-header { padding: 12px 16px; background: #fff; border-bottom: 2px solid var(--bs-primary); display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }

.anx-header-title { display: inline-flex; align-items: center; gap: 6px; background: var(--bs-primary-lt); border: 1px solid #86b7fe; border-radius: var(--rms-radius); padding: 4px 12px; font-size: 0.92rem; font-weight: 700; color: #084298; }
.anx-header-title .tag-lbl { color: #6ea8fe; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap; }

.anx-info-chip { display: inline-flex; align-items: center; gap: 5px; background: var(--bs-light); border: 1px solid var(--bs-border); border-radius: 20px; padding: 3px 12px; font-size: 0.85rem; color: var(--bs-dark); font-weight: 500; }
.anx-info-chip i { color: var(--bs-primary); font-size: 0.8rem; }

.anx-card-body { padding: 14px 16px; overflow-x: auto; }

.anx-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; min-width: 900px; }
.anx-table thead th { background: #f8f9fa; color: #495057; font-weight: 700; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.05em; padding: 8px 12px; border-bottom: 2px solid var(--bs-border); text-align: left; white-space: nowrap; }
.anx-table tbody td { padding: 8px 12px; color: var(--bs-dark); border-bottom: 1px solid #f0f0f0; vertical-align: middle; }
.anx-table tbody tr:last-child td { border-bottom: none; }
.anx-table tbody tr:hover td { background: #e8f0fe; }

.anx-area-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; min-width: 700px; }
.anx-area-table thead th { background: #f8f9fa; color: #495057; font-weight: 700; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.05em; padding: 8px 12px; border-bottom: 2px solid var(--bs-border); text-align: center; white-space: nowrap; }
.anx-area-table thead th.group-sqm { background: var(--bs-primary-lt); color: #084298; border-bottom-color: #86b7fe; }
.anx-area-table thead th.group-sqf { background: var(--bs-success-lt); color: #0f5132; border-bottom-color: #a3cfbb; }
.anx-area-table thead th.col-label { text-align: left; background: #f8f9fa; }
.anx-area-table thead tr.sub-header th { font-size: 0.75rem; opacity: 0.88; }
.anx-area-table tbody td { padding: 8px 12px; color: var(--bs-dark); border-bottom: 1px solid #f0f0f0; text-align: center; vertical-align: middle; }
.anx-area-table tbody td:first-child { text-align: left; font-weight: 600; color: #495057; }
.anx-area-table tbody tr:last-child td { border-bottom: none; }
.anx-area-table tbody tr:hover td { background: #e8f0fe; }

.anx-pill { display: inline-block; padding: 2px 9px; border-radius: 10px; font-size: 0.74rem; font-weight: 600; }
.anx-pill-yes { background: #d1e7dd; color: #0f5132; }
.anx-pill-no  { background: #f8d7da; color: #842029; }
.anx-pill-tenancy-yes { background: #d1e7dd; color: #0f5132; }
.anx-pill-tenancy-no  { background: var(--bs-warning-lt); color: #664d03; }


/* ============================================================
   DASHBOARD.CSHTML — PivotGrid wrapper
   ============================================================ */

#pivotgrid { width: 70%; }
.hidden-on-narrow { display: inline-block; vertical-align: top; }


/* ============================================================
   APPEAL PAGE STYLES
   ============================================================ */

.apl-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.apl-topbar { display: flex; justify-content: flex-end; margin-bottom: 18px; }

.apl-card {
    background: white;
    border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    margin-bottom: 16px;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border-left: 5px solid #0d6efd;
}
.apl-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08), 0 12px 32px rgba(0,0,0,0.07);
}

.apl-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    padding: 16px 20px 14px;
    border-bottom: 1px solid #f1f5f9;
    background: #fff;
}

.apl-card-identity { flex: 1; min-width: 0; }

.apl-num-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: white;
    border: 1.5px solid #86b7fe;
    border-radius: 8px;
    padding: 5px 14px;
    font-size: 0.95rem;
    font-weight: 700;
    color: #0d6efd;
    word-break: break-all;
}
.apl-num-tag .tag-lbl {
    color: #86b7fe;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    white-space: nowrap;
}

.apl-card-body { padding: 20px; }

.apl-body-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

.apl-info-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; margin-bottom: 16px; }
.apl-info-table th {
    text-align: left; font-weight: 600; color: #6c757d;
    padding: 6px 12px 6px 0; width: 34%;
    border-bottom: 1px dashed #dee2e6; vertical-align: top;
}
.apl-info-table td { color: #212529; padding: 6px 0; border-bottom: 1px dashed #dee2e6; }
.apl-info-table tr:last-child th,
.apl-info-table tr:last-child td { border-bottom: none; }

.apl-section-label {
    font-size: 0.8rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.1em; color: #6c757d; margin-bottom: 12px;
    display: flex; align-items: center; justify-content: space-between; gap: 8px;
}

.apl-cat-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
.apl-cat-table thead th {
    background: #f8f9fa; font-weight: 700; color: #6c757d;
    font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.06em;
    padding: 8px 10px; border-bottom: 2px solid #dee2e6; text-align: left;
}
.apl-cat-table tbody td {
    padding: 8px 10px; color: #212529;
    border-bottom: 1px solid #f1f5f9; vertical-align: middle;
}
.apl-cat-table tbody tr:last-child td { border-bottom: none; }
.apl-cat-table tbody tr:hover td { background: #f8f9fa; }

.apl-cat-status {
    display: inline-block; padding: 2px 10px; border-radius: 50px;
    font-size: 0.82rem; font-weight: 600; background: #f1f5f9; color: #475569;
}

.apl-cat-actions { display: flex; align-items: center; gap: 10px; }
.apl-cat-actions a {
    font-size: 0.92rem; transition: opacity 0.2s, transform 0.2s;
    cursor: pointer; text-decoration: none;
}
.apl-cat-actions a:hover { opacity: 0.7; transform: scale(1.15); }
.apl-cat-actions .ico-history { color: #0d6efd; }
.apl-cat-actions .ico-add     { color: #198754; }
.apl-cat-actions .ico-edit    { color: #0dcaf0; }
.apl-cat-actions .ico-delete  { color: #dc3545; }

.apl-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 14px; border-radius: 8px; font-size: 0.875rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s; border: 1.5px solid;
}

.apl-btn-create { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.apl-btn-create:hover { background: #0d6efd; color: white; border-color: #0d6efd; text-decoration: none; }

.apl-btn-edit   { color: #0dcaf0; border-color: #bae6fd; background: #cff4fc; }
.apl-btn-edit:hover   { background: #0dcaf0; color: white; border-color: #0dcaf0; text-decoration: none; }

.apl-btn-delete { color: #dc3545; border-color: #f8d7da; background: #f8d7da; }
.apl-btn-delete:hover { background: #dc3545; color: white; border-color: #dc3545; text-decoration: none; }

.apl-btn-addcat { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.apl-btn-addcat:hover { background: #198754; color: white; border-color: #198754; text-decoration: none; }

.apl-action-row {
    display: flex; gap: 8px; flex-wrap: wrap;
    padding-top: 14px; border-top: 1px solid #f1f5f9; margin-top: 10px;
}

.apl-no-cats { text-align: center; padding: 24px 10px; color: #6c757d; font-size: 0.92rem; }

@media (max-width: 768px) {
    .apl-body-grid { grid-template-columns: 1fr; }
    .apl-card-top  { flex-direction: column; align-items: flex-start; }
}


/* ============================================================
   EXCEPTIONS PAGE STYLES
   ============================================================ */

.exc-card {
    background: white;
    border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    margin-bottom: 16px;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border-left: 5px solid #dee2e6;
    font-family: 'Segoe UI', system-ui, sans-serif;
}
.exc-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08), 0 12px 32px rgba(0,0,0,0.07);
}
.exc-card.status-pending  { border-left-color: #ffc107; }
.exc-card.status-approved { border-left-color: #198754; }
.exc-card.status-rejected { border-left-color: #dc3545; }

.exc-card-top {
    display: flex; align-items: flex-start; justify-content: space-between;
    flex-wrap: wrap; gap: 12px; padding: 16px 20px 14px;
    border-bottom: 1px solid #f1f5f9;
}

.exc-card-identity { flex: 1; min-width: 0; }

.exc-uid-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 6px; }
.exc-uid-row h3 { font-size: 1rem; font-weight: 700; color: #212529; margin: 0; line-height: 1.2; }

.exc-num-tag {
    display: inline-flex; align-items: baseline; gap: 5px;
    background: #f1f5f9; border: 1px solid #dee2e6; border-radius: 6px;
    padding: 3px 10px; font-size: 0.85rem; font-weight: 600; color: #475569;
    word-break: break-all; max-width: 100%; margin-bottom: 6px;
}
.exc-num-tag .tag-lbl {
    color: #6c757d; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.06em; font-size: 0.78rem; white-space: nowrap; flex-shrink: 0;
}

.exc-status-pill {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 11px; border-radius: 50px; font-size: 0.82rem;
    font-weight: 700; letter-spacing: 0.03em;
}
.exc-status-pill::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.exc-status-pill.pill-pending  { background: #fff3cd; color: #b45309; }
.exc-status-pill.pill-approved { background: #d1e7dd; color: #065f46; }
.exc-status-pill.pill-rejected { background: #f8d7da; color: #991b1b; }
.exc-status-pill.pill-default  { background: #f1f5f9; color: #475569; }

.exc-tab-bar { display: flex; border-bottom: 2px solid #dee2e6; margin-bottom: 16px; }

.exc-tab-btn {
    padding: 8px 18px; font-size: 0.9rem; font-weight: 600; color: #6c757d;
    background: none; border: none; border-bottom: 2px solid transparent;
    margin-bottom: -2px; cursor: pointer; transition: all 0.2s;
    display: inline-flex; align-items: center; gap: 7px;
}
.exc-tab-btn:hover { color: #0d6efd; }
.exc-tab-btn.active { color: #0d6efd; border-bottom-color: #0d6efd; background: #cfe2ff; border-radius: 6px 6px 0 0; }

.exc-card-body { padding: 16px 20px 18px; }

.exc-info-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 12px; margin-bottom: 16px; padding-bottom: 14px; border-bottom: 1px solid #f1f5f9;
}
.exc-info-item { display: flex; flex-direction: column; gap: 3px; }
.exc-info-item .info-label { font-size: 0.8rem; font-weight: 700; color: #6c757d; text-transform: uppercase; letter-spacing: 0.06em; }
.exc-info-item .info-value { font-size: 0.9rem; font-weight: 500; color: #212529; }

.exc-detail-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; margin-bottom: 14px; }
.exc-detail-table th {
    text-align: left; font-weight: 600; color: #6c757d;
    padding: 6px 10px 6px 0; width: 32%; vertical-align: top; border-bottom: 1px dashed #dee2e6;
}
.exc-detail-table td { color: #212529; padding: 6px 0; border-bottom: 1px dashed #dee2e6; }
.exc-detail-table tr:last-child th,
.exc-detail-table tr:last-child td { border-bottom: none; }

.exc-detail-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 4px; }

.exc-action-row { display: flex; gap: 8px; flex-wrap: wrap; padding-top: 14px; border-top: 1px solid #f1f5f9; }

.exc-doc-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 14px; border-radius: 8px; font-size: 0.875rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s; border: 1.5px solid;
}

.exc-doc-btn-edit   { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.exc-doc-btn-edit:hover   { background: #0d6efd; color: white; border-color: #0d6efd; text-decoration: none; }

.exc-doc-btn-delete { color: #dc3545; border-color: #f8d7da; background: #f8d7da; }
.exc-doc-btn-delete:hover { background: #dc3545; color: white; border-color: #dc3545; text-decoration: none; }

.exc-doc-btn-print  { color: #0dcaf0; border-color: #bae6fd; background: #cff4fc; }
.exc-doc-btn-print:hover  { background: #0dcaf0; color: white; border-color: #0dcaf0; text-decoration: none; }

.exc-doc-btn-view   { color: #6610f2; border-color: #ddd6fe; background: #cfe2ff; }
.exc-doc-btn-view:hover   { background: #6610f2; color: white; border-color: #6610f2; text-decoration: none; }

.exc-doc-btn-area   { color: #ffc107; border-color: #fde68a; background: #fff3cd; }
.exc-doc-btn-area:hover   { background: #ffc107; color: white; border-color: #ffc107; text-decoration: none; }

.exc-timeline { position: relative; padding-left: 22px; }
.exc-timeline::before {
    content: ''; position: absolute; left: 7px; top: 6px; bottom: 6px;
    width: 2px; background: #dee2e6; border-radius: 2px;
}
.exc-tl-item { position: relative; padding: 0 0 14px 18px; font-size: 0.92rem; }
.exc-tl-item:last-child { padding-bottom: 0; }
.exc-tl-item::before {
    content: ''; position: absolute; left: -15px; top: 4px;
    width: 10px; height: 10px; border-radius: 50%;
    border: 2px solid #dee2e6; background: white;
}
.exc-tl-item.tl-approved::before { border-color: #198754; background: #198754; }
.exc-tl-item.tl-rejected::before { border-color: #dc3545; background: #dc3545; }
.exc-tl-item.tl-pending::before  { border-color: #ffc107; background: #ffc107; }

.tl-status { font-weight: 700; color: #212529; margin-bottom: 2px; }
.tl-meta   { font-size: 0.85rem; color: #6c757d; }
.tl-remark { font-size: 0.9rem; color: #334155; font-style: italic; }

.exc-appeal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

.exc-no-appeal { text-align: center; padding: 30px 20px; color: #6c757d; font-size: 0.92rem; }
.exc-no-appeal i { font-size: 2rem; display: block; margin-bottom: 10px; opacity: 0.4; }

.exc-doc-btn-link   { color: #0dcaf0; border-color: #99f6e4; background: #cff4fc; }
.exc-doc-btn-link:hover   { background: #0dcaf0; color: white; border-color: #0dcaf0; text-decoration: none; }

.exc-doc-btn-appeal { color: #0dcaf0; border-color: #99f6e4; background: #cff4fc; }
.exc-doc-btn-appeal:hover { background: #0dcaf0; color: white; border-color: #0dcaf0; text-decoration: none; }

.exc-section-lbl {
    font-size: 0.8rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.1em; color: #6c757d; margin-bottom: 10px;
}

@media (max-width: 768px) {
    .exc-card-top     { flex-direction: column; }
    .exc-appeal-grid  { grid-template-columns: 1fr; }
    .exc-detail-cols  { grid-template-columns: 1fr; }
    .exc-info-grid    { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   EXCEPTION LIST PAGE STYLES
   ============================================================ */

.exc-page { background: #f4f6f9; min-height: 100vh; font-family: 'Segoe UI', system-ui, sans-serif; }

.exc-hero {
    background: #fff;
    padding: 40px 40px 52px;
    position: relative; overflow: hidden;
    border-bottom: 1px solid #86b7fe;
}
.exc-hero::after {
    content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--bs-primary), var(--bs-info));
}
.exc-hero::before {
    content: ''; position: absolute; top: -60px; right: -60px;
    width: 260px; height: 260px; border-radius: 50%;
    background: rgba(13, 110, 253, 0.07);
}

.exc-hero-inner { position: relative; z-index: 1; }

.exc-hero-label {
    font-size: 0.8rem; font-weight: 700; letter-spacing: 0.18em;
    text-transform: uppercase; color: #0d6efd; margin-bottom: 8px;
}
.exc-hero h1 { font-size: 2.2rem; font-weight: 700; color: #212529; margin: 0 0 6px; letter-spacing: -0.03em; line-height: 1.1; }
.exc-hero p  { font-size: 0.95rem; color: #0d6efd; margin: 0; font-weight: 500; }

.exc-toolbar {
    background: white; border-bottom: 1px solid #dee2e6;
    padding: 14px 40px; display: flex; align-items: center;
    justify-content: space-between; gap: 16px; flex-wrap: wrap;
    position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.exc-search-wrap { position: relative; flex: 1; max-width: 520px; }
.exc-search-wrap i {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    color: #6c757d; font-size: 0.9rem; pointer-events: none;
}
.exc-search {
    width: 100%; padding: 10px 16px 10px 40px; border: 1.5px solid #dee2e6;
    border-radius: 50px; font-size: 0.9rem; color: #212529;
    background: #f8f9fa; outline: none; transition: all 0.25s;
}
.exc-search:focus { border-color: #0d6efd; background: white; box-shadow: 0 0 0 3px rgba(13,110,253,0.12); }

.exc-result-count { font-size: 0.92rem; color: #0d6efd; white-space: nowrap; font-weight: 500; }
.exc-result-count strong { color: #0d6efd; }

.exc-content { padding: 28px 40px 48px; }

.exc-alert {
    background: #f8d7da; border: 1px solid #f8d7da;
    border-left: 4px solid #dc3545; color: #7f1d1d;
    border-radius: 10px; padding: 14px 18px; margin-bottom: 24px;
    font-size: 0.9rem; display: flex; align-items: center; gap: 10px;
}

.exc-sub { font-size: 0.9rem; color: #6c757d; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.exc-actions { display: flex; gap: 8px; flex-wrap: wrap; flex-shrink: 0; }

.exc-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 7px 16px; border-radius: 8px; font-size: 0.9rem; font-weight: 600;
    border: none; cursor: pointer; text-decoration: none; transition: all 0.2s ease;
}

.exc-btn-approve { background: #198754; color: white; }
.exc-btn-approve:hover { background: #198754; box-shadow: 0 4px 14px rgba(25,135,84,0.4); transform: translateY(-1px); color: white; }

.exc-btn-reject  { background: #dc3545; color: white; }
.exc-btn-reject:hover  { background: #dc3545; box-shadow: 0 4px 14px rgba(220,53,69,0.4); transform: translateY(-1px); color: white; }

.exc-btn-upload  { background: #0d6efd; color: white; }
.exc-btn-upload:hover  { background: #0d6efd; box-shadow: 0 4px 14px rgba(13,110,253,0.4); transform: translateY(-1px); color: white; }

.exc-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 16px; padding-bottom: 14px; border-bottom: 1px solid #f1f5f9; }

.exc-chip {
    display: inline-flex; align-items: center; gap: 5px;
    background: #f8f9fa; border: 1px solid #dee2e6;
    border-radius: 7px; padding: 4px 10px; font-size: 0.79rem;
}
.exc-chip .chip-label { font-weight: 700; color: #6c757d; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em; }
.exc-chip .chip-val   { font-weight: 500; color: #212529; }

.exc-tab-panel { display: none; }
.exc-tab-panel.active { display: block; }

.exc-remark-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
.exc-remark-table th {
    text-align: left; font-weight: 600; color: #6c757d;
    padding: 6px 10px 6px 0; width: 32%; vertical-align: top; border-bottom: 1px dashed #dee2e6;
}
.exc-remark-table td { color: #212529; padding: 6px 0; border-bottom: 1px dashed #dee2e6; }
.exc-remark-table tr:last-child th,
.exc-remark-table tr:last-child td { border-bottom: none; }

.exc-doc-links { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }

.exc-timeline-item { position: relative; padding: 0 0 14px 18px; }
.exc-timeline-item:last-child { padding-bottom: 0; }
.exc-timeline-item::before {
    content: ''; position: absolute; left: -15px; top: 4px;
    width: 10px; height: 10px; border-radius: 50%;
    border: 2px solid #dee2e6; background: white;
}
.exc-timeline-item.tl-approved::before { border-color: #198754; background: #198754; }
.exc-timeline-item.tl-rejected::before { border-color: #dc3545; background: #dc3545; }
.exc-timeline-item.tl-pending::before  { border-color: #ffc107; background: #ffc107; }

.exc-empty { text-align: center; padding: 80px 20px; color: #6c757d; }
.exc-empty i { font-size: 3.5rem; display: block; margin-bottom: 16px; opacity: 0.35; }
.exc-empty p { font-size: 1rem; font-weight: 500; }

@media (max-width: 900px) {
    .exc-hero    { padding: 28px 20px 48px; }
    .exc-toolbar { padding: 12px 20px; }
    .exc-content { padding: 20px 16px 40px; }
    .exc-search-wrap { max-width: 100%; }
}
@media (max-width: 600px) {
    .exc-hero h1  { font-size: 1.6rem; }
    .exc-card-top { flex-direction: column; }
}


/* ============================================================
   CRM PAGE STYLES
   ============================================================ */

.crm-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.crm-topbar { display: flex; justify-content: flex-end; margin-bottom: 18px; }

.crm-card {
    background: white; border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    margin-bottom: 16px; overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border-left: 5px solid #0d6efd;
}
.crm-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.08), 0 12px 32px rgba(0,0,0,0.07); }

.crm-card-top {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px; padding: 14px 18px 12px;
    border-bottom: 1px solid #f1f5f9;
    background: #fff;
}

.crm-ref-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #86b7fe; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #0d6efd; word-break: break-all;
}
.crm-ref-tag .tag-lbl {
    color: #86b7fe; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}

.crm-card-body { padding: 18px 20px; }

.crm-body-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

.crm-section-lbl {
    font-size: 0.70rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.09em; color: #6c757d; margin-bottom: 8px;
    display: flex; align-items: center; gap: 5px;
}

.crm-info-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin-bottom: 14px; }
.crm-info-table th {
    text-align: left; font-weight: 600; color: #6c757d;
    padding: 6px 10px 6px 0; width: 36%; border-bottom: 1px dashed #dee2e6; vertical-align: top;
}
.crm-info-table td { color: #212529; padding: 6px 0; border-bottom: 1px dashed #dee2e6; }
.crm-info-table tr:last-child th,
.crm-info-table tr:last-child td { border-bottom: none; }

.crm-text-box {
    background: #f8f9fa; border: 1px solid #dee2e6; border-radius: 8px;
    padding: 10px 14px; font-size: 0.9rem; color: #212529;
    line-height: 1.55; margin-bottom: 14px;
}

.crm-status-pill {
    display: inline-block; padding: 3px 10px; border-radius: 20px;
    font-size: 0.82rem; font-weight: 600; background: #cfe2ff; color: #0d6efd; margin-bottom: 4px;
}

.crm-active-yes { background: #d1e7dd; color: #166534; }
.crm-active-no  { background: #f8d7da; color: #991b1b; }

.crm-action-row {
    display: flex; gap: 8px; flex-wrap: wrap;
    padding-top: 14px; border-top: 1px solid #f1f5f9; margin-top: 8px;
}

.crm-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 13px; border-radius: 8px; font-size: 0.85rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s;
    border: 1.5px solid; background: none;
}
.crm-btn:hover { text-decoration: none; }

.crm-btn-create { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.crm-btn-create:hover { background: #0d6efd; color: white; border-color: #0d6efd; }

.crm-btn-edit   { color: #0dcaf0; border-color: #bae6fd; background: #cff4fc; }
.crm-btn-edit:hover { background: #0dcaf0; color: white; border-color: #0dcaf0; }

.crm-btn-delete { color: #dc3545; border-color: #f8d7da; background: #f8d7da; }
.crm-btn-delete:hover { background: #dc3545; color: white; border-color: #dc3545; }

@media (max-width: 768px) {
    .crm-body-grid { grid-template-columns: 1fr; }
    .crm-card-top  { flex-direction: column; align-items: flex-start; }
}


/* ============================================================
   CHANGE REQUEST LOG (BUILDING) STYLES
   ============================================================ */

.crl-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.crl-topbar { display: flex; justify-content: flex-end; margin-bottom: 18px; }

.crl-searchbar {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
    margin-bottom: 18px; background: white; padding: 12px 16px;
    border-radius: 12px; box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.crl-searchbar label { font-size: 0.9rem; font-weight: 600; color: #6c757d; white-space: nowrap; margin: 0; }
.crl-searchbar select { border: 1.5px solid #dee2e6; border-radius: 8px; padding: 6px 12px; font-size: 0.9rem; color: #212529; background: white; }
.crl-searchbar select:focus { outline: none; border-color: #0d6efd; }

.crl-card {
    background: white; border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    margin-bottom: 16px; overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border-left: 5px solid #0d6efd;
}
.crl-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.08), 0 12px 32px rgba(0,0,0,0.07); }

.crl-approved { border-left-color: #198754; }
.crl-rejected { border-left-color: #dc3545; }
.crl-progress { border-left-color: #3b82f6; }
.crl-pending  { border-left-color: #ffc107; }

.crl-card-top {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px; padding: 14px 18px 12px;
    border-bottom: 1px solid #f1f5f9;
    background: #fff;
}

.crl-status-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #86b7fe; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #0d6efd;
}
.crl-status-tag .tag-lbl {
    color: #86b7fe; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}

.crl-card-identity { flex: 1; min-width: 0; }

.crl-entity-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #86b7fe; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #0d6efd; word-break: break-all;
}
.crl-entity-tag .tag-lbl {
    color: #86b7fe; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}

.crl-pill { display: inline-block; padding: 4px 12px; border-radius: 20px; font-size: 0.82rem; font-weight: 600; }
.crl-pill-approved  { background: #d1e7dd; color: #166534; }
.crl-pill-completed { background: #d1e7dd; color: #166534; }
.crl-pill-rejected  { background: #f8d7da; color: #991b1b; }
.crl-pill-cancelled { background: #f8d7da; color: #991b1b; }
.crl-pill-progress  { background: #dbeafe; color: #1e40af; }
.crl-pill-pending   { background: #fff3cd; color: #92400e; }

.crl-card-body { padding: 18px 20px; }

.crl-body-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

.crl-section-lbl {
    font-size: 0.70rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.09em; color: #6c757d; margin-bottom: 8px;
    display: flex; align-items: center; gap: 5px;
}

.crl-request-text {
    background: #f8f9fa; border: 1px solid #dee2e6; border-radius: 8px;
    padding: 10px 14px; font-size: 0.92rem; color: #212529; line-height: 1.5; margin-bottom: 14px;
}

.crl-info-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin-bottom: 14px; }
.crl-info-table th {
    text-align: left; font-weight: 600; color: #6c757d;
    padding: 5px 10px 5px 0; width: 32%; border-bottom: 1px dashed #dee2e6; vertical-align: top;
}
.crl-info-table td { color: #212529; padding: 5px 0; border-bottom: 1px dashed #dee2e6; }
.crl-info-table tr:last-child th,
.crl-info-table tr:last-child td { border-bottom: none; }

.crl-history-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.crl-history-table thead th {
    background: #f8f9fa; font-weight: 700; color: #6c757d; font-size: 0.8rem;
    text-transform: uppercase; letter-spacing: 0.06em; padding: 7px 10px;
    border-bottom: 2px solid #dee2e6; text-align: left;
}
.crl-history-table tbody td {
    padding: 7px 10px; color: #212529; border-bottom: 1px solid #f1f5f9; vertical-align: middle;
}
.crl-history-table tbody tr:last-child td { border-bottom: none; }
.crl-history-table tbody tr:hover td { background: #f8f9fa; }

.crl-action-row {
    display: flex; gap: 8px; flex-wrap: wrap;
    padding-top: 14px; border-top: 1px solid #f1f5f9; margin-top: 8px;
}

.crl-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 13px; border-radius: 8px; font-size: 0.85rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s;
    border: 1.5px solid; background: none;
}
.crl-btn:hover { text-decoration: none; }

.crl-btn-add      { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.crl-btn-add:hover { background: #0d6efd; color: white; border-color: #0d6efd; }

.crl-btn-edit     { color: #0dcaf0; border-color: #bae6fd; background: #cff4fc; }
.crl-btn-edit:hover { background: #0dcaf0; color: white; border-color: #0dcaf0; }

.crl-btn-approve  { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.crl-btn-approve:hover { background: #198754; color: white; border-color: #198754; }

.crl-btn-reject   { color: #dc3545; border-color: #f8d7da; background: #f8d7da; }
.crl-btn-reject:hover { background: #dc3545; color: white; border-color: #dc3545; }

.crl-btn-progress { color: #3b82f6; border-color: #bfdbfe; background: #eff6ff; }
.crl-btn-progress:hover { background: #3b82f6; color: white; border-color: #3b82f6; }

.crl-btn-return   { color: #ffc107; border-color: #fde68a; background: #fff3cd; }
.crl-btn-return:hover { background: #ffc107; color: white; border-color: #ffc107; }

.crl-btn-complete { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.crl-btn-complete:hover { background: #198754; color: white; border-color: #198754; }

.crl-btn-cancel   { color: #dc3545; border-color: #f8d7da; background: #f8d7da; }
.crl-btn-cancel:hover { background: #dc3545; color: white; border-color: #dc3545; }

.crl-btn-search   { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.crl-btn-search:hover { background: #0d6efd; color: white; border-color: #0d6efd; }

@media (max-width: 768px) {
    .crl-body-grid { grid-template-columns: 1fr; }
    .crl-card-top  { flex-direction: column; align-items: flex-start; }
}


/* ============================================================
   CHANGE REQUEST LOG (BUILDING UNIT) STYLES
   ============================================================ */
/* Classes identical to BuildingCRL — no duplicate CSS needed */


/* ============================================================
   DUES PAGE STYLES
   ============================================================ */

.dues-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.dues-card {
    background: white; border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    overflow: hidden; border-left: 5px solid #0d6efd; margin-bottom: 20px;
}
.dues-card-danger { border-left-color: #dc3545; }
.dues-card-info   { border-left-color: #0dcaf0; }

.dues-card-header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 10px; padding: 14px 18px 12px;
    border-bottom: 1px solid #f1f5f9;
    background: #fff;
}
.dues-card-header-danger { background: #fff; border-bottom-color: var(--bs-danger); }
.dues-card-header-info   { background: #fff; border-bottom-color: var(--bs-info); }

.dues-header-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #86b7fe; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #0d6efd;
}
.dues-header-tag .tag-lbl {
    color: #86b7fe; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}
.dues-header-tag-danger { border-color: #f8d7da; color: #991b1b; }
.dues-header-tag-danger .tag-lbl { color: #f87171; }
.dues-header-tag-info   { border-color: #bae6fd; color: #0dcaf0; }
.dues-header-tag-info .tag-lbl   { color: #38bdf8; }

.dues-summary-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.dues-summary-table td,
.dues-summary-table th { padding: 10px 18px; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.dues-summary-table tr:last-child td,
.dues-summary-table tr:last-child th { border-bottom: none; }

.dues-row-sub td   { color: #6c757d; font-size: 0.80rem; background: #fafbff; }
.dues-row-section td,
.dues-row-section th { background: #f8f9fa; font-weight: 700; color: #212529; border-top: 2px solid #dee2e6; }
.dues-row-total td,
.dues-row-total th { background: #eff6ff; font-weight: 700; color: #1d4ed8; border-top: 2px solid #bfdbfe; font-size: 0.95rem; }
.dues-row-paid td  { color: #198754; font-weight: 600; background: #f0fdf4; }
.dues-row-balance th,
.dues-row-balance td { background: #f0fdf4; color: #166534; font-weight: 700; border-top: 2px solid #a7f3d0; font-size: 0.90rem; }
.dues-row-balance.overdue th,
.dues-row-balance.overdue td { background: #fff1f2; color: #991b1b; border-top-color: #f8d7da; }
.dues-row-actions td { padding: 14px 18px; background: #f8f9fa; }

.dues-label { color: #6c757d; font-weight: 600; min-width: 280px; }
.dues-sublabel { font-size: 0.74rem; color: #6c757d; font-weight: 400; display: block; margin-top: 1px; }
.dues-amount  { text-align: right; font-weight: 600; white-space: nowrap; }
.dues-collect { text-align: right; font-weight: 600; white-space: nowrap; min-width: 180px; }

.dues-tag {
    display: inline-block; background: #dbeafe; color: #1d4ed8;
    font-size: 0.75rem; font-weight: 700; padding: 1px 7px;
    border-radius: 20px; margin-left: 4px; vertical-align: middle;
}

.dues-status-pill {
    display: inline-block; padding: 2px 10px; border-radius: 20px;
    font-size: 0.74rem; font-weight: 600; background: #cfe2ff; color: #0d6efd; margin-right: 6px;
}

.dues-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 13px; border-radius: 8px; font-size: 0.85rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s;
    border: 1.5px solid; background: none;
}
.dues-btn:hover { text-decoration: none; }

.dues-btn-print   { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.dues-btn-print:hover   { background: #0d6efd; color: white; border-color: #0d6efd; }
.dues-btn-pay     { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.dues-btn-pay:hover     { background: #198754; color: white; border-color: #198754; }
.dues-btn-settle  { color: #ffc107; border-color: #fde68a; background: #fff3cd; }
.dues-btn-settle:hover  { background: #ffc107; color: white; border-color: #ffc107; }
.dues-btn-approve { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.dues-btn-approve:hover { background: #198754; color: white; border-color: #198754; }
.dues-btn-reject  { color: #dc3545; border-color: #f8d7da; background: #f8d7da; }
.dues-btn-reject:hover  { background: #dc3545; color: white; border-color: #dc3545; }
.dues-btn-enter   { color: #0dcaf0; border-color: #bae6fd; background: #cff4fc; }
.dues-btn-enter:hover   { background: #0dcaf0; color: white; border-color: #0dcaf0; }
.dues-btn-muted   { color: #6c757d; border-color: #dee2e6; background: #f8f9fa; }
.dues-btn-muted:hover   { background: #6c757d; color: white; border-color: #6c757d; }

.dues-details-body { padding: 16px 18px; }

.dues-section-lbl {
    font-size: 0.70rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.09em; color: #6c757d; margin-bottom: 8px;
    display: flex; align-items: center; gap: 5px;
}

.dues-toolbar { display: flex; align-items: center; justify-content: flex-end; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }

.dues-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin-bottom: 14px; }
.dues-table thead th {
    background: #f8f9fa; font-weight: 700; color: #6c757d; font-size: 0.8rem;
    text-transform: uppercase; letter-spacing: 0.05em; padding: 9px 12px;
    border-bottom: 2px solid #dee2e6; text-align: left; white-space: nowrap;
}
.dues-table tbody td { padding: 8px 12px; color: #212529; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.dues-table tbody tr:last-child td { border-bottom: none; }
.dues-table tbody tr:hover td { background: #fafbff; }

.dues-nested-table { width: 100%; border-collapse: collapse; font-size: 0.80rem; }
.dues-nested-table td { padding: 5px 10px; border-bottom: 1px solid #f1f5f9; }
.dues-nested-table tr:last-child td { border-bottom: none; }

.dues-empty {
    background: #fafbff; border: 1.5px dashed #86b7fe; border-radius: 12px;
    padding: 32px 20px; text-align: center; color: #6c757d; font-size: 0.95rem;
}
.dues-empty i { font-size: 2rem; color: #86b7fe; margin-bottom: 10px; display: block; }


/* ============================================================
   TENANT PORTAL PAGE STYLES
   ============================================================ */

.tp-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.tp-empty {
    background: #fafbff; border: 1.5px dashed #86b7fe; border-radius: 12px;
    padding: 40px 20px; text-align: center; color: #6c757d; font-size: 0.92rem;
}
.tp-empty i { font-size: 2.2rem; color: #86b7fe; display: block; margin-bottom: 12px; }

.tp-card {
    background: white; border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    overflow: hidden; border-left: 5px solid #0d6efd; margin-bottom: 20px;
}

.tp-card-header {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 18px 12px; border-bottom: 1px solid #f1f5f9;
    background: #fff;
}

.tp-header-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #86b7fe; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #0d6efd;
}
.tp-header-tag .tag-lbl {
    color: #86b7fe; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}

.tp-card-body { padding: 20px 22px; }

.tp-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 20px; }

.tp-info-item { background: #f8f9fa; border: 1px solid #dee2e6; border-radius: 10px; padding: 12px 16px; }
.tp-info-item .i-label {
    font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em;
    color: #6c757d; margin-bottom: 5px; display: flex; align-items: center; gap: 5px;
}
.tp-info-item .i-label i { color: #86b7fe; }
.tp-info-item .i-value  { font-size: 0.95rem; font-weight: 600; color: #212529; }

.tp-section-lbl {
    font-size: 0.70rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.09em; color: #6c757d; margin-bottom: 10px; margin-top: 20px;
    display: flex; align-items: center; gap: 5px;
}
.tp-section-lbl:first-child { margin-top: 0; }

.tp-docs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 20px; }

.tp-doc-item { background: #f8f9fa; border: 1px solid #dee2e6; border-radius: 10px; padding: 12px 16px; }
.tp-doc-item .doc-label {
    font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em;
    color: #6c757d; margin-bottom: 8px; display: flex; align-items: center; gap: 5px;
}
.tp-doc-item .doc-label i { color: #86b7fe; }

.tp-divider { border: none; border-top: 1px solid #f1f5f9; margin: 4px 0 20px; }

.tp-timeline { display: flex; flex-direction: column; gap: 0; }

.tp-timeline-row {
    display: grid; grid-template-columns: 160px 1fr 1fr 1fr;
    gap: 12px; padding: 10px 14px; border-radius: 8px;
    align-items: center; font-size: 0.9rem; transition: background 0.15s;
}
.tp-timeline-row:hover { background: #fafbff; }
.tp-timeline-row + .tp-timeline-row { border-top: 1px solid #f1f5f9; }

.tp-timeline-header {
    background: #f8f9fa; border-radius: 8px 8px 0 0; font-size: 0.70rem;
    font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
    color: #6c757d; padding: 9px 14px; border-bottom: 2px solid #dee2e6;
}
.tp-timeline-header:hover { background: #f8f9fa; }

.tp-status-pill {
    display: inline-block; padding: 3px 10px; border-radius: 20px;
    font-size: 0.74rem; font-weight: 600; background: #cfe2ff; color: #0d6efd;
}
.tp-status-approved { background: #d1e7dd; color: #166534; }
.tp-status-rejected { background: #f8d7da; color: #991b1b; }
.tp-status-pending  { background: #fff3cd; color: #92400e; }

.tp-cell-date   { color: #6c757d; font-size: 0.80rem; }
.tp-cell-user   { color: #475569; font-weight: 500; }
.tp-cell-remark { color: #6c757d; font-size: 0.80rem; font-style: italic; }

@media (max-width: 768px) {
    .tp-info-grid  { grid-template-columns: 1fr; }
    .tp-docs-grid  { grid-template-columns: 1fr; }
    .tp-timeline-row { grid-template-columns: 1fr 1fr; }
}


/* ============================================================
   TENANT RENT RECEIPTS PAGE STYLES
   ============================================================ */

.rr-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.rr-card {
    background: white; border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    overflow: hidden; border-left: 5px solid #198754; margin-bottom: 20px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.rr-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.08), 0 12px 32px rgba(0,0,0,0.07); }

.rr-card-header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 10px; padding: 14px 18px 12px;
    border-bottom: 1px solid #f1f5f9;
    background: #fff;
}

.rr-header-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #a7f3d0; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #065f46; word-break: break-all;
}
.rr-header-tag .tag-lbl {
    color: #6ee7b7; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}

.rr-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 13px; border-radius: 8px; font-size: 0.85rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s;
    border: 1.5px solid; background: none;
}
.rr-btn:hover { text-decoration: none; }

.rr-btn-block { color: #dc3545; border-color: #f8d7da; background: #f8d7da; }
.rr-btn-block:hover { background: #dc3545; color: white; border-color: #dc3545; }

.rr-btn-download { color: #198754; border-color: #a7f3d0; background: #d1e7dd; font-size: 0.82rem; padding: 4px 10px; }
.rr-btn-download:hover { background: #198754; color: white; border-color: #198754; }

.rr-card-body { padding: 20px 22px; }

.rr-section-lbl {
    font-size: 0.70rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.09em; color: #6c757d; margin-bottom: 10px; margin-top: 20px;
    display: flex; align-items: center; gap: 5px;
}
.rr-section-lbl:first-child { margin-top: 0; }

.rr-name-banner {
    background: #fff;
    border: 1px solid #a7f3d0; border-radius: 10px; padding: 12px 18px;
    margin-bottom: 16px; font-size: 1rem; font-weight: 700; color: #065f46;
    display: flex; align-items: center; gap: 8px;
}
.rr-name-banner i { color: #34d399; }

.rr-info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 16px; }

.rr-info-item { background: #f8f9fa; border: 1px solid #dee2e6; border-radius: 10px; padding: 10px 14px; }
.rr-info-item .i-label {
    font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
    color: #6c757d; margin-bottom: 4px; display: flex; align-items: center; gap: 4px;
}
.rr-info-item .i-label i { color: #86b7fe; }
.rr-info-item .i-value   { font-size: 0.92rem; font-weight: 600; color: #212529; }

.rr-info-item.green-item { border-color: #a7f3d0; background: #f0fdf4; }
.rr-info-item.green-item .i-value { color: #065f46; }
.rr-info-item.amber-item { border-color: #fde68a; background: #fff3cd; }
.rr-info-item.amber-item .i-value { color: #92400e; }

.rr-divider { border: none; border-top: 1px solid #f1f5f9; margin: 4px 0 20px; }

.rr-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.rr-table thead th {
    background: #f8f9fa; font-weight: 700; color: #6c757d; font-size: 0.70rem;
    text-transform: uppercase; letter-spacing: 0.05em; padding: 9px 12px;
    border-bottom: 2px solid #dee2e6; text-align: left; white-space: nowrap;
}
.rr-table tbody td { padding: 8px 12px; color: #212529; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.rr-table tbody tr:last-child td { border-bottom: none; }
.rr-table tbody tr:hover td { background: #f0fdf4; }

.rr-pay-pill { display: inline-block; padding: 2px 10px; border-radius: 20px; font-size: 0.8rem; font-weight: 600; }
.rr-pay-paid   { background: #d1e7dd; color: #166534; }
.rr-pay-unpaid { background: #f8d7da; color: #991b1b; }
.rr-pay-other  { background: #cfe2ff; color: #0d6efd; }

@media (max-width: 900px) { .rr-info-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) {
    .rr-info-grid { grid-template-columns: 1fr; }
    .rr-card-header { flex-direction: column; align-items: flex-start; }
}


/* ============================================================
   PENDING DUES PAGE STYLES
   ============================================================ */

.pd-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.pd-card {
    background: white; border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    overflow: hidden; border-left: 5px solid #0d6efd;
}

.pd-card-header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px; padding: 14px 18px 12px;
    border-bottom: 1px solid #f1f5f9;
    background: #fff;
}

.pd-header-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #86b7fe; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #0d6efd;
}
.pd-header-tag .tag-lbl {
    color: #86b7fe; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}

.pd-card-body { padding: 16px 18px; }

.pd-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 14px; border-radius: 8px; font-size: 0.80rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s; border: 1.5px solid; background: none;
}
.pd-btn:hover { text-decoration: none; }

.pd-btn-approve { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.pd-btn-approve:hover { background: #198754; color: white; border-color: #198754; }


/* ============================================================
   TRANSFERS PAGE STYLES
   ============================================================ */

.trf-page { font-family: 'Segoe UI', system-ui, sans-serif; }

.trf-topbar {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 10px; margin-bottom: 18px;
}
.trf-topbar-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.trf-notice { font-size: 0.9rem; font-weight: 600; color: #6610f2; display: flex; align-items: center; gap: 6px; }
.trf-notice i { color: #a78bfa; }

.trf-card {
    background: white; border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.05);
    margin-bottom: 16px; overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border-left: 5px solid #0d6efd;
}
.trf-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.08), 0 12px 32px rgba(0,0,0,0.07); }

.trf-card-top {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px; padding: 14px 18px 12px;
    border-bottom: 1px solid #f1f5f9;
    background: #fff;
}

.trf-label-tag {
    display: inline-flex; align-items: center; gap: 6px;
    background: white; border: 1.5px solid #86b7fe; border-radius: 8px;
    padding: 5px 14px; font-size: 0.95rem; font-weight: 700; color: #0d6efd;
}
.trf-label-tag .tag-lbl {
    color: #86b7fe; font-size: 0.70rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
}

.trf-tab-bar { display: flex; gap: 6px; }

.trf-tab-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 13px; border-radius: 8px; font-size: 0.85rem; font-weight: 600;
    cursor: pointer; transition: all 0.2s; border: 1.5px solid; background: none; text-decoration: none;
}
.trf-tab-btn:hover { text-decoration: none; }

.trf-tab-info { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.trf-tab-info:hover,
.trf-tab-info.active { background: #0d6efd; color: white; border-color: #0d6efd; }

.trf-tab-logs { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.trf-tab-logs:hover,
.trf-tab-logs.active { background: #198754; color: white; border-color: #198754; }

.trf-card-body { padding: 18px 20px; }

.trf-body-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

.trf-section-lbl {
    font-size: 0.70rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.09em; color: #6c757d; margin-bottom: 8px;
    display: flex; align-items: center; gap: 5px;
}

.trf-info-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin-bottom: 14px; }
.trf-info-table th {
    text-align: left; font-weight: 600; color: #6c757d;
    padding: 6px 10px 6px 0; width: 38%; border-bottom: 1px dashed #dee2e6; vertical-align: top;
}
.trf-info-table td { color: #212529; padding: 6px 0; border-bottom: 1px dashed #dee2e6; }
.trf-info-table tr:last-child th,
.trf-info-table tr:last-child td { border-bottom: none; }

.trf-remark-box {
    background: #f8f9fa; border: 1px solid #dee2e6; border-radius: 8px;
    padding: 10px 14px; font-size: 0.9rem; color: #212529;
    line-height: 1.55; margin-bottom: 14px;
}

.trf-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 13px; border-radius: 8px; font-size: 0.85rem; font-weight: 600;
    text-decoration: none; cursor: pointer; transition: all 0.2s; border: 1.5px solid; background: none;
}
.trf-btn:hover { text-decoration: none; }

.trf-btn-print  { color: #0d6efd; border-color: #86b7fe; background: #cfe2ff; }
.trf-btn-print:hover { background: #0d6efd; color: white; border-color: #0d6efd; }

.trf-btn-create { color: #198754; border-color: #a7f3d0; background: #d1e7dd; }
.trf-btn-create:hover { background: #198754; color: white; border-color: #198754; }

@media (max-width: 768px) {
    .trf-body-grid { grid-template-columns: 1fr; }
    .trf-card-top  { flex-direction: column; align-items: flex-start; }
    .trf-topbar    { flex-direction: column; align-items: flex-start; }
}


/* ============================================================
   SMS PAGE STYLES
   ============================================================ */

.change-background { background-color: #dc3545; }


/* ============================================================
   DETAILS PAGE — SIDEBAR NAV
   ============================================================ */

.rms-sidebar {
    background: #fff !important;
    border-right: 1px solid var(--bs-border);
    min-height: calc(100vh - 60px);
    padding-top: 12px;
}
.rms-sidebar .nav-link {
    color: #495057 !important;
    font-size: 0.9rem;
    font-weight: 500;
    border-radius: var(--rms-radius);
    padding: 7px 12px;
    margin-bottom: 2px;
    transition: all 0.15s;
}
.rms-sidebar .nav-link:hover { background: var(--bs-primary-lt) !important; color: var(--bs-primary) !important; }
.rms-sidebar .nav-link.active { background: var(--bs-primary) !important; color: #fff !important; font-weight: 600; }
.rms-sidebar-nav { top: 125px; }


/* ============================================================
   TENANT UNIT DISPLAY (_TenantUnitDisplay) STYLES
   ============================================================ */

.tud-card {
    background: #fff; border-radius: var(--rms-radius-lg);
    box-shadow: var(--rms-shadow); border-left: 5px solid var(--bs-primary);
    display: flex; flex-direction: column; height: 450px;
    font-family: 'Segoe UI', system-ui, sans-serif; transition: box-shadow 0.2s;
    border: 1px solid var(--bs-border);
}
.tud-card:hover { box-shadow: var(--rms-shadow-lg); }

.tud-header {
    padding: 14px 18px 12px; border-bottom: 2px solid var(--bs-primary);
    background: #fff; flex-shrink: 0;
    border-radius: var(--rms-radius-lg) var(--rms-radius-lg) 0 0;
}
.tud-header-title { font-size: 0.95rem; font-weight: 700; color: var(--bs-dark); margin-bottom: 3px; line-height: 1.3; }
.tud-header-sub { font-size: 0.85rem; color: var(--bs-primary); font-weight: 500; display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.tud-header-sub i { font-size: 0.8rem; color: #86b7fe; }

.tud-tab-bar { display: flex; border-bottom: 2px solid var(--bs-border); flex-shrink: 0; background: var(--bs-light); }
.tud-tab-btn {
    flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
    padding: 8px 4px; font-size: 0.8rem; font-weight: 600; color: var(--bs-secondary);
    background: none; border: none; border-bottom: 2px solid transparent; margin-bottom: -2px;
    cursor: pointer; transition: all 0.2s; text-align: center; line-height: 1.2;
}
.tud-tab-btn i { font-size: 0.9rem; }
.tud-tab-btn:hover { color: var(--bs-primary); background: var(--bs-primary-lt); }
.tud-tab-btn.active { color: var(--bs-primary); border-bottom-color: var(--bs-primary); background: #e8f0fe; }

.tud-body { flex: 1; overflow-y: auto; padding: 12px 14px; }
.tud-section { margin-bottom: 12px; }

.tud-info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 12px; }
.tud-info-item { display: flex; flex-direction: column; gap: 2px; }
.tud-info-item .info-label { font-size: 0.75rem; font-weight: 700; color: var(--bs-secondary); text-transform: uppercase; letter-spacing: 0.06em; }
.tud-info-item .info-value { font-size: 0.92rem; font-weight: 500; color: var(--bs-dark); }
.tud-info-item .info-value .info-sub { font-size: 0.8rem; color: var(--bs-secondary); font-weight: 400; }

.tud-status-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 12px; }
.tud-status-box { padding: 8px 6px; border-radius: var(--rms-radius); background: var(--bs-light); border: 1px solid var(--bs-border); text-align: center; transition: box-shadow 0.15s; }
.tud-status-box:hover { box-shadow: var(--rms-shadow-sm); }
.tud-status-box .s-label { font-size: 0.75rem; font-weight: 700; color: var(--bs-secondary); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 3px; }
.tud-status-box .s-value { display: inline-block; font-size: 0.85rem; font-weight: 600; padding: 3px 10px; border-radius: 20px; background: var(--bs-border); color: #495057; }
.tud-status-box.highlight { border-color: var(--bs-primary); background: var(--bs-primary-lt); }
.tud-status-box.highlight .s-label { color: var(--bs-primary); }

.tud-reason-box { padding: 9px 12px; background: var(--bs-warning-lt); border-left: 3px solid var(--bs-warning); border-radius: 0 var(--rms-radius) var(--rms-radius) 0; color: #664d03; font-size: 0.9rem; display: flex; align-items: flex-start; gap: 8px; }
.tud-reason-box i { color: var(--bs-warning); margin-top: 1px; flex-shrink: 0; }

.tud-detail-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin-bottom: 10px; }
.tud-detail-table th { text-align: left; font-weight: 600; color: var(--bs-secondary); padding: 5px 10px 5px 0; width: 35%; border-bottom: 1px dashed var(--bs-border); vertical-align: top; }
.tud-detail-table td { color: var(--bs-dark); padding: 5px 0; border-bottom: 1px dashed var(--bs-border); }
.tud-detail-table tr:last-child th, .tud-detail-table tr:last-child td { border-bottom: none; }

.tud-section-lbl { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--bs-secondary); margin-bottom: 8px; display: flex; align-items: center; gap: 5px; }
.tud-grid-container { height: 180px; }

.tud-btn-wrap { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 10px; }
.tud-exc-btn { display: inline-flex; align-items: center; gap: 6px; padding: 7px 13px; font-size: 0.875rem; font-weight: 600; border: none; border-radius: var(--rms-radius); color: #fff; cursor: pointer; transition: opacity 0.15s, transform 0.1s; }
.tud-exc-btn:hover { opacity: 0.88; color: #fff; }
.tud-exc-btn:active { transform: scale(0.97); }

.btn-purple { background: #6610f2; }
.btn-teal   { background: var(--bs-success); }
.btn-blue   { background: var(--bs-primary); }
.btn-amber  { background: #cc9800; }
.btn-coral  { background: var(--bs-danger); }
.btn-pink   { background: #d63384; }

.tud-outline-btn { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: var(--rms-radius); font-size: 0.875rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: all 0.2s; border: 1.5px solid; background: none; }
.tud-btn-success { color: var(--bs-success); border-color: #a3cfbb; background: var(--bs-success-lt); }
.tud-btn-success:hover { background: var(--bs-success); color: #fff; border-color: var(--bs-success); }
.tud-btn-danger  { color: var(--bs-danger);  border-color: #f5c2c7; background: var(--bs-danger-lt); }
.tud-btn-danger:hover  { background: var(--bs-danger);  color: #fff; border-color: var(--bs-danger); }

.tud-club-info { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.tud-club-row { display: flex; align-items: flex-start; gap: 8px; font-size: 0.92rem; }
.tud-club-row .c-label { font-size: 0.8rem; font-weight: 700; color: var(--bs-secondary); text-transform: uppercase; letter-spacing: 0.06em; min-width: 60px; padding-top: 1px; }
.tud-club-row .c-value { font-weight: 500; color: var(--bs-dark); }


/* ============================================================
   PRINT
   ============================================================ */
@media print {
    body { background: #fff !important; padding-top: 0 !important; }
    .navbar, .k-grid-toolbar { display: none !important; }
    .k-grid-header th.k-header,
    .table thead th { background: #f8f9fa !important; color: #495057 !important; border-bottom: 1px solid #dee2e6 !important; }
}
