/**
 * AutoAssist Portal — Sage & Linen Theme
 * Calm, formal, easy on the eyes for 8–9 hour daily use.
 */

:root {
    --bg-page: #F8FAF7;
    --bg-surface: #FFFFFF;
    --bg-muted: #EEF2EC;
    --bg-elevated: #FFFFFF;
    --border: #D8E0D4;
    --border-strong: #C5D0C0;
    --text-primary: #1A1F18;
    --text-secondary: #3D4540;
    --text-muted: #5C6458;
    --text-label: #3D4540;
    --accent: #5F7A6A;
    --accent-strong: #4A6354;
    --accent-soft: #E8F0EA;
    --primary: #5F7A6A;
    --primary-dark: #4A6354;
    --primary-light: #E8F0EA;
    --secondary: #7A9484;
    --urgent: #B45309;
    --fast: #A16207;
    --medium: #5F7A6A;
    --low: #4D7C5A;
    --waiting: #A16207;
    --bg-dark: #F8FAF7;
    --bg-card: #FFFFFF;
    --bg-card-hover: #EEF2EC;
    --glass-border: #D8E0D4;
    --glass-shadow: rgba(95, 122, 106, 0.08);
    --shadow-sm: 0 1px 2px rgba(42, 47, 40, 0.04);
    --shadow-md: 0 4px 12px rgba(42, 47, 40, 0.06);
    --shadow-lg: 0 12px 32px rgba(42, 47, 40, 0.08);
    --shadow-card: 0 1px 3px rgba(42, 47, 40, 0.05);
    --link: #4A6354;
    --link-hover: #3D5248;
    --success: #4D7C5A;
    --warning: #A16207;
    --danger: #B45309;
    --info: #5B7A8A;
    --sage-50: #F4F7F4;
    --sage-100: #E8F0EA;
    --sage-200: #D8E0D4;
    /* Legacy aliases (templates may reference rose-*) */
    --rose-50: var(--sage-50);
    --rose-100: var(--sage-100);
    --rose-200: var(--sage-200);
}

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

* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    background: var(--bg-page) !important;
    color: var(--text-primary) !important;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.6;
}

.bg-gradient,
.bg-gradient-layer {
    background: linear-gradient(180deg, #F8FAF7 0%, #EEF2EC 100%) !important;
}


.text-muted { color: var(--text-muted) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-primary { color: var(--text-primary) !important; }
.empty-cell { color: var(--text-muted) !important; }

.navbar {
    background: var(--bg-surface) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom: 1px solid var(--border) !important;
    box-shadow: var(--shadow-sm);
}

.nav-link {
    background: var(--bg-muted) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-secondary) !important;
    min-height: 44px;
}

.nav-link:hover {
    background: var(--accent-soft) !important;
    border-color: var(--border-strong) !important;
    color: var(--accent-strong) !important;
}

.nav-link-active {
    background: var(--accent-soft) !important;
    border-color: var(--sage-200) !important;
    color: var(--accent-strong) !important;
}

.glass-card {
    background: var(--bg-surface) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: 1px solid var(--border) !important;
    border-radius: 16px;
    box-shadow: var(--shadow-card);
}

.glass-card:hover {
    background: var(--bg-surface) !important;
    border-color: var(--border-strong) !important;
    box-shadow: var(--shadow-md);
}

.page-title { color: var(--text-primary) !important; }
.page-subtitle { color: var(--text-muted) !important; }
.stats-label { color: var(--text-muted) !important; }
.stats-value { color: var(--text-primary) !important; }

.stats-icon.pink {
    background: var(--accent-soft) !important;
    color: var(--accent-strong) !important;
}

.stats-icon.blue {
    background: #EEF2F5 !important;
    color: var(--info) !important;
}

.stats-icon.yellow {
    background: #F5F3E8 !important;
    color: var(--warning) !important;
}

.stats-icon.green {
    background: #E8F2EA !important;
    color: var(--success) !important;
}

.breakdown-title { color: var(--text-muted) !important; }

.priority-badge,
.type-badge,
.status-badge,
.method-badge {
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

.priority-badge {
    background: var(--bg-muted) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-secondary) !important;
}

.badge-urgent {
    background: #F5EBE6 !important;
    border-color: #E8D4C8 !important;
    color: #8B4A3A !important;
}

.badge-fast {
    background: #F5F3E8 !important;
    border-color: #E8E0C8 !important;
    color: #7A5C1A !important;
}

.badge-medium {
    background: var(--accent-soft) !important;
    border-color: var(--sage-200) !important;
    color: var(--accent-strong) !important;
}

.badge-low {
    background: #E8F2EA !important;
    border-color: #C5D9C8 !important;
    color: #3D5C45 !important;
}

.type-technical,
.type-payment,
.type-support,
.type-warranty,
.type-spam,
.type-account,
.badge-forwarded,
.badge-assigned,
.badge-technician {
    background: var(--bg-muted) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-secondary) !important;
}

