:root {
    --pg-bg: #F5F7FA;
    --pg-sidebar: #FFFFFF;
    --pg-primary: #0F172A;
    --pg-secondary: #1E293B;
    --pg-highlight: #0E9F6E;
    --pg-text: #111827;
    --pg-muted: #6B7280;
    --pg-border: #E5E7EB;
    --pg-card: #FFFFFF;
    --pg-soft: #F8FAFC;
    --pg-shadow: 0 18px 45px rgba(15, 23, 42, .06);
    --pg-shadow-soft: 0 10px 24px rgba(15, 23, 42, .045);
    
    --primary-color: #0E9F6E;
    --primary-rgb: 14, 159, 110;

    /* Centralized Typography Scale variables */
    --pg-font-xs: 11px;
    --pg-font-sm: 12px;
    --pg-font-md: 13px;
    --pg-font-lg: 14px;
    --pg-font-xl: 16px;
    --pg-font-2xl: 18px;
    --pg-font-3xl: 22px;
    --pg-font-4xl: 26px;
    --pg-font-5xl: 30px;
}

/* Centralized Typography Scale Overrides */
html {
    font-size: 14px !important;
}

h1, .h1 { font-size: var(--pg-font-5xl) !important; }
h2, .h2 { font-size: var(--pg-font-4xl) !important; }
h3, .h3 { font-size: var(--pg-font-3xl) !important; }
h4, .h4 { font-size: var(--pg-font-2xl) !important; }
h5, .h5 { font-size: var(--pg-font-xl) !important; }
h6, .h6 { font-size: var(--pg-font-lg) !important; }

/* Form Controls and Labels overrides */
.form-control, .form-select {
    font-size: var(--pg-font-lg) !important;
}
.form-floating > label {
    font-size: var(--pg-font-sm) !important;
}
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-select ~ label {
    transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem) !important;
    font-size: var(--pg-font-sm) !important;
}

/* Helper Text and small prints */
.form-text, .text-muted, small, .small, .eyebrow {
    font-size: var(--pg-font-xs) !important;
}

/* Global table overrides */
.table th, .table td {
    font-size: var(--pg-font-sm) !important;
}

/* Button font sizing overrides */
.btn {
    font-size: var(--pg-font-lg) !important;
}
.btn-sm, .btn-link {
    font-size: var(--pg-font-sm) !important;
}

* {
    letter-spacing: 0;
}

body {
    background: var(--pg-bg);
    color: var(--pg-text);
    font-family: "Montserrat", system-ui, -apple-system, "Segoe UI", sans-serif;
    font-size: var(--pg-font-lg);
}

a {
    color: var(--pg-primary);
    text-decoration: none;
}

a:hover {
    color: var(--pg-highlight);
}

.login-page {
    min-height: 100vh;
    background: #EEF2F7;
    padding: 18px;
}

.login-shell {
    background: #fff;
    border: 1px solid rgba(229, 231, 235, .78);
    border-radius: 28px;
    box-shadow: 0 28px 70px rgba(15, 23, 42, .09);
    display: grid;
    grid-template-columns: minmax(390px, 45%) minmax(470px, 55%);
    min-height: calc(100vh - 36px);
    margin: 0 auto;
    overflow: hidden;
}

.login-visual {
    background: #07111F;
    color: #fff;
    display: flex;
    flex-direction: column;
    isolation: isolate;
    overflow: hidden;
    padding: clamp(36px, 5vw, 62px);
    position: relative;
}

.login-light {
    pointer-events: none;
    position: absolute;
    z-index: -1;
}

.login-light-one {
    background: radial-gradient(ellipse at center, rgba(37, 99, 235, .45) 0%, rgba(37, 99, 235, .12) 38%, transparent 70%);
    height: 74%;
    left: -24%;
    top: 18%;
    width: 112%;
}

.login-light-two {
    background: radial-gradient(ellipse at center, rgba(14, 159, 110, .24) 0%, rgba(14, 159, 110, .04) 45%, transparent 72%);
    bottom: -28%;
    height: 62%;
    right: -28%;
    width: 116%;
}

