/* Inter font moved to layout for better performance */

:root {
    color-scheme: dark;
    /* Core Semantic Tokens - Dark Mode */
    --bg-app: #0f172a;
    --bg-surface: #1e293b;
    --bg-surface-soft: rgba(30, 41, 59, 0.4);
    --sidebar-bg: #0f172a;
    --topbar-bg: #1e293b;
    --accent: #38bdf8;
    --accent-hover: #0ea5e9;
    --text-main: #f8fafc;
    --text-secondary: #cbd5e1;
    --text-muted: #64748b;
    --text-inverse: #0f172a;
    --border-main: #334155;
    --border-soft: rgba(255, 255, 255, 0.05);
    --success: #10b981;
    --warning: #f59e0b;
    --danger: #ef4444;
    
    --card-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2), 0 2px 4px -1px rgba(0, 0, 0, 0.1);
    --overlay-bg: rgba(0, 0, 0, 0.75);
    --input-bg: rgba(15, 23, 42, 0.4);
    --dropdown-bg: #1e293b;
    --nav-item-hover: rgba(255, 255, 255, 0.05);
    --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    
    /* Legacy aliases to maintain compatibility with existing CSS */
    --bg-dark: var(--bg-app);
    --bg-card: var(--bg-surface);
    --border: var(--border-main);
}

[data-theme="light"] {
    color-scheme: light;
    /* Core Semantic Tokens - Light Mode */
    --bg-app: #f4f7fb;
    --bg-surface: #ffffff;
    --bg-surface-soft: #f1f5f9;
    --sidebar-bg: #ffffff;
    --topbar-bg: #ffffff;
    --accent: #0284c7;
    --accent-hover: #0369a1;
    --text-main: #0f172a;
    --text-secondary: #475569;
    --text-muted: #94a3b8;
    --text-inverse: #f8fafc;
    --border-main: #e2e8f0;
    --border-soft: rgba(0, 0, 0, 0.04);
    --success: #059669;
    --warning: #d97706;
    --danger: #dc2626;
    
    --card-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
    --overlay-bg: rgba(0, 0, 0, 0.4);
    --input-bg: #f3f4f6;
    --dropdown-bg: #ffffff;
    --nav-item-hover: rgba(0, 0, 0, 0.04);

    /* Legacy aliases for Light Mode */
    --bg-dark: var(--bg-app);
    --bg-card: var(--bg-surface);
    --border: var(--border-main);
}

/* Global Light Mode Visibility Fixes */
[data-theme="light"] .text-white:not(.btn-primary .text-white):not(.btn .text-white):not(.badge .text-white):not(.status-badge .text-white) {
    color: var(--text-main) !important;
}

[data-theme="light"] .text-white-50 {
    color: var(--text-muted) !important;
}


::placeholder {
    color: var(--text-muted) !important;
    opacity: 0.5;
}

::-webkit-input-placeholder {
    color: var(--text-muted) !important;
    opacity: 0.5;
}

.text-main {
    color: var(--text-main) !important;
}

.text-accent {
    color: var(--accent) !important;
}

.border-theme {
    border-color: var(--border) !important;
}

.bg-surface-soft {
    background-color: var(--bg-surface-soft) !important;
}

.text-muted {
    color: var(--text-muted) !important;
}


label,
.form-label {
    color: var(--text-muted) !important;
}

/* Premium Tabs System */
.nav-tabs-premium {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--border);
    background: transparent;
    /* Parent header handles bg */
}

.tab-link {
    all: unset;
    padding: 16px 28px;
    color: var(--text-muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    border-bottom: 2px solid transparent;
}

.tab-link:hover {
    color: var(--text-main);
    background: var(--nav-item-hover);
}

.tab-link.active {
    color: var(--accent);
    background: var(--bg-surface-soft);
}

.tab-link.active::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--accent);
    box-shadow: 0 0 12px var(--accent);
    z-index: 10;
}

/* Ensure tab corners match card radius if they're at the edges */
.nav-tabs-premium .tab-link:first-child {
    border-top-left-radius: 18px;
}

.smaller,
.small {
    color: inherit;
}

.text-white-muted {
    color: var(--text-muted) !important;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Inter', sans-serif;
}

body {
    background-color: var(--bg-dark);
    color: var(--text-main);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--text-main);
}

a {
    text-decoration: none;
    color: inherit;
}

/* Layout */
.app-container {
    display: flex;
    min-height: 100vh;
}

/* Sidebar */
.sidebar {
    width: 260px;
    background-color: var(--sidebar-bg);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    position: fixed;
    height: 100vh;
    left: 0;
    top: 0;
    overflow-y: auto;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 1000;
}

/* Mini Sidebar State */
body.sidebar-collapsed .sidebar {
    width: 80px !important;
}

body.sidebar-collapsed .sidebar-logo {
    justify-content: center;
    padding: 24px 0;
}

body.sidebar-collapsed .sidebar-logo span,
body.sidebar-collapsed .nav-section-title,
body.sidebar-collapsed .nav-item span {
    display: none !important;
}

body.sidebar-collapsed .nav-item {
    justify-content: center;
    padding: 12px 0;
}

body.sidebar-collapsed .nav-item i {
    margin-right: 0;
    font-size: 18px;
}

body.sidebar-collapsed .sidebar-footer {
    padding: 24px 10px;
    display: flex;
    justify-content: center;
}

.sidebar-logo {
    padding: 24px;
    font-size: 24px;
    font-weight: 700;
    color: var(--accent);
    display: flex;
    align-items: center;
    gap: 10px;
}

.sidebar-nav {
    flex: 1;
    padding: 0 12px;
}

.nav-section {
    margin-bottom: 24px;
}

.nav-section-title {
    font-size: 11px;
    text-transform: uppercase;
    color: var(--text-muted);
    font-weight: 600;
    margin-bottom: 12px;
    padding-left: 12px;
}

.nav-item {
    display: flex;
    align-items: center;
    padding: 10px 12px;
    border-radius: 8px;
    color: var(--text-muted);
    font-size: 14px;
    margin-bottom: 4px;
    transition: all 0.2s;
}

.nav-item i {
    margin-right: 12px;
    width: 20px;
    text-align: center;
    transition: margin 0.3s, font-size 0.3s;
}

.nav-item:hover,
.nav-item.active {
    background-color: var(--nav-item-hover);
    color: var(--text-main);
}

.nav-item.active i {
    color: var(--accent);
}

.sidebar-footer {
    padding: 24px;
    border-top: 1px solid var(--border);
}

/* Collapsible Sections */
.nav-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    cursor: pointer;
    border-radius: 8px;
    margin-bottom: 4px;
    transition: all 0.2s;
}

.nav-section-header:hover {
    background: var(--nav-item-hover);
}

.nav-section-header .nav-section-title {
    margin-bottom: 0;
    padding-left: 0;
    flex: 1;
}

.nav-section-header .chevron {
    font-size: 10px;
    color: var(--text-muted);
    transition: transform 0.3s;
}

.nav-section.collapsed .nav-items-container {
    display: none;
}

.nav-section.collapsed .chevron {
    transform: rotate(-90deg);
}

.nav-items-container {
    padding-left: 8px;
}

body.sidebar-collapsed .nav-section-header .chevron {
    display: none !important;
}

body.sidebar-collapsed .nav-items-container {
    padding-left: 0;
}

body.sidebar-collapsed .nav-section-title {
    display: none;
}

/* Main Content */
.main-wrapper {
    flex: 1;
    margin-left: 260px;
    transition: margin-left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body.sidebar-collapsed .main-wrapper {
    margin-left: 80px !important;
}

.topbar {
    height: 64px;
    background-color: var(--topbar-bg);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
    position: sticky;
    top: 0;
    z-index: 100;
}

.topbar-left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.sidebar-toggle {
    background: var(--input-bg);
    border: 1px solid var(--border);
    color: var(--text-muted);
    width: 38px;
    height: 38px;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.sidebar-toggle:hover {
    background: var(--nav-item-hover);
    color: var(--accent);
    border-color: var(--accent);
}

.search-bar {
    background: var(--input-bg);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 10px 18px;
    display: flex;
    align-items: center;
    width: 450px;
    transition: all 0.3s ease;
}

.search-bar:focus-within {
    border-color: var(--accent);
    background: var(--input-bg);
    box-shadow: 0 0 0 4px rgba(56, 189, 248, 0.1);
}

.search-bar input {
    background: none;
    border: none;
    outline: none;
    color: var(--text-main);
    margin-left: 10px;
    width: 100%;
}

.topbar-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

.company-badge {
    color: var(--text-main);
    font-weight: 600;
    font-size: 14px;
    background: var(--input-bg);
    padding: 4px 12px;
    border-radius: 20px;
    border: 1px solid var(--accent);
}

/* Page Content */
.content {
    padding: 24px;
}

.page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

.page-title {
    font-size: 24px;
    font-weight: 700;
}

.page-content {
    animation: pageSlideIn 0.4s ease-out forwards;
}

@keyframes pageSlideIn {
    from {
        opacity: 0;
        transform: translateY(15px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Cards */
.card {
    background-color: var(--bg-card);
    border-radius: 12px;
    border: 1px solid var(--border);
    padding: 24px;
    margin-bottom: 24px;
}

.welcome-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.welcome-card h2 {
    margin-bottom: 8px;
}

.welcome-card p {
    color: var(--text-muted);
    font-size: 14px;
}

/* Dashboard Grid */
.dashboard-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 24px;
}

.map-container {
    background-color: var(--bg-card);
    border-radius: 12px;
    padding: 20px;
    height: 100%;
    position: relative;
    /* For tooltip positioning */
}

.map-tooltip {
    position: fixed;
    background: var(--bg-surface);
    color: var(--text-main);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    pointer-events: none;
    display: none;
    z-index: 1000;
    box-shadow: var(--card-shadow);
    border: 1px solid var(--border-main);
    transition: opacity 0.1s ease;
    white-space: nowrap;
    text-align: center;
}

.map-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-color: var(--bg-card) transparent transparent transparent;
}

.map-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.map-title {
    font-size: 18px;
    font-weight: 600;
}

.us-map-svg {
    width: 100%;
    height: auto;
}

.us-map-svg path {
    fill: var(--input-bg);
    stroke: var(--border-main);
    stroke-width: 0.8px;
    transition: all 0.2s ease;
}

.us-map-svg path:hover {
    fill: var(--accent);
    stroke: var(--text-main);
    stroke-width: 1px;
    cursor: pointer;
    filter: drop-shadow(0 0 12px rgba(59, 130, 246, 0.4));
}

.us-map-svg path.active-state {
    fill: rgba(56, 189, 248, 0.4) !important;
    stroke: var(--accent) !important;
    stroke-width: 1.5px !important;
}


.hot-loads-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 300px;
}

.empty-state-img {
    width: 150px;
    margin-bottom: 20px;
    opacity: 0.5;
}

/* Tabs */
.tabs-nav {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}

.tab-btn {
    background-color: var(--border);
    border: none;
    color: var(--text-muted);
    padding: 10px 16px;
    border-radius: 8px;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
}

.tab-btn.active {
    background-color: var(--accent);
    color: var(--text-inverse);
}

/* Forms */
.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-size: 14px;
    color: var(--text-muted);
}

.form-control {
    width: 100%;
    background-color: var(--bg-app);
    border: 1px solid var(--border-main);
    border-radius: 8px;
    padding: 12px;
    color: var(--text-main) !important;
    outline: none;
}

.form-select {
    color: var(--text-main) !important;
}

.btn {
    padding: 12px 24px;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: background 0.2s;
}

.btn-primary {
    background-color: var(--accent);
    color: var(--text-main);
}

.btn-primary:hover {
    background-color: var(--accent-hover);
}

/* Table */
.data-table {
    width: 100%;
    border-collapse: collapse;
}

.data-table th {
    text-align: left;
    padding: 12px;
    border-bottom: 1px solid var(--border);
    color: var(--text-muted);
    font-size: 12px;
    text-transform: uppercase;
}

.data-table td {
    padding: 16px 12px;
    border-bottom: 1px solid var(--border);
    font-size: 14px;
    color: var(--text-main) !important;
}

select option {
    background-color: var(--dropdown-bg) !important;
    color: var(--text-main) !important;
}

/* Auth Pages */
.auth-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: var(--bg-dark);
}