.badge-star {
    background: #F5F3E8 !important;
    border-color: #E8E0C8 !important;
    color: #7A5C1A !important;
}

.search-input,
.custom-dropdown,
.filter-input,
.form-input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
select,
textarea {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-primary) !important;
}

.search-container input,
.search-container input[type="text"],
.search-container input[type="search"],
.search-bar input,
.search-bar input[type="text"] {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    min-height: 0 !important;
}

.search-container:focus-within,
.search-bar:focus-within {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(95, 122, 106, 0.18) !important;
}

.search-container input:focus,
.search-container input[type="text"]:focus,
.search-container input[type="search"]:focus,
.search-bar input:focus {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

.search-input::placeholder,
input::placeholder,
textarea::placeholder {
    color: var(--text-muted) !important;
}

.search-input:focus,
.custom-dropdown:focus,
.form-input:focus,
input:focus,
select:focus,
textarea:focus {
    outline: none !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(95, 122, 106, 0.2) !important;
}

.search-icon { color: var(--text-muted) !important; }

.custom-dropdown option {
    background: var(--bg-surface) !important;
    color: var(--text-primary) !important;
}

.clear-btn { color: var(--text-muted) !important; }
.clear-btn:hover { color: var(--accent-strong) !important; }

.section-header { border-bottom: 1px solid var(--border) !important; }
.section-title { color: var(--text-primary) !important; }
.section-title i { color: var(--text-muted) !important; }

.total-badge {
    background: var(--bg-muted) !important;
    color: var(--text-secondary) !important;
}

.ticket-table thead th {
    color: var(--text-muted) !important;
    border-bottom: 1px solid var(--border) !important;
    background: var(--bg-muted) !important;
    backdrop-filter: none !important;
}

.ticket-table tbody tr:hover {
    background: var(--sage-50) !important;
}

.ticket-table tbody tr:not(:last-child) td {
    border-bottom: 1px solid var(--border) !important;
}

.ticket-table td { color: var(--text-secondary) !important; }
.ticket-table td.td-id { color: var(--accent-strong) !important; }
.ticket-table td.td-subject .subj-title { color: var(--text-primary) !important; }
.ticket-table td.td-subject .subj-body { color: var(--text-muted) !important; }
.ticket-table .td-user .user-name { color: var(--text-primary) !important; }
.ticket-table .td-user .user-email { color: var(--text-muted) !important; }
.ticket-table td.td-tech,
.ticket-table td.td-assignment { color: var(--text-secondary) !important; }
.ticket-table td.td-assignment .assign-label { color: var(--text-muted) !important; }
.ticket-table td.td-assignment .assign-name { color: var(--text-secondary) !important; }
.ticket-table td.td-date { color: var(--text-muted) !important; }
.ticket-table-empty { color: var(--text-muted) !important; }

.ticket-highlight-new {
    background: #F5F3E8 !important;
    box-shadow: inset 4px 0 0 var(--warning) !important;
}

.ticket-highlight-returned {
    background: var(--sage-50) !important;
    box-shadow: inset 4px 0 0 var(--accent) !important;
}

.ticket-highlight-forwarded {
    background: #E8F2EA !important;
    box-shadow: inset 4px 0 0 var(--success) !important;
}

.ticket-table .returned-badge {
    background: var(--accent-soft) !important;
    color: var(--accent-strong) !important;
    border-color: var(--sage-200) !important;
}

.btn-primary {
    background: var(--accent-strong) !important;
    color: #fff !important;
    border: 1px solid var(--accent-strong) !important;
    min-height: 44px;
}

.btn-primary:hover {
    background: var(--link-hover) !important;
    border-color: var(--link-hover) !important;
}

.btn-secondary {
    background: var(--bg-surface) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border) !important;
}

.btn-secondary:hover {
    background: var(--bg-muted) !important;
    border-color: var(--border-strong) !important;
}

