/* RunHub - RunRDP Ltd internal platform
   ============================================================================
   CSS ARCHITECTURE (keep it consistent):
     1. wwwroot/brand/runrdp.css  — the brand kit. Design tokens (--rdp-*) and
        .rdp-* utilities. SOURCE OF TRUTH for the palette. Edit brand here.
     2. wwwroot/app.css (this file) — the global component layer (tables, forms,
        modals, tabs, badges, tickets…). It maps semantic tokens (--primary-color
        etc.) onto the brand and styles shared components. NEVER hardcode a raw
        colour here — always go through a token (var(--…)) or a brand-derived
        rgba()/gradient. Change the brand once and the whole UI re-tones.
     3. *.razor.css (scoped) — PAGE-LEVEL OVERRIDES ONLY. Per-component tweaks,
        not new global styles or new colours.
   ============================================================================ */

:root {
    /* Accent — Current (#2A8A9E) is the brand's light-surface accent */
    --primary-color: #2A8A9E;   /* Current  */
    --primary-dark: #11405E;    /* Tide — hover/active/emphasis */
    --secondary-color: #44626C; /* Slate */
    --success-color: #5BBF6A;   /* Kelp */
    --danger-color: #E5484D;    /* functional red (not a brand colour) */
    --warning-color: #E0A22A;   /* functional amber */

    /* Darker accent variants — hover / active / gradient ends (brand-derived) */
    --secondary-dark: #35505A;  /* darker Slate */
    --success-dark: #46A456;    /* darker Kelp */
    --danger-dark: #C83B40;     /* darker functional red */
    --warning-dark: #B07D18;    /* darker functional amber */

    /* Surfaces & text */
    --background-color: #F4F5F7; /* Paper  */
    --surface-color: #FFFFFF;    /* card surface */
    --border-color: #E1E4E8;     /* Line */
    --text-primary: #0A2540;     /* Navy */
    --text-secondary: #44626C;   /* Slate */

    /* Type — brand families (imported by runrdp.css) */
    --font-display: "Sora", "Geist", ui-sans-serif, system-ui, sans-serif;
    --font-body: "Geist", "Inter", ui-sans-serif, system-ui, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;

    /* Navy-tinted shadows */
    --shadow-sm: 0 1px 2px 0 rgba(6, 26, 43, 0.06);
    --shadow-md: 0 4px 10px -2px rgba(6, 26, 43, 0.10);
    --shadow-lg: 0 16px 32px -12px rgba(6, 26, 43, 0.18);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Remove focus outline from non-interactive elements */
h1:focus, h2:focus, h3:focus, h4:focus, h5:focus, h6:focus,
p:focus, span:focus, div:not([tabindex]):focus {
    outline: none;
}

html, body {
    font-family: var(--font-body);
    background-color: var(--background-color);
    color: var(--text-primary);
    line-height: 1.6;
    height: 100%;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    letter-spacing: -0.02em;
}

/* Layout */
.app-container {
    display: flex;
    height: 100vh;
}

.sidebar {
    width: 260px;
    background-color: var(--surface-color);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    box-shadow: var(--shadow-sm);
}

.sidebar-header {
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.sidebar-header h1 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
    margin: 0;
    outline: none;
}

.sidebar-header h1:focus {
    outline: none;
}

.sidebar-header p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
    outline: none;
}

.sidebar-header p:focus {
    outline: none;
}

.sidebar-brand-link {
    text-decoration: none;
    display: inline-block;
}

.sidebar-brand-link h1 {
    transition: opacity 0.15s ease;
}

.sidebar-brand-link:hover h1 {
    opacity: 0.85;
}

.nav-menu {
    flex: 1;
    padding: 1rem 0;
    overflow-y: auto;
}

.nav-menu ul {
    list-style: none;
}

.nav-item {
    margin: 0.25rem 0.75rem;
}

.nav-link {
    display: flex;
    align-items: center;
    padding: 0.75rem 1rem;
    color: var(--text-secondary);
    text-decoration: none;
    border-radius: 0.5rem;
    transition: all 0.2s;
    font-weight: 500;
}

.nav-link:hover {
    background-color: var(--background-color);
    color: var(--primary-color);
}

.nav-link.active {
    background-color: var(--primary-color);
    color: white;
}

.nav-icon {
    margin-right: 0.75rem;
    font-size: 1.25rem;
}

.main-content {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
}

/* Page Header */
.page-header {
    margin-bottom: 0.75rem;
}

.page-header h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

.page-header p {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Card */
.card {
    background-color: var(--surface-color);
    border-radius: 0.5rem;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-color);
    overflow: hidden;
}

.card-header {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.card-header h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.card-body {
    padding: 0.75rem;
}

.card-compact {
    margin-bottom: 0.5rem;
}

.card-compact .card-body {
    padding: 0.5rem 0.75rem;
}

/* Balance Formatting */
.balance-positive {
    color: var(--success-color);
    font-weight: 600;
}

.balance-negative {
    color: var(--danger-color);
    font-weight: 600;
}

/* Table */
.table-container {
    overflow-x: auto;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9375rem;
}

.data-table thead {
    background-color: var(--background-color);
    border-bottom: 2px solid var(--border-color);
}

.data-table th {
    padding: 0.5rem 0.75rem;
    text-align: left;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.025em;
}

.data-table tbody tr {
    border-bottom: 1px solid var(--border-color);
    transition: background-color 0.3s ease;
}

.data-table tbody tr:hover {
    background-color: var(--background-color);
}

.data-table td {
    padding: 0.4rem 0.75rem;
    color: var(--text-primary);
    font-size: 0.875rem;
    line-height: 1.3;
}

.data-table td small {
    font-size: 0.75rem;
}

.data-table td.amount {
    font-weight: 600;
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.data-table td.positive {
    color: var(--success-color);
}

.data-table td.negative {
    color: var(--danger-color);
}

.data-table td.date {
    color: var(--text-secondary);
}

/* Badge */
.badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    font-size: 0.7rem;
    font-weight: 600;
    border-radius: 9999px;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.badge-primary {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.badge-success {
    background-color: rgba(91, 191, 106, 0.1);
    color: var(--success-color);
}

.badge-danger {
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
}

/* Button */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.4rem 0.875rem;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 0.375rem;
    border: none;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
}

.btn-sm {
    padding: 0.25rem 0.625rem;
    font-size: 0.8125rem;
}

.btn-icon {
    padding: 0.4rem 0.5rem;
}

.btn-primary {
    background-color: var(--primary-color);
    color: white;
}

.btn-primary:hover {
    background-color: var(--primary-dark);
}

.btn-secondary {
    background-color: var(--secondary-color);
    color: white;
}

.btn-secondary:hover {
    background-color: var(--secondary-dark);
}

/* Loading State */
.loading {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 3rem;
    color: var(--text-secondary);
}

.spinner {
    border: 3px solid var(--border-color);
    border-top: 3px solid var(--primary-color);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
    margin-right: 1rem;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Error Message */
.error-message {
    background-color: rgba(229, 72, 77, 0.1);
    border: 1px solid var(--danger-color);
    border-radius: 0.5rem;
    padding: 1rem 1.25rem;
    color: var(--danger-color);
    display: flex;
    align-items: center;
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--text-secondary);
}

.empty-state-icon {
    font-size: 3rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

/* Responsive */
@media (max-width: 768px) {
    .app-container {
        flex-direction: column;
    }

    .sidebar {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid var(--border-color);
    }

    .main-content {
        padding: 1rem;
    }

    .data-table {
        font-size: 0.875rem;
    }

    .data-table th,
    .data-table td {
        padding: 0.75rem 0.5rem;
    }
}

/* Blazor Error UI */
#blazor-error-ui {
    background: var(--danger-color);
    color: white;
    padding: 1rem;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    display: none;
    align-items: center;
    justify-content: space-between;
}

#blazor-error-ui .reload {
    color: white;
    text-decoration: underline;
    margin-left: 1rem;
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    margin-left: 1rem;
}

/* Form validation styles */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--success-color);
}

.invalid {
    outline: 1px solid var(--danger-color);
}

.validation-message {
    color: var(--danger-color);
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred."
}

/* Balance Chart */
.balance-chart {
    height: 300px;
    margin: 0.5rem 0;
}

.balance-chart canvas {
    max-height: 300px;
}

/* Forecast Chart - Larger */
.forecast-chart {
    height: 300px;
    margin: 0.5rem 0;
}

.forecast-chart canvas {
    max-height: 300px;
}

/* Balance Boxes */
.balance-boxes {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.balance-box {
    flex: 1;
    padding: 0.75rem 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.balance-box-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
    margin-bottom: 0.25rem;
}

.balance-box-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

/* Matched Row */
.matched-row {
    opacity: 0.6;
    font-style: italic;
}

/* Overdue Row */
.overdue-row {
    background-color: rgba(229, 72, 77, 0.05);
    border-left: 3px solid var(--danger-color);
}

/* Filter Panel */
.filter-panel {
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    max-height: 0;
}

.filter-panel.expanded {
    max-height: 500px;
}

.filter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.75rem;
    padding: 0.75rem;
}

.filter-item label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.filter-item input,
.filter-item select {
    width: 100%;
    padding: 0.4rem 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    font-size: 0.875rem;
    background-color: var(--surface-color);
}

.filter-item input:focus,
.filter-item select:focus {
    outline: none;
    border-color: var(--primary-color);
}

.filter-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    padding: 0.75rem;
    border-top: 1px solid var(--border-color);
}

/* Form Styles */
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.form-group {
    display: flex;
    flex-direction: column;
}

.form-group label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.form-control {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    font-size: 0.875rem;
    background-color: var(--surface-color);
    transition: border-color 0.2s;
}

.form-control:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(42, 138, 158, 0.1);
}

.form-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-start;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

/* Currency Input with Prefix */
.input-with-prefix {
    position: relative;
    display: flex;
    align-items: center;
}

.input-prefix {
    position: absolute;
    left: 0.75rem;
    color: var(--text-secondary);
    font-weight: 600;
    pointer-events: none;
    z-index: 1;
}

.form-control-with-prefix {
    padding-left: 2rem;
}

/* Inline Currency Input with Prefix */
.input-with-prefix-inline {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
}

.input-prefix-inline {
    position: absolute;
    left: 0.5rem;
    color: var(--text-secondary);
    font-weight: 600;
    pointer-events: none;
    z-index: 1;
    font-size: 0.875rem;
}

.input-with-prefix-inline .inline-edit-amount {
    padding-left: 1.5rem;
}

/* Inline Edit Inputs */
.inline-edit-date,
.inline-edit-amount {
    width: 100%;
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: 0.25rem;
    font-size: 0.875rem;
    background-color: var(--surface-color);
    transition: all 0.2s;
}

.inline-edit-date:focus,
.inline-edit-amount:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(42, 138, 158, 0.1);
}

.inline-edit-date:hover,
.inline-edit-amount:hover {
    border-color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.02);
}

.inline-edit-amount {
    text-align: right;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    min-width: 130px;
}

.inline-edit-amount.positive {
    color: var(--success-color);
}

.inline-edit-amount.negative {
    color: var(--danger-color);
}

/* Amount Input Sizing */
.amount-input {
    width: 100%;
    min-width: 180px;
    font-variant-numeric: tabular-nums;
}

/* Compact Select */
.compact-select {
    padding: 0.4rem 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    font-size: 0.875rem;
    background-color: var(--surface-color);
    max-width: 100%;
}

.compact-select:focus {
    outline: none;
    border-color: var(--primary-color);
}

/* Toolbar */
.toolbar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.toolbar-spacer {
    flex: 1;
}

/* Icon Helpers */
.empty-state-icon i {
    font-size: 3rem;
    color: var(--text-secondary);
    opacity: 0.5;
}

.btn i {
    margin-right: 0.25rem;
}

.error-message i {
    margin-right: 0.5rem;
}

.nav-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 0.75rem;
    font-size: 1.125rem;
    width: 1.25rem;
}

/* Back to Top Button */
#backToTop {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    width: 50px;
    height: 50px;
    background-color: var(--primary-color);
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all 0.3s ease;
    z-index: 1000;
}

#backToTop.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

#backToTop:hover {
    background-color: var(--primary-dark);
    transform: translateY(-2px);
    box-shadow: 0 12px 20px -5px rgba(0, 0, 0, 0.2);
}

#backToTop:active {
    transform: translateY(0);
}

@media (max-width: 768px) {
    #backToTop {
        bottom: 1rem;
        right: 1rem;
        width: 45px;
        height: 45px;
        font-size: 1.1rem;
    }
}

/* Modal Dialog */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    padding: 1rem;
}

.modal-dialog {
    background-color: var(--surface-color);
    border-radius: 0.5rem;
    box-shadow: var(--shadow-lg);
    max-width: 500px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
}

.modal-header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.modal-header h3 {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.btn-close {
    background: none;
    border: none;
    font-size: 1.25rem;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0.25rem;
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.25rem;
    transition: all 0.2s;
}

.btn-close:hover {
    background-color: var(--background-color);
    color: var(--text-primary);
}

.modal-body {
    padding: 1.5rem;
}

.modal-footer {
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

/* Forward-ticket modal */
.forward-modal {
    max-width: 620px;
}

.forward-field {
    margin-bottom: 14px;
}

.forward-field > label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.forward-optional {
    font-weight: 400;
    color: var(--text-secondary);
}

.forward-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--text-primary);
    margin: 4px 0 12px;
    cursor: pointer;
}

.forward-hint {
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
    font-size: 0.8rem;
    color: var(--text-secondary);
    background: var(--background-color);
    border-radius: 0.375rem;
    padding: 0.55rem 0.65rem;
    line-height: 1.5;
}

.forward-hint i {
    color: var(--primary-color);
    margin-top: 2px;
}

/* Extra Small Buttons */
.btn-xs {
    padding: 0.15rem 0.4rem;
    font-size: 0.75rem;
    border-radius: 0.25rem;
}

.btn-warning {
    background-color: var(--warning-color);
    color: white;
}

.btn-warning:hover {
    background-color: var(--warning-dark);
}

.btn-success {
    background-color: var(--success-color);
    color: white;
}

.btn-success:hover {
    background-color: var(--success-dark);
}

.btn-danger {
    background-color: var(--danger-color);
    color: white;
}

.btn-danger:hover {
    background-color: var(--danger-dark);
}

/* Salary Calculator Specific Styles */
.salary-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.salary-table thead {
    background-color: var(--background-color);
    border-bottom: 2px solid var(--border-color);
}

.salary-table th {
    padding: 0.5rem 0.75rem;
    text-align: left;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.025em;
}

.salary-table th:first-child {
    text-align: left;
}

.salary-table th:not(:first-child) {
    text-align: right;
}

.salary-table tbody tr {
    border-bottom: 1px solid var(--border-color);
}

.salary-table tbody tr:hover {
    background-color: rgba(42, 138, 158, 0.02);
}

.salary-table tbody tr.summary-row {
    background-color: var(--background-color);
    font-weight: 600;
    border-top: 2px solid var(--border-color);
}

.salary-table tbody tr.summary-row.highlight {
    background-color: rgba(42, 138, 158, 0.1);
    border-top: 3px solid var(--primary-color);
    border-bottom: 3px solid var(--primary-color);
}