.auth-card {
    width: 400px;
    background-color: var(--bg-surface);
    padding: 40px;
    border-radius: 16px;
    box-shadow: var(--card-shadow);
    border: 1px solid var(--border-main);
}

/* Floating Quick Actions */
.quick-actions-container {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    padding: 10px;
    /* Bridge gap for continuous hover */
}

.quick-actions-fab {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--accent);
    color: var(--text-inverse);
    border: none;
    box-shadow: 0 0 20px rgba(56, 189, 248, 0.4);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    z-index: 10001;
}

.quick-actions-fab i {
    transition: transform 0.3s ease;
}

.quick-actions-container:hover .quick-actions-fab i {
    transform: rotate(45deg);
    /* Turns the Plus into an X-like shape */
}

.quick-actions-container:hover .quick-actions-fab {
    transform: scale(1.1) rotate(90deg);
    box-shadow: 0 0 30px rgba(56, 189, 248, 0.6);
}



.quick-actions-panel {
    position: absolute;
    bottom: 70px;
    right: 10px;
    width: 320px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 24px;
    backdrop-filter: blur(25px);
    z-index: 9999;
    padding: 24px;
    box-shadow: var(--card-shadow);

    /* Animation properties */
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(20px) scale(0.95);
    transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.quick-actions-container:hover .quick-actions-panel {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
    transform: translateY(0) scale(1);
}

.quick-actions-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.quick-actions-header h3 {
    font-size: 16px;
    font-weight: 800;
    color: var(--text-main);
    letter-spacing: 0.5px;
    text-transform: uppercase;
    opacity: 0.9;
}

.quick-actions-header button {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 18px;
}

.quick-actions-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.quick-action-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: var(--input-bg);
    border: 1px solid var(--border);
    border-radius: 16px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    text-decoration: none !important;
    position: relative;
    overflow: hidden;
}

.quick-action-card:hover {
    background: var(--nav-item-hover);
    border-color: var(--accent);
    transform: translateY(-2px);
    box-shadow: var(--card-shadow);
}

.quick-action-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.05), transparent);
    transition: 0.5s;
}

.quick-action-card:hover::after {
    left: 100%;
}

.action-icon {
    width: 48px;
    height: 48px;
    background: rgba(56, 189, 248, 0.12);
    color: var(--accent);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    transition: all 0.3s ease;
}

.quick-action-card:hover .action-icon {
    transform: scale(1.1);
    background: rgba(56, 189, 248, 0.2);
}

.action-info h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-main);
    margin-bottom: 2px;
}

.action-info span {
    font-size: 12px;
    color: var(--text-muted);
}

.gpt-sparkle .action-icon {
    background: linear-gradient(135deg, rgba(56, 189, 248, 0.15), rgba(168, 85, 247, 0.15));
    color: #a855f7;
    box-shadow: 0 0 20px rgba(168, 85, 247, 0.2);
    animation: gpt-pulse 2s infinite ease-in-out;
}

@keyframes gpt-pulse {
    0% {
        box-shadow: 0 0 10px rgba(168, 85, 247, 0.2);
    }

    50% {
        box-shadow: 0 0 25px rgba(168, 85, 247, 0.4);
    }

    100% {
        box-shadow: 0 0 10px rgba(168, 85, 247, 0.2);
    }
}

.gpt-sparkle:hover .action-icon {
    background: linear-gradient(135deg, rgba(56, 189, 248, 0.25), rgba(168, 85, 247, 0.25));
}

.gpt-sparkle:hover {
    border-color: rgba(168, 85, 247, 0.4);
}

/* GPT Modal Styles */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--overlay-bg);
    backdrop-filter: blur(8px);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 20000;
    opacity: 0;
    pointer-events: none;
    /* Crucial: prevent click blocking when invisible */
    transition: opacity 0.3s ease;
}

.modal-overlay.active {
    display: flex;
    opacity: 1;
    pointer-events: all;
}

.ai-modal {
    width: 960px;
    background: var(--bg-surface);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--card-shadow),
        inset 0 0 0 1px var(--border-soft);
    transform: scale(0.95);
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.modal-overlay.active .ai-modal {
    transform: scale(1);
}

.ai-modal-header {
    background: var(--accent);
    padding: 24px 30px;
    color: var(--text-inverse);
    border-bottom: 1px solid var(--border-soft);
}

.ai-modal-header h2 {
    margin: 0;
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.5px;
}

.ai-modal-header p {
    margin: 4px 0 0;
    font-size: 14px;
    font-weight: 600;
    opacity: 0.9;
}

.ai-modal-body {
    padding: 30px;
}

.ai-form-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-bottom: 25px;
}

.ai-form-grid.single-col {
    grid-template-columns: 1fr;
    margin-bottom: 35px;
}

.ai-input-group {
    position: relative;
    border: 1px solid var(--border-soft);
    background: var(--bg-surface-soft);
    border-radius: 8px;
    padding: 10px 12px;
    height: 52px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: all 0.2s ease;
}

.ai-input-group:focus-within {
    background: rgba(30, 41, 59, 0.6);
    border-color: #06b6d4;
    box-shadow: 0 0 15px rgba(6, 182, 212, 0.1);
}

.ai-input-group label {
    position: absolute;
    top: -9px;
    left: 12px;
    background: var(--bg-surface);
    /* Same as body for seamless label backdrop */
    padding: 0 6px;
    font-size: 10px;
    color: #64748b;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    pointer-events: none;
}

.ai-input-group .input-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ai-input-group input,
.ai-input-group select {
    background: transparent;
    border: none;
    color: var(--text-main);
    font-size: 14px;
    font-weight: 700;
    width: 100%;
    outline: none;
}

.ai-input-group select {
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}

/* Ensure select options are visible in AI modal */
.ai-input-group select option {
    background-color: var(--bg-surface);
    color: var(--text-main);
}

/* Global select option fix for dark theme */
select option {
    background-color: #1e293b;
    color: #f1f5f9;
}

.ai-input-group .icon {
    color: #475569;
    font-size: 11px;
    display: flex;
    align-items: center;
    gap: 6px;
    margin-left: 8px;
    pointer-events: none;
}

.ai-divider {
    height: 1px;
    background: var(--border-soft);
    margin: 15px 0 30px 0;
}

.upload-section {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 0;
    margin-bottom: 30px;
    background: rgba(15, 23, 42, 0.2);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.ai-dropzone {
    border: 1px dashed rgba(255, 255, 255, 0.15);
    background: rgba(255, 255, 255, 0.02);
    border-radius: 12px;
    height: 180px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.ai-dropzone:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: #06b6d4;
}

.ai-dropzone i {
    font-size: 38px;
    color: #475569;
    margin-bottom: 15px;
}

.ai-dropzone p {
    font-size: 13px;
    font-weight: 600;
    color: #cbd5e1;
    margin: 0;
}

.ai-dropzone span {
    font-size: 10px;
    color: #475569;
    margin-top: 6px;
    text-transform: uppercase;
    font-weight: 700;
}

.upload-status {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #475569;
    text-align: center;
}

.upload-status i {
    font-size: 44px;
    margin-bottom: 12px;
    opacity: 0.3;
}

.upload-status p {
    font-size: 12px;
    font-weight: 600;
    max-width: 150px;
    line-height: 1.4;
}

.ai-modal-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 25px;
    border-top: 1px solid var(--border-soft);
}

.warning-notice {
    color: #f59e0b;
    font-size: 12px;
    font-weight: 600;
    max-width: 400px;
    line-height: 1.4;
    display: flex;
    gap: 10px;
    align-items: flex-start;
}

.warning-notice i {
    margin-top: 2px;
}

.modal-btns {
    display: flex;
    gap: 10px;
}

.btn-ai-cancel {
    background: rgba(255, 255, 255, 0.05);
    color: #cbd5e1;
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 10px 24px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-ai-cancel:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    color-scheme: dark;
}

::placeholder {
    color: var(--text-muted) !important;
}