.btn-fullscreen {
    background: var(--bg-muted) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-secondary) !important;
}

.btn-fullscreen:hover {
    background: var(--accent-soft) !important;
    color: var(--accent-strong) !important;
}

.pagination-btn,
.page-btn {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-secondary) !important;
}

.pagination-btn:hover:not(:disabled),
.page-btn:hover:not(:disabled) {
    background: var(--bg-muted) !important;
    color: var(--accent-strong) !important;
}

.pagination-btn.active,
.page-btn.active {
    background: var(--accent-strong) !important;
    color: #fff !important;
    border-color: var(--accent-strong) !important;
}

.login-card,
.portal-card,
.role-card {
    background: var(--bg-surface) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow-lg);
}

.back-link { color: var(--text-muted) !important; }
.back-link:hover { color: var(--accent-strong) !important; }

.member-option {
    background: var(--bg-muted) !important;
    border: 1px solid var(--border) !important;
}

.member-option:hover {
    background: var(--accent-soft) !important;
    border-color: var(--sage-200) !important;
}

.member-option.selected {
    background: var(--accent-soft) !important;
    border-color: var(--accent) !important;
}

.avatar-circle {
    background: var(--accent-soft) !important;
    border: 1px solid var(--sage-200) !important;
    color: var(--accent-strong) !important;
}

.member-name { color: var(--text-primary) !important; }
.member-role { color: var(--text-muted) !important; }

.header-bar {
    background: var(--bg-surface) !important;
    border-bottom: 1px solid var(--border) !important;
}

::-webkit-scrollbar-track { background: var(--bg-muted) !important; }

::-webkit-scrollbar-thumb {
    background: var(--sage-200) !important;
    border-color: var(--border) !important;
}

::-webkit-scrollbar-thumb:hover { background: var(--accent) !important; }

* {
    scrollbar-color: var(--sage-200) var(--bg-muted) !important;
}

:focus-visible {
    outline: 2px solid var(--accent-strong) !important;
    outline-offset: 2px;
}

#toast-container .toast-notification,
#toast-container > div {
    background: var(--bg-surface) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow-lg) !important;
}

.modal-overlay {
    background: rgba(42, 47, 40, 0.25) !important;
}

.modal-content,
.modal-box {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-primary) !important;
}

.status-open { background: #E8F2EA !important; color: #3D5C45 !important; }
.status-closed { background: var(--bg-muted) !important; color: var(--text-muted) !important; }
.status-waiting { background: #F5F3E8 !important; color: #7A5C1A !important; }

/* Ticket detail */
.right-sidebar,
body .right-sidebar,
html body .right-sidebar,
html body div#rightSidebar.right-sidebar {
    background: var(--bg-surface) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-left: 1px solid var(--border) !important;
    box-shadow: -2px 0 12px rgba(42, 47, 40, 0.04) !important;
}

.right-sidebar .sidebar-section {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    padding: 16px !important;
    margin-bottom: 0 !important;
    box-shadow: var(--shadow-card) !important;
}

.right-sidebar .sidebar-section:hover {
    border-color: var(--border-strong) !important;
    box-shadow: var(--shadow-md) !important;
}

.right-sidebar .note-card {
    background: var(--bg-muted) !important;
    border: 1px solid var(--border) !important;
}

.right-sidebar .sidebar-title { color: var(--text-primary) !important; }
.right-sidebar .add-btn { background: var(--accent-strong) !important; }
.right-sidebar .add-btn:hover { background: var(--link-hover) !important; }

.glass-panel,
.stats-card,
.ticket-card,
.main-container-glass,
.enhanced-search-container,
.detail-card {
    background: var(--bg-surface) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: 1px solid var(--border) !important;
}

.badge-urgent,
.badge-fast,
.badge-medium,
.badge-low,
.priority-urgent,
.priority-fast,
.priority-high,
.priority-medium,
.priority-low {
    background: var(--bg-surface) !important;
    backdrop-filter: none !important;
    color: var(--text-primary) !important;
}

.message.customer-message {
    background: var(--sage-50) !important;
    border-color: var(--border) !important;
}

.message.support-message,
.message.agent-message,
.message.staff-message {
    background: var(--bg-muted) !important;
    border-color: var(--border) !important;
}

.reply-card,
.original-message-container,
.message {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border) !important;
}

.reply-card:hover,
.message:hover {
    background: var(--bg-muted) !important;
}

