/**
 * Insurance Portal — centralized theme (CSS variables only)
 */
:root,
[data-theme="default"] {
    --tb-font-sans-serif: "Outfit", system-ui, -apple-system, "Segoe UI", sans-serif;
    --primary-color: #117db7;
    --primary-light: #0e6a9e;
    --insurance-primary: #117db7;
    --insurance-primary-rgb: 17, 125, 183;
    --insurance-primary-hover: #0e6a9e;
    --insurance-secondary: #405189;
    --insurance-table-border: rgba(17, 125, 183, 0.38);
    --insurance-table-head-bg: #e3f0f7;
    --insurance-table-cell-bg: #ffffff;
    --insurance-table-cell-hover: #f0f7fb;
    --secondary-color: #2E7D32;
    --warning-color: #F9A825;
    --danger-color: #D32F2F;
    --info-color: #0288D1;
    --text-color: #2C3E50;
    --border-color: #E5E7EB;
    --background-color: #F8FAFC;
    --sidebar-color: #FFFFFF;
    --card-color: #FFFFFF;
    --success-color: #43A047;

    /* Map to Steex / Bootstrap tokens */
    --tb-primary: var(--primary-color);
    --tb-secondary: var(--secondary-color);
    --tb-success: var(--success-color);
    --tb-info: var(--info-color);
    --tb-warning: var(--warning-color);
    --tb-danger: var(--danger-color);
    --bs-primary: var(--primary-color);
    --bs-secondary: var(--secondary-color);
    --bs-success: var(--success-color);
    --bs-info: var(--info-color);
    --bs-warning: var(--warning-color);
    --bs-danger: var(--danger-color);
    --bs-body-color: var(--text-color);
    --bs-border-color: var(--border-color);
    --bs-body-bg: var(--background-color);
}

/* Base */
body {
    font-family: var(--tb-font-sans-serif, "Outfit", sans-serif);
    color: var(--text-color);
    background-color: var(--background-color);
}

/* Sidebar */
.navbar-menu {
    background-color: var(--sidebar-color) !important;
    border-right: 1px solid var(--border-color);
}

.navbar-menu .navbar-nav .nav-link {
    color: var(--text-color);
}

.navbar-menu .navbar-nav .nav-link.active,
.navbar-menu .navbar-nav .menu-link.active {
    color: var(--primary-color) !important;
    background-color: color-mix(in srgb, var(--primary-color) 8%, transparent);
}

/* Expanded sidebar hover (collapsed sm hover is in insurance-portal.css) */
[data-layout=vertical][data-sidebar-size=lg] .navbar-menu .navbar-nav .nav-link:hover,
[data-layout=vertical][data-sidebar-size=lg] .navbar-menu .navbar-nav .menu-link:hover {
    color: var(--primary-color) !important;
    background-color: color-mix(in srgb, var(--primary-color) 8%, transparent);
}

.navbar-menu .menu-title span {
    color: color-mix(in srgb, var(--text-color) 55%, transparent);
}

/* Cards */
.card {
    background-color: var(--card-color);
    border-color: var(--border-color);
    box-shadow: 0 1px 2px color-mix(in srgb, var(--text-color) 6%, transparent);
}

.card-header,
.card-footer {
    background-color: var(--card-color);
    border-color: var(--border-color);
}

/* Equal-height card rows */
.row-equal-height {
    display: flex;
    flex-wrap: wrap;
}

.row-equal-height > [class*="col-"] {
    display: flex;
    flex-direction: column;
}

.row-equal-height .card,
.row-equal-height .insurance-stat-card,
.row-equal-height .hs-support-tile {
    flex: 1 1 auto;
    height: 100%;
    width: 100%;
}

.row-equal-height .insurance-stat-card {
    display: flex;
    align-items: center;
}

.row-equal-height .hs-support-tile {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

/* Page header */
.insurance-page-header {
    margin-bottom: 1.25rem;
}

.insurance-page-header .page-title {
    color: var(--text-color);
    font-weight: 600;
}

.insurance-page-header .breadcrumb-item a {
    color: var(--primary-light);
}

.insurance-page-header .breadcrumb-item.active {
    color: var(--text-color);
}

/* Statistics widgets */
.insurance-stat-card {
    background: var(--card-color);
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    padding: 1.25rem;
}

.insurance-stat-card .insurance-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
}

.insurance-stat-card .insurance-stat-icon.primary {
    background: color-mix(in srgb, var(--primary-color) 12%, transparent);
    color: var(--primary-color);
}

.insurance-stat-card .insurance-stat-icon.success {
    background: color-mix(in srgb, var(--success-color) 12%, transparent);
    color: var(--success-color);
}

.insurance-stat-card .insurance-stat-icon.warning {
    background: color-mix(in srgb, var(--warning-color) 18%, transparent);
    color: var(--warning-color);
}

.insurance-stat-card .insurance-stat-icon.danger {
    background: color-mix(in srgb, var(--danger-color) 12%, transparent);
    color: var(--danger-color);
}

.insurance-stat-card .insurance-stat-icon.info {
    background: color-mix(in srgb, var(--info-color) 12%, transparent);
    color: var(--info-color);
}

.insurance-stat-card .insurance-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-color);
}

.insurance-stat-card .insurance-stat-label {
    color: color-mix(in srgb, var(--text-color) 55%, transparent);
    font-size: 0.875rem;
}

/* Buttons */
.btn-primary {
    --bs-btn-bg: var(--primary-color);
    --bs-btn-border-color: var(--primary-color);
    --bs-btn-hover-bg: var(--primary-light);
    --bs-btn-hover-border-color: var(--primary-light);
    --bs-btn-active-bg: var(--primary-color);
    --bs-btn-active-border-color: var(--primary-color);
}