::-webkit-input-placeholder {
    color: var(--text-muted) !important;
}

.btn-ai-proceed {
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff;
    border: none;
    padding: 10px 24px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 4px 15px rgba(16, 185, 129, 0.2);
    transition: all 0.2s;
}

.btn-ai-proceed:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.3);
}

.ai-file-preview {
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.ai-file-preview i {
    color: #ef4444;
}

.ai-file-preview span {
    color: #f1f5f9;

    font-size: 14px;
    font-weight: 600;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.btn-remove-file {
    background: none;
    border: none;
    color: #ef4444;
    cursor: pointer;
    margin-top: 5px;
    font-size: 12px;
}


/* Load Entry and AI Styles */
.load-create-container,
.ai-load-container {
    padding: 40px 24px;
    max-width: 680px;
    margin: 0 auto;
    min-height: calc(100vh - 64px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.card-dark {
    background: var(--bg-surface);
    border: 1px solid var(--border-main);
    border-radius: 12px;
}

.card-dark .card-header {
    background: var(--bg-surface-soft);
    border-bottom: 1px solid var(--border-main);
    color: #94a3b8;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 11px;
    padding: 12px 20px;
    letter-spacing: 0.5px;
}

.readonly-input {
    background: var(--bg-app) !important;
    border-color: var(--border-soft) !important;
    color: var(--text-muted) !important;
}

.ai-banner {
    background: linear-gradient(90deg, #1e1b4b, #312e81);
    border: 1px solid #4338ca;
    padding: 12px 20px;
    border-radius: 12px;
    margin-bottom: 25px;
    display: flex;
    align-items: center;
    gap: 15px;
}

.ai-banner i {
    color: #818cf8;
    font-size: 20px;
}

.total-rates-box {
    background: var(--bg-surface-soft);
    padding: 15px;
    border-radius: 10px;
    border-left: 3px solid var(--accent);
}

.upload-link-box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 15px;
    background: var(--bg-surface-soft);
    border: 1px dashed var(--border-main);
    border-radius: 8px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.upload-link-box:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--accent);
}

.stop-box {
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid var(--border-main);
    background: var(--bg-surface);
}

.stop-header {
    background: var(--bg-app);
    padding: 12px 20px;
    display: flex;
    align-items: center;
    gap: 20px;
}

.stop-badge {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 120px;
}

.stop-number {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--accent);
    color: var(--text-inverse);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: bold;
}

.stop-label {
    font-weight: 800;
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: 0.5px;
}

.delivery-stop .stop-number {
    background: #10b981;
}

.stop-top-fields {
    display: flex;
    gap: 10px;
    flex-grow: 1;
}

.stop-top-fields .form-control {
    background: var(--bg-surface);
    border-color: var(--border-main);
    height: 38px;
    font-size: 13px;
}

.stop-body {
    padding: 24px;
}

/* AI Upload Page */
.ai-load-card {
    background: var(--bg-surface);
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--border-main);
    box-shadow: var(--card-shadow),
        0 0 0 1px var(--border-soft);
}

.ai-load-header {
    background: linear-gradient(135deg, #0891b2 0%, #1d4ed8 100%);
    padding: 36px 40px;
    color: white;
    position: relative;
    overflow: hidden;
}

.ai-load-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: rgba(255, 255, 255, 0.07);
    border-radius: 50%;
    pointer-events: none;
}

.ai-load-header h2 {
    margin: 0;
    font-weight: 800;
    font-size: 26px;
    letter-spacing: -0.5px;
}

.ai-load-header p {
    margin: 8px 0 0;
    opacity: 0.85;
    font-size: 14px;
    font-weight: 500;
}

.ai-upload-form {
    padding: 36px 40px;
}

/* Form Row Layout */
.form-row {
    display: flex;
    gap: 16px;
    margin-bottom: 0;
}

.form-row .col {
    flex: 1;
    min-width: 0;
}

.form-group.col {
    flex: 1;
    min-width: 0;
}

/* Readonly field styling */
.readonly-field {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-soft) !important;
    color: var(--text-muted) !important;
    cursor: not-allowed;
}

/* Form control focus state */
.form-control:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.12);
    transition: box-shadow 0.2s, border-color 0.2s;
}

.form-control option {
    background: var(--bg-surface);
    color: var(--text-main);
}

/* Upload Zone */
.upload-zone {
    border: 2px dashed var(--border-main);
    background: var(--bg-surface-soft);
    border-radius: 16px;
    padding: 50px 40px;
    text-align: center;
    margin: 8px 0 24px;
    transition: all 0.3s ease;
    cursor: pointer;
}

.upload-zone:hover {
    border-color: #38bdf8;
    background: rgba(56, 189, 248, 0.03);
}

.upload-zone.drag-over {
    border-color: #38bdf8;
    background: rgba(56, 189, 248, 0.06);
    transform: scale(1.01);
    box-shadow: 0 0 0 4px rgba(56, 189, 248, 0.1);
}

.upload-content i {
    font-size: 48px;
    color: #38bdf8;
    margin-bottom: 16px;
    display: block;
    opacity: 0.7;
}

.upload-content p {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 6px;
    color: #e2e8f0;
}

.upload-content span {
    color: #64748b;
    font-size: 13px;
}

.file-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 8px;
}

.file-preview i {
    font-size: 40px;
    color: #ef4444;
}

.file-preview span {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-main);
    max-width: 250px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#remove-file {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #ef4444;
    border-radius: 8px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
    flex-shrink: 0;
}

#remove-file:hover {
    background: rgba(239, 68, 68, 0.2);
    border-color: #ef4444;
}

/* Form Notice */
.form-notice {
    font-size: 13px;
    color: #f59e0b;
    background: rgba(245, 158, 11, 0.08);
    border: 1px solid rgba(245, 158, 11, 0.2);
    padding: 14px 18px;
    border-radius: 10px;
    margin-bottom: 28px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    line-height: 1.5;
}

.form-notice i {
    margin-top: 1px;
    flex-shrink: 0;
    font-size: 15px;
}

/* Form Actions */
.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    align-items: center;
    border-top: 1px solid var(--border-soft);
    padding-top: 24px;
    margin-top: 4px;
}

.btn-secondary {
    background: rgba(255, 255, 255, 0.06);
    color: #94a3b8;
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.2s;
}

.btn-secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #f1f5f9;
    border-color: rgba(255, 255, 255, 0.2);
}

.btn-primary i {
    margin-left: 4px;
}

/* Alert styles for error messages */
.alert {
    padding: 14px 18px;
    border-radius: 10px;
    margin-bottom: 20px;
    font-size: 14px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 10px;
}

.alert-danger {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.25);
    color: #fca5a5;
}

/* ════════════════════════════════════════════════
   PREMIUM LOAD FORM — Teal Glass Design
   ════════════════════════════════════════════════ */
.premium-load-container {
    padding: 0;
    background: var(--bg-app);
    min-height: 100vh;
    color: var(--text-main);
}

.premium-header {
    background: var(--bg-surface);
    padding: 16px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-soft);
    position: relative;
}

.premium-header::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, #0e7490 30%, #06b6d4 50%, #0e7490 70%, transparent 100%);
    opacity: 0.5;
}

.premium-header h2 {
    color: var(--text-main);
    text-shadow: none;
}

.premium-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.premium-header-actions .btn-premium-cancel {
    background: rgba(71, 85, 105, 0.5);
    color: #94a3b8;
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 7px 20px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 12px;
    text-decoration: none;
    transition: all 0.25s;
    cursor: pointer;
}

.premium-header-actions .btn-premium-cancel:hover {
    background: rgba(71, 85, 105, 0.7);
    color: #e2e8f0;
    border-color: rgba(255, 255, 255, 0.15);
}

.premium-header-actions .btn-premium-save {
    background: var(--success);
    color: var(--text-inverse);
    border: none;
    padding: 7px 28px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.25s;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.25);
}

.premium-header-actions .btn-premium-save:hover {
    background: linear-gradient(135deg, #34d399, #10b981);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(16, 185, 129, 0.35);
}

.premium-body-content {
    padding: 28px 36px;
}

.top-info-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 22px;
}

.top-info-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
}

.card-glass {
    background: var(--bg-surface);
    backdrop-filter: blur(12px);
    border: 1px solid var(--border-soft);
    border-radius: 14px;
    margin-bottom: 22px;
    box-shadow: var(--card-shadow);
}

.card-glass-header {
    padding: 12px 15px;
    font-size: 13px;
    font-weight: 800;
    color: #2d6a82;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Premium Inputs Refinement */
.premium-input-group {
    position: relative;
    border: 1px solid var(--border-main);
    background: var(--bg-surface-soft);
    border-radius: 6px;
    padding: 6px 12px;
    margin-bottom: 8px;
    height: 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.premium-input-group:hover {
    border-color: rgba(14, 116, 144, 0.35);
    background: rgba(30, 41, 59, 0.6);
}

.premium-input-group:focus-within {
    border-color: #0891b2;
    background: rgba(30, 41, 59, 0.8);
    box-shadow: 0 0 0 3px rgba(8, 145, 178, 0.1);
}

.premium-input-group label {
    position: absolute;
    top: -8px;
    left: 8px;
    background: var(--bg-surface);
    padding: 0 5px;
    font-size: 9px;
    color: var(--text-muted);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.7px;
    transition: color 0.2s;
}

.premium-input-group:focus-within label {
    color: #0891b2;
}

.premium-input-group input,
.premium-input-group select,
.premium-input-group textarea {
    background: transparent;
    border: none;
    color: var(--text-main);
    font-size: 13px;
    font-weight: 600;
    width: 100%;
    outline: none;
    font-family: inherit;
}

.premium-input-group input::placeholder {
    color: #1a3d52;
}

.input-marker {
    color: #06b6d4;
    font-weight: bold;
}

.input-side-icon {
    color: #1e4a5e;
    font-size: 11px;
    transition: color 0.2s;
}

.premium-input-group:focus-within .input-side-icon {
    color: #0891b2;
}

/* Middle Grid (Reference, Payments, Documents) */
.middle-grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr 1fr;
    gap: 20px;
    margin-bottom: 24px;
    border: 1px solid var(--border-main);
    padding: 24px;
    border-radius: 10px;
    background: var(--bg-surface);
}

.payments-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.total-rates-display {
    background: var(--bg-app);
    border-radius: 4px;
    padding: 12px;
}

.total-rates-item {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.total-rates-item .amount {
    font-size: 15px;
    font-weight: 800;
}

.total-rates-item .label {
    font-size: 10px;
    color: #64748b;
    font-weight: 800;
}

.btn-service-fee {
    background: transparent;
    border: 1px solid #f59e0b;
    color: #f59e0b;
    width: 100%;
    padding: 8px;
    font-weight: 700;
    font-size: 12px;
    border-radius: 4px;
    margin-top: 10px;
    cursor: pointer;
}

/* Documents */
.doc-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-surface-soft);
    border: 1px solid var(--border-soft);
    padding: 10px 15px;
    border-radius: 6px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: all 0.2s;
}