.btn-gradient {
    background: linear-gradient(135deg, var(--accent-strong), var(--secondary)) !important;
    color: #fff !important;
    box-shadow: var(--shadow-sm) !important;
}

.btn-gradient:hover {
    box-shadow: var(--shadow-md) !important;
}

.gradient-text {
    background: none !important;
    -webkit-text-fill-color: var(--accent-strong) !important;
    color: var(--accent-strong) !important;
}

.header-badge.badge-takeover,
.header-badge.badge-refer,
.header-badge.badge-forward-btn {
    background: var(--accent-soft) !important;
    color: var(--accent-strong) !important;
    border-color: var(--sage-200) !important;
}

.header-badge.badge-email {
    background: var(--bg-muted) !important;
    color: var(--accent-strong) !important;
}

.ticket-detail-page [class*="bg-gray-"],
.ticket-detail-page [class*="bg-slate-"],
.ticket-detail-page .bg-gray-50,
.ticket-detail-page .bg-gray-100 {
    background: var(--bg-muted) !important;
}

.ticket-detail-page .bg-white,
.ticket-detail-page [class*="bg-white"] {
    background: var(--bg-surface) !important;
}

/* ===== Ticket page: main + right tools rail (CSS grid, not fixed) ===== */
.ticket-detail-page .main-layout {
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1rem 1.5rem;
    box-sizing: border-box;
}

.ticket-detail-page .parallel-container {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    width: 100% !important;
    align-items: start;
}

@media (min-width: 1024px) {
    .ticket-detail-page .parallel-container {
        grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
        gap: 1.5rem;
    }
}

.ticket-detail-page .app-container {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
    padding-right: 0 !important;
    overflow: visible !important;
}

.ticket-detail-page .container.main-content {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
}

.ticket-detail-page .right-sidebar,
.ticket-detail-page #rightSidebar,
.ticket-detail-page .sidebar-toggle,
.ticket-detail-page #sidebarToggleMobile,
.ticket-detail-page .sidebar-overlay,
.ticket-detail-page #sidebarOverlay {
    display: none !important;
}

/* Right tools column */
.ticket-detail-page .ticket-tools-rail {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

@media (min-width: 1024px) {
    .ticket-detail-page .ticket-tools-rail {
        position: sticky;
        top: 5.5rem;
        max-height: calc(100vh - 6rem);
        overflow-y: auto;
        overflow-x: hidden;
        padding-right: 2px;
    }
}

.ticket-detail-page .ticket-tools-rail .sidebar-section:not(.tools-rail-block) {
    margin: 0 !important;
    padding: 1rem 1.125rem !important;
    background: var(--bg-surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    box-shadow: var(--shadow-card) !important;
    flex-shrink: 0;
}

.ticket-detail-page .tools-rail-shell .tools-rail-block.sidebar-section {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0.875rem 1.125rem !important;
}

.ticket-detail-page .ticket-tools-rail .sidebar-header {
    margin-bottom: 0.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--border);
}

.ticket-detail-page .ticket-tools-rail #notesContainer,
.ticket-detail-page .ticket-tools-rail #templatesContainer,
.ticket-detail-page .ticket-tools-rail #documentsContainer {
    max-height: 200px;
    overflow-y: auto;
    overflow-x: hidden;
}