.salary-table td {
    padding: 0.5rem 0.75rem;
    color: var(--text-primary);
}

.salary-table td:not(:first-child) {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.salary-table .amount {
    font-weight: 600;
}

.salary-table .amount.positive {
    color: var(--success-color);
}

.salary-table .amount.negative {
    color: var(--danger-color);
}

.salary-input {
    width: 100%;
    max-width: 120px;
    min-width: 90px;
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: 0.25rem;
    font-size: 0.875rem;
    background-color: var(--surface-color);
    text-align: right;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    transition: all 0.2s;
}

.salary-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(42, 138, 158, 0.1);
}

.salary-input:hover {
    border-color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.02);
}

.input-with-prefix-inline {
    display: inline-flex;
    align-items: center;
    max-width: 120px;
}

/* Action Buttons - Improved Design */
.action-buttons {
    display: flex;
    gap: 0.375rem;
    align-items: center;
    justify-content: flex-start;
}

.action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid transparent;
    border-radius: 0.375rem;
    background-color: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.875rem;
    padding: 0;
}

.action-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.action-btn:active {
    transform: translateY(0);
}

.action-btn-edit {
    color: var(--primary-color);
    border-color: rgba(42, 138, 158, 0.2);
}

.action-btn-edit:hover {
    background-color: rgba(42, 138, 158, 0.1);
    border-color: var(--primary-color);
    color: var(--primary-dark);
}

.action-btn-skip {
    color: var(--warning-color);
    border-color: rgba(224, 162, 42, 0.2);
}

.action-btn-skip:hover {
    background-color: rgba(224, 162, 42, 0.1);
    border-color: var(--warning-color);
    color: var(--warning-dark);
}

.action-btn-match {
    color: var(--success-color);
    border-color: rgba(91, 191, 106, 0.2);
}

.action-btn-match:hover {
    background-color: rgba(91, 191, 106, 0.1);
    border-color: var(--success-color);
    color: var(--success-dark);
}

.action-btn-delete {
    color: var(--danger-color);
    border-color: rgba(229, 72, 77, 0.2);
}

.action-btn-delete:hover {
    background-color: rgba(229, 72, 77, 0.1);
    border-color: var(--danger-color);
    color: var(--danger-dark);
}

/* Hover tooltips are handled by title attribute */
.action-btn[title] {
    position: relative;
}

@media (max-width: 768px) {
    .action-buttons {
        gap: 0.25rem;
    }
    
    .action-btn {
        width: 28px;
        height: 28px;
        font-size: 0.8125rem;
    }
}

/* Database Selection Page */
.database-selection-container {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--rdp-current) 0%, var(--rdp-tide) 100%);
    padding: 2rem;
}

.database-selection-card {
    background-color: var(--surface-color);
    border-radius: 1rem;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    max-width: 800px;
    width: 100%;
    overflow: hidden;
}

.database-selection-header {
    background: linear-gradient(135deg, var(--rdp-current) 0%, var(--rdp-tide) 100%);
    color: white;
    padding: 2rem;
    text-align: center;
}

.database-selection-header h1 {
    font-size: 2.5rem;
    font-weight: 700;
    margin: 0;
    margin-bottom: 0.5rem;
}

.database-selection-header p {
    font-size: 1.125rem;
    margin: 0;
    opacity: 0.9;
}

.database-list-container {
    padding: 2rem;
}

.database-list-container h2 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.5rem 0;
}

.database-list-container .subtitle {
    color: var(--text-secondary);
    margin: 0 0 1.5rem 0;
}

.database-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.database-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    transition: all 0.2s;
}

.database-item:hover {
    border-color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.02);
    box-shadow: var(--shadow-sm);
}

.database-info {
    flex: 1;
}

.database-info h3 {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.25rem 0;
}

.database-info p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0;
}

.database-actions {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

@media (max-width: 768px) {
    .database-selection-container {
        padding: 1rem;
    }

    .database-selection-header h1 {
        font-size: 2rem;
    }

    .database-list-container {
        padding: 1.5rem;
    }

    .database-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .database-actions {
        width: 100%;
        justify-content: flex-end;
    }
}


.btn-link {
    background: none;
    border: none;
    color: var(--primary-color);
    text-decoration: underline;
    cursor: pointer;
    font-size: 0.875rem;
    padding: 0;
    font-weight: 500;
}

.btn-link:hover {
    color: var(--primary-dark);
}

.user-info-container {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    background-color: rgba(42, 138, 158, 0.05);
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
}

.user-avatar {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, var(--rdp-current) 0%, var(--rdp-tide) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1rem;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(42, 138, 158, 0.3);
}

.user-details {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

.user-greeting {
    font-size: 0.7rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.user-name {
    font-size: 0.875rem;
    color: var(--text-primary);
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.signout-form {
    margin-bottom: 0.5rem;
}

.btn-signout,
.btn-signin {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background-color: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    border-radius: 0.375rem;
    cursor: pointer;
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.2s ease;
    text-decoration: none;
}

.btn-signout:hover,
.btn-signin:hover {
    background-color: rgba(229, 72, 77, 0.1);
    border-color: var(--danger-color);
    color: var(--danger-color);
}

.btn-signin:hover {
    background-color: rgba(42, 138, 158, 0.1);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.login-display {
    padding: 0.75rem 0 0.5rem 0;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 0.5rem;
}

/* =========================================
   Collapsible Navigation Sections
   ========================================= */

.nav-section {
    margin: 0.5rem 0;
}

.nav-section-header {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 0.75rem 1rem;
    margin: 0 0.5rem;
    background: none;
    border: none;
    border-radius: 0.5rem;
    cursor: pointer;
    color: var(--text-primary);
    font-weight: 600;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    transition: all 0.2s;
}

.nav-section-header:hover {
    background-color: var(--background-color);
}

.nav-section-header.expanded {
    color: var(--primary-color);
}

.nav-section-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 0.75rem;
    font-size: 1rem;
    width: 1.25rem;
}

.nav-section-title {
    flex: 1;
    text-align: left;
}

.nav-section-chevron {
    font-size: 0.75rem;
    color: var(--text-secondary);
    transition: transform 0.2s;
}

.nav-section-items {
    list-style: none;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    padding-left: 0.5rem;
}

.nav-section-items.expanded {
    max-height: 500px;
}

/* =========================================
   Tabs Container
   ========================================= */

.tabs-container {
    background-color: var(--surface-color);
    border-radius: 0.5rem;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-color);
    overflow: hidden;
}

.tabs-header {
    display: flex;
    gap: 0;
    background-color: var(--background-color);
    border-bottom: 1px solid var(--border-color);
    overflow-x: auto;
    padding: 0;
}

.tab-button {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.tab-button:hover {
    color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.05);
}

.tab-button.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
    background-color: var(--surface-color);
}

.tab-button i {
    font-size: 1rem;
}

.tabs-content {
    padding: 1rem;
    min-height: 400px;
}

/* =========================================
   System Selector
   ========================================= */

.system-selector {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.system-selector label {
    font-weight: 500;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.system-selector select {
    min-width: 200px;
}

/* =========================================
   Overview Grid
   ========================================= */

.overview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.overview-card {
    height: 100%;
    min-width: 0;
    overflow: hidden;
}

.info-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
    min-width: 0;
}

.info-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 0;
    overflow: hidden;
}

.info-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.info-value {
    font-size: 0.9375rem;
    color: var(--text-primary);
    font-weight: 500;
}

/* =========================================
   Health Status
   ========================================= */

.health-summary {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.health-status {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    border-radius: 0.5rem;
    font-weight: 600;
    font-size: 1.125rem;
}

.health-status.status-healthy {
    background-color: rgba(91, 191, 106, 0.1);
    color: var(--success-color);
}

.health-status.status-degraded {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.health-status.status-unhealthy {
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
}

.overall-health {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 2rem;
    border-radius: 0.5rem;
}

.dependencies-summary {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.dep-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
}

.dep-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.dep-indicator.status-healthy {
    background-color: var(--success-color);
}

.dep-indicator.status-degraded {
    background-color: var(--warning-color);
}

.dep-indicator.status-unhealthy {
    background-color: var(--danger-color);
}

.dep-name {
    flex: 1;
    font-weight: 500;
}

.dep-time {
    color: var(--text-secondary);
    font-size: 0.8125rem;
}

/* =========================================
   Metrics Grid
   ========================================= */

.metrics-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.metric-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.metric-item .metric-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
}

.metric-item .metric-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
    margin-top: 0.25rem;
}

/* =========================================
   Performance Tab
   ========================================= */

.metrics-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
}

.metric-card {
    display: flex;
    flex-direction: column;
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.metric-icon {
    width: 40px;
    height: 40px;
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    margin-bottom: 0.75rem;
}

.metric-icon.cpu {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.metric-icon.memory {
    background-color: rgba(91, 191, 106, 0.1);
    color: var(--success-color);
}

.metric-icon.gc {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.metric-icon.threads {
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
}

.metric-icon.circuits {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.metric-icon.handles {
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
}

.metric-content {
    display: flex;
    flex-direction: column;
}

.metric-content .metric-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

.metric-content .metric-value.cpu-normal {
    color: var(--success-color);
}

.metric-content .metric-value.cpu-warning {
    color: var(--warning-color);
}

.metric-content .metric-value.cpu-critical {
    color: var(--danger-color);
}

.metric-content .metric-label {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.metric-bar {
    height: 4px;
    background-color: var(--border-color);
    border-radius: 2px;
    margin-top: 0.75rem;
    overflow: hidden;
}

.metric-bar-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s ease;
}

.metric-bar-fill.cpu-normal {
    background-color: var(--success-color);
}

.metric-bar-fill.cpu-warning {
    background-color: var(--warning-color);
}

.metric-bar-fill.cpu-critical {
    background-color: var(--danger-color);
}

/* Auto Refresh Controls */
.auto-refresh-controls {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.auto-refresh-indicator {
    color: var(--primary-color);
    font-size: 0.875rem;
}

.refresh-frequency {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.refresh-frequency label {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--text-secondary);
    white-space: nowrap;
}

.refresh-frequency select {
    padding: 0.25rem 0.5rem;
    font-size: 0.8125rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    background-color: var(--surface-color);
    color: var(--text-primary);
    cursor: pointer;
    min-width: 100px;
}

.refresh-frequency select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(42, 138, 158, 0.1);
}

.form-control-sm {
    padding: 0.25rem 0.5rem;
    font-size: 0.8125rem;
}

.performance-chart-container {
    height: 300px;
    position: relative;
}

.performance-chart-container canvas {
    max-height: 300px;
}

.gc-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
}

.gc-metric {
    display: flex;
    justify-content: space-between;
    padding: 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.375rem;
}

.gc-label {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.gc-value {
    font-weight: 600;
    color: var(--text-primary);
}

/* =========================================
   Sessions Tab
   ========================================= */

.sessions-summary {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.summary-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.5rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.summary-card.small {
    padding: 0.75rem 1rem;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 100px;
    text-align: center;
}

.summary-icon {
    width: 48px;
    height: 48px;
    background-color: var(--primary-color);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.summary-content {
    display: flex;
    flex-direction: column;
}

.summary-value {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
}

.summary-label {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.page-distribution {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.page-bar-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.page-name {
    width: 150px;
    font-size: 0.875rem;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.page-bar {
    flex: 1;
    height: 8px;
    background-color: var(--background-color);
    border-radius: 4px;
    overflow: hidden;
}

.page-bar-fill {
    height: 100%;
    background-color: var(--primary-color);
    border-radius: 4px;
    transition: width 0.3s ease;
}

.page-count {
    width: 30px;
    text-align: right;
    font-weight: 600;
    color: var(--text-primary);
}

.user-cell {
    display: flex;
    flex-direction: column;
}

.user-cell .user-name {
    font-weight: 600;
}

.user-cell .user-email {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* =========================================
   Jobs Tab
   ========================================= */

.jobs-summary {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.job-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.75rem 1.25rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
    min-width: 80px;
}

.job-stat.success {
    background-color: rgba(91, 191, 106, 0.1);
    border-color: var(--success-color);
}

.job-stat.danger {
    background-color: rgba(229, 72, 77, 0.1);
    border-color: var(--danger-color);
}

.job-stat.active {
    background-color: rgba(42, 138, 158, 0.15);
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(42, 138, 158, 0.2);
    transform: translateY(-2px);
}

.job-stat:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.job-stat.active:hover {
    transform: translateY(-2px);
}

.job-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

.job-stat.success .job-stat-value {
    color: var(--success-color);
}

.job-stat.danger .job-stat-value {
    color: var(--danger-color);
}

.job-stat-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.queue-list {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.queue-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.375rem;
}

.queue-name {
    font-weight: 500;
    color: var(--text-primary);
}

.error-text {
    color: var(--danger-color);
    font-size: 0.8125rem;
}

/* =========================================
   Logs Tab
   ========================================= */

.log-distribution {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.log-level-badge {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 600;
}

.log-level-badge.level-error {
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
}

.log-level-badge.level-warning {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.log-level-badge.level-info {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.log-level-badge.level-debug {
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
}

.log-level-badge.total {
    background-color: var(--background-color);
    color: var(--text-primary);
}

.level-count {
    font-weight: 700;
}

.logs-table-container {
    max-height: 500px;
    overflow-y: auto;
}

.log-row-error {
    background-color: rgba(229, 72, 77, 0.05);
}

.log-row-warning {
    background-color: rgba(224, 162, 42, 0.05);
}

.log-message {
    max-width: 400px;
}

.message-text {
    word-break: break-word;
}

.exception-details {
    margin-top: 0.5rem;
}

.exception-details summary {
    cursor: pointer;
    color: var(--danger-color);
    font-size: 0.8125rem;
}

.exception-details pre {
    margin-top: 0.5rem;
    padding: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
    font-size: 0.75rem;
    overflow-x: auto;
    max-height: 200px;
}

.badge-warning {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.badge-secondary {
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
}

/* =========================================
   Security Tab
   ========================================= */

.security-summary {
    margin-bottom: 1rem;
}

.security-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem;
    background-color: rgba(91, 191, 106, 0.1);
    border: 2px solid var(--success-color);
    border-radius: 0.5rem;
}

.security-card.suspicious {
    background-color: rgba(229, 72, 77, 0.1);
    border-color: var(--danger-color);
}

.security-icon {
    width: 60px;
    height: 60px;
    background-color: var(--success-color);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
}

.security-card.suspicious .security-icon {
    background-color: var(--danger-color);
}

.security-status {
    font-size: 1.25rem;
    font-weight: 600;
}

.security-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}

.security-metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.security-metric.warning {
    background-color: rgba(224, 162, 42, 0.1);
    border-color: var(--warning-color);
}

.security-metric .metric-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
}

.security-metric.warning .metric-value {
    color: var(--warning-color);
}

.security-metric .metric-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
    margin-top: 0.25rem;
}

.ip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.ip-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background-color: rgba(229, 72, 77, 0.1);
    border-radius: 0.375rem;
    color: var(--danger-color);
}

.ip-attempts-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.ip-attempt-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background-color: var(--background-color);
    border-radius: 0.375rem;
    border: 1px solid var(--border-color);
}

.ip-attempt-item.high {
    background-color: rgba(229, 72, 77, 0.1);
    border-color: var(--danger-color);
}

/* =========================================
   Database Cards
   ========================================= */

.database-card {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
    margin-bottom: 1rem;
    overflow: hidden;
}

.database-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    background-color: var(--surface-color);
    border-bottom: 1px solid var(--border-color);
}

.database-header h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.database-server {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.database-details {
    padding: 1rem;
}

.database-metrics {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.db-metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0.5rem 1rem;
    background-color: var(--surface-color);
    border-radius: 0.375rem;
    min-width: 80px;
}

.db-metric-value {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--primary-color);
}

.db-metric-label {
    font-size: 0.6875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.database-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.db-info-item {
    display: flex;
    gap: 0.5rem;
    font-size: 0.8125rem;
}

.db-info-label {
    color: var(--text-secondary);
}

.db-info-value {
    color: var(--text-primary);
    font-weight: 500;
}

.largest-tables {
    margin-top: 1rem;
}

.largest-tables h5 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.5rem 0;
}

/* =========================================
   Setup Help Panel
   ========================================= */

.help-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border: none;
    background: none;
    color: var(--text-secondary);
    cursor: pointer;
    border-radius: 50%;
    transition: all 0.2s;
    margin-left: 0.5rem;
    vertical-align: middle;
}

.help-icon-btn:hover {
    color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.1);
}

.help-icon-btn i {
    font-size: 1rem;
}

.setup-help-panel {
    background: linear-gradient(135deg, rgba(42, 138, 158, 0.05) 0%, rgba(68, 98, 108, 0.05) 100%);
    border: 1px solid rgba(42, 138, 158, 0.2);
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    overflow: hidden;
}

.setup-help-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    background-color: rgba(42, 138, 158, 0.1);
    border-bottom: 1px solid rgba(42, 138, 158, 0.15);
}

.setup-help-header h4 {
    margin: 0;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--primary-color);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.btn-close-sm {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border: none;
    background: none;
    color: var(--text-secondary);
    cursor: pointer;
    border-radius: 0.25rem;
    transition: all 0.2s;
}

.btn-close-sm:hover {
    background-color: rgba(0, 0, 0, 0.1);
    color: var(--text-primary);
}

.setup-help-content {
    padding: 1rem;
}

.setup-help-intro {
    margin: 0 0 0.75rem 0;
    color: var(--text-primary);
    font-size: 0.875rem;
    line-height: 1.5;
}

.setup-steps {
    margin: 0 0 1rem 1.25rem;
    padding: 0;
    color: var(--text-primary);
    font-size: 0.875rem;
    line-height: 1.8;
}

.setup-steps li {
    margin-bottom: 0.5rem;
}

.setup-steps ul {
    margin: 0.5rem 0 0 1.25rem;
    padding: 0;
}

.setup-steps ul li {
    margin-bottom: 0.25rem;
}

.setup-steps code {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-dark);
    padding: 0.15rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.8125rem;
}

.required-badge {
    display: inline-block;
    padding: 0.1rem 0.4rem;
    font-size: 0.65rem;
    font-weight: 600;
    border-radius: 0.25rem;
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
    text-transform: uppercase;
    margin-left: 0.5rem;
}

.optional-badge {
    display: inline-block;
    padding: 0.1rem 0.4rem;
    font-size: 0.65rem;
    font-weight: 600;
    border-radius: 0.25rem;
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
    text-transform: uppercase;
    margin-left: 0.5rem;
}

.setup-note {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.75rem;
    background-color: rgba(224, 162, 42, 0.1);
    border: 1px solid rgba(224, 162, 42, 0.3);
    border-radius: 0.375rem;
    font-size: 0.8125rem;
    color: var(--warning-dark);
}

.setup-note i {
    color: var(--warning-color);
    margin-top: 0.1rem;
}

/* =========================================
   Version Value (Overflow Fix)
   ========================================= */

.version-value {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: help;
}

/* =========================================
   Helper Classes
   ========================================= */

.text-secondary {
    color: var(--text-secondary);
}

.text-success {
    color: var(--success-color);
}

.text-danger {
    color: var(--danger-color);
}

code {
    font-family: 'Cascadia Code', 'Fira Code', Consolas, monospace;
    font-size: 0.8125rem;
    background-color: var(--background-color);
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
}

/* =========================================
   Enhanced Jobs Tab Styles
   ========================================= */

.jobs-header {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 1rem;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

/* Queue Grid - Expandable Cards */
.queue-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1rem;
}

.queue-card {
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s;
}

.queue-card:hover {
    border-color: var(--primary-color);
    box-shadow: var(--shadow-sm);
}

.queue-card.expanded {
    grid-column: 1 / -1;
    cursor: default;
}

.queue-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    background-color: var(--background-color);
}

.queue-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.queue-jobs {
    padding: 1rem;
    border-top: 1px solid var(--border-color);
    max-height: 400px;
    overflow-y: auto;
}

.loading-inline {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
    padding: 1rem;
}

.pagination-info {
    text-align: center;
    padding: 0.75rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
    border-top: 1px solid var(--border-color);
    margin-top: 0.75rem;
}

/* Job Details Modal */
.modal-lg {
    max-width: 700px;
}

.job-details-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.job-detail-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.job-detail-item.full-width {
    grid-column: 1 / -1;
}

.job-detail-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.job-detail-value {
    font-size: 0.9375rem;
    color: var(--text-primary);
    word-break: break-word;
}

.job-section {
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}

.job-section h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 1rem 0;
}

.job-parameters {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.param-item {
    display: flex;
    gap: 0.75rem;
    padding: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.375rem;
}

.param-name {
    font-weight: 600;
    color: var(--text-secondary);
    min-width: 100px;
    flex-shrink: 0;
}

.param-value {
    flex: 1;
    word-break: break-all;
}

.error-section {
    background-color: rgba(229, 72, 77, 0.05);
    margin-left: -1.5rem;
    margin-right: -1.5rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    padding-bottom: 1rem;
    border-radius: 0;
}

.error-section h4 {
    color: var(--danger-color);
}

.exception-info {
    font-size: 0.875rem;
}

.exception-type {
    font-weight: 600;
    color: var(--danger-color);
    margin-bottom: 0.5rem;
}

.exception-message {
    color: var(--text-primary);
    margin-bottom: 0.75rem;
}

.exception-stack {
    background-color: var(--surface-color);
    padding: 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.75rem;
    overflow-x: auto;
    max-height: 200px;
    white-space: pre-wrap;
    word-break: break-word;
}

.state-history {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.state-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.375rem;
}

.state-time {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.state-reason {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    font-style: italic;
}

/* Button link style without underline */
.btn-link {
    text-decoration: none;
}

.btn-link:hover {
    text-decoration: underline;
}

/* =========================================
   System Registration Form Styles
   ========================================= */

.registration-container {
    max-width: 1000px;
    margin: 0 auto;
}

/* Progress Indicator */
.form-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2rem;
    padding: 1.5rem;
    background-color: var(--surface-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.progress-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
}

.step-number {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: var(--background-color);
    border: 2px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--text-secondary);
    transition: all 0.3s;
}

.progress-step.active .step-number {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
    box-shadow: 0 0 0 4px rgba(42, 138, 158, 0.2);
}

.progress-step.completed .step-number {
    background-color: var(--success-color);
    border-color: var(--success-color);
    color: white;
}

.step-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.progress-step.active .step-label {
    color: var(--primary-color);
    font-weight: 600;
}

.progress-step.completed .step-label {
    color: var(--success-color);
}

.progress-line {
    flex: 1;
    height: 2px;
    background-color: var(--border-color);
    margin: 0 0.5rem;
    max-width: 80px;
    margin-bottom: 1.5rem;
}

.progress-line.completed {
    background-color: var(--success-color);
}

/* Form Tabs */
.form-tabs {
    display: flex;
    gap: 0;
    background-color: var(--background-color);
    border-radius: 0.5rem 0.5rem 0 0;
    border: 1px solid var(--border-color);
    border-bottom: none;
    overflow-x: auto;
}

.form-tab {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    color: var(--text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.form-tab:hover {
    color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.05);
}

.form-tab.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
    background-color: var(--surface-color);
}

/* Form Content */
.form-content {
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0 0 0.5rem 0.5rem;
    min-height: 500px;
}

.form-section {
    padding: 1.5rem;
}

.section-header {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-color);
}

.section-header h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.25rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.section-header p {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0;
}

/* Form Rows */
.form-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-bottom: 1rem;
}

.form-row .flex-1 {
    grid-column: span 1;
}

.form-row .flex-2 {
    grid-column: span 1;
}

@media (min-width: 768px) {
    .form-row {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .form-row .flex-2 {
        grid-column: span 1;
    }
}

.form-group.full-width {
    grid-column: 1 / -1;
    margin-bottom: 1rem;
}

/* Form Elements */
.form-group label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 0.375rem;
}

.form-group label .required {
    color: var(--danger-color);
}

.form-hint {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.form-textarea {
    resize: vertical;
    min-height: 100px;
}

.char-counter {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-align: right;
    margin-top: 0.25rem;
}

/* Tags Input */
.tags-input-container {
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    padding: 0.5rem;
    background-color: var(--surface-color);
}

.tags-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    margin-bottom: 0.5rem;
}

.tag {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.5rem;
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
    border-radius: 0.25rem;
    font-size: 0.8125rem;
    font-weight: 500;
}

.tag-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border: none;
    background: none;
    color: var(--primary-color);
    cursor: pointer;
    border-radius: 50%;
    transition: all 0.2s;
}