.doc-item:hover {
    border-color: rgba(14, 116, 144, 0.3);
    background: rgba(30, 41, 59, 0.6);
}

.doc-item span {
    font-weight: 600;
    font-size: 12px;
    color: #94a3b8;
}

.doc-item i {
    color: #1e4a5e;
    font-size: 14px;
    transition: color 0.2s;
}

.doc-item:hover i {
    color: #06b6d4;
}

.doc-item.uploaded {
    border-color: rgba(16, 185, 129, 0.3);
}

/* Toggle Group Bar */
.settings-bar {
    display: flex;
    gap: 30px;
    margin-bottom: 25px;
    padding: 0 10px;
}

.setting-option {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
}

.setting-option i {
    font-size: 16px;
}

.setting-option .fa-circle-dot {
    color: #06b6d4;
}

.setting-option .fa-circle {
    color: rgba(255, 255, 255, 0.1);
}

.v-line {
    width: 1px;
    height: 25px;
    background: rgba(255, 255, 255, 0.1);
}

/* Stop Management Design */
.stop-card {
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 30px;
    background: var(--bg-surface);
}

.stop-top-bar {
    background: var(--bg-app);
    padding: 10px 15px;
    display: flex;
    gap: 15px;
    align-items: center;
    border: 1px solid var(--border-soft);
}

.stop-badge {
    background: #111a2e;
    color: #fff;
    padding: 8px 15px;
    border-radius: 4px;
    font-weight: 800;
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.stop-badge.pickup {
    background: #0d9488;
}

.stop-badge.delivery {
    background: #4f46e5;
}

.stop-top-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    flex-grow: 1;
}

.stop-main-form {
    background: var(--bg-surface-soft);
    padding: 25px;
    display: grid;
    grid-template-columns: 2fr 1.2fr;
    gap: 40px;
}

.stop-left-grid {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.stop-right-settings {
    border-left: 1px solid rgba(255, 255, 255, 0.05);
    padding-left: 30px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.load-dimensions-toggle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: #64748b;
    font-weight: 700;
    font-size: 13px;
    margin: 10px 0;
    cursor: pointer;
}

.footer-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 40px 0 60px;
}

.btn-add-stop {
    background: #0891b2;
    color: #fff;
    border: none;
    padding: 8px 20px;
    border-radius: 4px;
    font-weight: 700;
    font-size: 12px;
    margin-right: 12px;
}

.input-icon-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.input-icon-label input,
.input-icon-label select {
    flex-grow: 1;
    background: transparent !important;
    border: none !important;
    color: inherit !important;
    font: inherit;
    outline: none !important;
    padding: 2px 0;
}

.btn-service-fee {
    background: transparent;
    border: 1px solid #f59e0b;
    color: #f59e0b;
    width: 100%;
    padding: 8px;
    font-weight: 700;
    font-size: 12px;
    border-radius: 4px;
    margin-top: 10px;
    cursor: pointer;
}

/* New Radio Label Styles */
.radio-label {
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    color: #94a3b8;
    transition: color 0.2s;
}

.radio-label.active {
    color: var(--accent);
}

.radio-label input[type="radio"] {
    display: none;
}

.setting-option input[type="radio"] {
    display: none;
}

.setting-option.active {
    color: var(--accent) !important;
}

.setting-option.active i {
    color: var(--accent);
}

/* Layout Width Fix to match screenshot */
.premium-header,
.premium-body-content {
    max-width: 1100px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.premium-load-container {
    background: var(--bg-dark);
    width: 100%;
}

.premium-body-content {
    padding: 30px 20px !important;
    width: 100%;
}

/* Refined Width and Centering */
.premium-load-container {
    background: var(--bg-dark);
    padding-bottom: 50px;
}

.premium-header {
    margin-top: 0 !important;
    border-radius: 0 0 8px 8px;
}

.premium-body-content {
    background: transparent;
}

/* Adjust grid gaps for tighter look */
.top-info-row {
    gap: 20px !important;
}

/* PREMIUM SAFETY DESIGN SYSTEM */
.stat-card-premium {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 20px;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.stat-card-premium::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 100px;
    height: 100px;
    background: radial-gradient(circle at top right, rgba(255, 255, 255, 0.03), transparent);
    pointer-events: none;
}

.stat-card-premium:hover {
    transform: translateY(-5px);
    border-color: var(--accent);
    box-shadow: var(--card-shadow);
}

.stat-icon-glow {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
}

.card-modern {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 20px;
    box-shadow: var(--card-shadow);
    overflow: hidden;
}

.card-modern-header {
    background: var(--nav-item-hover);
    border-bottom: 1px solid var(--border);
    padding: 1rem 1.5rem;
}

.table-premium {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.table-premium thead th {
    background: var(--nav-item-hover);
    padding: 18px 20px;
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    font-weight: 800;
    border-bottom: 1px solid var(--border);
    letter-spacing: 1px;
}

.table-premium tbody td {
    padding: 18px 20px;
    border-bottom: 1px solid var(--border);
    font-size: 14px;
    color: var(--text-main);
    vertical-align: middle;
}

.table-premium tbody tr:hover {
    background: rgba(255, 255, 255, 0.015);
}

.bg-danger-soft {
    background: rgba(239, 68, 68, 0.1);
    color: #f87171 !important;
}

.bg-success-soft {
    background: rgba(16, 185, 129, 0.1);
    color: #34d399 !important;
}

.bg-info-soft {
    background: rgba(6, 182, 212, 0.1);
    color: #38bdf8 !important;
}

.bg-primary-soft {
    background: rgba(56, 189, 248, 0.1);
    color: #38bdf8 !important;
}

.bg-warning-soft {
    background: rgba(245, 158, 11, 0.1);
    color: #fbbf24 !important;
}

.badge-error {
    background: rgba(239, 68, 68, 0.2);
    color: #f87171;
    border-radius: 8px;
    padding: 4px 8px;
    font-weight: 700;
}

.badge-warning {
    background: rgba(245, 158, 11, 0.2);
    color: #fbbf24;
    border-radius: 8px;
    padding: 4px 8px;
    font-weight: 700;
}

.badge-success {
    background: rgba(16, 185, 129, 0.2);
    color: #34d399;
    border-radius: 8px;
    padding: 4px 10px;
    font-weight: 700;
}

.bg-card-glass {
    background: var(--bg-card);
    backdrop-filter: blur(8px);
}

/* Ensure form sub-sections don't overflow */
.top-info-grid,
.middle-grid,
.settings-bar,
#stops-container,
.footer-actions {
    max-width: 100%;
}

.input-icon-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.input-icon-label input,
.input-icon-label select {
    flex-grow: 1;
    background: transparent !important;
    border: none !important;
    color: inherit !important;
    font: inherit;
    outline: none !important;
    padding: 2px 0;
}

/* Fix visibility of select options in premium inputs */
.input-icon-label select option {
    background-color: var(--bg-card);
    color: var(--text-main);
}

.btn-service-fee {
    background: transparent;
    border: 1px solid #f59e0b;
    color: #f59e0b;
    width: 100%;
    padding: 8px;
    font-weight: 700;
    font-size: 12px;
    border-radius: 4px;
    margin-top: 10px;
    cursor: pointer;
}

/* New Radio Label Styles */
.radio-label {
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    color: #94a3b8;
    transition: color 0.2s;
}

.radio-label.active {
    color: #06b6d4;
}

.radio-label input[type="radio"] {
    display: none;
}

.setting-option input[type="radio"] {
    display: none;
}

.setting-option.active {
    color: #06b6d4 !important;
}

.setting-option.active i {
    color: var(--accent);
}

/* Layout Width Fix to match screenshot */
.premium-body-content {
    max-width: 1157px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 28px 20px !important;
    width: 100%;
    background: transparent;
}

.premium-header {
    width: 100%;
    background: var(--sidebar-bg);
    padding: 16px 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid rgba(14, 116, 144, 0.2);
    margin-top: -24px;
    margin-left: -24px;
    margin-right: -24px;
    width: calc(100% + 48px);
    position: relative;
}

.premium-load-container {
    background: var(--bg-dark);
    width: 100%;
    padding-bottom: 50px;
    display: flex;
    flex-direction: column;
}

/* Premium Minimal Form Controls */
.search-input-group {
    position: relative;
    display: flex;
    align-items: center;
    background: var(--bg-dark);
    border: 1px solid var(--border);
    border-radius: 14px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.search-input-group:focus-within {
    border-color: #38bdf8;
    background: rgba(15, 23, 42, 0.6);
    box-shadow: 0 0 0 4px rgba(56, 189, 248, 0.15);
}

.form-control-minimal {
    background: transparent !important;
    border: none !important;
    color: var(--text-main) !important;
    padding: 12px 18px !important;
    font-size: 14px !important;
    width: 100%;
}

.form-control-minimal::placeholder {
    color: #64748b;
}

.form-control-minimal:focus {
    box-shadow: none !important;
    outline: none !important;
}

.form-select-minimal {
    background: var(--input-bg) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-main) !important;
    padding: 12px 18px !important;
    font-size: 14px !important;
    border-radius: 14px !important;
    cursor: pointer !important;
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    background-size: 18px !important;
    padding-right: 45px !important;
    transition: all 0.3s ease !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.form-select-minimal:hover {
    border-color: var(--accent) !important;
    background-color: var(--bg-surface-soft) !important;
}

.form-select-minimal:focus {
    border-color: #38bdf8 !important;
    box-shadow: 0 0 0 4px rgba(56, 189, 248, 0.15) !important;
    outline: none !important;
}

/* Ensure form sub-sections don't overflow */
.top-info-grid,
.middle-grid,
.settings-bar,
#stops-container,
.footer-actions {
    max-width: 1157px;
    margin-left: auto;
    margin-right: auto;
}

/* Adjust grid gaps for tighter look */
.top-info-row {
    gap: 16px !important;
}

.middle-grid {
    padding: 24px !important;
    gap: 24px !important;
    background: var(--bg-card) !important;
    border-color: var(--border) !important;
    border-radius: 10px !important;
}

/* Company Switcher Premium Styling */
.company-switcher-container {
    position: relative;
}

.company-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    width: 280px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    margin-top: 12px;
    box-shadow: var(--card-shadow);
    z-index: 1000;
    overflow: hidden;
    animation: fadeInDown 0.2s ease-out;
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.company-dropdown .dropdown-header {
    padding: 12px 16px;
    font-size: 11px;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
    background: var(--nav-item-hover);
}

.company-list {
    max-height: 300px;
    overflow-y: auto;
}

.company-item {
    padding: 12px 16px;
    cursor: pointer;
    transition: all 0.2s;
    border-bottom: 1px solid var(--border-soft);
}

.company-item:hover {
    background: var(--nav-item-hover);
}

.company-item.active {
    background: rgba(56, 189, 248, 0.05);
    border-left: 3px solid var(--accent);
}

.company-item:last-child {
    border-bottom: none;
}

/* Page Subtitle */
.page-subtitle {
    color: var(--text-muted);
    font-size: 14px;
    margin-top: -8px;
    margin-bottom: 0;
}

[v-cloak] {
    display: none !important;
}

/* Table & Card Design */
.premium-card {
    background: var(--bg-card) !important;
    backdrop-filter: blur(12px);
    border: 1px solid var(--border) !important;
    border-radius: 18px;
    box-shadow: var(--card-shadow);
    /* overflow: hidden removed — it clips Bootstrap dropdowns */
    overflow: visible;
    color: var(--text-main);
    margin-bottom: 1.5rem;
    /* Clip only the visual border-radius, not content */
    isolation: isolate;
}

/* Restore rounded corners on header/body without clipping dropdown */
.premium-card .card-header:first-child {
    border-radius: 18px 18px 0 0;
}

.premium-card .card-body:last-child,
.premium-card>div:last-child {
    border-radius: 0 0 18px 18px;
}

/* Table wrapper — allow overflow so dropdown pops out */
.premium-card .table-responsive {
    overflow: visible;
}

/* Ensure Bootstrap dropdowns always sit on top */
.dropdown-menu {
    z-index: 9999 !important;
}

.table-premium {
    --bs-table-bg: transparent !important;
    --bs-table-color: var(--text-main) !important;
    background: transparent !important;
    color: var(--text-main) !important;
}

.table-premium tbody td {
    color: var(--text-main) !important;
}

.table-premium thead th {
    background: var(--nav-item-hover) !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text-muted) !important;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 16px 20px;
}

.table-premium tbody td {
    padding: 18px 20px;
    vertical-align: middle;
    border-bottom: 1px solid var(--border-soft) !important;
    background: transparent !important;
}

.table-premium.table-hover tbody tr:hover {
    background: var(--nav-item-hover) !important;
}

/* Stat Cards */
.stat-card {
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    padding: 1.25rem;
    border-radius: 1rem;
    display: flex;
    align-items: center;
}

.stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 1rem;
}

.stat-label {
    color: var(--text-muted);
    font-size: 0.875rem;
    margin-bottom: 2px;
}

.stat-value {
    color: var(--text-main);
    font-weight: 700;
    margin-bottom: 0;
}

/* Modern Pagination */
.pagination-modern .page-link {
    background: var(--input-bg);
    border: 1px solid var(--border);
    color: var(--text-muted);
    margin: 0 3px;
    border-radius: 8px !important;
}

.pagination-modern .page-item.active .page-link {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--text-inverse);
}