.login-grid {
    background-image: linear-gradient(rgba(148, 163, 184, .045) 1px, transparent 1px), linear-gradient(90deg, rgba(148, 163, 184, .045) 1px, transparent 1px);
    background-size: 56px 56px;
    bottom: 0;
    left: 0;
    mask-image: linear-gradient(to top, #000 0%, transparent 72%);
    opacity: .72;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 36%;
    z-index: -1;
}

.login-visual-brand img {
    height: 48px;
    max-width: min(245px, 100%);
}

.login-visual-brand span,
.login-mobile-brand span {
    color: rgba(226, 232, 240, .72);
    display: block;
    font-size: .68rem;
    font-weight: 600;
    margin: 9px 0 0 3px;
    text-transform: uppercase;
}

.login-visual-copy {
    margin: auto 0;
    max-width: 500px;
    padding: 64px 0 72px;
}

.login-kicker {
    border: 1px solid rgba(148, 163, 184, .22);
    border-radius: 999px;
    color: #A7F3D0;
    display: inline-block;
    font-size: .68rem;
    font-weight: 600;
    margin-bottom: 22px;
    padding: 8px 13px;
    text-transform: uppercase;
}

.login-visual-copy h1 {
    color: #fff;
    font-size: clamp(2.1rem, 3.1vw, 3rem);
    font-weight: 700;
    line-height: 1.14;
    margin-bottom: 20px;
}

.login-visual-copy p {
    color: #A8B4C8;
    font-size: .94rem;
    font-weight: 400;
    line-height: 1.78;
    margin: 0;
    max-width: 450px;
}

.login-capabilities {
    border-top: 1px solid rgba(148, 163, 184, .16);
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    padding-top: 22px;
}

.login-capabilities span {
    align-items: center;
    color: #B8C4D7;
    display: inline-flex;
    font-size: .72rem;
    font-weight: 500;
    gap: 8px;
}

.login-capabilities i {
    color: #5EEAD4;
    font-size: .9rem;
}

.login-form-pane {
    align-items: center;
    background: #F8FAFC;
    display: flex;
    justify-content: center;
    padding: clamp(34px, 6vw, 50px);
}

.login-card {
    background: #fff;
    border: 1px solid rgba(229, 231, 235, .82);
    border-radius: 24px;
    box-shadow: 0 20px 54px rgba(15, 23, 42, .065);
    padding: clamp(32px, 4vw, 46px);
    width: min(550px, 100%);
}

.login-mobile-brand {
    margin-bottom: 30px;
}

.login-mobile-brand img {
    height: 44px;
    max-width: 100%;
}

.login-mobile-brand span {
    color: var(--pg-muted);
}

.login-card-heading > span {
    color: var(--pg-highlight);
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    margin-bottom: 12px;
    text-transform: uppercase;
}

.login-card-heading h2 {
    color: var(--pg-text);
    font-size: 1.72rem;
    font-weight: 700;
    margin-bottom: 10px;
}

.login-card-heading p {
    color: var(--pg-muted);
    font-size: .84rem;
    line-height: 1.7;
    margin-bottom: 30px;
}

.login-alert {
    border: 0;
    border-radius: 13px;
    font-size: .81rem;
    margin-bottom: 20px;
    padding: 12px 14px;
}

.login-field {
    position: relative;
}

.login-field i {
    color: #8A94A6;
    font-size: 1rem;
    left: 18px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.login-page .form-label {
    color: #374151;
    font-size: .78rem;
    margin-bottom: 10px;
}

.login-page .login-field .form-control {
    background: #FAFBFC;
    border: 1px solid #E5E7EB;
    border-radius: 999px;
    font-size: .86rem;
    height: 54px;
    min-height: 54px;
    padding: 0 20px 0 48px;
}

.login-page .login-field .form-control::placeholder {
    color: #A3ACBB;
}

.login-page .login-field .form-control:focus {
    background: #fff;
    border-color: rgba(14, 159, 110, .42);
    box-shadow: 0 0 0 .25rem rgba(14, 159, 110, .08);
}

.login-options {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin: 22px 0 30px;
}

.login-options .form-check-label,
.login-options a {
    color: var(--pg-muted);
    font-size: .76rem;
    font-weight: 500;
}

.login-options a:hover {
    color: var(--pg-highlight);
}

.login-options .form-check-input {
    border-color: #CBD5E1;
    margin-top: .14rem;
}

.login-options .form-check-input:checked {
    background-color: var(--pg-highlight);
    border-color: var(--pg-highlight);
}

.login-submit {
    align-items: center;
    background: var(--pg-primary);
    border: 1px solid var(--pg-primary);
    border-radius: 999px;
    box-shadow: 0 14px 25px rgba(15, 23, 42, .16);
    color: #fff;
    display: flex;
    font-size: .87rem;
    gap: 8px;
    height: 54px;
    justify-content: center;
}

.login-submit:hover,
.login-submit:focus {
    background: var(--pg-secondary);
    border-color: var(--pg-secondary);
    box-shadow: 0 16px 30px rgba(15, 23, 42, .2);
    color: #fff;
}

.login-security {
    align-items: center;
    color: #94A3B8;
    display: flex;
    font-size: .71rem;
    font-weight: 500;
    gap: 7px;
    justify-content: center;
    margin-top: 28px;
}

.login-access-menu {
    border: 1px solid #E5E7EB;
    border-radius: 16px;
    margin-top: 18px;
    overflow: hidden;
}

.login-access-menu summary {
    align-items: center;
    color: #64748B;
    cursor: pointer;
    display: flex;
    font-size: .75rem;
    font-weight: 600;
    gap: 9px;
    justify-content: center;
    list-style: none;
    min-height: 44px;
    padding: 0 14px;
    transition: background .18s ease, color .18s ease;
}

.login-access-menu summary::-webkit-details-marker {
    display: none;
}

.login-access-menu summary .bi-chevron-down {
    font-size: .67rem;
    margin-left: auto;
    transition: transform .18s ease;
}

.login-access-menu summary:hover {
    background: #F8FAFC;
    color: var(--pg-primary);
}

.login-access-menu[open] summary .bi-chevron-down {
    transform: rotate(180deg);
}

.login-access-list {
    border-top: 1px solid #EEF1F5;
    display: grid;
    gap: 7px;
    padding: 9px;
}

.login-access-item {
    align-items: center;
    background: #F8FAFC;
    border: 1px solid transparent;
    border-radius: 11px;
    color: var(--pg-text);
    display: grid;
    gap: 9px;
    grid-template-columns: 67px 1fr 16px;
    padding: 8px 10px;
    text-align: left;
    transition: background .18s ease, border-color .18s ease;
}

.login-access-item:hover {
    background: #fff;
    border-color: #DCE5EF;
}

.login-access-role {
    background: #EFF6FF;
    border-radius: 999px;
    color: #2563EB;
    font-size: .63rem;
    font-weight: 700;
    padding: 5px 8px;
    text-align: center;
    text-transform: uppercase;
}

.login-access-role.operator {
    background: #ECFDF5;
    color: #047857;
}

.login-access-item strong,
.login-access-item small {
    display: block;
    font-size: .7rem;
}

.login-access-item strong {
    font-weight: 700;
}

.login-access-item small {
    color: var(--pg-muted);
    margin-top: 2px;
}

.login-access-item > i {
    color: #94A3B8;
}

.brand {
    color: var(--pg-text);
    display: flex;
    gap: 12px;
    align-items: center;
    text-decoration: none;
    margin: 22px 18px 24px;
}

.brand:hover {
    color: var(--pg-text);
}

.brand-mark {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    background: linear-gradient(145deg, #0E9F6E, #087f5b);
    color: #fff;
    border-radius: 12px;
    font-weight: 700;
    box-shadow: 0 10px 20px rgba(14, 159, 110, .22);
}

.brand strong {
    display: block;
    font-size: 1rem;
    font-weight: 700;
}

.brand small {
    display: block;
    color: var(--pg-muted);
    line-height: 1.1;
    font-size: .74rem;
    font-weight: 500;
}

.app-shell {
    min-height: 100vh;
    display: flex;
}

.sidebar,
.mobile-menu {
    background: var(--pg-sidebar);
    color: var(--pg-text);
}

.sidebar {
    width: 260px;
    flex: 0 0 260px;
    height: 100vh;
    min-height: 100vh;
    position: sticky;
    top: 0;
    display: flex;
    flex-direction: column;
    border-right: 1px solid rgba(229, 231, 235, .75);
    box-shadow: 8px 0 28px rgba(15, 23, 42, .025);
    isolation: isolate;
    overflow: hidden;
    transition: width 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 30;
}

.mobile-menu {
    border-right: 1px solid var(--pg-border);
}

.sidebar-nav {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    flex: 1;
    flex-basis: 0;
    min-height: 0;
    padding: 0 14px 24px;
    overflow-y: auto;
    overflow-x: hidden;
    contain: layout paint;
    scrollbar-color: #CBD5E1 transparent;
    scrollbar-width: thin;
    transition: padding 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-nav::-webkit-scrollbar {
    width: 6px;
}

.sidebar-nav::-webkit-scrollbar-track {
    background: transparent;
}

.sidebar-nav::-webkit-scrollbar-thumb {
    background: #CBD5E1;
    border-radius: 999px;
}

.sidebar-section {
    color: #8A94A6;
    flex: 0 0 auto;
    font-size: var(--pg-font-xs);
    font-weight: 700;
    margin: 10px 12px 8px;
    white-space: nowrap;
    transition: opacity 0.2s ease, margin 0.2s ease, height 0.2s ease;
}

/* Sidebar Brand Header Layout */
.brand-wrapper {
    position: relative;
    padding: 22px 18px 24px;
    transition: padding 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.brand-full, .brand-collapsed {
    transition: opacity 0.2s ease;
}

/* Collapse Toggle Button Styling */
.sidebar-collapse-btn {
    position: fixed;
    left: 260px;
    top: 42px;
    transform: translate(-50%, -50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #FFFFFF;
    border: 1px solid var(--pg-border);
    box-shadow: 0 4px 10px rgba(15, 23, 42, 0.08);
    display: grid;
    place-items: center;
    cursor: pointer;
    color: var(--pg-muted);
    font-size: 0.85rem;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 45;
}

.sidebar-collapse-btn:hover {
    color: var(--pg-primary);
    background: var(--pg-soft);
    border-color: #CBD5E1;
    transform: translate(-50%, -50%) scale(1.05);
}

.sidebar-collapse-btn i {
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Collapsed Sidebar Rules */
.sidebar-collapsed .sidebar {
    width: 78px;
    flex-basis: 78px;
}

.sidebar-collapsed .sidebar-collapse-btn {
    left: 78px;
}

.sidebar-collapsed .brand-wrapper {
    padding: 22px 8px 24px;
}

.sidebar-collapsed .brand-full {
    display: none !important;
}

.sidebar-collapsed .brand-collapsed {
    display: block !important;
}

.sidebar-collapsed .sidebar-collapse-btn i {
    transform: rotate(180deg);
}

.sidebar-collapsed .sidebar-section {
    opacity: 0;
    height: 0;
    margin: 0;
    overflow: hidden;
}

.sidebar-collapsed .sidebar-nav {
    padding: 0 8px 24px;
}

.sidebar-collapsed .sidebar-nav .nav-link {
    justify-content: center;
    padding: 10px 0;
    gap: 0;
    margin: 4px 0;
    transform: none;
}

.sidebar-collapsed .sidebar-nav .nav-link span,
.sidebar-collapsed .sidebar-nav .nav-link .bi-chevron-down {
    display: none !important;
}

.sidebar-collapsed .sidebar-nav .nav-link i:first-child {
    margin: 0;
    font-size: 1.2rem;
}

.sidebar-collapsed .sidebar-nav .nav-link.active::before {
    background: var(--pg-highlight);
    border-radius: 0 6px 6px 0;
    content: "";
    height: 22px;
    left: -8px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
}

.sidebar-collapsed .sidebar-submenu {
    display: none !important;
}

.sidebar-nav .nav-link {
    color: #404B5F;
    flex: 0 0 auto;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 11px;
    min-height: 42px;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    padding: 10px 12px;
    border: 0;
    background: transparent;
    text-align: left;
    width: 100%;
    font-weight: 500;
    font-size: var(--pg-font-md);
    position: relative;
    transition: background .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.sidebar-nav .nav-link i:first-child {
    font-size: var(--pg-font-xl);
    color: #64748B;
}

.sidebar-nav .nav-link:hover,
.sidebar-nav .nav-link:focus {
    background: #F3F5F8;
    color: var(--pg-primary);
    transform: none;
}

.sidebar-nav .nav-link.active {
    background: rgba(14, 159, 110, 0.08);
    color: #0E9F6E;
    border-left: 3px solid #0E9F6E;
    border-radius: 0 8px 8px 0;
    font-weight: 600;
    box-shadow: none;
}

.sidebar-nav .nav-link.active i {
    color: #0E9F6E;
}

/* Active Parent styling: light brand background, left accent border, green text, and medium font weight */
.sidebar-nav .nav-link.sidebar-toggle.active {
    background: rgba(var(--primary-rgb), 0.08) !important;
    color: var(--primary-color) !important;
    border-left: 3px solid var(--primary-color) !important;
    border-radius: 0 8px 8px 0 !important;
    font-weight: 600 !important;
}
.sidebar-nav .nav-link.sidebar-toggle.active i:first-child {
    color: var(--primary-color) !important;
}

/* Expanded Parent Category header styling (only normal text color when expanded, unless active) */
.sidebar-nav .nav-link.sidebar-toggle[aria-expanded="true"] {
    color: #404B5F;
    font-weight: 600;
}
.sidebar-nav .nav-link.sidebar-toggle[aria-expanded="true"] i:first-child {
    color: #64748B;
}

/* If parent is both active and expanded, keep the active text/icon color */
.sidebar-nav .nav-link.sidebar-toggle.active[aria-expanded="true"] {
    color: var(--primary-color) !important;
}
.sidebar-nav .nav-link.sidebar-toggle.active[aria-expanded="true"] i:first-child {
    color: var(--primary-color) !important;
}

/* Active Child leaf styling: highlighted background, brand text, rounded corners, and NO left border */
.sidebar-submenu .nav-link.active {
    background: rgba(var(--primary-rgb), 0.12) !important;
    color: var(--primary-color) !important;
    border-left: 0 !important;
    border-radius: 8px !important;
    font-weight: 600 !important;
}
.sidebar-submenu .nav-link.active i:first-child {
    color: var(--primary-color) !important;
}

/* Dynamic chevron rotation */
.sidebar-toggle .bi-chevron-down {
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.sidebar-toggle[aria-expanded="true"] .bi-chevron-down {
    transform: rotate(180deg);
}

.sidebar-submenu {
    padding-left: 18px;
    margin: 3px 0 8px;
    max-width: 100%;
}

.sidebar-submenu .nav-link {
    min-height: 34px;
    font-size: var(--pg-font-sm);
    padding: 8px 12px;
    color: var(--pg-muted);
}

.sidebar-nav .nav-link span {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sidebar-nav .nav-link i {
    flex: 0 0 auto;
}

.sidebar-tooltip .tooltip-inner {
    background: var(--pg-primary);
    border-radius: 9px;
    box-shadow: 0 9px 20px rgba(15, 23, 42, .14);
    font-family: "Montserrat", system-ui, sans-serif;
    font-size: .72rem;
    font-weight: 500;
    padding: 8px 11px;
}

.app-main {
    flex: 1;
    min-width: 0;
    position: relative;
}

.topbar {
    min-height: 76px;
    background: rgba(255, 255, 255, .92);
    border-bottom: 1px solid rgba(229, 231, 235, .72);
    backdrop-filter: blur(16px);
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 0 28px;
    position: sticky;
    top: 0;
    z-index: 20;
}

.breadcrumb-wrap {
    align-items: center;
    gap: 10px;
    color: var(--pg-muted);
    font-size: .8rem;
    font-weight: 500;
    min-width: 190px;
}

.breadcrumb-wrap a,
.breadcrumb-wrap span {
    color: var(--pg-muted);
}

.breadcrumb-wrap i {
    font-size: .72rem;
}

.content-area {
    padding: 10px 20px;
}

.global-search {
    position: relative;
    max-width: 460px;
}

.global-search > i {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: #8A94A6;
    z-index: 2;
}

.global-search .form-control {
    height: 44px;
    padding-left: 42px;
    border-radius: 14px;
    border-color: var(--pg-border);
    background: #F9FAFB;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .75);
}

.global-search .form-control:focus {
    background: #fff;
    border-color: rgba(14, 159, 110, .36);
    box-shadow: 0 0 0 .25rem rgba(14, 159, 110, .08);
}

.search-results {
    position: absolute;
    inset: calc(100% + 8px) 0 auto 0;
    background: #fff;
    border: 1px solid var(--pg-border);
    border-radius: 16px;
    display: none;
    overflow: hidden;
    z-index: 40;
    box-shadow: var(--pg-shadow-soft);
}

.search-results a {
    display: block;
    padding: 12px 16px;
    color: var(--pg-text);
    text-decoration: none;
}

.search-results a:hover {
    background: #F8FAFC;
}

.topbar-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 10px;
}

.user-pill {
    background: transparent;
    border: 0;
    border-radius: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 48px;
    padding: 5px 6px 5px 8px;
    white-space: nowrap;
    transition: background .18s ease;
}

.user-pill:hover,
.user-pill[aria-expanded="true"] {
    background: #F3F5F8;
}

.user-pill-details strong,
.user-pill-details small {
    display: block;
    text-align: left;
}

.user-pill-details strong {
    font-size: .84rem;
    font-weight: 700;
}

.user-pill-details small {
    color: var(--pg-muted);
    font-size: .72rem;
}

.user-pill-caret {
    color: #94A3B8;
    font-size: .66rem;
    margin: 0 5px 0 2px;
    transition: transform .18s ease;
}

.user-pill[aria-expanded="true"] .user-pill-caret {
    transform: rotate(180deg);
}

.avatar {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: #ECFDF5;
    color: #047857;
    font-weight: 700;
}

.account-menu {
    border: 1px solid var(--pg-border);
    border-radius: 16px;
    box-shadow: var(--pg-shadow-soft);
    margin-top: 9px !important;
    min-width: 218px;
    padding: 7px;
}

.account-menu-heading {
    border-bottom: 1px solid #EEF1F5;
    margin: 0 4px 6px;
    padding: 8px 9px 12px;
}

.account-menu-heading strong,
.account-menu-heading small {
    display: block;
}

.account-menu-heading strong {
    color: var(--pg-text);
    font-size: .8rem;
    font-weight: 700;
}

.account-menu-heading small {
    color: var(--pg-muted);
    font-size: .7rem;
    margin-top: 3px;
}

.account-menu .dropdown-item {
    align-items: center;
    border-radius: 10px;
    color: #374151;
    display: flex;
    font-size: .8rem;
    font-weight: 500;
    gap: 10px;
    padding: 10px;
}

.account-menu .dropdown-item:hover {
    background: #F8FAFC;
    color: var(--pg-primary);
}

.account-menu .dropdown-divider {
    border-color: #EEF1F5;
    margin: 6px 4px;
}

.account-menu .account-logout:hover {
    background: #FEF2F2;
    color: #B91C1C;
}

.page-heading {
    margin-bottom: 22px;
}

.eyebrow {
    display: inline-block;
    color: var(--pg-highlight);
    font-size: .72rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.page-title {
    font-weight: 700;
    color: var(--pg-text);
}

.text-muted {
    color: var(--pg-muted) !important;
}

.stat-card,
.panel-card,
.receipt-box {
    background: var(--pg-card);
    border: 1px solid rgba(229, 231, 235, .82);
    border-radius: 20px;
    box-shadow: var(--pg-shadow-soft);
}

.stat-card {
    padding: 20px;
    min-height: 150px;
    transition: transform .18s ease, box-shadow .18s ease;
}

.stat-card:hover,
.panel-card:hover {
    /* transform: translateY(0px); */
    /* box-shadow: var(--pg-shadow); */
}

.stat-card .icon {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: #F0FDF4;
    color: var(--pg-highlight);
    font-size: 1.12rem;
}

.stat-label {
    color: var(--pg-muted);
    font-size: .82rem;
    font-weight: 600;
}

.stat-value {
    font-size: 1.85rem;
    line-height: 1.1;
    font-weight: 700;
    margin: 12px 0;
}

.trend-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: #ECFDF5;
    color: #047857;
    border-radius: 999px;
    padding: 5px 9px;
    font-size: .72rem;
    font-weight: 700;
}

.trend-pill.muted {
    background: #F3F4F6;
    color: #4B5563;
}

.stat-card.compact {
    min-height: 142px;
    padding: 18px;
}

.stat-card.compact .stat-value {
    margin: 14px 0 9px;
    font-size: 1.7rem;
}

.stat-card.compact .stat-value.amount {
    font-size: 1.42rem;
}

.stat-card.compact .icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
}

.stat-card.source-online-stat {
    border-color: #D7E7FF;
}

.stat-card.source-online-stat .icon,
.trend-pill.online {
    background: #EFF6FF;
    color: #2563EB;
}

.stat-card .icon.outlet {
    background: #ECFDF5;
    color: #047857;
}

.stat-card .icon.pending,
.trend-pill.pending {
    background: #FFF7ED;
    color: #C2410C;
}

.stat-card .icon.revenue {
    background: #ECFDF5;
    color: #0E9F6E;
}

.source-badge {
    align-items: center;
    border-radius: 999px;
    display: inline-flex;
    font-size: .72rem;
    font-weight: 700;
    gap: 6px;
    padding: 6px 10px;
    white-space: nowrap;
}

.source-website { background: #EFF6FF; color: #2563EB; }
.source-outlet { background: #ECFDF5; color: #047857; }
.source-admin { background: #F5F3FF; color: #6D28D9; }
.source-whatsapp { background: #FFF7ED; color: #C2410C; }

.source-summary {
    background: #F8FAFC;
    border: 1px solid var(--pg-border);
    border-radius: 999px;
    color: var(--pg-muted);
    font-size: .76rem;
    font-weight: 600;
    padding: 8px 12px;
}

.source-overview {
    display: grid;
    gap: 18px;
}

.source-overview-row {
    align-items: center;
    display: grid;
    gap: 14px;
    grid-template-columns: 126px minmax(90px, 1fr) 42px;
}

.source-overview-label {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.source-overview-label strong {
    color: var(--pg-text);
    font-size: .88rem;
}

.source-meter {
    background: #F1F5F9;
    border-radius: 999px;
    height: 8px;
    overflow: hidden;
}

.source-meter span {
    border-radius: inherit;
    display: block;
    height: 100%;
    min-width: 0;
}

.source-meter-website { background: #3B82F6; }
.source-meter-outlet { background: #0E9F6E; }
.source-meter-admin { background: #8B5CF6; }
.source-meter-whatsapp { background: #F97316; }

.source-overview-row small {
    color: var(--pg-muted);
    font-size: .75rem;
    font-weight: 600;
    text-align: right;
}

.online-ticket-list {
    padding: 10px 12px 14px;
}

.online-ticket-item {
    align-items: center;
    border-radius: 14px;
    color: var(--pg-text);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    padding: 12px;
    transition: background .18s ease;
}

.online-ticket-item:hover {
    background: #F8FAFC;
    color: var(--pg-text);
}

.online-ticket-item strong,
.online-ticket-item span:not(.status-badge) {
    display: block;
}

.online-ticket-item strong {
    font-size: .82rem;
    margin-bottom: 3px;
}

.online-ticket-item span:not(.status-badge) {
    color: var(--pg-muted);
    font-size: .76rem;
}

.dashboard-filter-tabs {
    margin-left: auto;
}

.dashboard-ticket-table {
    max-height: 630px;
}

.dashboard-ticket-table .table {
    min-width: 1020px;
}

.dashboard-ticket-table td {
    font-size: .83rem;
}

.activity-card {
    height: 100%;
}

.activity-feed {
    display: grid;
    gap: 3px;
    padding: 14px;
}

.activity-item {
    align-items: flex-start;
    border-radius: 14px;
    display: flex;
    gap: 11px;
    padding: 10px;
}

.activity-item:hover {
    background: #F8FAFC;
}

.activity-icon {
    align-items: center;
    background: #F3F4F6;
    border-radius: 10px;
    color: #475569;
    display: inline-flex;
    flex: none;
    height: 35px;
    justify-content: center;
    width: 35px;
}

.activity-online { background: #EFF6FF; color: #2563EB; }
.activity-payment { background: #ECFDF5; color: #047857; }
.activity-completed { background: #ECFDF5; color: #0E9F6E; }

.activity-item strong,
.activity-item span,
.activity-item small {
    display: block;
}

.activity-item strong {
    color: var(--pg-text);
    font-size: .78rem;
}

.activity-item span,
.activity-item small {
    color: var(--pg-muted);
    font-size: .72rem;
    margin-top: 2px;
}

.panel-card {
    transition: transform .18s ease, box-shadow .18s ease;
}

.panel-header {
    padding: 20px 22px;
    border-bottom: 1px solid var(--pg-border);
}

.panel-header h2,
.panel-card h2 {
    font-weight: 700;
}

.quick-action {
    min-height: 54px;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 14px;
    border: 1px solid var(--pg-border);
    border-radius: 16px;
    color: var(--pg-text);
    font-weight: 600;
    background: #fff;
    transition: background .18s ease, border-color .18s ease, transform .18s ease;
}

.quick-action i:first-child {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 11px;
    background: #F0FDF4;
    color: var(--pg-highlight);
}

.quick-action:hover {
    background: #F8FAFC;
    border-color: #D1D5DB;
    transform: translateX(2px);
}

.btn {
    border-radius: 13px;
    font-weight: 600;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}

.btn:hover {
    transform: translateY(-1px);
}

.btn-primary {
    --bs-btn-bg: var(--pg-primary);
    --bs-btn-border-color: var(--pg-primary);
    --bs-btn-hover-bg: var(--pg-secondary);
    --bs-btn-hover-border-color: var(--pg-secondary);
    box-shadow: 0 12px 24px rgba(15, 23, 42, .13);
}

.btn-outline-primary {
    --bs-btn-color: var(--pg-primary);
    --bs-btn-border-color: var(--pg-border);
    --bs-btn-hover-bg: var(--pg-primary);
    --bs-btn-hover-border-color: var(--pg-primary);
}

.btn-gold {
    background: var(--pg-highlight);
    border-color: var(--pg-highlight);
    color: #fff;
    font-weight: 700;
}

.btn-gold:hover {
    background: #087f5b;
    border-color: #087f5b;
    color: #fff;
}

.btn-icon {
    width: 42px;
    height: 42px;
    min-height: 42px;
    display: grid;
    place-items: center;
    border: 1px solid var(--pg-border);
    background: #fff;
    border-radius: 14px;
    color: var(--pg-primary);
    box-shadow: 0 8px 18px rgba(15, 23, 42, .035);
}

.form-label {
    color: #374151;
    font-weight: 600;
    margin-bottom: 8px;
}

.form-control,
.form-select {
    background-color: #fff;
    border-radius: 14px;
    border-color: var(--pg-border);
    min-height: 46px;
    font-weight: 500;
    color: var(--pg-text);
    transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5.5 7.5L10 12L14.5 7.5' stroke='%230F172A' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-position: right 1rem center;
    background-repeat: no-repeat;
    background-size: 18px 18px;
    padding-right: 2.85rem;
}

.form-select:hover,
.form-control:hover,
.classy-date-input:hover {
    border-color: #CBD5E1;
}

.form-floating > .form-control,
.form-floating > .form-select {
    min-height: 58px;
    padding-top: 1.55rem;
}

.form-floating > label {
    color: var(--pg-muted);
    font-weight: 600;
    padding: 1rem .95rem;
}

.form-floating > textarea.form-control {
    min-height: 124px;
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(14, 159, 110, .42);
    box-shadow: 0 0 0 .25rem rgba(14, 159, 110, .08);
}

.form-control[readonly] {
    background: #FBFCFE;
    border-color: #E7EBF0;
}

.classy-date-input {
    background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.5 2.5V5.5M13.5 2.5V5.5M3.25 8.25H16.75M5.25 4H14.75C15.8546 4 16.75 4.89543 16.75 6V15.25C16.75 16.3546 15.8546 17.25 14.75 17.25H5.25C4.14543 17.25 3.25 16.3546 3.25 15.25V6C3.25 4.89543 4.14543 4 5.25 4Z' stroke='%230F172A' stroke-width='1.55' stroke-linecap='round'/%3E%3C/svg%3E");
    background-position: right 1rem center;
    background-repeat: no-repeat;
    background-size: 18px 18px;
    padding-right: 2.85rem;
}

.flatpickr-calendar.progro-calendar {
    border: 1px solid rgba(229, 231, 235, .92);
    border-radius: 20px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, .16);
    font-family: "Montserrat", system-ui, sans-serif;
    overflow: hidden;
    padding: 10px;
    width: 320px;
    z-index: 1095;
}

.progro-calendar::before,
.progro-calendar::after {
    display: none;
}

.progro-calendar .flatpickr-months {
    align-items: center;
    padding: 4px 4px 10px;
}

.progro-calendar .flatpickr-month,
.progro-calendar .flatpickr-current-month {
    color: var(--pg-primary);
    fill: var(--pg-primary);
    height: 40px;
}

.progro-calendar .flatpickr-current-month {
    align-items: center;
    display: flex;
    font-size: .95rem;
    font-weight: 700;
    justify-content: center;
    left: 36px;
    padding: 0;
    width: calc(100% - 72px);
}

.progro-calendar .flatpickr-current-month input.cur-year,
.progro-calendar .flatpickr-current-month .numInputWrapper {
    font-weight: 700;
}

.progro-calendar .flatpickr-prev-month,
.progro-calendar .flatpickr-next-month {
    align-items: center;
    border: 1px solid #E5E7EB;
    border-radius: 12px;
    color: var(--pg-primary);
    display: grid;
    height: 34px;
    justify-content: center;
    padding: 0;
    top: 14px;
    width: 34px;
}

.progro-calendar .flatpickr-prev-month:hover,
.progro-calendar .flatpickr-next-month:hover {
    background: #F8FAFC;
    color: var(--pg-highlight);
}

.progro-calendar .flatpickr-weekdays {
    height: 34px;
}

.progro-calendar span.flatpickr-weekday {
    color: #667085;
    font-size: .72rem;
    font-weight: 700;
}

.progro-calendar .flatpickr-days,
.progro-calendar .dayContainer {
    width: 300px;
}

.progro-calendar .flatpickr-day {
    border: 0;
    border-radius: 12px;
    color: #1F2937;
    font-size: .8rem;
    font-weight: 600;
    height: 38px;
    line-height: 38px;
    margin: 1px;
    max-width: 40px;
}

.progro-calendar .flatpickr-day:hover,
.progro-calendar .flatpickr-day:focus {
    background: #ECFDF5;
    color: #047857;
}

.progro-calendar .flatpickr-day.today {
    background: #F0FDF4;
    color: #047857;
}

.progro-calendar .flatpickr-day.selected,
.progro-calendar .flatpickr-day.startRange,
.progro-calendar .flatpickr-day.endRange {
    background: var(--pg-primary);
    box-shadow: 0 10px 18px rgba(15, 23, 42, .16);
    color: #fff;
}

.progro-calendar .flatpickr-day.prevMonthDay,
.progro-calendar .flatpickr-day.nextMonthDay {
    color: #A8B1C1;
}

textarea.form-control {
    min-height: 112px;
}

input[type="file"].form-control {
    padding: 12px;
    background: #F9FAFB;
    border-style: dashed;
}

.modal-content {
    border: 1px solid var(--pg-border);
    border-radius: 22px;
    box-shadow: var(--pg-shadow);
}

.modal {
    z-index: 1085;
}

.modal-backdrop {
    z-index: 1080;
}

.modal-header,
.modal-footer {
    border-color: var(--pg-border);
    padding: 18px 22px;
}

.modal-body {
    padding: 22px;
}

.table-responsive {
    border-radius: 0 0 20px 20px;
    overflow-x: auto;
}

.panel-card {
    overflow: hidden;
}

.table {
    color: var(--pg-text);
}

.table > :not(caption) > * > * {
    padding: 0.6rem 1.25rem;
    border-bottom-color: #EEF1F5;
}

.table thead th {
    color: var(--pg-muted);
    font-size: .74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: #FAFBFC !important;
    border-bottom: 1px solid var(--pg-border);
    position: sticky;
    top: 0;
    z-index: 5;
}

.table tbody tr {
    transition: background .18s ease, transform .15s ease;
}

.table tbody tr:hover {
    background: #FAFBFC;
}

.status-badge {
    border-radius: 999px;
    padding: 6px 12px;
    font-size: var(--pg-font-xs);
    font-weight: 700;
    display: inline-block;
}

.status-payment-received { background: #EFF6FF; color: #1D4ED8; }
.status-pending { background: #FEF3C7; color: #A16207; }
.status-under-review { background: #FFFBEB; color: #B45309; }
.status-in-process { background: #ECFDF5; color: #047857; }
.status-in-progress { background: #EFF6FF; color: #1D4ED8; }
.status-completed { background: #DCFCE7; color: #166534; }
.status-delivered { background: #F3F4F6; color: #374151; }
.status-rejected { background: #FEF2F2; color: #B91C1C; }
.status-failed { background: #FEF2F2; color: #B91C1C; }

.notification-count {
    position: absolute;
    top: -5px;
    right: -5px;
    display: grid;
    place-items: center;
    min-width: 19px;
    height: 19px;
    padding: 0 5px;
    border-radius: 999px;
    background: #EF4444;
    color: #fff;
    border: 2px solid #fff;
    font-size: .63rem;
    font-weight: 700;
}

.notification-menu {
    width: 330px;
    margin-top: 10px !important;
    padding: 8px;
    border-radius: 16px;
    border: 1px solid var(--pg-border);
    box-shadow: var(--pg-shadow);
}

.notification-heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 12px 12px;
    border-bottom: 1px solid var(--pg-border);
    font-weight: 700;
}

.notification-heading span {
    color: var(--pg-muted);
    font-size: .78rem;
}

.notification-item {
    display: flex;
    gap: 11px;
    align-items: flex-start;
    padding: 12px;
    border-radius: 12px;
    color: var(--pg-text);
}

.notification-item:hover {
    color: var(--pg-text);
    background: #F8FAFC;
}

.notification-item strong,
.notification-item small,
.notification-item em {
    display: block;
}

.notification-item small {
    color: var(--pg-muted);
    margin: 2px 0 5px;
}

.notification-item em {
    font-style: normal;
    font-size: .71rem;
    font-weight: 700;
}

.notification-item em.overdue { color: #B91C1C; }
.notification-item em.today { color: #C2410C; }
.notification-item em.tomorrow { color: #A16207; }
.notification-item em.soon { color: #047857; }

.notification-dot {
    width: 9px;
    height: 9px;
    margin-top: 5px;
    border-radius: 50%;
    flex: none;
}

.notification-dot.overdue { background: #EF4444; }
.notification-dot.today { background: #F97316; }
.notification-dot.tomorrow { background: #EAB308; }
.notification-dot.soon { background: #10B981; }

.notification-empty {
    padding: 24px 12px;
    color: var(--pg-muted);
    text-align: center;
}

/* Dynamic Table Search Styling */
.table-search-box {
    position: relative;
    max-width: 320px;
    width: 100%;
}
.table-search-box > i {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #8A94A6;
    z-index: 2;
}
.table-search-box .form-control {
    height: 40px;
    padding-left: 38px;
    border-radius: 12px;
    background: #F9FAFB;
    border: 1px solid var(--pg-border);
    font-size: 0.85rem;
    transition: all 0.18s ease;
}
.table-search-box .form-control:focus {
    background: #fff;
    border-color: rgba(14, 159, 110, .36);
    box-shadow: 0 0 0 0.2rem rgba(14, 159, 110, .08);
}

.ticket-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}

.date-filter-actions {
    display: flex;
    gap: 10px;
}

.date-range-inline-form {
    margin: 0;
}

.date-range-button-wrap {
    align-items: center;
    display: inline-flex;
    position: relative;
}

.date-range-button-wrap > i {
    color: #fff;
    left: 16px;
    pointer-events: none;
    position: absolute;
    z-index: 2;
}

.date-range-button {
    background: #2563EB;
    border: 1px solid #2563EB;
    border-radius: 13px;
    box-shadow: 0 12px 24px rgba(37, 99, 235, .18);
    color: #fff;
    cursor: pointer;
    font-weight: 700;
    min-height: 42px;
    min-width: 220px;
    padding: 9px 34px 9px 42px;
}

.date-range-button::placeholder {
    color: rgba(255, 255, 255, .92);
    opacity: 1;
}

.date-range-button:focus,
.date-range-button:hover {
    background: #1D4ED8;
    border-color: #1D4ED8;
    color: #fff;
    outline: 0;
}

.date-range-button-wrap::after {
    color: #fff;
    content: "\F282";
    font-family: "bootstrap-icons";
    font-size: .72rem;
    pointer-events: none;
    position: absolute;
    right: 15px;
}

.progro-range-calendar {
    z-index: 1100;
}

.calendar-action-row {
    border-top: 1px solid var(--pg-border);
    display: flex;
    gap: 10px;
    margin: 10px -10px -10px;
    padding: 12px;
}

.calendar-action-row .btn {
    flex: 1;
    min-height: 38px;
}

.ticket-filter-tabs {
    display: flex;
    gap: 5px;
    padding: 5px;
    border-radius: 14px;
    background: #F3F4F6;
    overflow-x: auto;
}

.ticket-filter-tabs button {
    border: 0;
    background: transparent;
    border-radius: 10px;
    color: var(--pg-muted);
    font-weight: 600;
    padding: 9px 14px;
    white-space: nowrap;
    transition: background .18s ease, color .18s ease, box-shadow .18s ease;
}

.ticket-filter-tabs button.active {
    background: var(--pg-primary);
    color: #fff;
    box-shadow: 0 8px 16px rgba(15, 23, 42, .16);
}

.ticket-search {
    max-width: 360px;
}

@media (max-width: 1199.98px) {
    .dashboard-filter-tabs {
        margin-left: 0;
        order: 3;
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .source-overview-row {
        grid-template-columns: 1fr 42px;
    }

    .source-overview-label {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }
}

.export-menu {
    min-width: 270px;
    padding: 8px;
    border: 1px solid var(--pg-border);
    border-radius: 15px;
    box-shadow: var(--pg-shadow-soft);
}

.export-group {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 8px;
    border-radius: 10px;
}

.export-group:hover {
    background: #F8FAFC;
}

.export-group span {
    flex: 1;
    color: #374151;
    font-size: .77rem;
    font-weight: 600;
}

.export-group a,
.export-group button {
    border: 1px solid var(--pg-border);
    border-radius: 8px;
    background: #fff;
    color: var(--pg-primary);
    font-size: .7rem;
    font-weight: 700;
    padding: 5px 7px;
}

.export-group a:hover,
.export-group button:hover {
    border-color: var(--pg-highlight);
    background: #ECFDF5;
    color: #047857;
}

.table-action-dropdown .dropdown-menu {
    border: 1px solid var(--pg-border);
    border-radius: 14px;
    box-shadow: var(--pg-shadow-soft);
    padding: 7px;
}

.table-action-dropdown .dropdown-item {
    align-items: center;
    border-radius: 9px;
    display: flex;
    font-size: .82rem;
    font-weight: 500;
    gap: 10px;
    padding: 9px 11px;
}

.table-action-dropdown .dropdown-item:hover {
    background: #F8FAFC;
}

.table-pagination {
    align-items: center;
    border-top: 1px solid var(--pg-border);
    display: flex;
    justify-content: space-between;
    gap: 14px;
    min-height: 58px;
    padding: 10px 20px;
}

.pagination-summary {
    color: var(--pg-muted);
    font-size: var(--pg-font-xs);
    font-weight: 500;
}

.pagination-controls {
    display: flex;
    gap: 6px;
}

.pagination-controls button,
.pagination-button {
    background: #fff;
    border: 1px solid var(--pg-border);
    border-radius: 8px;
    color: var(--pg-muted);
    font-size: var(--pg-font-xs);
    font-weight: 600;
    height: 34px;
    min-width: 34px;
    padding: 0 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
    cursor: pointer;
    user-select: none;
}

.pagination-controls button:not(.active):not(:disabled):hover,
.pagination-button:not(.active):not(:disabled):hover {
    background-color: #f8fafc;
    border-color: #cbd5e1;
    color: #0f172a;
}

.pagination-controls button.active,
.pagination-button.active {
    background: var(--pg-primary);
    border-color: var(--pg-primary);
    color: #fff;
    font-weight: 700;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.pagination-controls button:disabled,
.pagination-button:disabled {
    background-color: #f1f5f9;
    border-color: var(--pg-border);
    color: #94a3b8;
    cursor: not-allowed;
    opacity: 0.6;
}

.pagination-ellipsis {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 34px;
    min-width: 34px;
    font-size: .78rem;
    color: var(--pg-muted);
    font-weight: 600;
}

.page-size-selector {
    background-color: #fff;
    border: 1px solid var(--pg-border);
    border-radius: 8px;
    color: var(--pg-muted);
    font-size: .78rem;
    font-weight: 500;
    height: 34px;
    padding: 4px 10px;
    transition: all 0.2s;
    outline: none;
    width: 70px !important;
}

.page-size-selector:focus {
    border-color: var(--pg-primary);
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.1);
}


.receipt-box {
    max-width: 900px;
    margin: 0 auto;
    padding: 0;
    overflow: hidden;
}

.receipt-logo {
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: rgba(255, 255, 255, .16);
    color: #fff;
    font-weight: 700;
}

.receipt-invoice {
    --receipt-blue: #5169a8;
    --receipt-blue-deep: #405892;
    --receipt-pink: #ed5c80;
}

.receipt-hero {
    position: relative;
    background: var(--receipt-blue);
    color: #fff;
    border-radius: 20px 20px 42px 42px;
    padding: 34px 38px 58px;
    overflow: hidden;
}

.receipt-hero::after {
    content: "";
    position: absolute;
    right: -20px;
    top: -76px;
    width: 360px;
    height: 150px;
    background: rgba(255, 255, 255, .045);
    transform: rotate(-17deg);
}

.receipt-hero h1 {
    color: #fff;
    font-weight: 700;
}

.receipt-subtitle,
.receipt-meta div:last-child,
.receipt-info div:not(.receipt-meta-label):not(strong) {
    color: rgba(255, 255, 255, .78);
    font-size: .83rem;
}

.receipt-meta {
    position: relative;
    z-index: 1;
}

.receipt-meta strong {
    display: block;
    font-size: .98rem;
    margin: 4px 0;
}

.receipt-meta-label {
    color: rgba(255, 255, 255, .72);
    font-size: .68rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.receipt-info {
    position: relative;
    z-index: 1;
    margin-top: 38px;
}

.receipt-info strong {
    display: block;
    margin-bottom: 4px;
    font-size: .92rem;
}

.receipt-line-items {
    background: #fff;
    border-radius: 22px;
    box-shadow: 0 14px 35px rgba(15, 23, 42, .08);
    margin: -28px 32px 0;
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.receipt-line-items .table-responsive {
    border-radius: 22px;
}

.receipt-table > :not(caption) > * > * {
    padding: 1.25rem 1.4rem;
}

.receipt-table thead th {
    background: #F9FAFC !important;
    color: #536176;
    position: static;
}

.receipt-table tbody td {
    font-weight: 500;
}

.receipt-summary {
    padding: 32px 34px 6px;
}

.receipt-detail-panel {
    border: 1px solid #E5E7EB;
    border-radius: 16px;
    padding: 17px 20px;
    height: 100%;
}

.receipt-detail-panel .receipt-meta-label {
    color: #667289;
}

.receipt-detail-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    color: var(--pg-muted);
    padding: 6px 0;
}

.receipt-detail-row strong {
    color: var(--pg-text);
    text-align: right;
}

.receipt-total {
    background: var(--receipt-blue);
    border-radius: 15px;
    color: #fff;
    min-height: 66px;
    padding: 18px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
}

.receipt-total span {
    font-size: .78rem;
    font-weight: 600;
    color: rgba(255, 255, 255, .86);
}

.receipt-total strong {
    font-size: 1.1rem;
}

.receipt-actions {
    padding: 0 34px 28px;
}

.receipt-thanks {
    background: var(--receipt-blue);
    color: rgba(255, 255, 255, .92);
    text-align: center;
    padding: 11px;
    font-size: .78rem;
    font-weight: 500;
}

.receipt-actions .btn-outline-success {
    --bs-btn-color: var(--receipt-blue-deep);
    --bs-btn-border-color: #ced5e8;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--receipt-blue);
    --bs-btn-hover-border-color: var(--receipt-blue);
}

@media (max-width: 1199.98px) {
    .global-search {
        max-width: none;
    }
}

@media (max-width: 991.98px) {
    .login-page {
        padding: 16px;
    }

    .login-shell {
        display: block;
        min-height: calc(100vh - 32px);
    }

    .login-visual {
        display: none;
    }

    .login-form-pane {
        min-height: calc(100vh - 34px);
        padding: 28px 20px;
    }

    .topbar {
        padding: 14px;
        min-height: 72px;
        gap: 10px;
    }

    .content-area {
        padding: 18px;
    }

    .topbar-actions .btn-icon {
        display: none;
    }

    .user-pill-details,
    .user-pill-caret {
        display: none;
    }

    .user-pill {
        min-height: 42px;
        padding: 2px;
    }

    .brand {
        margin: 0;
    }
}

@media (max-width: 575.98px) {
    .login-page {
        background: #fff;
        padding: 0;
    }

    .login-shell {
        border: 0;
        border-radius: 0;
        box-shadow: none;
        min-height: 100vh;
    }

    .login-form-pane {
        background: #fff;
        min-height: 100vh;
        padding: 28px 18px;
    }

    .login-card {
        border: 0;
        box-shadow: none;
        padding: 20px 6px;
    }

    .content-area {
        padding: 14px;
    }

    .stat-card {
        min-height: 132px;
    }

    .receipt-box {
        padding: 0;
    }

    .receipt-hero {
        padding: 24px 20px 46px;
    }

    .receipt-info {
        margin-top: 25px;
    }

    .receipt-line-items {
        margin: -24px 14px 0;
    }

    .receipt-summary,
    .receipt-actions {
        padding-left: 18px;
        padding-right: 18px;
    }

    .ticket-filter-tabs,
    .ticket-search {
        max-width: none;
        width: 100%;
    }

    .table-pagination {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media print {
    .sidebar,
    .topbar,
    .receipt-actions {
        display: none !important;
    }

    .page-actions,
    .table .btn,
    .ticket-toolbar,
    .table-pagination {
        display: none !important;
    }

    .app-shell,
    .app-main {
        display: block;
    }

    body,
    .content-area {
        background: #fff;
        padding: 0;
    }

    .receipt-box {
        border: 0;
        box-shadow: none;
        max-width: 100%;
    }

    .receipt-hero,
    .receipt-total,
    .receipt-thanks {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    /* Hide generic letterhead header on the receipt ticket page to avoid duplicate logos */
    .page-receipt .print-brand-header {
        display: none !important;
    }
}

/* Reusable Sticky Columns Framework for Enterprise SaaS Tables */
.table-sticky-columns {
    position: relative;
    border-collapse: separate;
    border-spacing: 0;
}

.table-sticky-columns th,
.table-sticky-columns td {
    white-space: nowrap;
}

/* First Column Sticky (Ticket ID or key reference) */
.table-sticky-columns th:first-child,
.table-sticky-columns td:first-child {
    position: sticky;
    left: 0;
    z-index: 3;
    background-color: #FFFFFF !important;
    border-right: 1px solid var(--pg-border);
}

/* Ensure the standard thead background applies when first cell is sticky */
.table-sticky-columns thead th:first-child {
    z-index: 6;
    background-color: #FAFBFC !important;
}

/* Maintain active row highlights for sticky cells on hover */
.table-sticky-columns tbody tr:hover td:first-child {
    background-color: #FAFBFC !important;
}

/* Last Column Sticky (Actions or settings menu) */
.table-sticky-columns th:last-child,
.table-sticky-columns td:last-child {
    position: sticky;
    right: 0;
    z-index: 3;
    background-color: #FFFFFF !important;
    border-left: 1px solid var(--pg-border);
    box-shadow: -6px 0 12px rgba(15, 23, 42, 0.025);
}

.table-sticky-columns thead th:last-child {
    z-index: 6;
    background-color: #FAFBFC !important;
}

.table-sticky-columns tbody tr:hover td:last-child {
    background-color: #FAFBFC !important;
}

/* Stacking Context Fix for open dropdowns inside sticky columns */
.table-sticky-columns tbody tr:focus-within,
.table-sticky-columns tbody tr:has(.show),
.table-sticky-columns tbody tr.dropdown-active {
    z-index: 12 !important;
    position: relative;
}

.table-sticky-columns tbody tr:focus-within td,
.table-sticky-columns tbody tr:has(.show) td,
.table-sticky-columns tbody tr.dropdown-active td {
    z-index: 12 !important;
}

.table-sticky-columns tbody tr:focus-within td:last-child,
.table-sticky-columns tbody tr:has(.show) td:last-child,
.table-sticky-columns tbody tr.dropdown-active td:last-child,
.table-sticky-columns tbody td.dropdown-active {
    z-index: 15 !important;
}

/* Wrapper */
.pg-upload-field {
    position: relative;
    width: 100%;
}

/* Hide native input */
.pg-upload-input {
    position: absolute;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

/* Custom Upload Field */
.pg-upload-label {
    width: 100%;
    height: 58px;
    padding: 0 18px;
    border: 1px solid #d9dde5;
    border-radius: 14px;
    background: #fff;

    display: flex;
    align-items: center;
    justify-content: space-between;

    cursor: pointer;
    transition: all .25s ease;
}

/* Left Text */
.pg-upload-placeholder {
    font-size: 15px;
    font-weight: 500;
    color: #344054;
}

/* Right Text */
.pg-upload-file-name {
    font-size: 13px;
    color: #98a2b3;
    white-space: nowrap;
}

/* Hover */
.pg-upload-label:hover {
    border-color: #b7c0cd;
    background: #fafbfc;
}

/* Focus */
.pg-upload-input:focus + .pg-upload-label,
.pg-upload-input:active + .pg-upload-label {
    border-color: #16a34a;
    box-shadow: 0 0 0 4px rgba(22,163,74,.12);
}

/* File Selected */
.pg-upload-label.has-file {
    border-color: #16a34a;
    background: #f0fdf4;
}

/* Mobile Responsive Upload Redesign */
@media (max-width: 768px) {
    .pg-upload-field {
        margin: 12px 0 !important;
    }
    
    .pg-upload-label {
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        height: auto !important;
        min-height: 120px !important;
        padding: 24px 16px !important;
        border: 2px dashed #CBD5E1 !important;
        background: #F8FAFC !important;
        border-radius: 12px !important;
        transition: all 0.25s ease !important;
    }

    .pg-upload-label:hover {
        border-color: var(--pg-highlight) !important;
        background: #F0FDF4 !important;
    }
    
    .pg-upload-placeholder {
        font-size: 13px !important;
        font-weight: 700 !important;
        color: var(--pg-secondary) !important;
        margin-bottom: 6px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 6px !important;
    }
    
    .pg-upload-placeholder i {
        font-size: 1.8rem !important;
        color: #64748B !important;
        margin: 0 !important;
        display: block !important;
        transition: color 0.25s ease !important;
    }
    
    .pg-upload-label:hover .pg-upload-placeholder i {
        color: var(--pg-highlight) !important;
    }

    .pg-upload-file-name {
        font-size: 11px !important;
        color: #64748B !important;
        white-space: normal !important;
        word-break: break-word !important;
        overflow-wrap: break-word !important;
        line-height: 1.4 !important;
        margin-top: 4px !important;
    }
    
    /* File Selected State */
    .pg-upload-label.has-file {
        border: 2px solid #22c55e !important;
        background: #F0FDF4 !important;
    }
    
    .pg-upload-label.has-file .pg-upload-placeholder {
        color: #166534 !important;
    }
    
    .pg-upload-label.has-file .pg-upload-placeholder i {
        color: #22c55e !important;
    }
    
    .pg-upload-label.has-file .pg-upload-file-name {
        font-size: 13px !important;
        font-weight: 600 !important;
        color: #166534 !important;
        margin-top: 2px !important;
    }
    
    .pg-upload-label.has-file::after {
        content: "✓ Uploaded" !important;
        display: inline-block !important;
        font-size: 11px !important;
        font-weight: 700 !important;
        color: #166534 !important;
        background: #DCFCE7 !important;
        padding: 3px 10px !important;
        border-radius: 999px !important;
        margin-top: 10px !important;
        border: 1px solid #BBF7D0 !important;
    }
}

/* Locked Field Container - Sidebar Service Launcher */
.locked-field-container {
    background-color: var(--pg-soft);
    border: 1px solid var(--pg-border);
    border-radius: 12px;
    height: 58px;
    padding: 10px 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: all 0.2s ease;
}

.locked-field-container strong {
    font-size: 0.88rem;
    font-weight: 600;
    color: #1E293B;
    margin-top: 1px;
}

/* Split Layout & Sticky Payment Card */
.pg-split-layout {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

@media (min-width: 992px) {
    .pg-split-layout {
        display: grid;
        grid-template-columns: 7fr 3fr;
        gap: 24px;
        align-items: start;
    }
}

@media (min-width: 992px) {
    .ticket-sidebar {
        position: sticky;
        top: 24px;
        align-self: flex-start;
    }
}

/* ==========================================================================
   Page Action Toolbar Alignment & Height Standardization (40px)
   ========================================================================== */
.page-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
}

.page-actions .btn,
.page-actions .dropdown,
.page-actions .dropdown-toggle,
.page-actions .date-range-inline-form,
.page-actions .date-range-button-wrap,
.page-actions .date-range-button {
    height: 40px !important;
    min-height: 40px !important;
    box-sizing: border-box !important;
}

.page-actions .btn,
.page-actions .dropdown-toggle,
.page-actions .date-range-button {
    border-radius: 12px !important;
    font-size: 0.92rem !important;
    font-weight: 600 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    vertical-align: middle !important;
    padding: 0 20px !important;
}

.page-actions .date-range-inline-form,
.page-actions .date-range-button-wrap {
    display: inline-flex !important;
    align-items: center !important;
    vertical-align: middle !important;
    margin: 0 !important;
}

.page-actions .date-range-button-wrap {
    position: relative !important;
}

.page-actions .date-range-button-wrap > i {
    color: rgba(255, 255, 255, 0.9) !important;
    position: absolute !important;
    left: 18px !important;
    font-size: 0.98rem !important;
    z-index: 2 !important;
    display: inline-flex !important;
    align-items: center !important;
    height: 100% !important;
    margin: 0 !important;
}

.page-actions .date-range-button {
    background: #0E9F6E !important;
    border: 1px solid #0E9F6E !important;
    color: #fff !important;
    min-width: 240px !important;
    padding-left: 46px !important;
    padding-right: 36px !important;
    box-shadow: none !important;
    cursor: pointer !important;
    text-align: left !important;
}

.page-actions .date-range-button:hover,
.page-actions .date-range-button:focus {
    background: #0B7A55 !important;
    border-color: #0B7A55 !important;
    color: #fff !important;
}

.page-actions .date-range-button-wrap::after {
    color: rgba(255, 255, 255, 0.9) !important;
    font-size: 0.72rem !important;
    right: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    height: 100% !important;
}

.page-actions .btn-new-ticket {
    display: none !important;
}

@media (min-width: 992px) {
    .page-actions .btn-new-ticket {
        display: inline-flex !important;
    }
}

/* ==========================================================================
   ProGro Service Desk Mobile-App Style Dashboard Experience
   ========================================================================== */
@media (max-width: 768px) {
    /* Layout & Base Constraints */
    body {
        padding-bottom: 92px !important; /* Space for floating bottom navigation bar */
    }
    
    .content-area {
        padding: 14px 14px 24px !important; /* Tighten area spacing */
    }
    
    /* Hide desktop elements on mobile */
    .desktop-topbar-content,
    .mobile-menu,
    .dashboard-recent-tickets-row {
        display: none !important;
    }
    
    /* Sticky Mobile Header */
    .topbar {
        min-height: 62px !important;
        height: 62px !important;
        padding: 0 12px !important;
        background: rgba(255, 255, 255, 0.96) !important;
        border-bottom: 1px solid rgba(226, 232, 240, 0.8) !important;
        backdrop-filter: blur(12px) !important;
        position: sticky !important;
        top: 0 !important;
        z-index: 1040 !important;
        display: flex !important;
        align-items: center !important;
    }
    
    /* Mobile Header Layout (Single Row, No Wrapping) */
    .mobile-topbar-content {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        width: 100% !important;
        flex-wrap: nowrap !important;
    }
    
    /* Mobile Logo (Auto Width) */
    .mobile-logo-wrap {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        flex: 0 0 auto !important;
        text-decoration: none !important;
    }
    
    .mobile-logo-wrap.flex-shrink-0 img {
        width: 50px !important;
        height: auto !important;
    }
    
    /* Mobile Search Bar (Exactly 53% Width) */
    .mobile-search-form {
        display: block !important;
        flex: 0 0 53% !important;
        max-width: 53% !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    .mobile-search-wrap {
        position: relative !important;
        width: 100% !important;
    }
    
    .mobile-search-wrap i {
        display: none !important;
    }
    
    .mobile-search-input {
        padding-left: 14px !important; /* Adjusted padding as search icon is hidden */
        padding-right: 10px !important;
        height: 42px !important; /* Compact height 42px */
        border-radius: 12px !important; /* Rounded corners */
        font-size: 0.82rem !important;
        background-color: #F1F5F9 !important; /* Light background */
        border: 1px solid transparent !important;
        transition: all 0.2s !important;
        width: 100% !important;
        outline: none !important;
        box-shadow: none !important;
    }
    
    .mobile-search-input:focus {
        background-color: #FFF !important;
        border-color: #0E9F6E !important;
        box-shadow: 0 0 0 2px rgba(14, 159, 110, 0.15) !important;
    }
    
    /* Mobile Account Dropdown (Auto Width) */
    .mobile-profile {
        flex: 0 0 auto !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
    }
    
    .mobile-avatar-btn {
        border: none !important;
        background: none !important;
        padding: 0 !important;
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 36px !important;
        height: 36px !important;
        border-radius: 50% !important;
        outline: none !important;
    }
    
    .mobile-avatar-btn .avatar {
        width: 36px !important;
        height: 36px !important;
        background: #0E9F6E !important;
        color: #FFF !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 50% !important;
        font-size: 0.88rem !important;
        font-weight: 700 !important;
        box-shadow: 0 2px 4px rgba(14, 159, 110, 0.2) !important;
    }
    
    .mobile-profile-menu {
        border-radius: 14px !important;
        box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.08), 0 8px 10px -6px rgba(0, 0, 0, 0.03) !important;
        width: 200px !important;
        border: 1px solid rgba(226, 232, 240, 0.8) !important;
    }
    
    /* Tactile Mobile Controls (Min touch target 44px) */
    .btn,
    .form-control,
    .nav-link,
    .dropdown-item,
    .mobile-avatar-btn {
        min-height: 44px;
        display: inline-flex;
        align-items: center;
    }
    
    .btn {
        justify-content: center;
        padding: 8px 16px !important;
    }
    
    /* Floating Premium Bottom Navigation Bar */
    .mobile-bottom-nav {
        position: fixed !important;
        bottom: 12px !important; /* Floating appearance */
        left: 16px !important; /* 16px side margin */
        right: 16px !important; /* 16px side margin */
        height: 68px !important;
        background: rgba(255, 255, 255, 0.96) !important;
        border: 1px solid rgba(226, 232, 240, 0.9) !important;
        border-radius: 24px !important; /* Highly rounded floating bar */
        display: flex !important;
        justify-content: space-around !important;
        align-items: center !important;
        z-index: 1045 !important;
        backdrop-filter: blur(16px) !important;
        padding: 0 8px !important;
        box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08) !important; /* Premium soft shadow */
    }
    
    .mobile-bottom-nav .nav-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-decoration: none !important;
        color: #94A3B8 !important; /* Inactive muted text */
        font-size: 0.65rem !important;
        font-weight: 500 !important;
        height: 48px !important;
        border-radius: 14px !important;
        padding: 4px 12px !important;
        transition: all 0.2s ease;
        position: relative !important;
        min-width: 62px !important;
        min-height: 44px;
    }
    
    .mobile-bottom-nav .nav-item i {
        font-size: 1.25rem !important;
        color: #94A3B8 !important; /* Inactive muted icon */
        margin-bottom: 2px !important;
        transition: transform 0.15s ease-in-out;
    }
    
    .mobile-bottom-nav .nav-item:active i {
        transform: scale(0.9);
    }
    
    /* Inactive State Hover/Tap */
    .mobile-bottom-nav .nav-item:active {
        background: rgba(148, 163, 184, 0.05) !important;
    }
    
    /* Active State Highlights (Targeted styling per menu item) */
    .mobile-bottom-nav .nav-home.active {
        color: #22c55e !important;
        background: rgba(34, 197, 94, 0.06) !important;
        font-weight: 600 !important;
    }
    
    .mobile-bottom-nav .nav-home.active i {
        color: #22c55e !important;
    }
    
    .mobile-bottom-nav .nav-tickets.active {
        color: #22c55e !important;
        background: rgba(34, 197, 94, 0.06) !important;
        font-weight: 600 !important;
    }
    
    .mobile-bottom-nav .nav-tickets.active i {
        color: #22c55e !important;
    }

    .mobile-bottom-nav .nav-add-ticket.active {
        color: #0E9F6E !important;
        background: transparent !important;
        font-weight: 600 !important;
    }
    
    /* Premium Centralized Protruded Add Ticket Action */
    .mobile-bottom-nav .add-ticket-item {
        position: relative !important;
        overflow: visible !important;
        min-width: 68px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: flex-end !important;
        padding: 0 !important;
        height: 100% !important;
        background: transparent !important;
    }
    
    .mobile-bottom-nav .add-ticket-item span {
        font-size: 0.65rem !important;
        font-weight: 600 !important;
        color: #64748B !important;
        margin-top: 36px !important;
        padding: 0 !important;
        line-height: 36px !important;
        transition: color 0.2s;
    }
    
    .mobile-bottom-nav .add-ticket-item.active span {
        color: #0E9F6E !important;
    }
    
    .mobile-bottom-nav .add-ticket-btn {
        position: absolute !important;
        top: -24px !important; /* Protrude upward */
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 52px !important;
        height: 52px !important;
        border-radius: 50% !important; /* Circular shape */
        background: #0E9F6E !important; /* Brand color */
        color: #FFF !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border: 4px solid #FFF !important; /* High contrast separation border */
        box-shadow: 0 4px 14px rgba(14, 159, 110, 0.35) !important; /* Brand glow shadow */
        transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
        z-index: 1050 !important;
    }
    
    .mobile-bottom-nav .add-ticket-btn i {
        font-size: 1.4rem !important;
        color: #FFF !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* Interactive states for protruding Add Button */
    .mobile-bottom-nav .add-ticket-item:active .add-ticket-btn {
        background: #0B7A55 !important;
        transform: translateX(-50%) translateY(-2px) scale(0.92) !important;
        box-shadow: 0 2px 8px rgba(14, 159, 110, 0.2) !important;
    }
    
    /* Compact Mobile Stats Cards (Equal height & width) */
    .stat-card.compact {
        min-height: 124px !important;
        padding: 12px !important;
        border-radius: 14px !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: space-between !important;
        box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.02), 0 2px 4px -1px rgba(0, 0, 0, 0.01) !important;
    }
    
    .stat-card.compact .stat-label {
        font-size: 0.7rem !important;
        font-weight: 600 !important;
        color: #64748B !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
    
    .stat-card.compact .icon {
        width: 28px !important;
        height: 28px !important;
        border-radius: 8px !important;
        font-size: 0.88rem !important;
    }
    
    .stat-card.compact .stat-value {
        margin: 6px 0 4px !important;
        font-size: 1.38rem !important;
        font-weight: 700 !important;
    }
    
    .stat-card.compact .stat-value.amount {
        font-size: 1.12rem !important;
    }
    
    .stat-card.compact .trend-pill {
        font-size: 0.62rem !important;
        padding: 2px 6px !important;
        font-weight: 600 !important;
        width: fit-content !important;
    }
}

/* Modernized All Tickets - CRM Card View */

/* Compact Segmented Tabs Redesign */
.ticket-filter-tabs {
    background: #F1F5F9 !important;
    padding: 3px !important;
    border-radius: 8px !important;
    display: inline-flex !important;
    gap: 2px !important;
    border: none !important;
    overflow-x: auto;
}

.ticket-filter-tabs button {
    border: 0 !important;
    background: transparent !important;
    border-radius: 6px !important;
    color: #475569 !important;
    font-weight: 600 !important;
    font-size: var(--pg-font-xs) !important;
    padding: 5px 12px !important;
    white-space: nowrap !important;
    box-shadow: none !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.ticket-filter-tabs button.active {
    background: #FFFFFF !important;
    color: var(--pg-highlight) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06) !important;
}

.ticket-filter-tabs button:hover:not(.active) {
    color: var(--pg-primary) !important;
    background: rgba(255, 255, 255, 0.5) !important;
}

/* Dual Responsive Views: Desktop Table vs Mobile Cards */

/* By default (Desktop ≥ 992px) */
.mobile-card-cell {
    display: none !important;
}
.desktop-cell {
    display: table-cell !important;
}

/* Tablet & Mobile (< 992px) Breakpoint */
@media (max-width: 991.98px) {
    .desktop-cell {
        display: none !important;
    }
    .mobile-card-cell {
        display: block !important;
    }
    
    /* Make Table display as CSS Grid for Premium CRM Cards on Mobile/Tablet */
    #allTicketsTable {
        display: block !important;
        border: none !important;
    }

    #allTicketsTable thead {
        display: none !important;
    }

    #allTicketsTable tbody {
        display: grid !important;
        gap: 16px !important;
        padding: 12px 0 24px !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    
    /* Mobile breakpoint (< 768px) */
    @media (max-width: 767.98px) {
        #allTicketsTable tbody {
            grid-template-columns: 1fr !important;
        }
    }

    #allTicketsTable tbody tr.all-ticket-row {
        display: block !important;
        background: transparent !important;
        border: none !important;
        padding: 0 !important;
        transition: none !important;
    }

    #allTicketsTable tbody tr.all-ticket-row td.mobile-card-cell {
        display: block !important;
        padding: 0 !important;
        border: none !important;
        background: transparent !important;
    }

    /* Handle empty states spanning across grid columns on mobile/tablet */
    #allTicketsTable tbody tr.empty-row,
    #allTicketsTable tbody tr.filtered-empty-row {
        display: block !important;
        grid-column: 1 / -1 !important;
        text-align: center !important;
    }

    #allTicketsTable tbody tr.empty-row td,
    #allTicketsTable tbody tr.filtered-empty-row td {
        display: block !important;
        width: 100% !important;
    }
}

/* Premium CRM Ticket Card styling */
.ticket-card {
    background: var(--pg-card) !important;
    border: 1px solid var(--pg-border) !important;
    border-radius: 12px !important;
    padding: 16px !important;
    transition: all 0.22s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: var(--pg-shadow-soft) !important;
    display: flex !important;
    flex-direction: column !important;
    height: auto !important;
    min-height: 200px !important;
    overflow: visible !important;
}

.ticket-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--pg-shadow) !important;
    border-color: #CBD5E1 !important;
}

.ticket-card-header {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 4px !important;
    border-bottom: 1px solid var(--pg-soft) !important;
    padding-bottom: 10px !important;
    margin-bottom: 12px !important;
    width: 100% !important;
}

.ticket-id-link {
    font-weight: 700 !important;
    color: var(--pg-highlight) !important;
    text-decoration: none !important;
    font-size: 0.96rem !important;
    transition: color 0.15s ease !important;
}

.ticket-id-link:hover {
    color: #0b8058 !important;
    text-decoration: underline !important;
}

.ticket-service-name {
    font-weight: 600 !important;
    color: var(--pg-primary) !important;
    font-size: 0.92rem !important;
    text-align: left !important;
    width: 100% !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    overflow: visible !important;
    text-overflow: clip !important;
}

.ticket-card-body {
    display: flex !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin-bottom: 12px !important;
    flex-grow: 1 !important;
}

.ticket-info-label {
    font-size: 0.68rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: var(--pg-muted) !important;
    margin-bottom: 6px !important;
    font-weight: 700 !important;
}

.ticket-customer-section {
    flex: 1 !important;
    min-width: 0 !important;
}

.ticket-customer-name {
    font-weight: 600 !important;
    color: var(--pg-secondary) !important;
    font-size: 0.88rem !important;
    margin-bottom: 2px !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

.ticket-customer-mobile {
    color: var(--pg-muted) !important;
    font-size: 0.82rem !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

.ticket-customer-mobile i {
    font-size: 0.8rem !important;
}

.ticket-status-section {
    flex: 1 !important;
    text-align: right !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    min-width: 0 !important;
}

.ticket-status-badge {
    margin-bottom: 6px !important;
}

.ticket-expected-date {
    font-size: 0.8rem !important;
    color: var(--pg-secondary) !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

.expected-label {
    color: var(--pg-muted) !important;
    margin-right: 2px !important;
}

.expected-value {
    font-weight: 600 !important;
}

.ticket-card-footer {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    border-top: 1px solid var(--pg-soft) !important;
    padding-top: 10px !important;
    margin-top: auto !important;
}

.ticket-amount-created {
    display: flex !important;
    flex-direction: column !important;
}

.ticket-amount {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--pg-primary) !important;
}

.ticket-created-date {
    font-size: 0.76rem !important;
    color: var(--pg-muted) !important;
}

.ticket-quick-actions {
    display: flex !important;
    gap: 6px !important;
    align-items: center !important;
}

.btn-action-icon {
    width: 30px !important;
    height: 30px !important;
    border-radius: 8px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid var(--pg-border) !important;
    color: var(--pg-muted) !important;
    background: var(--pg-card) !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
    cursor: pointer !important;
    padding: 0 !important;
    text-decoration: none !important;
}

.btn-action-icon:hover {
    background: #E8F5E9 !important; /* Premium light green tint */
    color: var(--pg-highlight) !important;
    border-color: var(--pg-highlight) !important;
    transform: scale(1.08) !important;
}

.btn-action-icon i {
    font-size: 0.88rem !important;
}

/* Light Status Pill colors for Tickets */
.status-badge.status-open {
    background: #EFF6FF !important;
    color: #1D4ED8 !important;
}

.status-badge.status-in-progress {
    background: #FFFBEB !important;
    color: #D97706 !important; /* beautiful CRM orange/amber */
}

.status-badge.status-completed {
    background: #DCFCE7 !important;
    color: #166534 !important;
}

.status-badge.status-rejected {
    background: #FEF2F2 !important;
    color: #B91C1C !important;
}

.status-badge.status-failed {
    background: #FEF2F2 !important;
    color: #B91C1C !important;
}

.status-badge.status-overdue {
    background: #FEF2F2 !important;
    color: #B91C1C !important;
}

/* Avoid horizontal scrollbars for card grids */
.ticket-workspace .table-responsive {
    overflow-x: visible !important;
    border: none !important;
}

/* Maintain Actions column stickiness on Desktop when mobile cards are hidden in DOM */
@media (min-width: 992px) {
    .table-sticky-columns th.actions-column,
    .table-sticky-columns td.actions-column {
        position: sticky !important;
        right: 0 !important;
        z-index: 3 !important;
        background-color: #FFFFFF !important;
        border-left: 1px solid var(--pg-border) !important;
        box-shadow: -6px 0 12px rgba(15, 23, 42, 0.025) !important;
    }

    .table-sticky-columns thead th.actions-column {
        z-index: 6 !important;
        background-color: #FAFBFC !important;
    }

    .table-sticky-columns tbody tr:hover td.actions-column {
        background-color: #FAFBFC !important;
    }

    .table-sticky-columns tbody tr:focus-within td.actions-column,
    .table-sticky-columns tbody tr:has(.show) td.actions-column,
    .table-sticky-columns tbody tr.dropdown-active td.actions-column {
        z-index: 15 !important;
    }
}

/* Mobile Header Enhancements - Center Aligned Single-Row Header */
@media (max-width: 768px) {
    .mobile-search-form {
        flex: 0 0 53% !important;
        max-width: 53% !important;
        width: 53% !important;
        margin: 0 !important;
    }
    
    .mobile-topbar-content {
        height: 58px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
    }

    .mobile-topbar-content > * {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
        align-self: center !important;
    }

    .mobile-notification {
        position: relative !important;
    }

    .mobile-notification-btn {
        width: 36px !important;
        height: 36px !important;
        border-radius: 50% !important;
        background: #F1F5F9 !important;
        border: none !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: #475569 !important;
        transition: all 0.2s !important;
        padding: 0 !important;
        cursor: pointer !important;
    }

    .mobile-notification-btn i {
        font-size: 1.15rem !important;
    }

    .mobile-notification-btn:active {
        background: #E2E8F0 !important;
        transform: scale(0.95) !important;
    }

    .mobile-notification-badge {
        position: absolute !important;
        top: -3px !important;
        right: -3px !important;
        background: #EF4444 !important;
        color: #FFFFFF !important;
        font-size: 9px !important;
        font-weight: 700 !important;
        padding: 1px 5px !important;
        border-radius: 999px !important;
        border: 2px solid #FFFFFF !important;
        line-height: 1 !important;
    }

    .mobile-notification-menu {
        width: 290px !important;
        border-radius: 12px !important;
        box-shadow: 0 10px 25px -5px rgba(0,0,0,0.1), 0 8px 10px -6px rgba(0,0,0,0.1) !important;
        border: 1px solid var(--pg-border) !important;
        margin-top: 8px !important;
        padding: 6px !important;
    }

    .border-bottom-dashed {
        border-bottom: 1px dashed var(--pg-border) !important;
    }
    
    .border-bottom-dashed:last-child {
        border-bottom: none !important;
    }

    .badge-status-text {
        font-size: 0.68rem !important;
        font-weight: 600 !important;
        margin-top: 2px !important;
    }
    
    .badge-status-text.overdue { color: #EF4444 !important; }
    .badge-status-text.today { color: #F97316 !important; }
    .badge-status-text.tomorrow { color: #EAB308 !important; }
    .badge-status-text.soon { color: #10B981 !important; }
}

/* ==========================================================================
   Modern Receipt UI Styles & Grid Layout (Desktop & Mobile Responsive)
   ========================================================================== */
.receipt-grid {
    margin-top: 24px !important;
}

.receipt-card {
    background: #ffffff !important;
    border: 1px solid rgba(226, 232, 240, 0.8) !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03) !important;
    padding: 20px !important;
    height: auto !important;
    min-height: unset !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.receipt-card-header {
    font-size: 0.74rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: #64748B !important;
    border-bottom: 1px solid rgba(226, 232, 240, 0.8) !important;
    padding-bottom: 8px !important;
    margin-bottom: 4px !important;
    display: flex !important;
    align-items: center !important;
}

.receipt-card-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.receipt-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 16px !important;
    font-size: 0.86rem !important;
    color: var(--pg-secondary) !important;
    padding: 4px 0 !important;
    border-bottom: 1px dashed rgba(241, 245, 249, 0.8) !important;
}

.receipt-row:last-child {
    border-bottom: none !important;
}

.receipt-row span {
    color: #64748B !important;
    font-weight: 500 !important;
    text-align: left !important;
}

.receipt-row strong {
    color: #0F172A !important;
    font-weight: 600 !important;
    text-align: right !important;
}

.receipt-row-total {
    padding-top: 8px !important;
}

.receipt-payment-highlight {
    border-left: 4px solid #0E9F6E !important;
}

.receipt-footer {
    color: #64748B !important;
}

.receipt-thanks-note {
    background: var(--receipt-blue) !important;
    color: #ffffff !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    padding: 10px 20px !important;
    border-radius: 12px !important;
    display: inline-block !important;
    letter-spacing: 0.5px !important;
    border-radius: 12px !important;
    display: inline-block !important;
    letter-spacing: 0.5px !important;
}

/* All Tickets Desktop Table Horizontal Scroll & Sizing */
.ticket-table-wrapper {
    width: 100%;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
}

@media (min-width: 992px) {
    .ticket-table {
        min-width: 1400px !important;
        width: 100% !important;
        border-collapse: collapse !important;
    }

    .col-ticket-id {
        width: 120px !important;
        min-width: 120px !important;
        white-space: nowrap !important;
    }

    .col-service {
        width: 240px !important;
        min-width: 240px !important;
    }

    .col-customer {
        width: 220px !important;
        min-width: 220px !important;
    }

    .col-operator {
        width: 180px !important;
        min-width: 180px !important;
    }

    .col-mobile {
        width: 150px !important;
        min-width: 150px !important;
        white-space: nowrap !important;
    }

    .col-status {
        width: 130px !important;
        min-width: 130px !important;
        white-space: nowrap !important;
    }

    .col-expected-date {
        width: 140px !important;
        min-width: 140px !important;
        white-space: nowrap !important;
    }

    .col-amount {
        width: 120px !important;
        min-width: 120px !important;
        white-space: nowrap !important;
    }

    .col-created-date {
        width: 140px !important;
        min-width: 140px !important;
        white-space: nowrap !important;
    }

    .actions-column,
    .ticket-table th.actions-column,
    .ticket-table td.actions-column {
        width: 80px !important;
        min-width: 80px !important;
        max-width: 80px !important;
        text-align: center !important;
        white-space: nowrap !important;
    }
}