.tag-remove:hover {
    background-color: var(--primary-color);
    color: white;
}

.tag-input {
    border: none !important;
    box-shadow: none !important;
    padding: 0.25rem !important;
}

.tag-input:focus {
    outline: none;
}

/* Radio Group */
.radio-group {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.radio-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}

.radio-item input[type="radio"] {
    width: 18px;
    height: 18px;
    accent-color: var(--primary-color);
}

.priority-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.priority-low {
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
}

.priority-medium {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.priority-high {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.priority-critical {
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
}

/* Input with Icon */
.input-with-icon {
    position: relative;
}

.input-with-icon i {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
}

.input-with-icon .form-control.with-icon {
    padding-left: 2.5rem;
}

/* Input with Actions */
.input-with-actions {
    display: flex;
    gap: 0.5rem;
}

.input-with-actions .form-control {
    flex: 1;
}

.btn-icon-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    background-color: var(--surface-color);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
}

.btn-icon-action:hover {
    background-color: var(--background-color);
    color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-icon-action.danger:hover {
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
    border-color: var(--danger-color);
}

/* Form Divider */
.form-divider {
    display: flex;
    align-items: center;
    margin: 1.5rem 0;
}

.form-divider::before,
.form-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background-color: var(--border-color);
}

.form-divider span {
    padding: 0 1rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

/* Range Input */
.range-input-container {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.form-range {
    flex: 1;
    height: 6px;
    -webkit-appearance: none;
    appearance: none;
    background: var(--border-color);
    border-radius: 3px;
}

.form-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    background: var(--primary-color);
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.range-value {
    min-width: 30px;
    text-align: center;
    font-weight: 600;
    color: var(--primary-color);
}

/* Switch Group */
.switch-group {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.switch-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.2s;
}

.switch-item:hover {
    background-color: rgba(42, 138, 158, 0.05);
}

.switch-item.featured {
    border: 2px solid var(--primary-color);
    background-color: rgba(42, 138, 158, 0.05);
}

.switch-input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.switch-slider {
    position: relative;
    width: 44px;
    height: 24px;
    background-color: var(--border-color);
    border-radius: 24px;
    transition: all 0.3s;
    flex-shrink: 0;
}

.switch-slider::after {
    content: "";
    position: absolute;
    top: 2px;
    left: 2px;
    width: 20px;
    height: 20px;
    background-color: white;
    border-radius: 50%;
    transition: all 0.3s;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.switch-input:checked + .switch-slider {
    background-color: var(--primary-color);
}

.switch-input:checked + .switch-slider::after {
    transform: translateX(20px);
}

.switch-label {
    display: flex;
    flex-direction: column;
}

.switch-label strong {
    font-size: 0.9375rem;
    color: var(--text-primary);
}

.switch-label small {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

/* Compact Switch */
.switch-compact {
    cursor: pointer;
}

.switch-compact .switch-slider {
    width: 40px;
    height: 22px;
}

.switch-compact .switch-slider::after {
    width: 18px;
    height: 18px;
}

.switch-compact .switch-input:checked + .switch-slider::after {
    transform: translateX(18px);
}

/* Conditional Section */
.conditional-section {
    margin-top: 1rem;
    padding: 1rem;
    background-color: rgba(42, 138, 158, 0.05);
    border-radius: 0.5rem;
    border-left: 3px solid var(--primary-color);
}

/* File Upload */
.file-upload-container {
    display: flex;
    gap: 0.5rem;
}

.file-upload-container .form-control {
    flex: 1;
}

/* Connection Test Panel */
.connection-test-panel {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
    margin-top: 1.5rem;
}

.test-status {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
}

.test-status i {
    font-size: 1.125rem;
}

.test-status.success {
    color: var(--success-color);
}

.test-status.error {
    color: var(--danger-color);
}

/* Threshold Cards */
.threshold-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}

.threshold-card {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
    overflow: hidden;
}

.threshold-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background-color: var(--surface-color);
    border-bottom: 1px solid var(--border-color);
    font-weight: 600;
    font-size: 0.875rem;
}

.threshold-header i {
    color: var(--primary-color);
}

.threshold-inputs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
    padding: 0.75rem;
}

.threshold-input label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}

.input-with-suffix {
    display: flex;
    align-items: center;
}

.input-with-suffix .form-control {
    border-radius: 0.375rem 0 0 0.375rem;
    border-right: none;
}

.input-with-suffix .suffix {
    padding: 0.5rem 0.75rem;
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: 0 0.375rem 0.375rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

/* Endpoints List */
.endpoints-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.endpoint-item {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.endpoint-method {
    padding: 0.5rem 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.75rem;
    font-weight: 600;
    min-width: 60px;
    text-align: center;
}

.endpoint-method.get {
    background-color: rgba(91, 191, 106, 0.1);
    color: var(--success-color);
}

.endpoint-method.post {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.endpoint-name {
    max-width: 200px;
}

/* Notification Channels */
.notification-channels {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.channel-card {
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    overflow: hidden;
    transition: all 0.2s;
}

.channel-card.enabled {
    border-color: var(--primary-color);
}

.channel-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    background-color: var(--background-color);
}

.channel-card.enabled .channel-header {
    background-color: rgba(42, 138, 158, 0.05);
}

.channel-icon {
    width: 40px;
    height: 40px;
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
}

.channel-icon.email {
    background: linear-gradient(135deg, var(--rdp-current) 0%, var(--rdp-tide) 100%);
}

.channel-icon.slack {
    background: linear-gradient(135deg, #4a154b 0%, #611f69 100%);
}

.channel-icon.teams {
    background: linear-gradient(135deg, #5059c9 0%, #7b83eb 100%);
}

.channel-icon.sms {
    background: linear-gradient(135deg, #00c853 0%, #64dd17 100%);
}

.channel-info {
    flex: 1;
}

.channel-info h4 {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.channel-info p {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin: 0;
}

.channel-body {
    padding: 1rem;
    background-color: var(--surface-color);
    border-top: 1px solid var(--border-color);
}

/* Alert Box */
.alert-box {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.8125rem;
    margin-top: 0.75rem;
}

.alert-box.warning {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-dark);
}

.alert-box i {
    color: var(--warning-color);
    margin-top: 0.1rem;
}

/* Notification Matrix */
.notification-matrix {
    overflow-x: auto;
}

.matrix-table {
    width: 100%;
    border-collapse: collapse;
}

.matrix-table th,
.matrix-table td {
    padding: 0.75rem;
    text-align: center;
    border-bottom: 1px solid var(--border-color);
}

.matrix-table th:first-child,
.matrix-table td:first-child {
    text-align: left;
}

.matrix-table th {
    background-color: var(--background-color);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.matrix-table th i {
    font-size: 1rem;
}

.matrix-table input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--primary-color);
}

.matrix-table input[type="checkbox"]:disabled {
    opacity: 0.3;
}

.event-type {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.event-type.info {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.event-type.warning {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.event-type.danger {
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
}

/* Time Range Input */
.time-range-input {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.time-range-input .form-control {
    max-width: 140px;
}

.time-range-input span {
    color: var(--text-secondary);
}

/* Review Summary */
.review-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1rem;
}

.review-card {
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    overflow: hidden;
}

.review-card-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background-color: var(--background-color);
    border-bottom: 1px solid var(--border-color);
}

.review-card-header i {
    color: var(--primary-color);
}

.review-card-header h4 {
    flex: 1;
    font-size: 0.9375rem;
    font-weight: 600;
    margin: 0;
}

.review-card-body {
    padding: 0.75rem 1rem;
}

.review-row {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border-color);
}

.review-row:last-child {
    border-bottom: none;
}

.review-label {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.review-value {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-primary);
}

.status-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 500;
}

.status-indicator.success {
    color: var(--success-color);
}

.status-indicator.warning {
    color: var(--warning-color);
}

.status-indicator.neutral {
    color: var(--text-secondary);
}

.channel-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}

.channel-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.2rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.6875rem;
    font-weight: 600;
}

.channel-badge.email {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.channel-badge.slack {
    background-color: rgba(74, 21, 75, 0.1);
    color: #4a154b;
}

.channel-badge.teams {
    background-color: rgba(80, 89, 201, 0.1);
    color: #5059c9;
}

.channel-badge.sms {
    background-color: rgba(0, 200, 83, 0.1);
    color: #00c853;
}

/* Terms Agreement */
.terms-agreement {
    margin-top: 1.5rem;
    padding: 1rem;
    background-color: var(--background-color);
    border-radius: 0.5rem;
}

.checkbox-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
}

.checkbox-item input[type="checkbox"] {
    width: 20px;
    height: 20px;
    accent-color: var(--primary-color);
    margin-top: 0.1rem;
}

.checkbox-label {
    font-size: 0.875rem;
    color: var(--text-primary);
    line-height: 1.5;
}

/* Form Actions Bar */
.form-actions-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-top: none;
    border-radius: 0 0 0.5rem 0.5rem;
    margin-top: -1px;
}

.actions-left,
.actions-right {
    display: flex;
    gap: 0.5rem;
}

/* Success Modal */
.success-header {
    background: linear-gradient(135deg, var(--success-color) 0%, var(--success-dark) 100%);
    color: white;
}

.success-header h3 {
    color: white;
}

.success-content {
    text-align: center;
    padding: 1rem 0;
}

.success-icon {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, var(--success-color) 0%, var(--success-dark) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.5rem;
    color: white;
    font-size: 2.5rem;
}

.success-details {
    background-color: var(--background-color);
    border-radius: 0.5rem;
    padding: 1rem;
    margin-top: 1rem;
}

.success-details .detail-item {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
}

.success-details .detail-label {
    color: var(--text-secondary);
}

.success-details .detail-value {
    font-weight: 600;
}

/* Monitoring Config */
.monitoring-config {
    margin-top: 1rem;
}

/* =========================================
   Support Desk Styles
   ========================================= */

/* Statistics Grid */
.support-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.support-stat-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    background-color: var(--surface-color);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}

.support-stat-card .stat-icon {
    width: 40px;
    height: 40px;
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
}

.support-stat-card .stat-content {
    display: flex;
    flex-direction: column;
}

.support-stat-card .stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1;
}

.support-stat-card .stat-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
    margin-top: 0.25rem;
}