.modal-content.bg-dark {
    background-color: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
}

/* ============================================================
   COMPREHENSIVE LIGHT MODE OVERRIDES
   Fixes: Safety, Fleet, Account Resources modules
   ============================================================ */

/* ---- 1. GLOBAL: Hardcoded text-white and fw-bold text-white ---- */
[data-theme="light"] .fw-bold.text-white,
[data-theme="light"] .fw-semibold.text-white,
[data-theme="light"] .fw-medium.text-white,
[data-theme="light"] .font-weight-bold.text-white,
[data-theme="light"] .h3.text-white,
[data-theme="light"] .h4.text-white,
[data-theme="light"] .h5.text-white,
[data-theme="light"] .h6.text-white {
    color: var(--text-main) !important;
}

/* ---- 2. GLOBAL: Table hover row for light mode ---- */
[data-theme="light"] .table-premium tbody tr:hover {
    background: rgba(0, 0, 0, 0.03) !important;
}

/* ---- 3. STAT-CARD-PREMIUM (used by Maintenance, Companies, etc.) ---- */
[data-theme="light"] .stat-card-premium {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .stat-card-premium .h4,
[data-theme="light"] .stat-card-premium .h5,
[data-theme="light"] .stat-card-premium .h6 {
    color: var(--text-main) !important;
}
[data-theme="light"] .stat-card-premium::after {
    background: radial-gradient(circle at top right, rgba(0, 0, 0, 0.02), transparent) !important;
}

/* ---- 4. CARD-MODERN (used everywhere) ---- */
[data-theme="light"] .card-modern {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .card-modern-header {
    background: var(--bg-surface-soft) !important;
    border-bottom-color: var(--border-main) !important;
}

/* ---- 5. TABLE-PREMIUM ---- */
[data-theme="light"] .table-premium thead th {
    background: var(--bg-surface-soft) !important;
    color: var(--text-muted) !important;
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .table-premium tbody td {
    color: var(--text-main) !important;
    border-bottom-color: var(--border-main) !important;
}

/* ---- 6. PREMIUM-CARD (used by Inventory, Drivers, etc.) ---- */
[data-theme="light"] .premium-card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}

/* ---- 7. KPI-CARD GLASS (used by Drivers & Contractors) ---- */
[data-theme="light"] .kpi-card.glass {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-main) !important;
    box-shadow: var(--card-shadow) !important;
}
[data-theme="light"] .kpi-card .kpi-value {
    color: var(--text-main) !important;
}

/* ---- 8. EQUIPMENT PAGE (eq-kpi-card) ---- */
[data-theme="light"] .eq-kpi-card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    border-left-width: 4px !important;
    border-left-style: solid !important;
}
[data-theme="light"] .eq-kpi-value {
    color: var(--text-main) !important;
}
[data-theme="light"] .eq-kpi-label {
    color: var(--text-muted) !important;
}
[data-theme="light"] .ownership-badge {
    background: rgba(0, 0, 0, 0.04) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .asset-icon-box {
    background: rgba(2, 132, 199, 0.08) !important;
    color: var(--accent) !important;
}
[data-theme="light"] .asset-icon-trailer {
    background: rgba(96, 165, 250, 0.08) !important;
    color: #3b82f6 !important;
}
[data-theme="light"] .details-link {
    color: var(--accent) !important;
}
[data-theme="light"] .details-link:hover {
    color: var(--text-main) !important;
}
[data-theme="light"] .arrow-circle {
    background: rgba(2, 132, 199, 0.08) !important;
    border-color: rgba(2, 132, 199, 0.2) !important;
    color: var(--accent) !important;
}

/* ---- 9. BG-DARK-SOFT (used in Equipment, Maintenance) ---- */
[data-theme="light"] .bg-dark-soft {
    background: var(--bg-surface-soft) !important;
}
[data-theme="light"] .border-light-alpha {
    border-color: var(--border-main) !important;
}

/* ---- 10. SEARCH INPUTS & FORM CONTROLS dark overrides ---- */
[data-theme="light"] .search-input-group {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .search-input-group input {
    color: var(--text-main) !important;
}

/* ---- 11. MODALS: modal-backdrop-premium, modal-dialog-premium ---- */
[data-theme="light"] .modal-backdrop-premium {
    background: rgba(0, 0, 0, 0.4) !important;
}
[data-theme="light"] .modal-dialog-premium {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    box-shadow: 0 25px 60px -12px rgba(0, 0, 0, 0.25) !important;
}
[data-theme="light"] .modal-header-premium {
    background: var(--bg-surface-soft) !important;
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .modal-header-premium h2 {
    color: var(--text-main) !important;
}
[data-theme="light"] .modal-body-premium {
    background: var(--bg-surface) !important;
}
[data-theme="light"] .modal-footer-premium {
    background: var(--bg-surface-soft) !important;
    border-top-color: var(--border-main) !important;
}
[data-theme="light"] .btn-close-premium,
[data-theme="light"] .btn-close-modal {
    background: rgba(0, 0, 0, 0.04) !important;
    border-color: var(--border-main) !important;
    color: var(--text-muted) !important;
}
[data-theme="light"] .btn-close-premium:hover,
[data-theme="light"] .btn-close-modal:hover {
    background: rgba(220, 38, 38, 0.08) !important;
    color: var(--danger) !important;
    border-color: rgba(220, 38, 38, 0.2) !important;
}
[data-theme="light"] .modal-label {
    color: var(--text-muted) !important;
}
[data-theme="light"] .modal-input-premium,
[data-theme="light"] .modal-select-premium {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .modal-input-premium:focus,
[data-theme="light"] .modal-select-premium:focus {
    background: #fff !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(2, 132, 199, 0.1) !important;
}
[data-theme="light"] .modal-select-premium {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E") !important;
}
[data-theme="light"] .modal-section-title {
    color: var(--accent) !important;
}
[data-theme="light"] .modal-section-title::after {
    background: linear-gradient(90deg, rgba(2, 132, 199, 0.15), transparent) !important;
}
[data-theme="light"] .modal-grid-2 .col-span-2 {
    color: var(--text-main) !important;
}

/* ---- 12. DRAWERS (used by Maintenance, Inventory) ---- */
[data-theme="light"] .drawer-backdrop {
    background: rgba(0, 0, 0, 0.3) !important;
}
[data-theme="light"] .drawer-right {
    background: var(--bg-surface) !important;
    border-left-color: var(--border-main) !important;
}
[data-theme="light"] .inv-drawer-backdrop {
    background: rgba(0, 0, 0, 0.3) !important;
}
[data-theme="light"] .inv-drawer {
    background: var(--bg-surface) !important;
    border-left-color: var(--border-main) !important;
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.1) !important;
}
[data-theme="light"] .inv-drawer-header {
    background: var(--bg-surface-soft) !important;
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .inv-drawer-body {
    background: var(--bg-surface) !important;
}
[data-theme="light"] .inv-section-label {
    color: var(--text-muted) !important;
}
[data-theme="light"] .inv-detail-key {
    color: var(--text-muted) !important;
}
[data-theme="light"] .inv-detail-val {
    color: var(--text-main) !important;
}
[data-theme="light"] .history-item {
    border-bottom-color: var(--border-main) !important;
}

/* ---- 13. INVENTORY PAGE specific ---- */
[data-theme="light"] .inv-kpi-card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .inv-kpi-value {
    color: var(--text-main) !important;
}
[data-theme="light"] .inv-kpi-label {
    color: var(--text-muted) !important;
}
[data-theme="light"] .inv-search-wrap input {
    color: var(--text-main) !important;
}
[data-theme="light"] .inv-search-wrap input::placeholder {
    color: var(--text-muted) !important;
}
[data-theme="light"] .inv-modal {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .inv-modal .modal-header {
    background: var(--bg-surface-soft) !important;
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .inv-modal .modal-footer {
    background: var(--bg-surface-soft) !important;
    border-top-color: var(--border-main) !important;
}
[data-theme="light"] .inv-modal .form-control,
[data-theme="light"] .inv-modal .form-select {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .inv-modal .form-control:focus,
[data-theme="light"] .inv-modal .form-select:focus {
    background: #fff !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(2, 132, 199, 0.1) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .inv-modal .form-label {
    color: var(--text-muted) !important;
}
[data-theme="light"] .inv-modal option {
    background: var(--bg-surface) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .inv-filter-sep {
    background: var(--border-main) !important;
}
[data-theme="light"] .page-title {
    background: linear-gradient(to right, var(--text-main), var(--accent)) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

/* ---- 14. BTN-ACTIONS-PREMIUM (action icon buttons) ---- */
[data-theme="light"] .btn-actions-premium {
    background: rgba(0, 0, 0, 0.04) !important;
    border-color: var(--border-main) !important;
    color: var(--text-muted) !important;
}
[data-theme="light"] .btn-actions-premium:hover {
    background: rgba(2, 132, 199, 0.08) !important;
    border-color: rgba(2, 132, 199, 0.2) !important;
    color: var(--accent) !important;
}

/* ---- 15. COMPANIES PAGE inline overrides ---- */
[data-theme="light"] .search-box-premium input {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .search-box-premium input:focus {
    background: #fff !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(2, 132, 199, 0.1) !important;
}
[data-theme="light"] .search-box-premium i {
    color: var(--text-muted) !important;
}
[data-theme="light"] .company-avatar {
    background: rgba(2, 132, 199, 0.06) !important;
    border-color: rgba(2, 132, 199, 0.15) !important;
    color: var(--accent) !important;
}

/* ---- 16. DROPDOWN MENUS (dark dropdowns in light mode) ---- */
[data-theme="light"] .dropdown-menu-dark,
[data-theme="light"] .dropdown-menu[style*="background: #1e293b"],
[data-theme="light"] .dropdown-menu[style*="background:#1e293b"],
[data-theme="light"] .dropdown-menu[style*="background:#111827"],
[data-theme="light"] .dropdown-menu[style*="background: #111827"] {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-main) !important;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.15) !important;
}
[data-theme="light"] .dropdown-menu-dark .dropdown-item,
[data-theme="light"] .dropdown-menu .dropdown-item {
    color: var(--text-main) !important;
}
[data-theme="light"] .dropdown-menu-dark .dropdown-item:hover,
[data-theme="light"] .dropdown-menu .dropdown-item:hover {
    background: rgba(2, 132, 199, 0.06) !important;
    color: var(--accent) !important;
}
[data-theme="light"] .dropdown-menu-dark .dropdown-item.text-danger {
    color: var(--danger) !important;
}
[data-theme="light"] .dropdown-menu-dark .dropdown-divider,
[data-theme="light"] .dropdown-menu .dropdown-divider {
    border-color: var(--border-main) !important;
}

/* ---- 17. DRIVERS & CONTRACTORS inline style overrides ---- */
[data-theme="light"] #drivers-contractors-app [style*="background: rgba(15,23,42"],
[data-theme="light"] #drivers-contractors-app [style*="background:rgba(15,23,42"] {
    background: var(--bg-surface-soft) !important;
}
[data-theme="light"] #drivers-contractors-app [style*="color:#f1f5f9"],
[data-theme="light"] #drivers-contractors-app [style*="color: #f1f5f9"] {
    color: var(--text-main) !important;
}
[data-theme="light"] #drivers-contractors-app [style*="color:#e2e8f0"],
[data-theme="light"] #drivers-contractors-app [style*="color: #e2e8f0"] {
    color: var(--text-main) !important;
}
[data-theme="light"] #drivers-contractors-app [style*="color:#cbd5e1"],
[data-theme="light"] #drivers-contractors-app [style*="color: #cbd5e1"] {
    color: var(--text-secondary) !important;
}
[data-theme="light"] #drivers-contractors-app tr[style*="border-bottom: 1px solid rgba(255,255,255"] {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] #drivers-contractors-app th[style*="border-bottom:1px solid rgba(255,255,255"] {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] #drivers-contractors-app [style*="background: rgba(255,255,255,0.05"],
[data-theme="light"] #drivers-contractors-app [style*="background:rgba(255,255,255,0.05"],
[data-theme="light"] #drivers-contractors-app [style*="background: rgba(255,255,255,0.04"],
[data-theme="light"] #drivers-contractors-app [style*="background:rgba(255,255,255,0.04"],
[data-theme="light"] #drivers-contractors-app [style*="background:rgba(255,255,255,0.03"] {
    background: rgba(0, 0, 0, 0.03) !important;
}
[data-theme="light"] #drivers-contractors-app [style*="border: 1px solid rgba(255,255,255,0.0"],
[data-theme="light"] #drivers-contractors-app [style*="border:1px solid rgba(255,255,255,0.0"] {
    border-color: var(--border-main) !important;
}
/* Driver inline form inputs */
[data-theme="light"] #drivers-contractors-app .form-control[style*="background: rgba(255,255,255"],
[data-theme="light"] #drivers-contractors-app .form-control[style*="background:rgba(255,255,255"],
[data-theme="light"] #drivers-contractors-app .form-select[style*="background: rgba(255,255,255"],
[data-theme="light"] #drivers-contractors-app .form-select[style*="background:rgba(255,255,255"] {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
/* Driver modal */
[data-theme="light"] #drivers-contractors-app .modal-content[style*="background:#0f172a"],
[data-theme="light"] #drivers-contractors-app .modal-content[style*="background: #0f172a"] {
    background: var(--bg-surface) !important;
}
[data-theme="light"] #drivers-contractors-app [style*="background:#111827"],
[data-theme="light"] #drivers-contractors-app [style*="background: #111827"] {
    background: var(--bg-surface-soft) !important;
}