.btn-success {
    --bs-btn-bg: var(--success-color);
    --bs-btn-border-color: var(--success-color);
}

.btn-danger {
    --bs-btn-bg: var(--danger-color);
    --bs-btn-border-color: var(--danger-color);
}

.btn-warning {
    --bs-btn-bg: var(--warning-color);
    --bs-btn-border-color: var(--warning-color);
    --bs-btn-color: var(--text-color);
}

.btn-info {
    --bs-btn-bg: var(--info-color);
    --bs-btn-border-color: var(--info-color);
}

.bg-primary {
    background-color: var(--primary-color) !important;
}

.text-primary {
    color: var(--primary-color) !important;
}

.border-primary {
    border-color: var(--primary-color) !important;
}

.badge.bg-primary-subtle,
.bg-primary-subtle {
    background-color: color-mix(in srgb, var(--primary-color) 12%, transparent) !important;
    color: var(--primary-color) !important;
}

.badge.bg-success-subtle,
.bg-success-subtle {
    background-color: color-mix(in srgb, var(--success-color) 12%, transparent) !important;
    color: var(--success-color) !important;
}

.badge.bg-warning-subtle,
.bg-warning-subtle {
    background-color: color-mix(in srgb, var(--warning-color) 18%, transparent) !important;
    color: color-mix(in srgb, var(--warning-color) 70%, var(--text-color)) !important;
}

.badge.bg-danger-subtle,
.bg-danger-subtle {
    background-color: color-mix(in srgb, var(--danger-color) 12%, transparent) !important;
    color: var(--danger-color) !important;
}

.badge.bg-info-subtle,
.bg-info-subtle {
    background-color: color-mix(in srgb, var(--info-color) 12%, transparent) !important;
    color: var(--info-color) !important;
}

/* Tables */
.insurance-table-toolbar {
    background: var(--card-color);
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    padding: 1rem;
    margin-bottom: 1rem;
}

.table {
    --bs-table-color: var(--text-color);
    --bs-table-border-color: var(--border-color);
}

.table thead th {
    background: color-mix(in srgb, var(--background-color) 50%, var(--card-color));
    color: var(--text-color);
    font-weight: 600;
    border-bottom: 1px solid var(--border-color);
}

/* Search filter */
.insurance-search-box {
    position: relative;
}

.insurance-search-box .form-control {
    border-color: var(--border-color);
    padding-left: 2.25rem;
}

.insurance-search-box .search-icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: color-mix(in srgb, var(--text-color) 45%, transparent);
}

/* Pagination */
.insurance-pagination .page-link {
    color: var(--primary-color);
    border-color: var(--border-color);
}

.insurance-pagination .page-item.active .page-link {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

/* Topbar */
#page-topbar {
    background: var(--card-color);
    border-bottom: 1px solid var(--border-color);
}

/* Toast container — bottom right */
#insurance-toast-container {
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 1090;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: 360px;
    width: calc(100% - 2rem);
    pointer-events: none;
}

.insurance-toast {
    pointer-events: auto;
    background: var(--card-color);
    border: 1px solid var(--border-color);
    border-left-width: 4px;
    border-radius: 0.375rem;
    box-shadow: 0 4px 12px color-mix(in srgb, var(--text-color) 12%, transparent);
    padding: 0.875rem 1rem;
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    animation: insurance-toast-in 0.3s ease;
}

@keyframes insurance-toast-in {
    from {
        opacity: 0;
        transform: translateX(1rem);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.insurance-toast.success { border-left-color: var(--success-color); }
.insurance-toast.error { border-left-color: var(--danger-color); }
.insurance-toast.warning { border-left-color: var(--warning-color); }
.insurance-toast.info { border-left-color: var(--info-color); }

.insurance-toast .insurance-toast-icon {
    font-size: 1.25rem;
    flex-shrink: 0;
}

.insurance-toast.success .insurance-toast-icon { color: var(--success-color); }
.insurance-toast.error .insurance-toast-icon { color: var(--danger-color); }
.insurance-toast.warning .insurance-toast-icon { color: var(--warning-color); }
.insurance-toast.info .insurance-toast-icon { color: var(--info-color); }

.insurance-toast .btn-close {
    margin-left: auto;
    flex-shrink: 0;
}

/* Modal */
.modal-content {
    border-color: var(--border-color);
}

.modal-header {
    border-bottom-color: var(--border-color);
    background: var(--card-color);
}

.modal-footer {
    border-top-color: var(--border-color);
    background: var(--card-color);
}

/* Portal brand */
.insurance-brand-text {
    color: var(--primary-color);
    font-weight: 700;
    letter-spacing: 0.02em;
}

/* Soft buttons (portal actions) */
.btn-soft-primary {
    background-color: color-mix(in srgb, var(--primary-color) 12%, transparent);
    color: var(--primary-color);
    border: none;
}

.btn-soft-primary:hover {
    background-color: color-mix(in srgb, var(--primary-color) 20%, transparent);
    color: var(--primary-color);
}

.btn-soft-secondary {
    background-color: color-mix(in srgb, var(--text-color) 8%, transparent);
    color: var(--text-color);
    border: none;
}

.btn-soft-danger {
    background-color: color-mix(in srgb, var(--danger-color) 12%, transparent);
    color: var(--danger-color);
    border: none;
}

/* Responsive utilities */
@media (max-width: 767.98px) {
    #insurance-toast-container {
        left: 1rem;
        right: 1rem;
        max-width: none;
    }

    .insurance-page-header .page-title {
        font-size: 1.15rem;
    }
}