.stat-new .stat-icon {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.stat-open .stat-icon {
    background-color: rgba(91, 191, 106, 0.1);
    color: var(--success-color);
}

.stat-pending .stat-icon {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.stat-unassigned .stat-icon {
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
}

.stat-urgent .stat-icon {
    background-color: rgba(229, 72, 77, 0.1);
    color: var(--danger-color);
}

/* Search Box */
.search-box {
    position: relative;
    display: flex;
    align-items: center;
}

.search-box i {
    position: absolute;
    left: 0.75rem;
    color: var(--text-secondary);
}

.search-box input {
    padding: 0.5rem 0.75rem 0.5rem 2.25rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    font-size: 0.875rem;
    min-width: 200px;
}

.search-box input:focus {
    outline: none;
    border-color: var(--primary-color);
}

/* Last Sync Info */
.last-sync-info {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

/* Alert Messages */
.alert-message {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    border-radius: 0.375rem;
    margin-bottom: 0.75rem;
    font-size: 0.875rem;
}

.alert-message.alert-success {
    background-color: rgba(91, 191, 106, 0.1);
    border: 1px solid var(--success-color);
    color: var(--success-color);
}

.alert-message.alert-error {
    background-color: rgba(229, 72, 77, 0.1);
    border: 1px solid var(--danger-color);
    color: var(--danger-color);
}

.alert-close {
    margin-left: auto;
    background: none;
    border: none;
    cursor: pointer;
    color: inherit;
    opacity: 0.7;
}

.alert-close:hover {
    opacity: 1;
}

/* Ticket List */
.ticket-list {
    display: flex;
    flex-direction: column;
}

.ticket-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    transition: all 0.2s;
}

.ticket-item:last-child {
    border-bottom: none;
}

.ticket-item:hover {
    background-color: var(--background-color);
}

.ticket-item.ticket-new {
    background-color: rgba(42, 138, 158, 0.02);
    border-left: 3px solid var(--primary-color);
}

.ticket-item.ticket-urgent {
    background-color: rgba(229, 72, 77, 0.02);
}

.ticket-item.is-selected {
    background-color: rgba(42, 138, 158, 0.08);
}

/* Bulk-select checkboxes (row + header select-all). */
.ticket-select, .ticket-select-all {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}
.ticket-select input, .ticket-select-all input {
    width: 1.05rem;
    height: 1.05rem;
    cursor: pointer;
    accent-color: var(--primary-color);
}
.ticket-select-all { margin-right: 0.6rem; }

/* Bulk action bar — shown above the list while tickets are selected. */
.bulk-bar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.75rem;
    padding: 0.5rem 0.85rem;
    background: var(--rdp-navy, #0A2540);
    color: var(--rdp-ice, #EAF4F6);
    border-radius: 0.45rem;
    box-shadow: 0 4px 14px rgba(10, 37, 64, 0.18);
}
.bulk-count { font-weight: 600; margin-right: 0.4rem; display: inline-flex; align-items: center; gap: 0.4rem; }
.bulk-count i { color: var(--rdp-coolant, #3FC6CF); }
.bulk-bar .bulk-clear { color: var(--rdp-mist, #9FC0C8); margin-left: auto; }

/* Keyboard-shortcut row cursor + help overlay. */
.ticket-item.is-highlighted {
    box-shadow: inset 3px 0 0 var(--primary-color);
    background-color: rgba(42, 138, 158, 0.06);
}
.kbd-hint { color: var(--text-secondary); padding: 0.2rem 0.4rem; }
kbd {
    display: inline-block;
    min-width: 1.1rem;
    padding: 0.05rem 0.35rem;
    font-family: monospace;
    font-size: 0.75rem;
    line-height: 1.4;
    text-align: center;
    color: var(--text-primary);
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-bottom-width: 2px;
    border-radius: 0.25rem;
}
.shortcut-help-overlay {
    position: fixed;
    inset: 0;
    z-index: 1100;
    background: rgba(10, 37, 64, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
}
.shortcut-help {
    width: min(420px, 92vw);
    background: var(--surface-color);
    border-radius: 0.6rem;
    box-shadow: 0 18px 48px rgba(10, 37, 64, 0.3);
    padding: 1rem 1.25rem 1.25rem;
}
.shortcut-help-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.5rem; }
.shortcut-help-head h3 { margin: 0; font-size: 1rem; display: flex; align-items: center; gap: 0.5rem; }
.shortcut-list { list-style: none; margin: 0; padding: 0; }
.shortcut-list li { display: flex; align-items: center; gap: 0.75rem; padding: 0.35rem 0; border-bottom: 1px solid var(--border-color); }
.shortcut-list li:last-child { border-bottom: none; }
.shortcut-list li span { color: var(--text-secondary); font-size: 0.875rem; }
.shortcut-list li kbd { margin-right: 0.15rem; }

/* Customer / organisation view (/support/customer). */
.cust-domain { color: var(--text-secondary); }
.cust-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}
.cust-stat {
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 0.85rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}
.cust-stat-value { font-size: 1.5rem; font-weight: 700; color: var(--text-primary); }
.cust-stat-label { font-size: 0.8rem; color: var(--text-secondary); }
.cust-ticket-list { display: flex; flex-direction: column; }
.cust-empty { padding: 1rem; color: var(--text-secondary); }
.cust-ticket {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 1rem;
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    transition: background-color 0.15s;
}
.cust-ticket:last-child { border-bottom: none; }
.cust-ticket:hover { background-color: var(--background-color); }
.cust-ticket-num { font-family: monospace; font-size: 0.8rem; color: var(--text-secondary); flex: 0 0 auto; }
.cust-ticket-peer { font-weight: 600; flex: 0 0 auto; max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cust-ticket-subj { flex: 1 1 auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cust-ticket-time { flex: 0 0 auto; font-size: 0.8rem; color: var(--text-secondary); }
.cust-ticket-flag { flex: 0 0 auto; font-size: 0.75rem; font-weight: 600; color: var(--primary-color); }

.ticket-status {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.375rem;
    min-width: 80px;
}

.status-badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    font-size: 0.6875rem;
    font-weight: 600;
    border-radius: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.status-badge.status-new {
    background-color: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.status-badge.status-open {
    background-color: rgba(91, 191, 106, 0.1);
    color: var(--success-color);
}

.status-badge.status-pending {
    background-color: rgba(224, 162, 42, 0.1);
    color: var(--warning-color);
}

.status-badge.status-resolved {
    background-color: rgba(68, 98, 108, 0.1);
    color: var(--secondary-color);
}

.status-badge.status-closed {
    background-color: var(--background-color);
    color: var(--text-secondary);
}

.priority-indicator {
    font-size: 0.875rem;
}

.ticket-main {
    flex: 1;
    min-width: 0;
}

.ticket-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.ticket-number {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.1);
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
}

.ticket-subject {
    font-weight: 500;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ticket-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.ticket-meta span {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.ticket-arrow {
    color: var(--text-secondary);
}

/* Ticket Detail Page */
.ticket-title-row {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.ticket-title-row h2 {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
    margin: 0;
}

.ticket-number-large {
    font-size: 1rem;
    font-weight: 600;
    color: var(--primary-color);
    background-color: rgba(42, 138, 158, 0.1);
    padding: 0.25rem 0.5rem;
    border-radius: 0.375rem;
}

.ticket-detail-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1rem;
    margin-top: 0.75rem;
}

@media (max-width: 1024px) {
    .ticket-detail-grid {
        grid-template-columns: 1fr;
    }
}

.ticket-conversation {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.ticket-sidebar {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

/* Messages */
.messages-container {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1rem;
    max-height: 600px;
    overflow-y: auto;
}

.message {
    display: flex;
    flex-direction: column;
    padding: 1rem;
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.message.message-inbound {
    background-color: var(--surface-color);
    margin-right: 2rem;
}

.message.message-outbound {
    background-color: rgba(42, 138, 158, 0.03);
    margin-left: 2rem;
    border-color: rgba(42, 138, 158, 0.2);
}

.message-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
}

.message-sender {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.sender-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    color: white;
}

.sender-avatar.avatar-customer {
    background: linear-gradient(135deg, var(--secondary-color) 0%, var(--secondary-dark) 100%);
}

.sender-avatar.avatar-support {
    background: linear-gradient(135deg, var(--rdp-current) 0%, var(--rdp-tide) 100%);
}

.sender-info {
    display: flex;
    flex-direction: column;
}

.sender-name {
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--text-primary);
}

.sender-email {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.message-time {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.message-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.message-split-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: none;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    border-radius: 9999px;
    padding: 2px 10px;
    font-size: 0.72rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.message-split-btn:hover {
    color: var(--primary-color);
    border-color: var(--primary-color);
    background: rgba(42, 138, 158, 0.06);
}

.split-intro {
    font-size: 0.875rem;
    color: var(--text-primary);
    margin: 0 0 12px;
    line-height: 1.5;
}

/* System event divider in the conversation (auto-reopen, merge) */
.thread-event {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: center;
    margin: 6px auto;
    padding: 6px 14px;
    max-width: 90%;
    background: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: 9999px;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.thread-event i {
    color: var(--primary-color);
}

.thread-event-text {
    font-weight: 500;
}

.thread-event-time {
    color: var(--text-secondary);
    opacity: 0.8;
    white-space: nowrap;
}

/* Merge modal — target search results */
.merge-results {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 260px;
    overflow-y: auto;
    margin-top: 4px;
}

.merge-result {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1px;
    text-align: left;
    width: 100%;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 9px 12px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.merge-result:hover {
    border-color: var(--primary-color);
    background: rgba(42, 138, 158, 0.04);
}

.merge-selected {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    background: rgba(42, 138, 158, 0.06);
    border: 1px solid var(--primary-color);
    border-radius: 0.5rem;
    padding: 10px 12px;
    margin-bottom: 12px;
}

.merge-result-text {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.merge-result-num {
    font-family: var(--font-mono, monospace);
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--primary-color);
}

.merge-result-subj {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 440px;
}

.merge-result-cust {
    font-size: 0.78rem;
    color: var(--text-secondary);
}

.merge-clear {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 4px;
    flex-shrink: 0;
}

.merge-clear:hover {
    color: var(--danger-color);
}

.merge-empty {
    font-size: 0.85rem;
    color: var(--text-secondary);
    padding: 10px 2px;
}

.message-body {
    line-height: 1.6;
}

.message-content {
    font-size: 0.9375rem;
    color: var(--text-primary);
    white-space: pre-wrap;
    word-break: break-word;
}

.message-attachments {
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border-color);
}

.attachments-header {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.attachment-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
    margin-bottom: 0.25rem;
    font-size: 0.8125rem;
}

.attachment-name {
    flex: 1;
    color: var(--text-primary);
}

.attachment-size {
    color: var(--text-secondary);
}

/* Reply Card */
.reply-card .card-body {
    padding: 1rem;
}

.reply-info {
    margin-bottom: 0.75rem;
    padding: 0.5rem;
    background-color: var(--background-color);
    border-radius: 0.25rem;
}

.reply-textarea {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    font-size: 0.9375rem;
    font-family: inherit;
    resize: vertical;
    min-height: 120px;
}

.reply-textarea:focus {
    outline: none;
    border-color: var(--primary-color);
}

.reply-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.75rem;
}

.reply-hint {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Editable reply recipient */
.recipient-change {
    margin-left: 0.4rem;
    padding: 0;
    border: none;
    background: none;
    font: inherit;
    font-size: 0.75rem;
    color: var(--primary-color);
    cursor: pointer;
}

.recipient-change:hover {
    text-decoration: underline;
}

.recipient-editor {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--text-secondary);
}

.recipient-input {
    flex: 1;
    min-width: 0;
    padding: 0.4rem 0.5rem;
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    font-size: 0.875rem;
    font-family: inherit;
    color: var(--text-primary);
}

.recipient-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(42, 138, 158, 0.15);
}

.recipient-hint {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.4rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Customer Info */
.customer-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.customer-avatar {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, var(--secondary-color) 0%, var(--secondary-dark) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
}

.customer-details {
    display: flex;
    flex-direction: column;
}

.customer-name {
    font-weight: 600;
    color: var(--text-primary);
}

.customer-email {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

/* Property Groups */
.property-group {
    margin-bottom: 1rem;
}

.property-group:last-child {
    margin-bottom: 0;
}

.property-group label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
    margin-bottom: 0.375rem;
}

/* Detail Rows */
.detail-row {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border-color);
    font-size: 0.875rem;
}

.detail-row:last-child {
    border-bottom: none;
}

.detail-label {
    color: var(--text-secondary);
}

.detail-value {
    font-weight: 500;
    color: var(--text-primary);
}

/* Quick Actions */
.quick-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.quick-action-btn {
    width: 100%;
    justify-content: center;
}

/* Toast Message */
.toast-message {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 1.25rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    box-shadow: var(--shadow-lg);
    z-index: 3000;
    animation: slideInUp 0.3s ease-out;
}

.toast-message.toast-success {
    background-color: var(--success-color);
    color: white;
}

.toast-message.toast-error {
    background-color: var(--danger-color);
    color: white;
}

@keyframes slideInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Checkbox Label for Filters */
.checkbox-label {
    cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
    accent-color: var(--primary-color);
}







/* ============================================================
   Dashboard shell (DashboardShell.razor)
   Shared app chrome — global (not scoped) because NavLink renders a
   child component that scoped CSS can't reach; per the architecture
   note above, shared components live here.
   ============================================================ */
/* RunRDP dashboard shell — dark navy icon rail + light content canvas.
   Brand tokens come from wwwroot/brand/runrdp.css (Deep Current). The rail is
   a .rdp-field surface, so its contextual accent is Coolant; the light content
   canvas uses Current. */

.dash {
    display: flex;
    height: 100vh;
    overflow: hidden;
    background: var(--rdp-paper);
}

/* ============================================================
   Sidebar
   ============================================================ */
.dash-sidebar {
    position: relative;
    z-index: 20;
    width: 264px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    border-right: 1px solid rgba(159, 192, 200, 0.14);
    transition: width 0.22s ease;
}

.dash.is-collapsed .dash-sidebar {
    width: 76px;
}

/* ----- Brand header ----- */
.dash-side-header {
    display: flex;
    align-items: center;
    height: 60px;
    flex-shrink: 0;
    padding: 0 1.1rem;
    border-bottom: 1px solid rgba(159, 192, 200, 0.12);
}

.dash-brand {
    display: inline-flex;
    align-items: center;
}

.dash-brand-lockup {
    height: 24px;
    display: block;
}

.dash-brand-mark {
    height: 26px;
    display: none;
}

.dash.is-collapsed .dash-side-header {
    justify-content: center;
    padding: 0;
}

.dash.is-collapsed .dash-brand-lockup {
    display: none;
}

.dash.is-collapsed .dash-brand-mark {
    display: block;
}

/* ----- Section identity band ----- */
.dash-side-ident {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 1rem 1.1rem;
}

.dash-ident-icon {
    width: 38px;
    height: 38px;
    flex-shrink: 0;
    display: grid;
    place-items: center;
    border-radius: 11px;
    color: var(--rdp-coolant);
    background: rgba(63, 198, 207, 0.12);
    border: 1px solid rgba(63, 198, 207, 0.25);
    font-size: 1rem;
}

.dash-ident-text {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.dash-ident-title {
    color: var(--rdp-ice);
    font-family: var(--rdp-font-display);
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: -0.01em;
    white-space: nowrap;
}

.dash-ident-sub {
    color: var(--rdp-mist);
    font-size: 0.72rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dash.is-collapsed .dash-side-ident {
    justify-content: center;
    padding-left: 0;
    padding-right: 0;
}

/* ============================================================
   Navigation
   ============================================================ */
.dash-nav {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0.35rem 0.6rem 1rem;
}

/* When collapsed, let fly-outs escape the rail instead of being clipped. */
.dash.is-collapsed .dash-nav {
    overflow: visible;
}

.dash-group {
    position: relative;
    margin-bottom: 0.2rem;
}

.dash-group-head {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.6rem 0.6rem 0.3rem;
    color: var(--rdp-mist);
    font-family: var(--rdp-font-mono);
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dash.is-collapsed .dash-group-head {
    justify-content: center;
    padding: 0.5rem 0;
}

.dash.is-collapsed .dash-group-head .dash-link-label {
    display: none;
}

.dash-sub {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dash.is-collapsed .dash-sub {
    display: none;
}

/* ----- Links ----- */
.dash-link {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.5rem 0.65rem;
    border-radius: 9px;
    color: var(--rdp-mist);
    text-decoration: none;
    font-size: 0.88rem;
    font-weight: 500;
    white-space: nowrap;
    transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.dash-link:hover {
    background: rgba(159, 192, 200, 0.10);
    color: var(--rdp-ice);
}

.dash-link.active {
    background: rgba(63, 198, 207, 0.14);
    color: var(--rdp-ice);
    box-shadow: inset 0 0 0 1px rgba(63, 198, 207, 0.30);
}

.dash-link.active .dash-link-icon {
    color: var(--rdp-coolant);
}

.dash-link.is-disabled {
    opacity: 0.45;
    cursor: default;
}

.dash-link.is-disabled:hover {
    background: none;
    color: var(--rdp-mist);
}

.dash-link-icon {
    width: 20px;
    flex-shrink: 0;
    display: inline-flex;
    justify-content: center;
    font-size: 0.95rem;
}

.dash-link-label {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dash-tag {
    font-family: var(--rdp-font-mono);
    font-size: 0.55rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--rdp-mist);
    border: 1px solid rgba(159, 192, 200, 0.3);
    border-radius: 5px;
    padding: 1px 5px;
}

/* Single-link groups (e.g. Overview) center their icon when collapsed. */
.dash.is-collapsed .dash-group--single .dash-link {
    justify-content: center;
    padding: 0.6rem 0;
}

.dash.is-collapsed .dash-link-label {
    display: none;
}

/* ============================================================
   Collapsed fly-out menus
   ============================================================ */
.dash-flyout {
    display: none;
    position: absolute;
    left: calc(100% + 10px);
    top: -2px;
    min-width: 192px;
    padding: 0.5rem;
    background: var(--rdp-deep);
    border: 1px solid rgba(120, 190, 205, 0.22);
    border-radius: 12px;
    box-shadow: 0 24px 50px -18px rgba(0, 0, 0, 0.7);
    z-index: 50;
}

/* Invisible bridge across the gap so the pointer can travel from the
   icon to the fly-out without the hover dropping. */
.dash-flyout::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -12px;
    width: 12px;
}

.dash.is-collapsed .dash-group:hover > .dash-flyout {
    display: block;
}

/* Never show fly-outs while expanded. */
.dash:not(.is-collapsed) .dash-flyout {
    display: none !important;
}

.dash-flyout-head {
    display: block;
    padding: 0.25rem 0.5rem 0.45rem;
    color: var(--rdp-ice);
    font-family: var(--rdp-font-display);
    font-weight: 600;
    font-size: 0.85rem;
    border-bottom: 1px solid rgba(159, 192, 200, 0.14);
    margin-bottom: 0.35rem;
}

.dash-group--single .dash-flyout {
    padding: 0.45rem 0.6rem;
    min-width: 0;
}

.dash-group--single .dash-flyout-head {
    border: none;
    margin: 0;
    padding: 0.1rem 0.4rem;
    white-space: nowrap;
}

.dash-flyout-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.dash-flyout-link {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.42rem 0.5rem;
    border-radius: 7px;
    color: var(--rdp-mist);
    text-decoration: none;
    font-size: 0.85rem;
    white-space: nowrap;
}

.dash-flyout-link i {
    width: 16px;
    text-align: center;
    font-size: 0.8rem;
}

.dash-flyout-link:hover {
    background: rgba(159, 192, 200, 0.10);
    color: var(--rdp-ice);
}

.dash-flyout-link.is-disabled {
    opacity: 0.5;
}

.dash-flyout-link.is-disabled:hover {
    background: none;
    color: var(--rdp-mist);
}

.dash-flyout-link .dash-tag {
    margin-left: auto;
}

/* ============================================================
   Sidebar footer
   ============================================================ */
.dash-side-footer {
    padding: 0.7rem 0.6rem 0.9rem;
    border-top: 1px solid rgba(159, 192, 200, 0.12);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.dash-db {
    display: block;
    width: 100%;
    text-align: left;
    font: inherit;
    cursor: pointer;
    background: rgba(63, 198, 207, 0.08);
    border: 1px solid rgba(63, 198, 207, 0.22);
    border-radius: 9px;
    padding: 0.45rem 0.6rem;
    transition: background 0.15s ease, border-color 0.15s ease;
}

.dash-db:hover {
    background: rgba(63, 198, 207, 0.16);
    border-color: var(--rdp-coolant);
}

.dash-db-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: var(--rdp-mist);
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.dash-db-label i {
    color: var(--rdp-coolant);
    font-size: 0.72rem;
}

.dash-db-name {
    display: block;
    color: var(--rdp-ice);
    font-size: 0.82rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dash.is-collapsed .dash-db {
    display: none;
}

.dash-foot-link {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.5rem 0.65rem;
    border-radius: 9px;
    color: var(--rdp-mist);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 500;
    white-space: nowrap;
}

.dash-foot-link:hover {
    background: rgba(159, 192, 200, 0.10);
    color: var(--rdp-ice);
}

.dash.is-collapsed .dash-foot-link {
    justify-content: center;
    padding: 0.6rem 0;
}

.dash-user {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.3rem 0.4rem;
}

.dash-user-avatar {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(159, 192, 200, 0.16);
    color: var(--rdp-ice);
    font-size: 0.8rem;
}

.dash-user-name {
    color: var(--rdp-ice);
    font-size: 0.82rem;
    font-weight: 500;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dash-signout-form {
    margin: 0;
}

.dash-signout {
    background: transparent;
    border: none;
    color: var(--rdp-mist);
    cursor: pointer;
    padding: 0.3rem 0.4rem;
    border-radius: 7px;
    font-size: 0.9rem;
    transition: background 0.15s ease, color 0.15s ease;
}

.dash-signout:hover {
    background: rgba(229, 72, 77, 0.16);
    color: #ff9a9d;
}

.dash.is-collapsed .dash-user {
    justify-content: center;
}

.dash.is-collapsed .dash-user-name,
.dash.is-collapsed .dash-signout-form {
    display: none;
}

/* ============================================================
   Main content column
   ============================================================ */
.dash-main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: var(--rdp-paper);
}

.dash-topbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    height: 60px;
    flex-shrink: 0;
    padding: 0 1.4rem;
    background: var(--rdp-bone);
    border-bottom: 1px solid var(--rdp-line);
}

.dash-collapse {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    display: grid;
    place-items: center;
    border: 1px solid var(--rdp-line);
    border-radius: 9px;
    background: #fff;
    color: var(--rdp-slate);
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.dash-collapse:hover {
    color: var(--rdp-current);
    border-color: var(--rdp-current);
}

.dash-crumbs {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--rdp-slate);
}

.dash-crumbs a {
    color: var(--rdp-slate);
    text-decoration: none;
}

.dash-crumbs a:hover {
    color: var(--rdp-current);
}

.dash-crumbs > i {
    font-size: 0.7rem;
    opacity: 0.55;
}

.dash-crumb-current {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--rdp-navy);
    font-weight: 600;
}

.dash-crumb-current i {
    color: var(--rdp-current);
    font-size: 0.8rem;
}

.dash-topbar-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.dash-content {
    flex: 1;
    overflow-y: auto;
    padding: 1.25rem 1.5rem 2rem;
}

/* ============================================================
   Shared content helpers (the "display page" — into the
   section page rendered as ChildContent)
   ============================================================ */
.dash-content .dash-page {
    max-width: 1180px;
    margin: 0 auto;
}

.dash-content .dash-page-head {
    margin-bottom: 1.6rem;
}

.dash-content .dash-page-title {
    font-size: clamp(26px, 3.4vw, 38px);
    color: var(--rdp-navy);
    line-height: 1.05;
    margin: 0.35rem 0 0;
}

.dash-content .dash-page-sub {
    color: var(--rdp-slate);
    font-size: 1rem;
    margin-top: 0.5rem;
    max-width: 62ch;
}

/* Stat placeholders */
.dash-content .dash-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 2rem;
}

.dash-content .dash-stat {
    background: #fff;
    border: 1px solid var(--rdp-line);
    border-radius: 14px;
    padding: 1.1rem 1.2rem;
    box-shadow: var(--shadow-sm);
}

.dash-content .dash-stat-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--rdp-slate);
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.dash-content .dash-stat-label i {
    color: var(--rdp-current);
}

.dash-content .dash-stat-value {
    font-family: var(--rdp-font-display);
    font-weight: 600;
    font-size: 1.9rem;
    color: var(--rdp-navy);
    margin-top: 0.5rem;
}

.dash-content .dash-stat-hint {
    color: var(--rdp-slate);
    font-size: 0.78rem;
    margin-top: 0.2rem;
}

/* Section label */
.dash-content .dash-section-label {
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--rdp-slate);
    font-weight: 700;
    margin: 0 0 0.9rem;
}

/* Quick-link cards */
.dash-content .dash-quick-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(232px, 1fr));
    gap: 1rem;
    margin-bottom: 2rem;
}

.dash-content .dash-quick {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    text-align: left;
    text-decoration: none;
    color: inherit;
    background: #fff;
    border: 1px solid var(--rdp-line);
    border-radius: 14px;
    padding: 1.05rem 1.1rem;
    box-shadow: var(--shadow-sm);
    transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.18s ease;
}

.dash-content .dash-quick:hover {
    transform: translateY(-3px);
    border-color: var(--rdp-current);
    box-shadow: var(--shadow-md);
}

.dash-content .dash-quick.is-disabled {
    opacity: 0.55;
    pointer-events: none;
}

.dash-content .dash-quick-icon {
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    border-radius: 11px;
    display: grid;
    place-items: center;
    font-size: 1.05rem;
    color: var(--rdp-current);
    background: rgba(42, 138, 158, 0.10);
}

.dash-content .dash-quick-title {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 600;
    color: var(--rdp-navy);
    font-size: 0.98rem;
}

.dash-content .dash-quick-desc {
    display: block;
    color: var(--rdp-slate);
    font-size: 0.82rem;
    margin-top: 0.2rem;
    line-height: 1.45;
}

/* Call-to-action banner (e.g. select a database) */
.dash-content .dash-cta {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    background: linear-gradient(135deg, rgba(42, 138, 158, 0.10), rgba(95, 211, 194, 0.08));
    border: 1px solid rgba(42, 138, 158, 0.25);
    border-radius: 14px;
    padding: 1.1rem 1.3rem;
    margin-bottom: 1.8rem;
}

.dash-content .dash-cta-icon {
    font-size: 1.3rem;
    color: var(--rdp-current);
}

.dash-content .dash-cta-text {
    flex: 1;
    min-width: 200px;
}

.dash-content .dash-cta-title {
    font-weight: 600;
    color: var(--rdp-navy);
}

.dash-content .dash-cta-sub {
    color: var(--rdp-slate);
    font-size: 0.85rem;
}

/* Scaffold note */
.dash-content .dash-note {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    color: var(--rdp-slate);
    font-size: 0.82rem;
    border-top: 1px dashed var(--rdp-line);
    padding-top: 1rem;
    margin-top: 0.5rem;
}

.dash-content .dash-note i {
    color: var(--rdp-current);
}

/* ============================================================
   Narrow screens — force the rail to its icon state
   ============================================================ */
@media (max-width: 860px) {
    .dash-sidebar {
        width: 76px;
    }

    .dash-side-header {
        justify-content: center;
        padding: 0;
    }

    .dash-brand-lockup {
        display: none;
    }

    .dash-brand-mark {
        display: block;
    }

    .dash-side-ident {
        justify-content: center;
        padding-left: 0;
        padding-right: 0;
    }

    .dash-ident-text,
    .dash-link-label,
    .dash-group-head .dash-link-label,
    .dash-db,
    .dash-user-name,
    .dash-signout-form {
        display: none;
    }

    .dash-nav {
        overflow: visible;
    }

    .dash-sub {
        display: none;
    }

    .dash-group--single .dash-link,
    .dash-group-head,
    .dash-foot-link,
    .dash-user {
        justify-content: center;
        padding-left: 0;
        padding-right: 0;
    }

    .dash-group:hover > .dash-flyout {
        display: block;
    }

    .dash-collapse {
        display: none;
    }

    .dash-content {
        padding: 1.2rem 1.1rem 2rem;
    }
}


/* Compact page header for section pages inside the dashboard shell. */
.dash-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem 1.5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.dash-head-titles {
    min-width: 0;
}

.dash-head-title {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    font-family: var(--font-display);
    font-size: 1.4rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--rdp-navy);
    margin: 0;
}

.dash-head-title i {
    color: var(--rdp-current);
    font-size: 0.9em;
}

.dash-head-sub {
    color: var(--rdp-slate);
    font-size: 0.875rem;
    margin-top: 0.2rem;
}

.dash-head-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

/* Internal notes & reply/note composer (Support Desk) */
.message.message-internal {
    background-color: rgba(224, 162, 42, 0.08);
    border-color: rgba(224, 162, 42, 0.35);
    margin-left: 1rem;
    margin-right: 1rem;
}

.sender-avatar.avatar-internal {
    background: linear-gradient(135deg, var(--warning-color) 0%, var(--warning-dark) 100%);
}

.note-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-left: 0.5rem;
    padding: 1px 7px;
    font-size: 0.62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--warning-dark);
    background: rgba(224, 162, 42, 0.15);
    border-radius: 5px;
}

.compose-tabs {
    display: flex;
    gap: 0.25rem;
}

.compose-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.85rem;
    border: none;
    background: none;
    cursor: pointer;
    font-family: inherit;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-secondary);
    border-radius: 0.375rem;
    transition: background 0.15s ease, color 0.15s ease;
}

.compose-tab:hover {
    background: var(--background-color);
    color: var(--text-primary);
}

.compose-tab.active {
    background: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
}

.compose-tab--note.active {
    background: rgba(224, 162, 42, 0.14);
    color: var(--warning-dark);
}

.reply-info.note-info {
    color: var(--warning-dark);
}

.card-body.compose-note .reply-textarea:focus {
    border-color: var(--warning-color);
    box-shadow: 0 0 0 2px rgba(224, 162, 42, 0.15);
}

/* Ticket tags & priority colours (Support Desk) */
.ticket-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-top: 0.4rem;
}

.ticket-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.1rem 0.55rem;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--primary-color);
    background: rgba(42, 138, 158, 0.1);
    border-radius: 9999px;
}

.priority-indicator.priority-urgent { color: var(--danger-color); }
.priority-indicator.priority-high { color: var(--warning-color); }
.priority-indicator.priority-normal { color: var(--secondary-color); }
.priority-indicator.priority-low { color: var(--text-secondary); }

.tag-editor {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.3rem;
}

.ticket-tag.tag-removable {
    padding-right: 0.25rem;
}

.tag-remove-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 15px;
    height: 15px;
    border: none;
    background: none;
    color: var(--primary-color);
    cursor: pointer;
    border-radius: 50%;
    font-size: 0.6rem;
    padding: 0;
}

.tag-remove-btn:hover {
    background: var(--primary-color);
    color: #fff;
}

.tag-input-inline {
    flex: 1;
    min-width: 80px;
    border: none;
    background: none;
    font-size: 0.8rem;
    padding: 0.2rem;
    color: var(--text-primary);
}

.tag-input-inline:focus {
    outline: none;
}

/* Canned replies (Support Desk) */
.canned-picker {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.6rem;
    color: var(--primary-color);
    font-size: 0.85rem;
}

.canned-picker .compact-select {
    min-width: 200px;
}

.canned-manage {
    margin-left: auto;
    font-size: 0.8rem;
    color: var(--text-secondary);
    text-decoration: none;
}

.canned-manage:hover {
    color: var(--primary-color);
}

/* Cc on a reply — toggle + Outlook-style picker row */
.reply-cc {
    margin-bottom: 0.6rem;
}

.reply-cc-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: none;
    border: none;
    padding: 0.15rem 0;
    font-size: 0.85rem;
    color: var(--primary-color);
    cursor: pointer;
}

.reply-cc-toggle:hover {
    text-decoration: underline;
}

.reply-cc-row {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}

.reply-cc-label {
    flex: 0 0 auto;
    padding-top: 0.5rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.reply-cc-row .recipient-picker {
    flex: 1 1 auto;
    min-width: 0;
}

.sender-cc {
    display: block;
    font-size: 0.72rem;
    color: var(--text-secondary);
    margin-top: 0.1rem;
}

/* ============================================================
   Support ticket — Gmail/Outlook-style 2-pane mail view (.tkt*)
   ============================================================ */
.tkt {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 120px);
    min-height: 520px;
    max-width: 100%;
    min-width: 0;
}

/* Top bar */
.tkt-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding-bottom: 0.7rem;
    min-width: 0;
}
.tkt-topbar-main { display: flex; align-items: center; gap: 0.6rem; min-width: 0; }
.tkt-title { display: flex; align-items: baseline; gap: 0.6rem; min-width: 0; }
.tkt-number {
    font-weight: 700;
    color: var(--primary-color);
    background: rgba(42, 138, 158, 0.1);
    padding: 0.15rem 0.5rem;
    border-radius: 0.3rem;
    white-space: nowrap;
}
.tkt-subject {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}
.tkt-topbar-actions { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.tkt-topbar-actions .compact-select { min-width: 6.5rem; }
.tkt-action-sep { width: 1px; align-self: stretch; background: var(--border-color); margin: 0 0.25rem; }

/* Meta strip */
.tkt-meta {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    flex-wrap: wrap;
    padding: 0.5rem 0;
    font-size: 0.82rem;
    color: var(--text-secondary);
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
}
.tkt-meta-cust { display: flex; align-items: center; gap: 0.4rem; min-width: 0; }
.tkt-meta-name { font-weight: 600; color: var(--text-primary); }
.tkt-meta-input { padding: 0.25rem 0.5rem; border: 1px solid var(--border-color); border-radius: 0.3rem; font-size: 0.82rem; min-width: 14rem; }
.tkt-meta-tags { display: flex; align-items: center; gap: 0.3rem; flex-wrap: wrap; }
.tkt-meta-tags .tag-input-inline { min-width: 5rem; }
.tkt-meta-dates { display: flex; align-items: center; gap: 1rem; margin-left: auto; white-space: nowrap; }

/* Body: list | reading */
.tkt-body {
    flex: 1;
    min-height: 0;
    display: flex;
    border: 1px solid var(--border-color);
    border-top: none;
    border-radius: 0 0 8px 8px;
    overflow: hidden;
    background: var(--surface-color);
}

/* Left: email list */
.tkt-list {
    flex: 0 0 320px;
    width: 320px;
    min-width: 0;
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--border-color);
    background: var(--background-color);
}
.tkt-list-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0.5rem 0.75rem; border-bottom: 1px solid var(--border-color);
    font-size: 0.78rem; color: var(--text-secondary);
}
.tkt-sort {
    display: inline-flex; align-items: center; gap: 0.35rem;
    background: var(--surface-color); border: 1px solid var(--border-color); border-radius: 0.3rem;
    padding: 0.2rem 0.5rem; font-size: 0.78rem; color: var(--text-primary); cursor: pointer;
}
.tkt-sort:hover { border-color: var(--primary-color); color: var(--primary-color); }
.tkt-list-items { flex: 1; overflow-y: auto; }
.tkt-list-item {
    display: flex; align-items: flex-start; gap: 0.55rem;
    width: 100%; text-align: left; background: none;
    border: none; border-bottom: 1px solid var(--border-color);
    border-left: 3px solid transparent;
    padding: 0.6rem 0.75rem; cursor: pointer; min-width: 0;
}
.tkt-list-item:hover { background: rgba(42, 138, 158, 0.06); }
.tkt-list-item.is-active { background: rgba(42, 138, 158, 0.1); border-left-color: var(--primary-color); }
.tkt-li-icon {
    flex: 0 0 auto; width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.72rem; color: #fff;
}
.tkt-li-icon.avatar-customer { background: linear-gradient(135deg, var(--secondary-color) 0%, var(--secondary-dark) 100%); }
.tkt-li-icon.avatar-support { background: linear-gradient(135deg, var(--rdp-current) 0%, var(--rdp-tide) 100%); }
.tkt-li-icon.avatar-internal { background: linear-gradient(135deg, var(--warning-color) 0%, var(--warning-dark) 100%); }
.tkt-li-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0.1rem; }
.tkt-li-top { display: flex; align-items: baseline; justify-content: space-between; gap: 0.5rem; }
.tkt-li-from { font-weight: 600; font-size: 0.82rem; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tkt-li-time { font-size: 0.7rem; color: var(--text-secondary); white-space: nowrap; flex: 0 0 auto; }
.tkt-li-dir { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--text-secondary); }
.tkt-li-out .tkt-li-dir { color: var(--primary-color); }
.tkt-li-snippet { font-size: 0.78rem; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tkt-li-clip { color: var(--text-secondary); font-size: 0.72rem; margin-top: 0.2rem; }

/* Right: reading pane */
.tkt-read { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow-y: auto; }
.tkt-read-head {
    display: flex; align-items: flex-start; gap: 0.75rem;
    padding: 1rem 1.25rem; border-bottom: 1px solid var(--border-color);
    position: sticky; top: 0; background: var(--surface-color); z-index: 1;
}
.tkt-read-who { flex: 1; min-width: 0; }
.tkt-read-name { font-weight: 700; color: var(--text-primary); display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.tkt-read-sub { font-size: 0.8rem; color: var(--text-secondary); margin-top: 0.15rem; word-break: break-word; }
.tkt-read-cc { font-size: 0.78rem; color: var(--text-secondary); margin-top: 0.15rem; }
.tkt-read-recip { font-size: 0.78rem; color: var(--text-secondary); margin-top: 0.15rem; word-break: break-word; }
.tkt-recip-lbl { display: inline-block; min-width: 1.6rem; font-weight: 600; color: var(--text-secondary); margin-right: 0.3rem; }
.note-badge.note-badge--out { background: rgba(42, 138, 158, 0.12); color: var(--primary-color); }
.tkt-read-body { padding: 1.25rem; min-width: 0; }
.tkt-read-body .message-content { min-width: 0; overflow-x: auto; }
.tkt-read-body .message-content img { max-width: 100%; height: auto; }
.tkt-read-body .message-content table { max-width: 100%; }
.tkt-read-body .message-content--plain { white-space: pre-wrap; word-break: break-word; }
.tkt-read-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--text-secondary); gap: 0.5rem; padding: 2rem; }
.tkt-read-empty i { font-size: 2rem; opacity: 0.5; }