/* ---- 18. WIZ-INPUT (wizard steps in Driver modal) ---- */
[data-theme="light"] .wiz-input {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .wiz-input:focus {
    background: #fff !important;
    border-color: var(--accent) !important;
}
[data-theme="light"] .wiz-label {
    color: var(--text-muted) !important;
}

/* ---- 19. MAINTENANCE PAGE specific ---- */
[data-theme="light"] .badge-asset strong {
    color: var(--text-main) !important;
}
[data-theme="light"] .badge-asset.truck span {
    color: var(--accent) !important;
}
[data-theme="light"] .badge-asset.trailer span {
    color: #7c3aed !important;
}

/* ---- 20. IFTA PAGE specific ---- */
[data-theme="light"] .ifta-page {
    color: var(--text-main) !important;
}
[data-theme="light"] .ifta-page .ifta-title span {
    background: linear-gradient(90deg, var(--accent), #6366f1) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}
[data-theme="light"] .ifta-page .period-control {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .period-control select {
    color: var(--text-main) !important;
}
[data-theme="light"] .ifta-page .kpi-premium-card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .kpi-val-text {
    color: var(--text-main) !important;
}
[data-theme="light"] .ifta-page .kpi-lbl-text {
    color: var(--text-muted) !important;
}
[data-theme="light"] .ifta-page .side-explorer {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .detail-viewer {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .explorer-header {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .tab-nav {
    background: rgba(0, 0, 0, 0.04) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .tab-btn {
    color: var(--text-muted) !important;
}
[data-theme="light"] .ifta-page .tab-btn:hover:not(.is-active) {
    color: var(--text-main) !important;
    background: rgba(0, 0, 0, 0.04) !important;
}
[data-theme="light"] .ifta-page .explorer-item:hover {
    background: rgba(0, 0, 0, 0.03) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .item-badge {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .ifta-page .item-title {
    color: var(--text-main) !important;
}
[data-theme="light"] .ifta-page .item-meta {
    color: var(--text-muted) !important;
}
[data-theme="light"] .ifta-page .detail-head-bar {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .placeholder-view {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .premium-table td {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .ifta-page .premium-table th {
    color: var(--text-muted) !important;
}
[data-theme="light"] .ifta-page .btn-secondary {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .ifta-page .btn-secondary:hover {
    background: rgba(0, 0, 0, 0.06) !important;
}
[data-theme="light"] .ifta-page .mini-progress {
    background: rgba(0, 0, 0, 0.06) !important;
}
[data-theme="light"] .ifta-page .ifta-modal-bg {
    background: rgba(0, 0, 0, 0.4) !important;
}
[data-theme="light"] .ifta-page .ifta-modal-bg > div {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .ifta-page .miles-val {
    color: var(--accent) !important;
}

/* ---- 21. DOT INSPECTIONS & SAFETY COMPLIANCE ---- */
[data-theme="light"] .sf-stat-card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .sf-panel {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .sf-table thead th {
    background: var(--bg-surface-soft) !important;
    border-bottom-color: var(--border-main) !important;
    color: var(--text-muted) !important;
}
[data-theme="light"] .sf-table tbody td {
    color: var(--text-main) !important;
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .sf-table tbody tr:hover {
    background: rgba(0, 0, 0, 0.02) !important;
}
[data-theme="light"] .sf-input,
[data-theme="light"] .sf-select {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .sf-input:focus,
[data-theme="light"] .sf-select:focus {
    background: #fff !important;
    border-color: var(--accent) !important;
}

/* ---- 22. MAINTENANCE modal/drawer ---- */
[data-theme="light"] #maintenance-app .modal-backdrop-premium {
    background: rgba(0, 0, 0, 0.4) !important;
}
[data-theme="light"] #maintenance-app .modal-dialog-premium {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] #maintenance-app .drawer-backdrop {
    background: rgba(0, 0, 0, 0.3) !important;
}
[data-theme="light"] #maintenance-app .drawer-right {
    background: var(--bg-surface) !important;
}
[data-theme="light"] #maintenance-app .glass-box,
[data-theme="light"] #maintenance-app [style*="background: rgba(255, 255, 255, 0.02"],
[data-theme="light"] #maintenance-app [style*="background: rgba(255, 255, 255, 0.01"],
[data-theme="light"] #maintenance-app [style*="background: rgba(15, 23, 42"] {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] #maintenance-app .shadow-accent {
    box-shadow: 0 0 12px rgba(2, 132, 199, 0.1) !important;
}
[data-theme="light"] #maintenance-app .modal-input,
[data-theme="light"] #maintenance-app .modal-select,
[data-theme="light"] #maintenance-app .modal-input-premium,
[data-theme="light"] #maintenance-app .modal-textarea {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] #maintenance-app .input-with-icon i {
    color: var(--text-muted) !important;
}

/* ---- 23. INLINE STYLE OVERRIDES for common dark patterns ---- */
/* These catch elements with inline background styles */
[data-theme="light"] [style*="background: rgba(15, 23, 42"],
[data-theme="light"] [style*="background:rgba(15, 23, 42"],
[data-theme="light"] [style*="background: rgba(15,23,42"],
[data-theme="light"] [style*="background:rgba(15,23,42"] {
    background: var(--bg-surface-soft) !important;
}
[data-theme="light"] [style*="background: #0f172a"],
[data-theme="light"] [style*="background:#0f172a"],
[data-theme="light"] [style*="background: #0b1120"],
[data-theme="light"] [style*="background:#0b1120"],
[data-theme="light"] [style*="background: #080f1e"],
[data-theme="light"] [style*="background:#080f1e"],
[data-theme="light"] [style*="background: #111827"],
[data-theme="light"] [style*="background:#111827"] {
    background: var(--bg-surface) !important;
}

/* Inline border overrides */
[data-theme="light"] [style*="border: 1px solid rgba(255, 255, 255, 0.0"],
[data-theme="light"] [style*="border:1px solid rgba(255, 255, 255, 0.0"],
[data-theme="light"] [style*="border: 1px solid rgba(255,255,255,0.0"],
[data-theme="light"] [style*="border:1px solid rgba(255,255,255,0.0"],
[data-theme="light"] [style*="border-bottom: 1px solid rgba(255, 255, 255"],
[data-theme="light"] [style*="border-bottom:1px solid rgba(255, 255, 255"],
[data-theme="light"] [style*="border-bottom: 1px solid rgba(255,255,255"],
[data-theme="light"] [style*="border-bottom:1px solid rgba(255,255,255"] {
    border-color: var(--border-main) !important;
}

/* Inline white text overrides */
[data-theme="light"] [style*="color: #fff"],
[data-theme="light"] [style*="color:#fff"] {
    color: var(--text-main) !important;
}

/* Forms with inline dark backgrounds */
[data-theme="light"] .form-control[style*="background: rgba(255,255,255"],
[data-theme="light"] .form-control[style*="background:rgba(255,255,255"],
[data-theme="light"] .form-select[style*="background: rgba(255,255,255"],
[data-theme="light"] .form-select[style*="background:rgba(255,255,255"],
[data-theme="light"] .form-control[style*="background: rgba(15"],
[data-theme="light"] .form-control[style*="background:rgba(15"],
[data-theme="light"] .form-select[style*="background: rgba(15"],
[data-theme="light"] .form-select[style*="background:rgba(15"],
[data-theme="light"] .form-select[style*="background:#080f1e"],
[data-theme="light"] .form-select[style*="background: #080f1e"] {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}

/* ---- 24. COLLISIONS & CLAIMS specific badge fixes ---- */
[data-theme="light"] .status-chip {
    font-weight: 700 !important;
}

/* ---- 25. TABS: tabs-premium & tab-item (Drivers page variant) ---- */
[data-theme="light"] .tabs-premium {
    background: rgba(0, 0, 0, 0.03) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .tab-item {
    color: var(--text-muted) !important;
}
[data-theme="light"] .tab-item.active {
    color: var(--accent) !important;
    background: var(--bg-surface) !important;
}
[data-theme="light"] .tab-item:hover:not(.active) {
    color: var(--text-main) !important;
}

/* ---- 26. BTN-DETAILS-SM, BTN-ICON-SM (action buttons) ---- */
[data-theme="light"] .btn-details-sm {
    background: rgba(2, 132, 199, 0.06) !important;
    color: var(--accent) !important;
    border-color: rgba(2, 132, 199, 0.15) !important;
}
[data-theme="light"] .btn-details-sm:hover {
    background: rgba(2, 132, 199, 0.12) !important;
}
[data-theme="light"] .btn-icon-sm {
    color: var(--text-muted) !important;
}
[data-theme="light"] .btn-dark-soft {
    background: rgba(0, 0, 0, 0.04) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-main) !important;
}

/* ---- 27. UNIT-PILL-SM (contractor owned units pills) ---- */
[data-theme="light"] .unit-pill-sm {
    background: rgba(2, 132, 199, 0.06) !important;
    color: var(--accent) !important;
    border-color: rgba(2, 132, 199, 0.15) !important;
}

/* ---- 28. QUICK-LINK-BTN (driver edit modal quick links) ---- */
[data-theme="light"] .quick-link-btn {
    background: rgba(0, 0, 0, 0.03) !important;
    border-color: var(--border-main) !important;
    color: var(--text-secondary) !important;
}
[data-theme="light"] .quick-link-btn:hover {
    background: rgba(2, 132, 199, 0.06) !important;
    color: var(--accent) !important;
}

/* ---- 29. INVENTORY btn-icon ---- */
[data-theme="light"] .btn-icon {
    border-color: var(--border-main) !important;
    background: rgba(0, 0, 0, 0.02) !important;
    color: var(--text-muted) !important;
}
[data-theme="light"] .btn-icon:hover {
    background: rgba(2, 132, 199, 0.06) !important;
    border-color: rgba(2, 132, 199, 0.15) !important;
    color: var(--accent) !important;
}
[data-theme="light"] .btn-icon.danger:hover {
    background: rgba(220, 38, 38, 0.06) !important;
    border-color: rgba(220, 38, 38, 0.15) !important;
    color: var(--danger) !important;
}

/* ---- 30. Custom checkbox (Maintenance) ---- */
[data-theme="light"] .custom-checkbox-container .checkmark {
    border-color: var(--border-main) !important;
    background: var(--input-bg) !important;
}

/* ---- 31. STAT-ICON-GLOW fix for light mode ---- */
[data-theme="light"] .stat-icon-glow {
    box-shadow: none !important;
}

/* ---- 32. BTN outline overrides ---- */
[data-theme="light"] .btn-outline-light {
    border-color: var(--border-main) !important;
    color: var(--text-secondary) !important;
}
[data-theme="light"] .btn-outline-light:hover {
    background: rgba(0, 0, 0, 0.04) !important;
    color: var(--text-main) !important;
    border-color: var(--text-muted) !important;
}

/* ---- 33. Address Book & Integrations (generic page-content) ---- */
[data-theme="light"] .page-content h1,
[data-theme="light"] .page-content h2,
[data-theme="light"] .page-content h3 {
    color: var(--text-main) !important;
}

/* ---- 34. Safety compliance inline overrides per-page ---- */
[data-theme="light"] .glass-bg,
[data-theme="light"] [style*="background: var(--glass-bg)"],
[data-theme="light"] [style*="background:var(--glass-bg)"] {
    background: var(--bg-surface) !important;
}

/* ---- 35. FLEET COMPLIANCE ---- */
[data-theme="light"] .fc-card,
[data-theme="light"] .fc-panel {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}

/* ---- 36. Fix for select option readability ---- */
[data-theme="light"] select option {
    background: var(--bg-surface) !important;
    color: var(--text-main) !important;
}

/* ============================================================
   DRIVER WIZARD & DRIVER PROFILE — LIGHT MODE OVERRIDES
   Targets: driver_wizard.php (#wizard-app) and
            driver_profile.php (.profile-section, etc.)
   ============================================================ */

/* ── Wizard: outer container ── */
[data-theme="light"] .wizard-container,
[data-theme="light"] #wizard-app {
    background: var(--bg-app) !important;
    color: var(--text-main) !important;
}

/* ── Wizard: driver name heading ── */
[data-theme="light"] #wizard-app .driver-name {
    color: var(--text-main) !important;
}

/* ── Wizard: step circles (inactive) ── */
[data-theme="light"] #wizard-app .wiz-step .circle {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    color: var(--text-muted) !important;
}

/* ── Wizard: step circles (active / complete) — keep accent ── */
[data-theme="light"] #wizard-app .wiz-step.active .circle {
    background: var(--accent) !important;
    color: #fff !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 15px rgba(2, 132, 199, 0.2) !important;
}
[data-theme="light"] #wizard-app .wiz-step.complete .circle {
    background: var(--accent) !important;
    color: #fff !important;
    border-color: var(--accent) !important;
}

/* ── Wizard: step badge (green check) ── */
[data-theme="light"] #wizard-app .wiz-step .badge {
    border-color: var(--bg-app) !important;
}

/* ── Wizard: step labels ── */
[data-theme="light"] #wizard-app .wiz-step .step-label {
    color: var(--text-muted) !important;
}
[data-theme="light"] #wizard-app .wiz-step.active .step-label {
    color: var(--accent) !important;
}

/* ── Wizard: connector lines ── */
[data-theme="light"] #wizard-app .wiz-line {
    background: var(--border-main) !important;
}
[data-theme="light"] #wizard-app .wiz-line.complete {
    background: var(--accent) !important;
}

/* ── Wizard: body card ── */
[data-theme="light"] #wizard-app .wizard-body {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important;
}

/* ── Wizard: section titles ── */
[data-theme="light"] #wizard-app .wiz-section-title {
    color: var(--text-main) !important;
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] #wizard-app .wiz-sub-title {
    color: var(--text-secondary) !important;
}