.ticket-detail-page .ticket-tools-rail .empty-state {
    padding: 1rem 0.75rem;
    min-height: 72px;
    border: 1px dashed var(--border-strong);
    border-radius: 8px;
    background: var(--bg-muted);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.ticket-detail-page .ticket-tools-rail .empty-state p {
    font-size: 0.9375rem !important;
    font-weight: 600 !important;
    color: var(--text-secondary) !important;
    margin-top: 0.5rem;
    line-height: 1.4;
}

.ticket-detail-page .ticket-tools-rail .empty-icon {
    color: var(--accent) !important;
    font-size: 1.25rem;
}

.ticket-detail-page .ticket-tools-rail .add-btn {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px;
    border-radius: 8px !important;
    background: var(--accent-strong) !important;
    color: #fff !important;
}

.ticket-detail-page .ticket-tools-rail .add-btn i {
    color: #fff !important;
}

@media (max-width: 1023px) {
    .ticket-detail-page .ticket-tools-rail {
        order: 2;
    }
    .ticket-detail-page .app-container {
        order: 1;
    }
}

/* ===== Readability: larger, bolder, higher contrast ===== */
.ticket-detail-page {
    font-size: 16px !important;
    color: var(--text-primary) !important;
}

.ticket-detail-page h1 {
    font-size: 1.375rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    line-height: 1.35 !important;
}

.ticket-detail-page h2 {
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
}

.ticket-detail-page h3 {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
}

.ticket-detail-page h4,
.ticket-detail-page h5 {
    font-size: 0.9375rem !important;
    font-weight: 700 !important;
    color: var(--text-secondary) !important;
}

/* Section labels (CUSTOMER, CREATED, etc.) */
.ticket-detail-page .detail-card h3,
.ticket-detail-page .detail-card h4,
.ticket-detail-page .detail-card .font-semibold,
.ticket-detail-page h3.text-sm.font-medium.text-gray-500,
.ticket-detail-page h4.text-xs.font-medium.text-gray-500,
.ticket-detail-page .text-xs.font-medium.text-gray-500,
.ticket-detail-page .text-gray-400,
.ticket-detail-page .text-gray-500,
.ticket-detail-page [class*="uppercase"].text-gray-400,
.ticket-detail-page [class*="uppercase"].text-gray-500,
.ticket-detail-page .text-purple-400,
.ticket-detail-page [class*="text-purple-400"],
.ticket-detail-page [class*="text-purple-"],
.ticket-detail-page .text-indigo-600,
.ticket-detail-page .text-\[10px\] {
    font-size: 0.8125rem !important;
    font-weight: 700 !important;
    color: var(--text-label) !important;
    letter-spacing: 0.04em !important;
}

.ticket-detail-page #vehicleClaimModal .form-label,
.ticket-detail-page #vehicleClaimModal .section-title span {
    color: var(--text-label) !important;
    font-size: 0.8125rem !important;
    font-weight: 700 !important;
}

.ticket-detail-page #vehicleClaimModal input,
.ticket-detail-page #vehicleClaimModal select,
.ticket-detail-page #vehicleClaimModal textarea {
    color: var(--text-primary) !important;
    font-size: 0.9375rem !important;
    font-weight: 500 !important;
    background: var(--bg-surface) !important;
}

/* Field values & body text */
.ticket-detail-page .detail-card p,
.ticket-detail-page .detail-card span:not(.header-badge):not([class*="badge"]),
.ticket-detail-page p.text-gray-800,
.ticket-detail-page p.text-gray-900,
.ticket-detail-page .text-gray-800,
.ticket-detail-page .text-gray-900,
.ticket-detail-page .text-gray-700,
.ticket-detail-page .text-gray-600 {
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
    line-height: 1.5 !important;
}

.ticket-detail-page .text-sm:not(.font-medium):not(h3):not(h4) {
    font-size: 0.9375rem !important;
    font-weight: 500 !important;
}

.ticket-detail-page .text-xs:not(.font-medium) {
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--text-secondary) !important;
}

.ticket-detail-page .sidebar-title {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
}

.ticket-detail-page .section-title,
.ticket-detail-page .section-title span {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
}

.ticket-detail-page .empty-state,
.ticket-detail-page .text-center.text-gray-500,
.ticket-detail-page p.text-gray-500 {
    font-size: 0.9375rem !important;
    font-weight: 600 !important;
    color: var(--text-secondary) !important;
}

.ticket-detail-page .original-message-content,
.ticket-detail-page .message-content,
.ticket-detail-page .message {
    font-size: 1rem !important;
    font-weight: 500 !important;
    line-height: 1.65 !important;
    color: var(--text-primary) !important;
}

.ticket-detail-page .header-badge {
    font-size: 0.8125rem !important;
    font-weight: 700 !important;
}

.ticket-detail-page select,
.ticket-detail-page .ticket-header select {
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    background: var(--bg-surface) !important;
    color: var(--text-primary) !important;
}

/* Portal-wide list & dashboard readability */
.main-container,
.glass-card {
    font-size: 16px;
}

.page-title {
    font-size: 1.75rem !important;
    font-weight: 700 !important;
}

.page-subtitle,
.stats-label,
.breakdown-title {
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: var(--text-secondary) !important;
}

.stats-value {
    font-size: 1.75rem !important;
    font-weight: 700 !important;
}

.ticket-table td {
    font-size: 0.9375rem !important;
    font-weight: 500 !important;
}

.ticket-table thead th {
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    color: var(--text-label) !important;
}

.ticket-table td.td-subject .subj-title {
    font-size: 0.9375rem !important;
    font-weight: 600 !important;
}