/* Gmail-style zoomable screenshots */
.rdp-zoomable { cursor: zoom-in; border-radius: 4px; }
.rdp-zoomable:hover { outline: 2px solid var(--primary-color); outline-offset: 2px; }
.rdp-lightbox {
    position: fixed; inset: 0; background: rgba(6, 26, 43, 0.88);
    display: none; align-items: center; justify-content: center;
    z-index: 1000; padding: 2.5rem; overflow: auto;
}
.rdp-lightbox.is-open { display: flex; }
.rdp-lightbox-img { max-width: none; height: auto; cursor: zoom-out; box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5); border-radius: 4px; }
.rdp-lightbox-hint { position: fixed; bottom: 1rem; left: 0; right: 0; text-align: center; color: rgba(255, 255, 255, 0.7); font-size: 0.8rem; }

/* Reply composer anchored at the bottom of the loaded email */
.tkt-reply { border-top: 1px solid var(--border-color); padding: 1rem 1.25rem; margin-top: auto; background: var(--background-color); }
.tkt-reply-field { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; }
.tkt-reply-label { flex: 0 0 28px; font-size: 0.8rem; font-weight: 600; color: var(--text-secondary); }
.tkt-reply-to { flex: 1; min-width: 0; padding: 0.35rem 0.55rem; border: 1px solid var(--border-color); border-radius: 0.3rem; font-size: 0.85rem; }
.tkt-reply-field .recipient-picker { flex: 1; min-width: 0; }