/* ── Wizard: labels ── */
[data-theme="light"] #wizard-app .wiz-label {
    color: var(--text-muted) !important;
}

/* ── Wizard: inputs & selects ── */
[data-theme="light"] #wizard-app .wiz-input {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] #wizard-app .wiz-input:focus {
    background: #fff !important;
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(2, 132, 199, 0.1) !important;
}
[data-theme="light"] #wizard-app .wiz-input[readonly],
[data-theme="light"] #wizard-app .wiz-input[disabled] {
    background: var(--bg-surface-soft) !important;
    color: var(--text-muted) !important;
}
[data-theme="light"] #wizard-app .wiz-input::placeholder {
    color: var(--text-muted) !important;
    opacity: 0.6 !important;
}
[data-theme="light"] #wizard-app .wiz-input option {
    background: var(--bg-surface) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] #wizard-app .wiz-input.empty {
    color: var(--text-muted) !important;
}

/* ── Wizard: radio & checkbox labels ── */
[data-theme="light"] #wizard-app .wiz-radio-label,
[data-theme="light"] #wizard-app .wiz-check-label,
[data-theme="light"] #wizard-app .deduct-check-row {
    color: var(--text-secondary) !important;
}

/* ── Wizard: divider ── */
[data-theme="light"] #wizard-app .wiz-divider,
[data-theme="light"] #wizard-app .deduction-matrix {
    border-color: var(--border-main) !important;
}