/* Narrow screens: stack the list above the reading pane */
@media (max-width: 860px) {
    .tkt { height: auto; min-height: 0; }
    .tkt-body { flex-direction: column; }
    .tkt-list { flex: 0 0 auto; width: auto; max-height: 240px; border-right: none; border-bottom: 1px solid var(--border-color); }
    .tkt-read { overflow-y: visible; }
    .tkt-meta-dates { margin-left: 0; }
}

/* Tickets list — richer rows + sort control */
.ticket-snippet {
    font-size: 0.82rem;
    color: var(--text-secondary);
    margin: 0.15rem 0 0.4rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}
.ticket-prio { display: inline-flex; align-items: center; gap: 0.3rem; }
.ticket-prio.priority-urgent { color: var(--danger-color); font-weight: 600; }
.ticket-prio.priority-high { color: var(--warning-dark); }
.sort-control { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--text-secondary); font-size: 0.85rem; }

/* Unread indicators (tickets list + ticket email list) */
.unread-dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--primary-color);
    margin-right: 0.35rem;
    flex: 0 0 auto;
    vertical-align: middle;
}
.unread-badge {
    display: inline-block;
    margin-left: 0.5rem;
    padding: 1px 7px;
    font-size: 0.66rem;
    font-weight: 700;
    color: #fff;
    background: var(--primary-color);
    border-radius: 999px;
    white-space: nowrap;
}
.ticket-item.ticket-unread { background: rgba(42, 138, 158, 0.05); }
.ticket-item.ticket-unread .ticket-subject { font-weight: 700; color: var(--text-primary); }
.tkt-list-item.tkt-li-unread { background: rgba(42, 138, 158, 0.05); }
.tkt-list-item.tkt-li-unread .tkt-li-from { font-weight: 800; color: var(--text-primary); }
.tkt-list-item.tkt-li-unread .tkt-li-snippet { color: var(--text-primary); }