/* ── Wizard: matrix & fee cards ── */
[data-theme="light"] #wizard-app .matrix-card,
[data-theme="light"] #wizard-app .fee-block,
[data-theme="light"] #wizard-app .status-box {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] #wizard-app .status-row {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] #wizard-app .fee-block-title {
    color: var(--text-muted) !important;
}

/* ── Wizard: warning box ── */
[data-theme="light"] #wizard-app .warn-box {
    background: rgba(245, 158, 11, 0.06) !important;
    border-color: rgba(245, 158, 11, 0.2) !important;
}

/* ── Wizard: save/exit/back buttons ── */
[data-theme="light"] #wizard-app .wiz-btn.exit,
[data-theme="light"] #wizard-app .wiz-btn.back {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    color: var(--text-secondary) !important;
}
[data-theme="light"] #wizard-app .wiz-btn.exit:hover,
[data-theme="light"] #wizard-app .wiz-btn.back:hover {
    background: var(--bg-surface-soft) !important;
}
[data-theme="light"] #wizard-app .wiz-btn.save {
    background: rgba(2, 132, 199, 0.06) !important;
    border-color: rgba(2, 132, 199, 0.2) !important;
    color: var(--accent) !important;
}
[data-theme="light"] #wizard-app .wiz-btn.quick {
    background: rgba(2, 132, 199, 0.06) !important;
    border-color: rgba(2, 132, 199, 0.2) !important;
    color: var(--accent) !important;
}

/* ── Wizard: iOS toggle track (off state) ── */
[data-theme="light"] #wizard-app .ios-slider {
    background: #d1d5db !important;
}

/* ── Wizard: input icon wrapper ── */
[data-theme="light"] #wizard-app .input-icon-wrap .icon {
    color: var(--text-muted) !important;
}

/* ── Wizard: driver pill ── */
[data-theme="light"] #wizard-app .driver-pill {
    background: rgba(2, 132, 199, 0.06) !important;
    border-color: rgba(2, 132, 199, 0.15) !important;
    color: var(--accent) !important;
}

/* ============================================================
   DRIVER PROFILE PAGE — LIGHT MODE OVERRIDES
   ============================================================ */

/* ── Profile: tab nav bar ── */
[data-theme="light"] .profile-tabs.tabs-nav {
    background: var(--bg-surface-soft) !important;
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .profile-tabs.tabs-nav .tab-btn {
    color: var(--text-muted) !important;
}
[data-theme="light"] .profile-tabs.tabs-nav .tab-btn:hover {
    color: var(--text-main) !important;
    background: rgba(0, 0, 0, 0.02) !important;
}
[data-theme="light"] .profile-tabs.tabs-nav .tab-btn.active {
    color: var(--accent) !important;
}

/* ── Profile: driver avatar ── */
[data-theme="light"] .driver-avatar {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}

/* ── Profile: mini compliance cards ── */
[data-theme="light"] .mini-card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    backdrop-filter: none !important;
}
[data-theme="light"] .mini-card:hover {
    border-color: var(--border-main) !important;
    box-shadow: var(--card-shadow) !important;
}
[data-theme="light"] .mini-card.valid {
    border-left-color: var(--success) !important;
}
[data-theme="light"] .mini-card.expiring {
    border-left-color: var(--warning) !important;
}
[data-theme="light"] .mini-card.expired {
    border-left-color: var(--danger) !important;
}
[data-theme="light"] .mini-card-body .date-value {
    color: var(--text-main) !important;
}

/* ── Profile: sections ── */
[data-theme="light"] .profile-section {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .section-header {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .section-header h3 {
    color: var(--text-main) !important;
}

/* ── Profile: field rows ── */
[data-theme="light"] .field-row {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .field-row span,
[data-theme="light"] .field span {
    color: var(--text-main) !important;
}

/* ── Profile: doc cards ── */
[data-theme="light"] .doc-card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .doc-card.active {
    border-color: rgba(2, 132, 199, 0.2) !important;
}
[data-theme="light"] .doc-card-footer {
    background: var(--bg-surface-soft) !important;
    border-top-color: var(--border-main) !important;
}
[data-theme="light"] .doc-label {
    color: var(--text-main) !important;
}
[data-theme="light"] .doc-desc {
    color: var(--text-muted) !important;
}
[data-theme="light"] .footer-col label {
    color: var(--text-muted) !important;
}
[data-theme="light"] .footer-col span {
    color: var(--text-main) !important;
}

/* ── Profile: category header ── */
[data-theme="light"] .category-header h3 {
    color: var(--text-secondary) !important;
}

/* ── Profile: sidebar section header ── */
[data-theme="light"] .sidebar-section-header {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .sidebar-section-header h3 {
    color: var(--text-main) !important;
}

/* ── Profile: detail items ── */
[data-theme="light"] .detail-item {
    border-bottom-color: var(--border-main) !important;
}
[data-theme="light"] .detail-item h4 {
    color: var(--text-main) !important;
}
[data-theme="light"] .detail-row label {
    color: var(--text-muted) !important;
}
[data-theme="light"] .detail-row span {
    color: var(--text-main) !important;
}
[data-theme="light"] .audit-info {
    color: var(--text-muted) !important;
}

/* ── Profile: special notes textarea ── */
[data-theme="light"] #notes-edit {
    background: var(--input-bg) !important;
    border-color: var(--border-main) !important;
    color: var(--text-main) !important;
}

/* ── Profile: options dropdown ── */
[data-theme="light"] #options-dropdown {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.12) !important;
}

/* ── Profile: data table (inspections tab) ── */
[data-theme="light"] .data-table thead th {
    background: var(--bg-surface-soft) !important;
    border-bottom-color: var(--border-main) !important;
    color: var(--text-muted) !important;
}
[data-theme="light"] .data-table tbody td {
    border-bottom-color: var(--border-main) !important;
    color: var(--text-main) !important;
}
[data-theme="light"] .data-table tbody tr:hover {
    background: rgba(0, 0, 0, 0.02) !important;
}

/* ── Profile: card wrapper ── */
[data-theme="light"] .tab-content .card {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .toolbar h3 {
    color: var(--text-main) !important;
}

/* ── Back button on profile header ── */
[data-theme="light"] .header-right a[style*="background: var(--bg-card)"] {
    background: var(--bg-surface) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-main) !important;
}

/* ── Profile: files details sidebar ── */
[data-theme="light"] .files-details-sidebar {
    background: var(--bg-surface) !important;
    border-color: var(--border-main) !important;
}

/* ── Profile: sub-tabs ── */
[data-theme="light"] .sub-tab {
    color: var(--text-muted) !important;
    background: transparent !important;
    border-bottom-color: transparent !important;
}
[data-theme="light"] .sub-tab.active {
    color: var(--accent) !important;
    border-bottom-color: var(--accent) !important;
}

/* ── Profile: grid header ── */
[data-theme="light"] .grid-header {
    border-bottom-color: var(--border-main) !important;
    background: var(--bg-surface-soft) !important;
}

/* ── Profile: messenger row ── */
[data-theme="light"] .m-label {
    color: var(--text-muted) !important;
}

/* ── Profile: Telegram code panel ── */
[data-theme="light"] #tg-code-panel {
    background: rgba(2, 132, 199, 0.05) !important;
    border-color: rgba(2, 132, 199, 0.2) !important;
}

/* ── Preview container ── */
[data-theme="light"] .preview-container {
    background: var(--bg-surface-soft) !important;
    border-color: var(--border-main) !important;
}
[data-theme="light"] .empty-preview i,
[data-theme="light"] .empty-preview p {
    color: var(--text-muted) !important;
}