/* AI suggested reply panel */
/* Floating "AI is drafting" banner — shown on support pages while a suggestion is being prepared
   (background sync or on-demand). Dark navy pill with a Coolant accent (Coolant = dark surfaces). */
.ai-activity-banner {
    position: fixed;
    top: 14px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1200;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    max-width: calc(100vw - 2rem);
    padding: 0.5rem 1rem;
    background: var(--rdp-navy, #0A2540);
    color: var(--rdp-ice, #EAF4F6);
    border: 1px solid rgba(63, 198, 207, 0.45);
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 600;
    box-shadow: 0 8px 24px rgba(10, 37, 64, 0.28);
    animation: ai-banner-in 0.2s ease-out;
}
.ai-activity-banner i { color: var(--rdp-coolant, #3FC6CF); }
@keyframes ai-banner-in {
    from { opacity: 0; transform: translate(-50%, -8px); }
    to   { opacity: 1; transform: translate(-50%, 0); }
}
@media (prefers-reduced-motion: reduce) {
    .ai-activity-banner { animation: none; }
    .ai-activity-banner .fa-spin { animation: none; }
}

.ai-suggestion {
    border: 1px solid rgba(42, 138, 158, 0.35);
    background: rgba(42, 138, 158, 0.06);
    border-radius: 0.4rem;
    padding: 0.6rem 0.75rem;
    margin-bottom: 0.6rem;
}
.ai-suggestion-head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.4rem;
}
.ai-suggestion-title { font-weight: 700; color: var(--primary-color); font-size: 0.85rem; }
.ai-suggestion-model { font-size: 0.7rem; color: var(--text-secondary); font-family: monospace; }
.ai-suggestion-actions { margin-left: auto; display: flex; gap: 0.35rem; }
.ai-suggestion-body {
    white-space: pre-wrap;
    font-size: 0.88rem;
    color: var(--text-primary);
    max-height: 220px;
    overflow-y: auto;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.3rem;
    padding: 0.6rem;
}
.ai-suggestion-note { font-size: 0.72rem; color: var(--text-secondary); margin-top: 0.4rem; }

/* Polish preview — distinct (aqua, "edit of your draft") from the teal AI-draft suggestion */
.ai-suggestion.polish-preview {
    border-color: rgba(95, 211, 194, 0.5);
    border-left: 3px solid rgba(95, 211, 194, 0.9);
    background: rgba(95, 211, 194, 0.09);
}

/* AI system-prompt editor (Support dashboard) */
.ai-prompt-card { display: block; }
.ai-prompt-editor {
    width: 100%;
    margin-top: 0.75rem;
    padding: 0.75rem 0.85rem;
    border: 1px solid var(--border-color);
    border-radius: 0.4rem;
    background: var(--surface-color);
    color: var(--text-primary);
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 0.82rem;
    line-height: 1.5;
    resize: vertical;
    min-height: 220px;
}
.ai-prompt-editor:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(42, 138, 158, 0.15);
}
.ai-prompt-actions { display: flex; align-items: center; gap: 0.6rem; margin-top: 0.75rem; flex-wrap: wrap; }
.ai-prompt-saved { color: var(--success-color); font-size: 0.85rem; font-weight: 600; }

.ai-ops { margin-top: 1rem; padding-top: 0.85rem; border-top: 1px solid var(--border-color); display: flex; flex-direction: column; gap: 0.6rem; }
.ai-op-row { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; flex-wrap: wrap; font-size: 0.88rem; color: var(--text-secondary); }
.ai-op-row strong { color: var(--text-primary); }
.ai-op-msg { font-size: 0.82rem; color: var(--text-secondary); margin: 0.2rem 0 0; }

/* AI helpers (Polish + Draft) sitting on the right of the Reply / Internal note tab row */
.compose-ai-tools { margin-left: auto; display: inline-flex; align-items: center; gap: 0.4rem; }
.polish-wrap { position: relative; }
.polish-menu {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    z-index: 30;
    min-width: 200px;
    padding: 4px;
    display: flex;
    flex-direction: column;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.4rem;
    box-shadow: 0 6px 18px rgba(10, 37, 64, 0.14);
}
.polish-menu button {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.45rem 0.6rem;
    border-radius: 0.3rem;
    font-size: 0.85rem;
    color: var(--text-primary);
}
.polish-menu button:hover { background: rgba(42, 138, 158, 0.1); }
.polish-menu button i { width: 1rem; text-align: center; color: var(--text-secondary); }

/* Snooze dropdown (ticket top bar) — mirrors the Polish menu, with a note input + custom time row. */
.tkt-snooze-wrap { position: relative; display: inline-flex; }
.snooze-menu {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    z-index: 30;
    min-width: 230px;
    padding: 4px;
    display: flex;
    flex-direction: column;
    gap: 1px;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 0.4rem;
    box-shadow: 0 6px 18px rgba(10, 37, 64, 0.14);
}
.snooze-menu > button {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.45rem 0.6rem;
    border-radius: 0.3rem;
    font-size: 0.85rem;
    color: var(--text-primary);
}
.snooze-menu > button:hover { background: rgba(42, 138, 158, 0.1); }
.snooze-menu > button i { width: 1rem; text-align: center; color: var(--text-secondary); }
.snooze-note {
    width: 100%;
    padding: 0.4rem 0.5rem;
    margin-bottom: 2px;
    border: 1px solid var(--border-color);
    border-radius: 0.3rem;
    font-size: 0.8rem;
}
.snooze-custom {
    display: flex;
    gap: 0.35rem;
    align-items: center;
    padding: 0.4rem 0.4rem 0.2rem;
    border-top: 1px solid var(--border-color);
    margin-top: 2px;
}
.snooze-custom input { flex: 1 1 auto; min-width: 0; padding: 0.3rem 0.4rem; border: 1px solid var(--border-color); border-radius: 0.3rem; font-size: 0.8rem; }

/* "Snoozed until …" banner under the ticket meta strip. */
.tkt-snooze-banner {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin: 0.5rem 0 0;
    padding: 0.5rem 0.8rem;
    background: rgba(42, 138, 158, 0.08);
    border: 1px solid rgba(42, 138, 158, 0.25);
    border-radius: 0.4rem;
    font-size: 0.85rem;
    color: var(--text-primary);
}
.tkt-snooze-banner > i { color: var(--primary-color); }
.tkt-snooze-banner > span { flex: 1 1 auto; }

/* Snoozed pill on a tickets-list row (visible when "Show snoozed" is ticked). */
.ticket-snoozed {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.78rem;
    color: var(--primary-color);
    font-weight: 600;
}

/* "Awaiting my reply" toolbar toggle — highlights when active. */
.awaiting-toggle {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.875rem;
    padding: 0.25rem 0.6rem;
    border: 1px solid var(--border-color);
    border-radius: 999px;
    cursor: pointer;
    white-space: nowrap;
}
.awaiting-toggle i { color: var(--primary-color); }
.awaiting-toggle.is-active {
    background: rgba(42, 138, 158, 0.12);
    border-color: rgba(42, 138, 158, 0.5);
    font-weight: 600;
}

/* Ageing pill on a tickets-list row — how long the customer has been waiting, escalating colour. */
.ticket-awaiting {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.78rem;
    font-weight: 600;
}
.ticket-awaiting.age-fresh { color: var(--primary-color); }
.ticket-awaiting.age-warn  { color: var(--warning-color); }
.ticket-awaiting.age-old   { color: var(--danger-color); }

/* Closure-reason select nudges for a value while a ticket is resolved/closed without one. */
.compact-select.needs-value {
    border-color: var(--warning-color);
    box-shadow: 0 0 0 2px rgba(224, 162, 42, 0.15);
}

/* Reason-code editor (dashboard): two side-by-side code lists. */
.reason-code-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin-bottom: 0.75rem;
}
.reason-code-label {
    display: block;
    font-weight: 600;
    font-size: 0.85rem;
    margin-bottom: 0.3rem;
    color: var(--text-primary);
}

/* MI report breakdown bars (/support/reports). */
.mi-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.35rem 0;
}
.mi-label {
    flex: 0 0 200px;
    font-size: 0.875rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mi-bar {
    flex: 1 1 auto;
    height: 0.85rem;
    background: var(--background-color);
    border-radius: 999px;
    overflow: hidden;
}
.mi-bar-fill {
    display: block;
    height: 100%;
    min-width: 2px;
    border-radius: 999px;
    background: var(--primary-color);
}
.mi-bar-fill.is-closure { background: var(--rdp-aqua, #5FD3C2); }
.mi-count { flex: 0 0 auto; min-width: 64px; text-align: right; font-weight: 600; font-size: 0.875rem; }
.mi-pct { color: var(--text-secondary); font-weight: 400; font-size: 0.8rem; margin-left: 0.25rem; }

@media (max-width: 640px) {
    .mi-label { flex-basis: 110px; }
}

.compose-tab-ai {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.7rem;
    border: 1px solid var(--primary-color);
    border-radius: 0.3rem;
    background: rgba(42, 138, 158, 0.1);
    color: var(--primary-color);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
}
.compose-tab-ai:hover { background: rgba(42, 138, 158, 0.18); }
.compose-tab-ai:disabled { opacity: 0.65; cursor: default; }

/* AI connection status strip */
.ai-status {
    margin-top: 1rem;
    padding: 0.75rem 0.85rem;
    border: 1px solid var(--border-color);
    border-radius: 0.4rem;
    background: var(--background-color);
}
.ai-status-head { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; margin-bottom: 0.5rem; }
.ai-status-title { font-weight: 700; font-size: 0.9rem; color: var(--text-primary); }
.ai-status-line { font-size: 0.85rem; color: var(--text-secondary); display: flex; align-items: center; gap: 0.4rem; padding: 0.12rem 0; flex-wrap: wrap; }
.ai-status-line code { font-size: 0.8rem; }
.ai-status-key { display: inline-block; min-width: 5rem; font-weight: 600; color: var(--text-secondary); }
.ai-status-line.ok { color: var(--success-color); }
.ai-status-line.bad { color: var(--danger-color); font-weight: 600; }
.ai-status-err {
    margin-top: 0.4rem;
    padding: 0.5rem 0.6rem;
    font-size: 0.82rem;
    color: var(--danger-dark, #9b2c2c);
    background: rgba(214, 69, 69, 0.08);
    border-radius: 0.3rem;
}

/* Reply preview modal */
.preview-modal { max-width: 780px; width: 100%; }
.preview-meta {
    font-size: 0.85rem;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 0.6rem;
    margin-bottom: 0.85rem;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}
.preview-lbl { display: inline-block; min-width: 3.5rem; font-weight: 600; color: var(--text-secondary); }
.preview-body {
    max-height: 60vh;
    overflow: auto;
    padding: 1rem;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 6px;
}
.preview-body img { max-width: 100%; height: auto; }
.preview-body table { max-width: 100%; }
.preview-foot-note {
    margin-right: auto;
    font-size: 0.78rem;
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.canned-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
}

.canned-item:last-child {
    border-bottom: none;
}

.canned-item-main {
    flex: 1;
    min-width: 0;
}

.canned-item-title {
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.2rem;
}

.canned-item-body {
    font-size: 0.8rem;
    color: var(--text-secondary);
    white-space: pre-wrap;
    max-height: 4.5rem;
    overflow: hidden;
}

.canned-placeholders {
    margin-top: 0.75rem;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* Rich-text editor (reply composer) */
.rte {
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    overflow: hidden;
    background: var(--surface-color);
}

.rte-toolbar {
    display: flex;
    align-items: center;
    gap: 0.15rem;
    padding: 0.3rem 0.4rem;
    border-bottom: 1px solid var(--border-color);
    background: var(--background-color);
}

.rte-btn {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: none;
    cursor: pointer;
    color: var(--text-secondary);
    border-radius: 0.25rem;
    font-size: 0.8rem;
}

.rte-btn:hover {
    background: var(--surface-color);
    color: var(--primary-color);
}

.rte-sep {
    width: 1px;
    height: 18px;
    background: var(--border-color);
    margin: 0 0.25rem;
}

.rte-emoji-toggle {
    font-size: 1rem !important;
    line-height: 1;
}

.rte-emoji-panel {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    padding: 6px;
    border-bottom: 1px solid var(--border-color);
    background: var(--background-color);
    max-height: 132px;
    overflow-y: auto;
}

.rte-emoji-item {
    border: none;
    background: none;
    cursor: pointer;
    font-size: 1.15rem;
    line-height: 1;
    padding: 4px;
    border-radius: 4px;
}

.rte-emoji-item:hover {
    background: rgba(42, 138, 158, 0.12);
}

.rte-area {
    min-height: 130px;
    max-height: 360px;
    overflow-y: auto;
    padding: 0.7rem 0.85rem;
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--text-primary);
    outline: none;
}

.rte-area:empty:before {
    content: attr(data-placeholder);
    color: var(--text-secondary);
    opacity: 0.7;
}

.rte-area p {
    margin: 0 0 0.5rem;
}

/* Pasted screenshots fit the editor instead of rendering at full (huge) resolution.
   The paste handler (rdpEditor.initImagePaste) also writes inline styles so the constraint
   travels into the sent email; the underlying image stays full-resolution. */
.rte-area img {
    max-width: 100%;
    height: auto;
}

/* Outbound attachments (reply composer) */
.reply-attachments {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.6rem;
}

.attach-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.7rem;
    font-size: 0.8rem;
    color: var(--primary-color);
    background: rgba(42, 138, 158, 0.08);
    border: 1px solid rgba(42, 138, 158, 0.25);
    border-radius: 0.375rem;
    cursor: pointer;
}

.attach-btn:hover {
    background: rgba(42, 138, 158, 0.14);
}

.attach-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.5rem;
    font-size: 0.78rem;
    background: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    color: var(--text-primary);
}

.attach-size {
    color: var(--text-secondary);
}

.attach-remove {
    border: none;
    background: none;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 0;
    font-size: 0.7rem;
    display: inline-flex;
}

.attach-remove:hover {
    color: var(--danger-color);
}

.attach-error {
    font-size: 0.78rem;
    color: var(--danger-color);
    width: 100%;
}

/* Attachment links + inline images (Support Desk) */
.attachment-item .attachment-name {
    text-decoration: none;
    color: var(--text-primary);
}

.attachment-item .attachment-name:hover {
    color: var(--primary-color);
    text-decoration: underline;
}

.attachment-dl {
    color: var(--text-secondary);
    text-decoration: none;
    padding: 0.15rem 0.35rem;
}

.attachment-dl:hover {
    color: var(--primary-color);
}

.message-content img {
    max-width: 100%;
    height: auto;
}

/* ============================================================
   Documentation section
   ============================================================ */

/* Sidebar nav (projects -> documents, in the dark rail) */
.docs-nav { padding: 0.25rem 0.3rem 1rem; }
.docs-nav-project { margin-bottom: 0.5rem; }

.docs-nav-project-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.4rem;
    padding: 0.45rem 0.5rem 0.3rem;
}

.docs-nav-project-name {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
    color: var(--rdp-mist);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.docs-nav-project-tools { display: flex; gap: 0.1rem; flex-shrink: 0; opacity: 0; transition: opacity 0.15s ease; }
.docs-nav-project:hover .docs-nav-project-tools { opacity: 1; }
.docs-nav-tool { background: none; border: none; color: var(--rdp-mist); cursor: pointer; padding: 0.15rem 0.3rem; border-radius: 5px; font-size: 0.72rem; }
.docs-nav-tool:hover { background: rgba(159, 192, 200, 0.14); color: var(--rdp-ice); }

.docs-nav-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1px; }
.docs-nav-doc {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.4rem 0.6rem;
    border-radius: 8px;
    color: var(--rdp-mist);
    text-decoration: none;
    font-size: 0.85rem;
}
.docs-nav-doc i { font-size: 0.8rem; flex-shrink: 0; }
.docs-nav-doc span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.docs-nav-doc:hover { background: rgba(159, 192, 200, 0.10); color: var(--rdp-ice); }
.docs-nav-doc.active { background: rgba(63, 198, 207, 0.14); color: var(--rdp-ice); box-shadow: inset 0 0 0 1px rgba(63, 198, 207, 0.30); }
.docs-nav-doc.active i { color: var(--rdp-coolant); }
.docs-nav-empty { padding: 0.3rem 0.6rem; color: var(--rdp-mist); opacity: 0.55; font-size: 0.78rem; font-style: italic; list-style: none; }

.docs-nav-newproject {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    margin-top: 0.5rem;
    padding: 0.5rem 0.6rem;
    background: rgba(63, 198, 207, 0.08);
    border: 1px dashed rgba(63, 198, 207, 0.3);
    border-radius: 8px;
    color: var(--rdp-coolant);
    cursor: pointer;
    font-size: 0.82rem;
}
.docs-nav-newproject:hover { background: rgba(63, 198, 207, 0.16); }
.dash.is-collapsed .docs-nav { display: none; }

/* Document area + on-this-page TOC (full width, TOC on the left) */
.docs-doc { display: flex; gap: 2.5rem; align-items: flex-start; }
.docs-doc-main { flex: 1; min-width: 0; }
.docs-doc-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.docs-doc-title { font-family: var(--font-display); font-size: clamp(24px, 3vw, 32px); color: var(--rdp-navy); margin: 0; line-height: 1.1; }
.docs-doc-actions { display: flex; gap: 0.4rem; flex-shrink: 0; }
.docs-title-input { flex: 1; font-size: 1.5rem; font-weight: 600; font-family: var(--font-display); color: var(--rdp-navy); border: 1px solid var(--border-color); border-radius: 0.375rem; padding: 0.4rem 0.6rem; }

.docs-editor {
    width: 100%;
    min-height: 60vh;
    resize: vertical;
    font-family: var(--font-mono);
    font-size: 0.875rem;
    line-height: 1.6;
    padding: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background: var(--surface-color);
    color: var(--text-primary);
}
.docs-editor:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(42, 138, 158, 0.1); }
.docs-editor-hint { font-size: 0.8rem; color: var(--text-secondary); margin-top: 0.5rem; }
.docs-editor-hint i { color: var(--rdp-current); }
.docs-doc-blank { padding: 2rem; text-align: center; color: var(--text-secondary); background: var(--background-color); border-radius: 0.5rem; }
.docs-doc-blank p { margin-bottom: 0.75rem; }

.docs-toc { width: 240px; flex-shrink: 0; order: -1; position: sticky; top: 0; align-self: flex-start; max-height: calc(100vh - 2rem); overflow-y: auto; padding-right: 0.5rem; border-right: 1px solid var(--border-color); }
.docs-doc-main { padding-left: 0.25rem; }

/* Folder tree (Projects → Folders → Documents) on the dark rail */
.docs-tree, .docs-tree-children { list-style: none; margin: 0; padding: 0; }
.docs-tree-children { padding-left: 0.55rem; margin-left: 0.5rem; border-left: 1px solid rgba(159, 192, 200, 0.14); }
.docs-tree-folder > details > summary {
    display: flex; align-items: center; gap: 0.4rem; padding: 0.32rem 0.5rem; border-radius: 7px;
    color: var(--rdp-mist); font-size: 0.82rem; cursor: pointer; list-style: none; user-select: none;
}
.docs-tree-folder > details > summary::-webkit-details-marker { display: none; }
.docs-tree-folder > details > summary::marker { content: ""; }
.docs-tree-folder > details > summary:hover { background: rgba(159, 192, 200, 0.10); color: var(--rdp-ice); }
.docs-tree-caret { font-size: 0.62rem; color: var(--rdp-mist); flex-shrink: 0; transition: transform 0.15s ease; }
.docs-tree-folder > details[open] > summary .docs-tree-caret { transform: rotate(90deg); }
.docs-tree-foldericon { font-size: 0.78rem; color: var(--rdp-coolant); flex-shrink: 0; }
.docs-tree-foldername { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.docs-tree-count { margin-left: auto; font-size: 0.66rem; color: var(--rdp-mist); opacity: 0.55; padding-left: 0.4rem; }
.docs-tree-doc { list-style: none; }

/* Mermaid diagrams in rendered docs */
.docs-markdown .mermaid { margin: 1.3rem 0; text-align: center; overflow-x: auto; }
.docs-markdown .mermaid svg { max-width: 100%; height: auto; }

/* Imported images */
.docs-markdown img { max-width: 100%; height: auto; margin: 0.7rem 0; border: 1px solid var(--border-color); border-radius: 8px; }

/* Container rasterised to PDF (kept on-page so html2canvas renders it, hidden behind .pdf-cover) */
.pdf-export-root { position: absolute; left: 0; top: 0; z-index: 2147483646; width: 760px; padding: 8px 10px; background: #ffffff; color: #1c2b33; }
.pdf-export-title { font-family: var(--font-display); font-size: 22px; color: var(--rdp-navy); margin: 0 0 0.6rem; }
.pdf-cover { position: fixed; inset: 0; z-index: 2147483647; background: rgba(244, 245, 247, 0.97); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1.05rem; color: var(--rdp-navy); }
.pdf-cover i { color: var(--rdp-current); margin-right: 0.5rem; }

@media (max-width: 980px) {
    .docs-doc { flex-direction: column; }
    .docs-toc { width: auto; position: static; max-height: none; order: 0; border-right: none; border-bottom: 1px solid var(--border-color); padding-bottom: 0.5rem; }
}
.docs-toc-title { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; color: var(--text-secondary); margin-bottom: 0.6rem; }
.docs-toc ul { list-style: none; margin: 0; padding: 0; border-left: 2px solid var(--border-color); }
.docs-toc li a { display: block; padding: 0.25rem 0 0.25rem 0.75rem; margin-left: -2px; border-left: 2px solid transparent; color: var(--text-secondary); text-decoration: none; font-size: 0.82rem; line-height: 1.3; }
.docs-toc li a:hover { color: var(--primary-color); border-left-color: var(--primary-color); }
.docs-toc-l2 a { padding-left: 1.5rem; }
.docs-toc-l3 a { padding-left: 2.25rem; font-size: 0.78rem; }

.docs-empty { max-width: 480px; margin: 8vh auto 0; text-align: center; }
.docs-empty-icon { font-size: 3rem; color: var(--rdp-current); opacity: 0.7; margin-bottom: 1rem; }
.docs-empty-title { font-family: var(--font-display); font-size: 1.6rem; color: var(--rdp-navy); margin: 0 0 0.5rem; }
.docs-empty-sub { color: var(--rdp-slate); margin-bottom: 1.25rem; }
.docs-empty-actions { display: flex; gap: 0.6rem; justify-content: center; flex-wrap: wrap; }

/* Secondary "Import" button on the dark sidebar rail */
.docs-nav-import { margin-top: 0.35rem; background: rgba(159, 192, 200, 0.06); border-color: rgba(159, 192, 200, 0.28); color: var(--rdp-mist); }
.docs-nav-import:hover { background: rgba(159, 192, 200, 0.14); color: var(--rdp-ice); }

/* Markdown import modal (light surface → Current accents) */
.modal-dialog--wide { max-width: 640px; }
.docs-import-intro { color: var(--text-secondary); font-size: 0.88rem; line-height: 1.5; margin: 0 0 1rem; }
.docs-import-hint { color: var(--text-secondary); font-weight: 400; font-size: 0.82em; }
.docs-import-tabs { display: flex; gap: 0.4rem; margin-bottom: 1rem; }
.docs-import-tab {
    flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 0.45rem;
    padding: 0.55rem 0.75rem; font-size: 0.85rem; font-weight: 500;
    background: var(--background-color); color: var(--text-secondary);
    border: 1px solid var(--border-color); border-radius: 8px; cursor: pointer; transition: all 0.15s ease;
}
.docs-import-tab:hover { border-color: var(--rdp-current); color: var(--rdp-current); }
.docs-import-tab.active { background: var(--rdp-current); border-color: var(--rdp-current); color: #fff; }
.docs-import-file { margin: 0.5rem 0 0; font-size: 0.82rem; color: var(--text-secondary); }
.docs-import-file i { color: var(--rdp-current); }
.docs-import-opts { display: flex; flex-direction: column; gap: 0.55rem; margin-top: 0.5rem; }
.docs-import-check { display: flex; align-items: flex-start; gap: 0.5rem; font-size: 0.85rem; color: var(--text-primary); cursor: pointer; }
.docs-import-check input { margin-top: 0.15rem; accent-color: var(--rdp-current); }
.docs-import-error {
    margin-top: 0.9rem; padding: 0.6rem 0.8rem; border-radius: 8px; font-size: 0.84rem;
    background: rgba(179, 38, 30, 0.08); color: #B3261E; border: 1px solid rgba(179, 38, 30, 0.25);
}
.docs-import-error i { margin-right: 0.35rem; }
.docs-import-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(86px, 1fr)); gap: 0.6rem; margin-bottom: 1rem; }
.docs-import-stat { text-align: center; padding: 0.7rem 0.4rem; background: var(--background-color); border: 1px solid var(--border-color); border-radius: 10px; }
.docs-import-stat .n { display: block; font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--rdp-navy); line-height: 1; }
.docs-import-stat .l { display: block; margin-top: 0.25rem; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-secondary); }
.docs-import-table { width: 100%; border-collapse: collapse; font-size: 0.84rem; }
.docs-import-table th, .docs-import-table td { text-align: left; padding: 0.4rem 0.6rem; border-bottom: 1px solid var(--border-color); }
.docs-import-table th { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-secondary); }
.docs-import-table td:not(:first-child), .docs-import-table th:not(:first-child) { text-align: right; width: 4.5rem; }
.docs-import-new { display: inline-block; margin-left: 0.4rem; padding: 0.05rem 0.4rem; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.04em; background: rgba(42, 138, 158, 0.12); color: var(--rdp-current); border-radius: 6px; }
.docs-import-errlist { margin-top: 0.9rem; font-size: 0.82rem; color: var(--text-secondary); }
.docs-import-errlist summary { cursor: pointer; color: #B3261E; }
.docs-import-errlist ul { margin: 0.5rem 0 0 1.2rem; }
.docs-import-errlist li { margin-bottom: 0.2rem; word-break: break-word; }
.docs-import-none { margin-top: 0.5rem; color: var(--text-secondary); font-size: 0.86rem; }

/* Rendered Markdown */
.docs-markdown { color: var(--text-primary); font-size: 0.95rem; line-height: 1.7; }
.docs-markdown h1, .docs-markdown h2, .docs-markdown h3, .docs-markdown h4 { font-family: var(--font-display); color: var(--rdp-navy); line-height: 1.25; scroll-margin-top: 1rem; }
.docs-markdown h1 { font-size: 1.7rem; margin: 1.8rem 0 0.8rem; }
.docs-markdown h2 { font-size: 1.35rem; margin: 1.6rem 0 0.7rem; padding-bottom: 0.3rem; border-bottom: 1px solid var(--border-color); }
.docs-markdown h3 { font-size: 1.1rem; margin: 1.3rem 0 0.5rem; }
.docs-markdown h1:first-child, .docs-markdown h2:first-child, .docs-markdown h3:first-child { margin-top: 0; }
.docs-markdown p { margin: 0 0 1rem; }
.docs-markdown a { color: var(--primary-color); text-decoration: underline; text-underline-offset: 2px; }
.docs-markdown ul, .docs-markdown ol { margin: 0 0 1rem 1.5rem; }
.docs-markdown li { margin-bottom: 0.3rem; }
.docs-markdown code { font-family: var(--font-mono); font-size: 0.85em; background: var(--background-color); padding: 0.12rem 0.4rem; border-radius: 0.25rem; }
.docs-markdown pre { background: var(--rdp-navy); color: var(--rdp-ice); padding: 1rem; border-radius: 0.5rem; overflow-x: auto; margin: 0 0 1rem; }
.docs-markdown pre code { background: none; color: inherit; padding: 0; font-size: 0.82rem; }
.docs-markdown blockquote { margin: 0 0 1rem; padding: 0.5rem 1rem; border-left: 3px solid var(--rdp-current); background: rgba(42, 138, 158, 0.05); color: var(--rdp-slate); }
.docs-markdown table { border-collapse: collapse; width: 100%; margin: 0 0 1rem; font-size: 0.9rem; }
.docs-markdown th, .docs-markdown td { border: 1px solid var(--border-color); padding: 0.4rem 0.6rem; text-align: left; }
.docs-markdown th { background: var(--background-color); font-weight: 600; }
.docs-markdown img { max-width: 100%; height: auto; border-radius: 0.5rem; }
.docs-markdown hr { border: none; border-top: 1px solid var(--border-color); margin: 1.5rem 0; }

@media (max-width: 1000px) {
    .docs-toc { display: none; }
    .docs-doc { gap: 0; }
}
